Mercurial > hg > rr-repo
comparison sites/all/modules/views/handlers/views_handler_field_boolean.inc @ 0:ff03f76ab3fe
initial version
author | danieleb <danielebarchiesi@me.com> |
---|---|
date | Wed, 21 Aug 2013 18:51:11 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:ff03f76ab3fe |
---|---|
1 <?php | |
2 | |
3 /** | |
4 * @file | |
5 * Definition of views_handler_field_boolean. | |
6 */ | |
7 | |
8 /** | |
9 * A handler to provide proper displays for booleans. | |
10 * | |
11 * Allows for display of true/false, yes/no, on/off, enabled/disabled. | |
12 * | |
13 * Definition terms: | |
14 * - output formats: An array where the first entry is displayed on boolean true | |
15 * and the second is displayed on boolean false. An example for sticky is: | |
16 * @code | |
17 * 'output formats' => array( | |
18 * 'sticky' => array(t('Sticky'), ''), | |
19 * ), | |
20 * @endcode | |
21 * | |
22 * @ingroup views_field_handlers | |
23 */ | |
24 class views_handler_field_boolean extends views_handler_field { | |
25 function option_definition() { | |
26 $options = parent::option_definition(); | |
27 $options['type'] = array('default' => 'yes-no'); | |
28 $options['type_custom_true'] = array('default' => '', 'translatable' => TRUE); | |
29 $options['type_custom_false'] = array('default' => '', 'translatable' => TRUE); | |
30 $options['not'] = array('definition bool' => 'reverse'); | |
31 | |
32 return $options; | |
33 } | |
34 | |
35 function init(&$view, &$options) { | |
36 parent::init($view, $options); | |
37 | |
38 $default_formats = array( | |
39 'yes-no' => array(t('Yes'), t('No')), | |
40 'true-false' => array(t('True'), t('False')), | |
41 'on-off' => array(t('On'), t('Off')), | |
42 'enabled-disabled' => array(t('Enabled'), t('Disabled')), | |
43 'boolean' => array(1, 0), | |
44 'unicode-yes-no' => array('✔', '✖'), | |
45 ); | |
46 $output_formats = isset($this->definition['output formats']) ? $this->definition['output formats'] : array(); | |
47 $custom_format = array('custom' => array(t('Custom'))); | |
48 $this->formats = array_merge($default_formats, $output_formats, $custom_format); | |
49 } | |
50 | |
51 function options_form(&$form, &$form_state) { | |
52 foreach ($this->formats as $key => $item) { | |
53 $options[$key] = implode('/', $item); | |
54 } | |
55 | |
56 $form['type'] = array( | |
57 '#type' => 'select', | |
58 '#title' => t('Output format'), | |
59 '#options' => $options, | |
60 '#default_value' => $this->options['type'], | |
61 ); | |
62 | |
63 $form['type_custom_true'] = array( | |
64 '#type' => 'textfield', | |
65 '#title' => t('Custom output for TRUE'), | |
66 '#default_value' => $this->options['type_custom_true'], | |
67 '#states' => array( | |
68 'visible' => array( | |
69 'select[name="options[type]"]' => array('value' => 'custom'), | |
70 ), | |
71 ), | |
72 ); | |
73 | |
74 $form['type_custom_false'] = array( | |
75 '#type' => 'textfield', | |
76 '#title' => t('Custom output for FALSE'), | |
77 '#default_value' => $this->options['type_custom_false'], | |
78 '#states' => array( | |
79 'visible' => array( | |
80 'select[name="options[type]"]' => array('value' => 'custom'), | |
81 ), | |
82 ), | |
83 ); | |
84 | |
85 $form['not'] = array( | |
86 '#type' => 'checkbox', | |
87 '#title' => t('Reverse'), | |
88 '#description' => t('If checked, true will be displayed as false.'), | |
89 '#default_value' => $this->options['not'], | |
90 ); | |
91 parent::options_form($form, $form_state); | |
92 } | |
93 | |
94 function render($values) { | |
95 $value = $this->get_value($values); | |
96 if (!empty($this->options['not'])) { | |
97 $value = !$value; | |
98 } | |
99 | |
100 if ($this->options['type'] == 'custom') { | |
101 return $value ? filter_xss_admin($this->options['type_custom_true']) : filter_xss_admin($this->options['type_custom_false']); | |
102 } | |
103 else if (isset($this->formats[$this->options['type']])) { | |
104 return $value ? $this->formats[$this->options['type']][0] : $this->formats[$this->options['type']][1]; | |
105 } | |
106 else { | |
107 return $value ? $this->formats['yes-no'][0] : $this->formats['yes-no'][1]; | |
108 } | |
109 } | |
110 } |