Browse Source

Library Feature Browser: Added functionality (add to node though nodeapi, expose block, register theme, created function to retrieve correct features)

Lacey Sanderson 13 years ago
parent
commit
f98f56fd63
1 changed files with 86 additions and 0 deletions
  1. 86 0
      base/tripal_feature/tripal_feature.module

+ 86 - 0
base/tripal_feature/tripal_feature.module

@@ -346,6 +346,9 @@ function tripal_feature_block($op = 'list', $delta = 0, $edit=array()){
 
          $blocks['org_feature_browser']['info'] = t('Tripal Organism Feature Browser');
          $blocks['org_feature_browser']['cache'] = BLOCK_NO_CACHE;
+
+         $blocks['library_feature_browser']['info'] = t('Tripal Library Feature Browser');
+         $blocks['library_feature_browser']['cache'] = BLOCK_NO_CACHE;
          return $blocks;
 
 
@@ -396,6 +399,10 @@ function tripal_feature_block($op = 'list', $delta = 0, $edit=array()){
                   $block['subject'] = t('Feature Browser');
                   $block['content'] = theme('tripal_organism_feature_browser', $node);
                   break;
+               case 'library_feature_browser':
+                  $block['subject'] = t('Library Feature Browser');
+                  $block['content'] = theme('tripal_library_feature_browser', $node);
+                  break;
                default :
             }
             return $block;
@@ -1407,6 +1414,69 @@ function tripal_feature_load_organism_feature_browser($organism){
    return array ( 'features' => $features, 'pager' => $pager, 'enabled' => true );
 }
 
+/**
+ * This generates the Feature Browse which can optionally be included on library pages
+ * and shows all features belonging to the given library. This Browse can be shown/hidden
+ * on the Feature Configuration page.
+ *
+ * @ingroup tripal_feature
+ */
+function tripal_feature_load_library_feature_browser($library){
+
+   // don't show the browser if the settings in the admin page is turned off
+   // instead return the array indicating the status of the browser
+   $show_browser = variable_get('tripal_library_feature_browse_setting','show_feature_browser');
+   if(strcmp($show_browser,'show_feature_browser')!=0){
+      return array ('enabled' => false);
+   }
+
+   // get a list of feature types to include in the browser
+   $allowed_types = variable_get('chado_browser_feature_types','EST contig');
+   $allowed_types = preg_replace("/[\s\n\r]+/"," ",$allowed_types);
+   $so_terms = split(' ',$allowed_types);
+   $where_cvt = "";
+   foreach ($so_terms as $term){
+      $where_cvt .= "CVT.name = '$term' OR ";
+   }
+   $where_cvt = substr($where_cvt,0,strlen($where_cvt)-3);  # strip trailing 'OR'
+
+   // get the features for this library
+   $sql  = "SELECT F.name,F.feature_id,F.uniquename,CVT.name as cvname ".
+           "FROM {feature} F ".
+              "  INNER JOIN {cvterm} CVT on F.type_id = CVT.cvterm_id ".
+              "  INNER JOIN {library_feature} LF on F.feature_id = LF.feature_id ".
+              "  INNER JOIN {library} L on LF.library_id = L.library_id ".
+            "WHERE LF.library_id = %d and ($where_cvt) ".
+            "ORDER BY feature_id ASC";
+
+   // the counting SQL
+   $csql  = "SELECT count(*) ".
+            "FROM {feature} F".
+              "  INNER JOIN {cvterm} CVT on F.type_id = CVT.cvterm_id ".
+              "  INNER JOIN {library_feature} LF on F.feature_id = LF.feature_id ".
+              "  INNER JOIN {library} L on LF.library_id = L.library_id ".
+            "WHERE LF.library_id = %d and ($where_cvt) ".
+            "GROUP BY L.library_id ";
+
+   $previous_db = tripal_db_set_active('chado');  // use chado database
+   $org_features = pager_query($sql,10,0,$csql,$library->library_id);
+   tripal_db_set_active($previous_db);  // now use drupal database
+   $pager = theme('pager');
+
+   // prepare the query that will lookup node ids
+   $sql = "SELECT nid FROM {chado_feature} ".
+           "WHERE feature_id = %d";
+   $i=0;
+   $features = array();
+   while($feature = db_fetch_object($org_features)){
+      $node = db_fetch_object(db_query($sql,$feature->feature_id));
+      $feature->nid = $node->nid;
+      $features[$i++] = $feature;
+   }
+
+   return array ( 'features' => $features, 'pager' => $pager, 'enabled' => true );
+}
+
 /**
  *  used to sort the list of relationship objects by start position
  *
@@ -1548,6 +1618,9 @@ function tripal_feature_nodeapi(&$node, $op, $teaser, $page) {
                }
                break;
             case 'chado_library':
+               $node->content['tripal_library_feature_browser'] = array(
+                 '#value' => theme('tripal_library_feature_browser', $node),
+               );               
                break;
             default:           
          }
@@ -1578,6 +1651,10 @@ function tripal_feature_theme () {
          'arguments' => array('node'=> null),
          'template' => 'tripal_organism_feature_counts',
       ),
+      'tripal_library_feature_browser' => array (
+         'arguments' => array('node'=> null),
+         'template' => 'tripal_library_feature_browser',
+      ),
       'tripal_feature_base' => array (
          'arguments' => array('node'=> null),
          'template' => 'tripal_feature_base',
@@ -1639,6 +1716,15 @@ function tripal_feature_preprocess_tripal_organism_feature_browser(&$variables){
    $organism->feature_browser = tripal_feature_load_organism_feature_browser($organism);
 }
 
+/**
+ * Preprocessor function for the Library Feature Browser
+ *
+ * @ingroup tripal_feature
+ */
+function tripal_feature_preprocess_tripal_library_feature_browser(&$variables){
+   $library = $variables['node']->library;
+   $library->feature_browser = tripal_feature_load_library_feature_browser($library);
+}
 
 /**
  *