sbo__relationship_formatter.inc 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. class sbo__relationship_formatter extends ChadoFieldFormatter {
  3. // The default label for this field.
  4. public static $default_label = 'Relationship Statements';
  5. // The list of field types for which this formatter is appropriate.
  6. public static $field_types = ['sbo__relationship'];
  7. public static $default_settings = [
  8. 'title' => 'Relationship',
  9. 'empty' => 'There are no relationships',
  10. ];
  11. /**
  12. *
  13. * @see TripalFieldFormatter::settingsForm()
  14. */
  15. public function settingsForm($view_mode, $form, &$form_state) {
  16. $display = $this->instance['display'][$view_mode];
  17. $settings = $display['settings'];
  18. $element = [];
  19. $element['title'] = [
  20. '#type' => 'textfield',
  21. '#title' => 'Table Header',
  22. '#default_value' => array_key_exists('title', $settings) ? $settings['title'] : 'Relationship',
  23. ];
  24. $element['empty'] = [
  25. '#type' => 'textfield',
  26. '#title' => 'Empty text',
  27. '#default_value' => array_key_exists('empty', $settings) ? $settings['empty'] : 'There are no relationships',
  28. ];
  29. return $element;
  30. }
  31. /**
  32. * @see TripalFieldFormatter::settingsSummary()
  33. */
  34. public function settingsSummary($view_mode) {
  35. $display = $this->instance['display'][$view_mode];
  36. $settings = $display['settings'];
  37. $summary = t('Title: @title<br>Empty: @empty',
  38. [
  39. '@title' => $settings['title'],
  40. '@empty' => $settings['empty'],
  41. ]
  42. );
  43. return $summary;
  44. }
  45. /**
  46. *
  47. * @see TripalFieldFormatter::view()
  48. */
  49. public function view(&$element, $entity_type, $entity, $langcode, $items, $display) {
  50. // Get the settings
  51. $settings = $display['settings'];
  52. $rows = [];
  53. $headers = [$settings['title']];
  54. foreach ($items as $delta => $item) {
  55. if (empty($item['value'])) {
  56. continue;
  57. }
  58. $subject_name = $item['value']['local:relationship_subject']['schema:name'];
  59. $subject_type = $item['value']['local:relationship_subject']['rdfs:type'];
  60. $object_name = $item['value']['local:relationship_object']['schema:name'];
  61. $object_type = $item['value']['local:relationship_object']['rdfs:type'];
  62. $rel_type = $item['value']['local:relationship_type'];
  63. // Get some better human-readable formats for the type and verb.
  64. $verb = sbo__relationship::get_rel_verb($rel_type);
  65. $rel_type_clean = lcfirst(preg_replace('/_/', ' ', $rel_type));
  66. $clause_parts = [ 'The ', $subject_type, ', ', $subject_name, ', ',
  67. $verb, ' ', $rel_type_clean, ' ', $object_type,
  68. ', ', $object_name, '.' ];
  69. // Handle some special cases.
  70. // For mRNA objects we don't want to show the CDS, exons, 5' UTR, etc.
  71. // we want to show the parent gene and the protein.
  72. if ($object_type == 'mRNA' and
  73. (in_array($subject_type, [
  74. 'CDS',
  75. 'exon',
  76. 'five_prime_UTR',
  77. 'three_prime_UTR',
  78. ]))) {
  79. continue;
  80. }
  81. // Convert the object/subject to a link if an entity exists for it.
  82. if (array_key_exists('entity', $item['value']['local:relationship_object'])) {
  83. list($entity_type, $object_entity_id) = explode(':', $item['value']['local:relationship_object']['entity']);
  84. if ($object_entity_id != $entity->id) {
  85. $clause_parts[11] = l($clause_parts[11], 'bio_data/' . $object_entity_id);
  86. }
  87. }
  88. if (array_key_exists('entity', $item['value']['local:relationship_subject'])) {
  89. list($entity_type, $subject_entity_id) = explode(':', $item['value']['local:relationship_subject']['entity']);
  90. if ($subject_entity_id != $entity->id) {
  91. $clause_parts[3] = l($clause_parts[3], 'bio_data/' . $subject_entity_id);
  92. }
  93. }
  94. // Add bold font to the object and subject names.
  95. $clause_parts[3] = '<b>' . $clause_parts[3] . '</b>';
  96. $clause_parts[11] = '<b>' . $clause_parts[11] . '</b>';
  97. $rows[][] = [
  98. 'data' => implode('', $clause_parts),
  99. //'class' => array('tripal-entity-unattached field-items')
  100. ];
  101. }
  102. // Build the pager
  103. $items_per_page = array_key_exists('items_per_page', $this->instance['settings']) ? $this->instance['settings']['items_per_page'] : 10;
  104. $total_records = count($rows);
  105. $total_pages = (int) ($total_records / $items_per_page) + 1;
  106. $pelement = 0;
  107. $current_page = pager_default_initialize($total_records, $items_per_page, $pelement);
  108. $pager = theme('pager', [
  109. 'tags' => [],
  110. 'element' => $pelement,
  111. 'parameters' => [],
  112. 'quantity' => $total_pages,
  113. ]);
  114. $pager = $this->ajaxifyPager($pager, $entity);
  115. $page_items = array_chunk($rows, $items_per_page);
  116. $caption = '';
  117. if ($total_records == 1) {
  118. $caption = 'There is ' . count($rows) . ' relationship.';
  119. }
  120. else {
  121. $caption = 'There are ' . count($rows) . ' relationships.';
  122. }
  123. $content = theme_table([
  124. 'header' => $headers,
  125. 'rows' => count($rows) > 0 ? $page_items[$current_page] : [],
  126. 'attributes' => [
  127. 'class' => 'tripal-data-table',
  128. ],
  129. 'sticky' => FALSE,
  130. 'caption' => $caption,
  131. 'colgroups' => [],
  132. 'empty' => $settings['empty'],
  133. ]);
  134. $element[0] = [
  135. '#type' => 'markup',
  136. '#markup' => $content . $pager,
  137. ];
  138. }
  139. }