blast_ui.theme.inc 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. /**
  3. * @file
  4. * This file contains functions specifically related to theme-ing the BLAST module
  5. */
  6. /**
  7. * Preprocess function for the show_blast_report.tpl.php
  8. *
  9. * Use this function to prepare variables for use in the template,
  10. * as well as to add css/javascript needed.
  11. *
  12. * @param $vars
  13. * The variables currently available to the template.
  14. */
  15. function blast_ui_preprocess_show_blast_report(&$vars) {
  16. // Add CSS and Javascript files
  17. $path = drupal_get_path('module', 'blast_ui');
  18. drupal_add_css($path . '/theme/css/blast_report.css');
  19. drupal_add_js('http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js');
  20. // Get the filename of the BLAST results
  21. $job = tripal_get_job($vars['job_id']);
  22. $job_args = unserialize($job->arguments);
  23. $vars['xml_filename'] = variable_get('file_public_path', conf_path() . '/files') . '/' . $job_args['output_filename'] . '.blast.xml';
  24. $vars['tsv_filename'] = variable_get('file_public_path', conf_path() . '/files') . '/' . $job_args['output_filename'] . '.blast.tsv';
  25. $vars['html_filename'] = variable_get('file_public_path', conf_path() . '/files') . '/' . $job_args['output_filename'] . '.blast.html';
  26. // Add the blast database node.
  27. // This is needed for link-out functionality.
  28. $vars['blastdb'] = get_blast_database(array('path' => $job_args['database']));
  29. }
  30. /**
  31. * Implements hook_theme_registery_alter().
  32. */
  33. function blast_ui_theme_registry_alter(&$theme_registry) {
  34. $theme_registry_copy = $theme_registry;
  35. $module_path = drupal_get_path('module', 'blast_ui') . '/theme';
  36. _theme_process_registry($theme_registry_copy, 'phptemplate', 'theme_engine', 'my_custom_theme', $module_path);
  37. $theme_registry += array_diff_key($theme_registry_copy, $theme_registry);
  38. // A list of templates the module will provide templates for
  39. $hooks = array('page');
  40. foreach ($hooks as $hook) {
  41. // Add the key 'theme paths' if it doesn't exist in this theme's registry
  42. if (!isset($theme_registry[$hook]['theme paths'])) {
  43. $theme_registry[$hook]['theme paths'] = array();
  44. }
  45. // Shift this module's directory to the top of the theme path list
  46. if (is_array($theme_registry[$hook]['theme paths'])) {
  47. $first_element = array_shift($theme_registry[$hook]['theme paths']);
  48. if ($first_element) {
  49. array_unshift($theme_registry[$hook]['theme paths'], $first_element, $module_path);
  50. }
  51. else {
  52. array_unshift($theme_registry[$hook]['theme paths'], $module_path);
  53. }
  54. }
  55. }
  56. }