| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312 | <?php/* *  */function tripal_pub_remote_search_page() {  global $pager_total, $pager_total_items;    $pager_id = 0;  $limit = 10;    // generate the search form   $form = drupal_get_form('tripal_pub_remote_search_form');  $output = $form;  // retrieve any results  $remote_db = $_SESSION['tripal_pub_search']['remote_db'];  $num_criteria = $_SESSION['tripal_pub_search']['num_criteria'];  $days = $_SESSION['tripal_pub_search']['days'];   $search_array = array();  $search_array['remote_db'] = $remote_db;  $search_array['num_criteria'] = $num_criteria;  $search_array['days'] = $days;   for ($i = 0; $i <= $num_criteria; $i++) {    $search_array['criteria'][$i]['search_terms'] = $_SESSION['tripal_pub_search']['criteria'][$i]['search_terms'];    $search_array['criteria'][$i]['scope'] = $_SESSION['tripal_pub_search']['criteria'][$i]['scope'];      $search_array['criteria'][$i]['operation'] = $_SESSION['tripal_pub_search']['criteria'][$i]['operation'];  }        if ($_SESSION['tripal_pub_search']['perform_search']) {    // get the list of publications from the remote database using the search criteria.      $pubs = tripal_pub_get_remote_search_results($remote_db, $search_array, $limit, $pager_id);      // generate the pager    $total_pages = $pager_total[$pager_id];    $total_items = $pager_total_items[$pager_id];    $page = isset($_GET['page']) ? $_GET['page'] : '0';    $pager = theme('pager');        // iterate through the results and construct the table displaying the publications    $rows = array();    $i = $page * $limit + 1;    if (count($pubs) > 0) {      foreach ($pubs as $pub) {        $rows[] = array(number_format($i), $pub['citation']);        $i++;      }    }    $headers = array('', 'Citation');    $table = theme('table', $headers, $rows);         // join all to form the results    $output .= "<br><p><b>Found " . number_format($total_items) .        ". Page " . ($page + 1) . " of $total_pages. " .      " Results</b></br>" . $table . '</p>' . $pager;      }  return $output;}/* *  */function theme_tripal_pub_remote_search_form($form) {  $rows = array();  foreach ($form['criteria'] as $i => $element) {    if(is_numeric($i)) {      $rows[] = array(          array('data' => drupal_render($element["operation-$i"]), 'width' => '10%'),            array('data' => drupal_render($element["scope-$i"]), 'width' => '10%'),        drupal_render($element["search_terms-$i"]),        array('data' => drupal_render($element["add-$i"]) . drupal_render($element["remove-$i"]), 'width' => '5%'),      );    }  }   $headers = array('Operation','Scope', 'Search Terms', '');    $markup  = '<div id="pub-search-form-row1">';  $markup .= '  <div id="pub-search-form-col1">' . drupal_render($form['loader_name']) . '</div>';  $markup .= '  <div id="pub-search-form-col2">' . drupal_render($form['remote_db']) . '</div>';  $markup .= '  <div id="pub-search-form-col3">' . drupal_render($form['days']) . '</div>';  $markup .= '</div>';  $markup .= theme('table', $headers, $rows);    $form['criteria'] = array(    '#type' => 'markup',    '#value' =>  $markup,    '#weight' => -10,  );  return drupal_render($form);}/** * Purpose: Provides the form to search pubmed *  * @ingroup tripal_pub */function tripal_pub_remote_search_form(&$form_state = NULL) {  tripal_core_ahah_init_form();  // set default values.  First use what is in the form_state['values'] array. If nothing there then use the session variable.  $remote_db = $form_state['values']['remote_db'] ? $form_state['values']['remote_db'] : $_SESSION['tripal_pub_search']['remote_db'];  $days = $form_state['values']['days'] ? $form_state['values']['days'] : $_SESSION['tripal_pub_search']['days'];   $num_criteria = $form_state['values']['num_criteria'] ? $form_state['values']['num_criteria'] : $_SESSION['tripal_pub_search']['num_criteria'];  $loader_name = $form_state['values']['loader_name'] ? $form_state['values']['loader_name'] : $_SESSION['tripal_pub_search']['loader_name'];    // change the number of criteria based on form_state post data.  if (!$num_criteria) {    $num_criteria = 0;  }  if($form_state['post']["add-$num_criteria"]) {        $num_criteria++;  }  if($form_state['post']["remove-$num_criteria"]) {        $num_criteria--;  }    $form['loader_name'] = array(    '#type'          => 'textfield',    '#title'         => t('Loader Name'),    '#description'   => t('Please provide a name for this loader setup..'),    '#default_value' => $loader_name,    '#required'      => TRUE,  );     $remote_dbs = array('Pubmed' => 'Pubmed');  $form['remote_db'] = array(    '#title' => t('Remote Database'),    '#type' => 'select',    '#options' => $remote_dbs,    '#default_value' => $remote_db,  );  $form['num_criteria']= array(    '#type'          => 'hidden',    '#default_value' => $num_criteria,  );    $form['days'] = array(    '#type'          => 'textfield',    '#title'         => t('Days'),    '#description'   => t('The number of days <br>from today to search.'),    '#default_value' => $days,    '#size'          => 5,  );    for($i = 0; $i <= $num_criteria; $i++) {    $search_terms = $form_state['values']["search_terms-$i"] ? $form_state['values']["search_terms-$i"] : $_SESSION['tripal_pub_search']['criteria'][$i]['search_terms'];    $scope = $form_state['values']["scope-$i"] ? $form_state['values']["scope-$i"] : $_SESSION['tripal_pub_search']['criteria'][$i]['scope'];    $operation = $form_state['values']["operation-$i"] ? $form_state['values']["operation-$i"] : $_SESSION['tripal_pub_search']['criteria'][$i]['operation'];        // default to searching the title and abstract    if (!$scope) {      $scope = 'abstract';    }      $form['criteria'][$i]["search_terms-$i"] = array(      '#type'          => 'textfield',      '#description'   => t('Please provide a list of words, separated by spaces for searching.'),      '#default_value' => $search_terms,      '#required'      => TRUE,    );    $form['criteria'][$i]["scope-$i"] = array(      '#type'          => 'select',      '#description'   => t('Please select the fields to search for this term.'),      '#options'       => array(        'any'      => 'Any Field',        'title'    => 'Title',        'abstract' => 'Title/Abstract',        'author'   => 'Author'),      '#default_value' => $scope,    );            if ($i > 0) {      $form['criteria'][$i]["operation-$i"] = array(        '#type'          => 'select',        '#options'       => array(          'AND' => 'AND',          'OR'  => 'OR',          'NOT' => 'NOT'),        '#default_value' => $operation,      );    }    if ($i == $num_criteria) {          if($i > 0) {        $form['criteria'][$i]["remove-$i"] = array(          '#type'         => 'image_button',          '#value'        => t('Remove'),          '#src'          => drupal_get_path('theme', 'tripal') . '/images/minus.png',          '#ahah' => array(            'path'    => "admin/tripal/tripal_pub/import_setup/criteria/minus/$i",            'wrapper' => 'tripal-pub-remote-search-form',            'event'   => 'click',            'method'  => 'replace',          ),           '#attributes' => array('onClick' => 'return false;'),        );      }      $form['criteria'][$i]["add-$i"] = array(        '#type'         => 'image_button',              '#value'        => t('Add'),        '#src'          => drupal_get_path('theme', 'tripal') . '/images/add.png',        '#ahah' => array(          'path'    => "admin/tripal/tripal_pub/import_setup/criteria/add/$i",          'wrapper' => 'tripal-pub-remote-search-form',          'event'   => 'click',          'method'  => 'replace',                  ),           '#attributes' => array('onClick' => 'return false;'),      );    }  }    $form['test'] = array(    '#type'         => 'submit',    '#value'        => t('Test Criteria'),  );  $form['save'] = array(    '#type'         => 'submit',    '#value'        => t('Save Criteria'),  );  return $form;}/** * */function tripal_pub_remote_search_form_validate($form, &$form_state) {  $num_criteria = $form_state['values']['num_criteria'];  $remote_db =  $form_state['values']["remote_db"];  $days =  trim($form_state['values']["days"]);  $loader_name =  trim($form_state['values']["loader_name"]);  for ($i = 0; $i <= $num_criteria; $i++) {                $search_terms =  trim($form_state['values']["search_terms-$i"]);    $scope =  $form_state['values']["scope-$i"];    $operation =  $form_state['values']["operation-$i"];        if ($days and !is_numeric($days) or preg_match('/\./', $days)) {      form_set_error("days-$i", "Please enter a numeric, non decimal value, for the number of days.");    }  }}/** * */function tripal_pub_remote_search_form_submit($form, &$form_state) {     $num_criteria = $form_state['values']['num_criteria'];  $remote_db =  $form_state['values']["remote_db"];  $days =  trim($form_state['values']["days"]);  $loader_name =  trim($form_state['values']["loader_name"]);      $_SESSION['tripal_pub_search']['remote_db'] = $remote_db;  $_SESSION['tripal_pub_search']['days'] = $days;  $_SESSION['tripal_pub_search']['num_criteria'] = $num_criteria;  $_SESSION['tripal_pub_search']['loader_name'] = $loader_name;  unset($_SESSION['tripal_pub_search']['criteria']);  for ($i = 0; $i <= $num_criteria; $i++) {    $search_terms =  trim($form_state['values']["search_terms-$i"]);    $scope =  $form_state['values']["scope-$i"];    $operation =  $form_state['values']["operation-$i"];        $_SESSION['tripal_pub_search']['criteria'][$i] = array(      'search_terms' => $search_terms,      'scope' => $scope,      'operation' => $operation    );  }     if ($form_state['values']['op'] == 'Test Criteria') {    $_SESSION['tripal_pub_search']['perform_search'] = 1;  }  if ($form_state['values']['op'] == 'Save Criteria') {    unset($_SESSION['tripal_pub_search']['perform_search']);    $record = array(      'name' => $loader_name,      'criteria' => serialize($_SESSION['tripal_pub_search']),    );    if(drupal_write_record('tripal_pub_import', $record)){      drupal_set_message('Publication import settings saved');    }    else {      drupal_set_message('Could not save publication import settings', 'error');    }  }  }/* * AHAH callback */function tripal_pub_remote_search_page_update_criteria($action, $i) {  $status = TRUE;  // prepare and render the form  $form = tripal_core_ahah_prepare_form();     $data = theme('tripal_pub_remote_search_form', $form);    // bind javascript events to the new objects that will be returned   // so that AHAH enabled elements will work.  $settings = tripal_core_ahah_bind_events();  // return the updated JSON  drupal_json(    array(      'status'   => $status,       'data'     => $data,      'settings' => $settings,    )    );}
 |