organism_id.inc 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <?php
  2. /**
  3. *
  4. * @param $entity_type
  5. * @param $entity
  6. * @param $field
  7. * @param $instance
  8. * @param $langcode
  9. * @param $items
  10. * @param $display
  11. * @return string
  12. */
  13. function tripal_chado_organism_select_formatter(&$element, $entity_type, $entity, $field,
  14. $instance, $langcode, $items, $display) {
  15. foreach ($items as $delta => $item) {
  16. $organism = chado_select_record('organism', array('genus', 'species'), array('organism_id' => $item['value']));
  17. $content = '<i>' . $organism[0]->genus .' ' . $organism[0]->species . '</i>';
  18. $element[$delta] = array(
  19. '#type' => 'markup',
  20. '#markup' => $content,
  21. );
  22. }
  23. }
  24. /**
  25. *
  26. * @param $field_name
  27. * @param $widget
  28. * @param $form
  29. * @param $form_state
  30. * @param $field
  31. * @param $instance
  32. * @param $langcode
  33. * @param $items
  34. * @param $delta
  35. * @param $element
  36. */
  37. function tripal_chado_organism_select_widget(&$widget, $form, $form_state, $field, $instance, $langcode, $items, $delta, $element) {
  38. $options = tripal_get_organism_select_options(FALSE);
  39. $widget['value'] = array(
  40. '#type' => 'select',
  41. '#title' => $element['#title'],
  42. '#description' => $element['#description'],
  43. '#options' => $options,
  44. '#default_value' => count($items) > 0 ? $items[0]['value'] : 0,
  45. '#required' => $element['#required'],
  46. '#weight' => isset($element['#weight']) ? $element['#weight'] : 0,
  47. '#delta' => $delta,
  48. '#element_validate' => array('tripal_chado_organism_select_widget_validate'),
  49. );
  50. $widget['add_organism'] = array(
  51. '#type' => 'item',
  52. '#markup' => l('Add a new species', 'admin/content/bio_data/add/species', array('attributes' => array('target' => '_blank'))),
  53. );
  54. }
  55. /**
  56. * Callback function for validating the tripal_chado_organism_select_widget.
  57. */
  58. function tripal_chado_organism_select_widget_validate($element, &$form_state) {
  59. $field_name = $element['#parents'][0];
  60. // If the form ID is field_ui_field_edit_form, then the user is editing the
  61. // field's values in the manage fields form of Drupal. We don't want
  62. // to validate it as if it were being used in a data entry form.
  63. if ($form_state['build_info']['form_id'] =='field_ui_field_edit_form') {
  64. return;
  65. }
  66. $organism_id = tripal_chado_get_field_form_values($field_name, $form_state);
  67. if (!$organism_id) {
  68. form_error($element, t("Please specify an organism."));
  69. }
  70. }
  71. function organism_id_field_formatter_settings_summary($field, $instance, $view_mode) {
  72. $display = $instance['display'][$view_mode];
  73. $settings = $display['settings'];
  74. $summary = '';
  75. if ($display['type'] == 'text_trimmed' || $display['type'] == 'text_summary_or_trimmed') {
  76. $summary = t('Length: @chars chars', array('@chars' => $settings['trim_length']));
  77. }
  78. return $summary;
  79. }
  80. /**
  81. * Implements hook_field_formatter_settings_form()
  82. *
  83. * @param $field
  84. * @param $instance
  85. * @param $view_mode
  86. * @param $form
  87. * @param $form_state
  88. */
  89. function organism_id_field_formatter_settings_form($field, $instance, $view_mode, $form, &$form_state) {
  90. $display = $instance['display'][$view_mode];
  91. $settings = $display['settings'];
  92. $element = array();
  93. if ($display['type'] == 'text_trimmed' || $display['type'] == 'text_summary_or_trimmed') {
  94. $element['trim_length'] = array(
  95. '#title' => t('Length'),
  96. '#type' => 'textfield',
  97. '#size' => 20,
  98. '#default_value' => $settings['trim_length'],
  99. '#element_validate' => array('element_validate_integer_positive'),
  100. '#required' => TRUE,
  101. );
  102. }
  103. return $element;
  104. }