//
  // Adapted for biblio: Ron Jerome
//  global $openURLResolver; // these variables are defined in 'ini.inc.php'
//  global $hostInstitutionAbbrevName;
  $openURLResolver = variable_get('biblio_baseopenurl','');
  $co = biblio_contextObject($node);
  $co["sid"] = "biblio:" . variable_get('site_name', 'Drupal');
  $openURL = $openURLResolver;
  if (!ereg("\?", $openURLResolver))
    $openURL .= "?";
  else
    $openURL .= "&";
  $openURL .= "ctx_ver=Z39.88-2004";
  foreach ($co as $coKey => $coValue) {
    $coKey = ereg_replace("rft.", "", $coKey);
    $coKey = ereg_replace("au[0-9]*", "au", $coKey);
    $openURL .= "&" . $coKey . "=" . rawurlencode($coValue);
  }
  return $openURL;
}
function theme_biblio_export_links($nid) {
  $base =  variable_get('biblio_base', 'biblio');
  $links .= '';
  $links .= '-  '.l(t("Tagged"),"$base/export/tagged/$nid").'';
  $links .= '
-  '.l(t("XML"),"$base/export/xml/$nid").'';
  $links .= '
-  '.l(t("BibTex"),"$base/export/bib/$nid").'
';
  return $links;
}
function theme_biblio_short($node, $base='biblio', $style_name='classic', $inline=false) {
  require_once( drupal_get_path('module', 'biblio') . "/biblio_style_$style_name.inc");
  $style_function = "biblio_style_$style_name";
  $styled_node = $style_function($node, $base, $inline);
  if (empty($node->biblio_coins)) biblio_coins_generate($node);
  return($styled_node.$node->biblio_coins);
}
function theme_biblio_long($node,$base='biblio',$style='classic') {
  if (empty($node->biblio_coins)) biblio_coins_generate($node);
  $output .= $node->biblio_coins;
  $layout = variable_get('biblio_node_layout', 'orig');
  if (variable_get('biblio_node_layout', 'orig') == 'ft' && strlen(trim($node->body)) && user_access('view full text') ) {
    $output .= ''.theme('biblio_short', $node,$base,$style).'
';
    $annotation_field = variable_get('biblio_annotations','none');
    if ($annotation_field != 'none' && $node->$annotation_field) {
      $output .= '';
      $output .= check_markup($node->$annotation_field, $node->format, FALSE);
      $output .= '
';
    }
    $output .= check_markup($node->body, $node->format, FALSE) ;
    if ( biblio_access('export',$node)) {
      $output .= theme('biblio_export_links',$node->nid);
    }
    return $output;
  }
  if (variable_get('biblio_normalize', 0)) {
    $authors = _biblio_parse_authors($node->biblio_authors);
  } else {
    $authors = $node->biblio_authors;
  }
  $openurl_base = variable_get('biblio_baseopenurl','');
  if ($openurl_base) $output .= theme('biblio_openurl', biblio_openurl($node, $openurl_base));
  $output .= ''.t("Publication Type").":
 $node->biblio_type_name\n";
  $output .= ''.t("Authors").':
 ' . _biblio_author_links($authors,$base) . "\n";
  $output .= ''.t("Source").': 
 ';
  $source = null;
  if ($node->biblio_secondary_title) $source .= check_plain($node->biblio_secondary_title);
  if ($node->biblio_publisher) {
    $source .= $source?", ":"";
    $source .= check_plain($node->biblio_publisher);
  }
  if ($node->biblio_volume) {
    $source .= $source?", ":"";
    $source .= t('Volume ') . check_plain($node->biblio_volume);
  }
  if ($node->biblio_issue) {
    $source .= $source?", ":"";
    $source .= t('Issue ') . check_plain($node->biblio_issue);
  }
  if ($node->biblio_number) {
    $source .= $source?", ":"";
    $source .= t('Number ') . check_plain($node->biblio_number);
  }
  if ($node->biblio_place_published) {
    $source .= $source?", ":"";
    $source .= check_plain($node->biblio_place_published);
  }
  if ($node->biblio_pages) {
    $source .= $source?", ":"";
    $source .= 'p.' . check_plain($node->biblio_pages);
  }
  if (isset($node->biblio_year)) {
    if ($node->biblio_year == 9998) { $node->biblio_year = t("In Press"); }
    if ($node->biblio_year == 9999) { $node->biblio_year = t("Submitted"); }
    $source .= ' (' . check_plain($node->biblio_year) . ')';
  }
  $output .= "$source\n";
  if ($node->biblio_isbn) $output .= ''.t("ISBN").':
 ' . check_plain($node->biblio_isbn) . "\n";
  if ($node->biblio_call_number) $output .= ''.t("Call Number").':
 ' . check_plain($node->biblio_call_number) . "\n";
  if ($node->biblio_accession_number) $output .= ''.t("Accession Number").':
 ' . check_plain($node->biblio_accession_number) . "\n";
  if ($node->biblio_other_number) $output .= ''.t("Other Number").':
 ' . check_plain($node->biblio_other_number) . "\n";
  if ($node->biblio_url) {
      $attrib = (variable_get('biblio_links_target_new_window',null)) ? array('target'=>'_blank') : array();
      $output .= ''.t("URL").':
'.l($node->biblio_url,$node->biblio_url,$attrib) . "\n";
  }
  if ($node->biblio_keywords) $output .= ''.t("Keywords").':
 ' . _biblio_keyword_links($node->biblio_keywords,$base) . "\n";
  if ($node->biblio_abst_e) $output .= ''.t("Abstract").':
 ' . check_markup($node->biblio_abst_e, $node->format, FALSE) . "\n";
  if ($node->biblio_abst_f) $output .= '' . check_markup($node->biblio_abst_f, $node->format, FALSE) . "\n";
  if ($node->biblio_notes) $output .= '
'.t("Notes").': 
' . check_markup($node->biblio_notes, $node->format, FALSE) . "\n";
  if ( strlen(trim($node->body)) && user_access('view full text') ) {
     $output .= ''.t('Full Text').':
'.check_markup($node->body, $node->format, FALSE);
  }
  if ( biblio_access('export',$node)) {
    $output .= theme('biblio_export_links',$node->nid);
  }
  return $output;
}
function theme_biblio_tabular($node, $base, $teaser = false) {
  $tid=$node->biblio_type;
  $result = db_query('SELECT * FROM {biblio_fields} as b  ORDER BY b.weight ASC');
  while ($row = db_fetch_array($result)) {
    if ($row['common']) {
      $fields[$row['fid']] = $row;
    }
  }
//  $result = db_query('SELECT t.* FROM {biblio_types} as t WHERE t.tid = %d', $tid);
//  $row = db_fetch_array($result);
//  $type_name=$row['name'];
  $result = db_query('SELECT d.*, f.name, f.type FROM {biblio_type_details} as d INNER JOIN {biblio_fields} as f on d.fid=f.fid where d.tid=%d  ORDER BY d.weight ASC', $tid);
  while ($row = db_fetch_array($result)) {
    $fields[$row['fid']] = (isset($fields[$row['fid']])) ? array_merge($fields[$row['fid']], $row) : $row;
  }
  uasort($fields, "biblio_form_sort"); // resort the fields since the weight may have changed
  if ($teaser) {
//    $rows[] =array(array('data' =>  '
', 'colspan'=>'3'));
//    $rows[] =array(array('data' =>  ''.t('Title').'','align'=>'right'),
//                   array('data' => '  '),
//                   array('data' => l($node->title, 'node/'.$node->nid)));
   unset($fields[21]);
  }
  $rows[] = array(array('data' =>  ''. t('Publication Type') .'', 'align' => 'right'),
                 array('data' => '  '),
                 array('data' => $node->biblio_type_name));
  if ($node->biblio_authors) {
    if (variable_get('biblio_normalize', 0)) {
      $node->biblio_authors = _biblio_parse_authors($node->biblio_authors);
    }
    $node->biblio_authors = _biblio_author_links($node->biblio_authors, $base);
  }
  if ($node->biblio_keywords) {
   $node->biblio_keywords = _biblio_keyword_links($node->biblio_keywords, $base);
  }
  if ($node->biblio_url) {
    $attrib = (variable_get('biblio_links_target_new_window',null)) ? array('target'=>'_blank') : array();
    $node->biblio_url = l($node->biblio_url, $node->biblio_url, $attrib);
  }
  foreach ($fields as $key => $row) {
    if (!empty($node->$row['name']) && ($row['name'] != 'biblio_coins') ) {
      switch ($row['name']) {
      case 'biblio_authors':
      case 'biblio_keywords':
      case 'biblio_url':
        // check_plain is not need on these since they have gone through
        // the l() function which does a check_plain
        $data = $node->$row['name'];
        break;
      default:
        if ( $row['type'] == 'textarea' ) {
          $data = check_markup($node->$row['name'], $node->format, FALSE);
        }else{
          $data = check_plain($node->$row['name']);
        }
      }
      $rows[] = array(array('data' => ''. $row['title'] .'', 'align' => 'right', 'valign' => 'top', 'width' => '20%'),
                      array('data' => '  '),
                      array('data' => $data));
    }
  }
  if ( strlen(trim($node->body)) && $teaser == false && user_access('view full text') ) {
    $rows[] = array(array('data' => ''. t('Full Text') .'', 'align' => 'right', 'valign' => 'center', 'width' => '20%'),
                      array('data' => '  '),
                      array('data' => check_markup($node->body,FILTER_HTML_ESCAPE, FALSE))
                            );
  }
  if ( biblio_access('export', $node) && $teaser == false ) {
    $rows[] = array(array('data' => ''. t('Export') .'', 'align' => 'right', 'valign' => 'center', 'width' => '20%'),
                    array('data' => '  '),
                    array('data' => l(t("Tagged"),"$base/export/tagged/$node->nid").' '.
                      l(t("XML"),"$base/export/xml/$node->nid").' '.
                      l(t("BibTex"),"$base/export/bib/$node->nid")
                    ));
  }
  $output = '';
  $output .= $node->biblio_coins;
  $header = array();
  $output .= theme('table', $header, $rows);
  $output .= '
';
  return $output;
}
function theme_biblio_list($node, $base='biblio', $style='classic', $inline=false) {
  $output .= theme('biblio_short', $node, $base, $style, $inline);
  if ($node->biblio_abst_e) {
    $output .= '';
    $output .= l(" Abstract", "node/$node->nid") . "\n";
    $output .= '';
  }
  $annotation_field = variable_get('biblio_annotations','none');
  if ($annotation_field != 'none' && $node->$annotation_field) {
    $output .= '';
    $output .= check_markup($node->$annotation_field,FILTER_HTML_ESCAPE,FALSE);
    $output .= '
';
  }
  $openurl_base = variable_get('biblio_baseopenurl','');
  if ($openurl_base) $output .= theme('biblio_openurl',biblio_openurl($node));
  if ( biblio_access('export',$node)) {
    $base =  variable_get('biblio_base', 'biblio');
    $output .= '';
    $output .= l("Tagged","$base/export/tagged/$node->nid") . ' ';
    $output .= l("XML","$base/export/xml/$node->nid") . ' ';
    $output .= l("BibTex","$base/export/bib/$node->nid") ;
    $output .= '';
  }
  return $output;
}
function theme_biblio_filters(&$form) {
  if (sizeof($form['current'])) {
    $output .= '';
    foreach (element_children($form['current']) as $key) {
      $output .= '- ' . drupal_render($form['current'][$key]) . '';
    }
    $output .= '
';
  }
  $output .= '' . (sizeof($form['current']) ? '- '. t('and') .' '. t('where') .'' : '') . '
- ';
  foreach (element_children($form['filter']) as $key) {
    $output .= drupal_render($form['filter'][$key]);
  }
  $output .= '';
  $output .= '
- '. t('is') .'' . '
- ';
  foreach (element_children($form['status']) as $key) {
    $output .= drupal_render($form['status'][$key]);
  }
  $output .= '';
  $output .= '
';
  $output .= ''. drupal_render($form['buttons']) .'
';
  $output .= '
';
  return $output;
}
function theme_biblio_form_filter(&$form) {
  $output .= '';
  $output .= drupal_render($form['filters']);
  $output .= '
';
  $output .= drupal_render($form);
  return $output;
}
function theme_biblio_admin_types_edit_form($form) {
  $base =  variable_get('biblio_base', 'biblio');
  $tid = (!empty($form['#parameters'][2])) ? $form['#parameters'][2] : FALSE;
  drupal_set_title($form['type_name']?$form['type_name']['#value']:"Default");
  // build the table with all the fields if no $tid is given, or only the common
  // and customized fields if $tid is given
  $conf_table = array();
  foreach(element_children($form['configured_flds']) as $fld) {
    $conf_row = array();
    $conf_row[] = array('data' => drupal_render($form['configured_flds'][$fld]['name']));
    $conf_row[] = array('data' => drupal_render($form['configured_flds'][$fld]['title']),'align' => 'center');
    $conf_row[] = array('data' => drupal_render($form['configured_flds'][$fld]['hint']),'align' => 'center');
    foreach (element_children($form['configured_flds'][$fld]['checkboxes']) as $oid) {
      if (is_array($form['configured_flds'][$fld]['checkboxes'])) {
            $conf_row[] = array('data' => drupal_render($form['configured_flds'][$fld]['checkboxes'][$oid]), 'align' => 'center', 'title' => $oid);
      }
    }
    $conf_row[] = array('data' => drupal_render($form['configured_flds'][$fld]['weight']),'align' => 'center');
    if ($tid) {
      if ($form['cust'][$fld]) {
        $conf_row[] = array('data' => l('remove',"$base/type/remove/$tid/$fld"),'align' => 'left');
      }else{
        $conf_row[] = array('data' => "common",'align' => 'left');
      }
    }
   $conf_table[] = $conf_row;
  }
  if ($tid) {
    $header =array(t('Field Name'),t('Default Title'),t('Hint'),t('Required'),t('Weight'),t('Action'));
  }else{
    $header =array(t('Field Name'),t('Default Title'),t('Hint'),t('Common'),t('Required'),t('Autocomplete'),t('Weight'));
  }
  $output .= '';
  drupal_add_js('misc/collapse.js');
  $output .= '
';
  if ($tid) {
    $avail_table = array();
    foreach(element_children($form['avail_flds']) as $fld) {
      $avail_row = array();
      $avail_row[] = array('data' => ''.drupal_render($form['avail_flds'][$fld]['name']).'
');
      $avail_row[] = array('data' => ''.drupal_render($form['avail_flds'][$fld]['size']).'
','align' => 'left');
      $avail_row[] = array('data' => ''.drupal_render($form['avail_flds'][$fld]['title']).'','align' => 'left');
      $avail_row[] = array('data' => l('add',"$base/type/add/$tid/$fld"),'align' => 'left');
      $avail_table[] = $avail_row;
    }
    $header2 =array(array('data'=>'Field Name','align'=>'right'),'Size','Default Name','Action');
    $output .= '';
  }
  $output .= drupal_render($form);
  return $output;
}