term_reference_tree.field.inc 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. /**
  3. * Implements hook_field_formatter_info().
  4. */
  5. function term_reference_tree_field_formatter_info() {
  6. return array(
  7. 'term_reference_tree' => array(
  8. 'label' => 'Term reference tree',
  9. 'field types' => array('taxonomy_term_reference'),
  10. 'settings' => array(
  11. 'token_display_selected' => '',
  12. 'token_display_unselected' => '',
  13. ),
  14. ),
  15. );
  16. }
  17. /**
  18. * Implements hook_field_formatter_view().
  19. */
  20. function term_reference_tree_field_formatter_view($entity_type, $entity, $field, $instance, $langcode, $items, $display) {
  21. $element = array();
  22. switch ($display['type']) {
  23. case 'term_reference_tree':
  24. if (!empty($items)) {
  25. $element[] = array(
  26. '#theme' => 'term_tree_list',
  27. '#data' => $items,
  28. '#display' => $display,
  29. '#attached' => array('css' => array(drupal_get_path('module', 'term_reference_tree') . '/term_reference_tree.css')),
  30. );
  31. }
  32. break;
  33. }
  34. return $element;
  35. }
  36. /**
  37. * Implements hook_field_formatter_settings_form().
  38. */
  39. function term_reference_tree_field_formatter_settings_form($field, $instance, $view_mode, $form, &$form_state) {
  40. $display = $instance['display'][$view_mode];
  41. $settings = $display['settings'];
  42. $element = array();
  43. if ($display['type'] == 'term_reference_tree' && module_exists('token')) {
  44. $element['token_display_selected'] = array(
  45. '#type' => 'textarea',
  46. '#title' => 'Custom Term Label',
  47. '#description' => t("Use tokens to change the term label. Leave this field blank to use the term name linked to its taxonomy page."),
  48. '#default_value' => $settings['token_display_selected'],
  49. );
  50. $element['token_display_unselected'] = array(
  51. '#type' => 'textarea',
  52. '#title' => 'Custom Term Label (unselected)',
  53. '#description' => t("Use tokens to change the term label for unselected parent terms. Leave this field blank to use the same tokens as above."),
  54. '#default_value' => $settings['token_display_unselected'],
  55. );
  56. $element['tokens_list'] = array(
  57. '#theme' => 'token_tree',
  58. '#token_types' => array('term'),
  59. );
  60. }
  61. return $element;
  62. }
  63. /**
  64. * Implements hook_field_formatter_settings_summary().
  65. */
  66. function term_reference_tree_field_formatter_settings_summary($field, $instance, $view_mode) {
  67. $display = $instance['display'][$view_mode];
  68. $settings = $display['settings'];
  69. $summary = '';
  70. if ($display['type'] == 'term_reference_tree') {
  71. $summary = t('Uses tokens: ') . ($settings['token_display_selected'] != '' ? t('Yes') : t('No'));
  72. }
  73. return $summary;
  74. }