Mercurial > hg > rr-repo
diff 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 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sites/all/modules/views/handlers/views_handler_field_boolean.inc Wed Aug 21 18:51:11 2013 +0100 @@ -0,0 +1,110 @@ +<?php + +/** + * @file + * Definition of views_handler_field_boolean. + */ + +/** + * A handler to provide proper displays for booleans. + * + * Allows for display of true/false, yes/no, on/off, enabled/disabled. + * + * Definition terms: + * - output formats: An array where the first entry is displayed on boolean true + * and the second is displayed on boolean false. An example for sticky is: + * @code + * 'output formats' => array( + * 'sticky' => array(t('Sticky'), ''), + * ), + * @endcode + * + * @ingroup views_field_handlers + */ +class views_handler_field_boolean extends views_handler_field { + function option_definition() { + $options = parent::option_definition(); + $options['type'] = array('default' => 'yes-no'); + $options['type_custom_true'] = array('default' => '', 'translatable' => TRUE); + $options['type_custom_false'] = array('default' => '', 'translatable' => TRUE); + $options['not'] = array('definition bool' => 'reverse'); + + return $options; + } + + function init(&$view, &$options) { + parent::init($view, $options); + + $default_formats = array( + 'yes-no' => array(t('Yes'), t('No')), + 'true-false' => array(t('True'), t('False')), + 'on-off' => array(t('On'), t('Off')), + 'enabled-disabled' => array(t('Enabled'), t('Disabled')), + 'boolean' => array(1, 0), + 'unicode-yes-no' => array('✔', '✖'), + ); + $output_formats = isset($this->definition['output formats']) ? $this->definition['output formats'] : array(); + $custom_format = array('custom' => array(t('Custom'))); + $this->formats = array_merge($default_formats, $output_formats, $custom_format); + } + + function options_form(&$form, &$form_state) { + foreach ($this->formats as $key => $item) { + $options[$key] = implode('/', $item); + } + + $form['type'] = array( + '#type' => 'select', + '#title' => t('Output format'), + '#options' => $options, + '#default_value' => $this->options['type'], + ); + + $form['type_custom_true'] = array( + '#type' => 'textfield', + '#title' => t('Custom output for TRUE'), + '#default_value' => $this->options['type_custom_true'], + '#states' => array( + 'visible' => array( + 'select[name="options[type]"]' => array('value' => 'custom'), + ), + ), + ); + + $form['type_custom_false'] = array( + '#type' => 'textfield', + '#title' => t('Custom output for FALSE'), + '#default_value' => $this->options['type_custom_false'], + '#states' => array( + 'visible' => array( + 'select[name="options[type]"]' => array('value' => 'custom'), + ), + ), + ); + + $form['not'] = array( + '#type' => 'checkbox', + '#title' => t('Reverse'), + '#description' => t('If checked, true will be displayed as false.'), + '#default_value' => $this->options['not'], + ); + parent::options_form($form, $form_state); + } + + function render($values) { + $value = $this->get_value($values); + if (!empty($this->options['not'])) { + $value = !$value; + } + + if ($this->options['type'] == 'custom') { + return $value ? filter_xss_admin($this->options['type_custom_true']) : filter_xss_admin($this->options['type_custom_false']); + } + else if (isset($this->formats[$this->options['type']])) { + return $value ? $this->formats[$this->options['type']][0] : $this->formats[$this->options['type']][1]; + } + else { + return $value ? $this->formats['yes-no'][0] : $this->formats['yes-no'][1]; + } + } +}