| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 | <?php/** * Generates JSON used for generating a chart * * @param $chart_id *   The unique identifier for the chart * * @return *   JSON array needed for the js caller * * @ingroup tripal_cv */function tripal_cv_chart($chart_id){  // parse out the tripal module name from the chart_id to find out   // which Tripal "hook" to call:  $tripal_mod = preg_replace("/^(tripal_.+?)_cv_chart_(.+)$/","$1",$chart_id);  $callback = $tripal_mod . "_cv_chart";  // now call the function in the module responsible for the chart.  This   // should call the tripal_cv_count_chart with the proper parameters set  $opt = call_user_func_array($callback,array($chart_id));  // build the JSON array to return to the javascript caller  $json_arr = tripal_cv_count_chart($opt[count_mview],$opt[cvterm_id_column],     $opt[count_column],$opt[filter],$opt[title], $opt[type],$opt[size]);  $json_arr[] = $chart_id;  // add the chart_id back into the json array  return drupal_json($json_arr);} /**  * Determines the counts needed for the chart to be rendered  *  * @param $cnt_table  *   The table containing counts for the various cvterms  * @param $fk_column  *   The column in the count table to join it to the cvterm table  * @param $cnt_column  *   The name of the column in the count table containing the counts  * @param $filter  *   A Filter string. Default is (1=1).  * @param $title  *   The title of the chart to be rendered.  * @param $type  *   The type of chart to be rendered. Default is p3 (pie chart).  * @param $size  *   The size of the chart to be rendered. Default is 300x75.  *  * @return   *   An options array needed to render the chart specified  *  * @ingroup tripal_cv_api  */function tripal_cv_count_chart($cnt_table, $fk_column,   $cnt_column, $filter = null, $title = '', $type = 'p3', $size='300x75') {   if(!$type){      $type = 'p3';   }   if(!$size){     $size = '300x75';   }   if(!$filter){      $filter = '(1=1)';    }   $isPie = 0;   if(strcmp($type,'p')==0 or strcmp($type,'p3')==0){      $isPie = 1;   }   $sql = "      SELECT CVT.name, CVT.cvterm_id, CNT.$cnt_column as num_items      FROM {$cnt_table} CNT        INNER JOIN {cvterm} CVT on CNT.$fk_column = CVT.cvterm_id       WHERE $filter   ";       $features = array();   $previous_db = tripal_db_set_active('chado');  // use chado database   $results = db_query($sql);   tripal_db_set_active($previous_db);  // now use drupal database   $data = array();   $axis = array();   $legend = array();   $total = 0;   $max = 0;   $i = 1;   while($term = db_fetch_object($results)){            if($isPie){         $axis[] = "$term->name (".number_format($term->num_items).")";         $data[] = array($term->num_items,0,0);      } else {         $axis[] = "$term->name (".number_format($term->num_items).")";         $data[] = array($term->num_items);    //     $legend[] = "$term->name (".number_format($term->num_items).")";      }      if($term->num_items > $max){         $max = $term->num_items;      }      $total += $term->num_items;      $i++;   }   // convert numerical values into percentages   foreach($data as &$set){      $set[0] = ($set[0] / $total) * 100;   }   $opt[] = array(      data => $data,      axis_labels => $axis,       legend => $legend,      size => $size,       type => $type,       bar_width     => 10,       bar_spacing   => 0,       title         => $title   );//   $opt[] = $sql;      return $opt;}
 |