tripal_phenotype.views.inc 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. /**
  3. * @file
  4. * This file contains the basic functions for views integration of
  5. * chado/tripal_phenotype tables. Supplementary functions can be found in
  6. * ./views/
  7. *
  8. * Documentation on views integration can be found at
  9. * http://views2.logrus.com/doc/html/index.html.
  10. */
  11. /*************************************************************************
  12. * Implements hook_views_data()
  13. * Purpose: Describe chado/tripal tables & fields to views
  14. *
  15. * @return: a data array which follows the structure outlined in the
  16. * views2 documentation for this hook. Essentially, it's an array of table
  17. * definitions keyed by chado/tripal table name. Each table definition
  18. * includes basic details about the table, fields in that table and
  19. * relationships between that table and others (joins)
  20. */
  21. function tripal_phenotype_views_data() {
  22. $data = array();
  23. if (module_exists('tripal_views')) {
  24. $tables = array(
  25. 'phenotype'
  26. );
  27. foreach ($tables as $tablename) {
  28. if (!tripal_views_is_integrated($tablename, 10)) {
  29. $table_integration_array = tripal_views_get_integration_array_for_chado_table($tablename, TRUE);
  30. tripal_views_integration_add_entry($table_integration_array);
  31. }
  32. }
  33. $tables = array(
  34. 'feature_phenotype',
  35. 'phenotype_cvterm'
  36. );
  37. foreach ($tables as $tablename) {
  38. if (!tripal_views_is_integrated($tablename, 10)) {
  39. $table_integration_array = tripal_views_get_integration_array_for_chado_table($tablename, FALSE);
  40. tripal_views_integration_add_entry($table_integration_array);
  41. }
  42. }
  43. }
  44. return $data;
  45. }
  46. /*************************************************************************
  47. * Implements hook_views_handlers()
  48. * Purpose: Register all custom handlers with views
  49. * where a handler describes either "the type of field",
  50. * "how a field should be filtered", "how a field should be sorted"
  51. *
  52. * @return: An array of handler definitions
  53. */
  54. function tripal_phenotype_views_handlers() {
  55. return array(
  56. 'info' => array(
  57. 'path' => drupal_get_path('module', 'tripal_phenotype') . '/views/handlers',
  58. ),
  59. 'handlers' => array(
  60. ),
  61. );
  62. }