You are here

class biblio_handler_citation in Bibliography Module 6.2

Same name and namespace in other branches
  1. 6 views/biblio_handler_citation.inc \biblio_handler_citation
  2. 7 views/biblio_handler_citation.inc \biblio_handler_citation
  3. 7.2 views/biblio_handler_citation.inc \biblio_handler_citation

@file Views citation handler for Drupal biblio module.

Hierarchy

Expanded class hierarchy of biblio_handler_citation

1 string reference to 'biblio_handler_citation'
biblio_views_data in views/biblio.views.inc
Implements hook_views_data().

File

views/biblio_handler_citation.inc, line 7
Views citation handler for Drupal biblio module.

View source
class biblio_handler_citation extends views_handler_field {
  var $author_options;
  var $biblio_base;
  function init(&$view, $options) {
    parent::init($view, $options);
    $this->additional_fields['nid'] = array(
      'table' => 'node',
      'field' => 'nid',
    );
  }
  function query() {
    $this
      ->add_additional_fields();
  }
  function option_definition() {
    $options = parent::option_definition();
    $options['style_name'] = array(
      'default' => biblio_get_style(),
    );
    $options['export_links'] = array(
      'default' => 1,
    );
    $options['file_attachments'] = array(
      'default' => 1,
    );
    $options['open_url_link'] = array(
      'default' => 1,
    );
    return $options;
  }
  function options_form(&$form, &$form_state) {
    parent::options_form($form, $form_state);
    $form['style_name'] = array(
      '#type' => 'select',
      '#title' => t('Style'),
      '#default_value' => $this->options['style_name'],
      '#options' => biblio_get_styles(),
      '#description' => t('Define the layout of author lists.'),
    );
    $form['export_links'] = array(
      '#type' => 'checkbox',
      '#title' => t('Show export links'),
      '#default_value' => $this->options['export_links'],
      '#description' => t('This will add a set of links to export the entry in various file formats such as Bibtex or RIS.'),
    );
    $form['file_attachments'] = array(
      '#type' => 'checkbox',
      '#title' => t('Show download links for file attachments'),
      '#default_value' => $this->options['file_attachments'],
      '#description' => t('If there are files attached to the entry, this will add a download link for each file attached.'),
    );
    $form['open_url_link'] = array(
      '#type' => 'checkbox',
      '#title' => t('Show Open links for file attachments'),
      '#default_value' => $this->options['open_url_link'],
      '#description' => t('This will add an !openurl link to the entry, assuming you have competed the OpenURL configuration on the Biblio !settings page.', array(
        '!openurl' => l('OpenURL', "http://en.wikipedia.org/wiki/OpenURL"),
        '!settings' => l('settings', 'admin/config/content/biblio'),
      )),
    );
  }
  function render($values) {
    if (empty($this->biblio_base)) {
      $this->biblio_base = variable_get('biblio_base', 'biblio');
    }
    $item = node_load($values->{$this->aliases['nid']});
    if ($item->type != 'biblio') {
      return;
    }
    if (isset($item->biblio_year)) {
      $item->biblio_year = _biblio_text_year($item->biblio_year);
    }
    if (variable_get('biblio_hide_bibtex_braces', 0)) {
      $item->title = biblio_remove_brace($item->title);
    }
    $output = "\n" . '<div class="biblio-entry">' . "\n";
    $output .= '<div class="biblio-style-' . $style . '">' . "\n";
    if (!$item->status) {
      $output .= '<div id="node-' . $item->nid . '" class="node node-unpublished">';
    }

    // first add the styled entry...
    $output .= theme('biblio_style', $item, $this->biblio_base, $this->options['style_name']);
    $annotation_field = variable_get('biblio_annotations', 'none');
    if ($annotation_field != 'none' && $item->{$annotation_field}) {
      $output .= '<div class="biblio-annotation">';
      $output .= check_markup($item->{$annotation_field}, $item->format, FALSE);
      $output .= '</div>';
    }
    $openurl_base = variable_get('biblio_baseopenurl', '');
    if (!empty($openurl_base) && $this->options['open_url_link']) {
      $output .= theme('biblio_openurl', biblio_openurl($item));
    }
    if (biblio_access('export', $item) && $this->options['export_links']) {
      $output .= theme('biblio_export_links', $item);
    }
    if (biblio_access('download', $item) && $this->options['file_attachments']) {

      // add links to attached files (if any)
      $output .= theme('biblio_download_links', $item);
    }
    if (!$item->status) {
      $output .= '</div>';
    }
    $output .= "\n</div></div>";
    return $output;
  }

}

Members