* @license http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2 * @author Icinga Development Team * */ // {{{ICINGA_LICENSE_HEADER}}} namespace Icinga\Form\Preference; use \DateTimeZone; use \Zend_Config; use \Zend_Form_Element_Text; use \Zend_Form_Element_Select; use \Zend_View_Helper_DateFormat; use \Icinga\Web\Form; use \Icinga\Web\Form\Validator\TimeFormatValidator; use \Icinga\Web\Form\Validator\DateFormatValidator; use \Icinga\Util\Translator; /** * General user preferences */ class GeneralForm extends Form { /** * The view helper to format date/time strings * * @var Zend_View_Helper_DateFormat */ private $dateHelper; /** * Return the view helper to format date/time strings * * @return Zend_View_Helper_DateFormat */ public function getDateFormatter() { if ($this->dateHelper === null) { return $this->getView()->dateFormat(); } return $this->dateHelper; } /** * Set the view helper that is used to format date/time strings (used for testing) * * @param Zend_View_Helper_DateFormat $dateHelper */ public function setDateFormatter(Zend_View_Helper_DateFormat $dateHelper) { $this->dateHelper = $dateHelper; } /** * Add a select field for setting the user's language * * Possible values are determined by Translator::getAvailableLocaleCodes. * Also, a 'use default format' checkbox is added in order to allow a user to discard his overwritten setting * * @param Zend_Config $cfg The "global" section of the config.ini to be used as default value */ private function addLanguageSelection(Zend_Config $cfg) { $languages = array(); foreach (Translator::getAvailableLocaleCodes() as $language) { $languages[$language] = $language; } $languages[Translator::DEFAULT_LOCALE] = Translator::DEFAULT_LOCALE; $prefs = $this->getUserPreferences(); $useDefaultLanguage = $this->getRequest()->getParam('default_language', !$prefs->has('app.language')); $this->addElement( 'checkbox', 'default_language', array( 'label' => t('Use Default Language'), 'value' => !$prefs->has('app.language'), 'required' => true ) ); $selectOptions = array( 'label' => t('Your Current Language'), 'required' => !$useDefaultLanguage, 'multiOptions' => $languages, 'helptext' => t('Use the following language to display texts and messages'), 'value' => $prefs->get('app.language', $cfg->get('language', Translator::DEFAULT_LOCALE)) ); if ($useDefaultLanguage) { $selectOptions['disabled'] = 'disabled'; } $this->addElement('select', 'language', $selectOptions); $this->enableAutoSubmit(array('default_language')); } /** * Add a select field for setting the user's timezone. * * Possible values are determined by DateTimeZone::listIdentifiers * Also, a 'use default format' checkbox is added in order to allow a user to discard his overwritten setting * * @param Zend_Config $cfg The "global" section of the config.ini to be used as default value */ private function addTimezoneSelection(Zend_Config $cfg) { $tzList = array(); foreach (DateTimeZone::listIdentifiers() as $tz) { $tzList[$tz] = $tz; } $helptext = 'Use the following timezone for dates and times'; $prefs = $this->getUserPreferences(); $useGlobalTimezone = $this->getRequest()->getParam('default_timezone', !$prefs->has('app.timezone')); $selectTimezone = new Zend_Form_Element_Select( array( 'name' => 'timezone', 'label' => 'Your Current Timezone', 'required' => !$useGlobalTimezone, 'multiOptions' => $tzList, 'helptext' => $helptext, 'value' => $prefs->get('app.timezone', $cfg->get('timezone', date_default_timezone_get())) ) ); $this->addElement( 'checkbox', 'default_timezone', array( 'label' => 'Use Default Timezone', 'value' => !$prefs->has('app.timezone'), 'required' => true ) ); if ($useGlobalTimezone) { $selectTimezone->setAttrib('disabled', 1); } $this->addElement($selectTimezone); $this->enableAutoSubmit(array('default_timezone')); } /** * Add text fields for the date and time format used for this user * * Also, a 'use default format' checkbox is added in order to allow a user to discard his overwritten setting * * @param Zend_Config $cfg The "global" section of the config.ini to be used as default values */ private function addDateFormatSettings(Zend_Config $cfg) { $prefs = $this->getUserPreferences(); $useGlobalDateFormat = $this->getRequest()->getParam('default_date_format', !$prefs->has('app.dateFormat')); $useGlobalTimeFormat = $this->getRequest()->getParam('default_time_format', !$prefs->has('app.timeFormat')); $phpUrl = '' . 'the official PHP documentation'; $this->addElement( 'checkbox', 'default_date_format', array( 'label' => 'Use Default Date Format', 'value' => !$prefs->has('app.dateFormat'), 'required' => true ) ); $dateFormatValue = $this->getRequest()->getParam('date_format', ''); if (empty($dateFormatValue)) { $dateFormatValue = $prefs->get('app.dateFormat', $cfg->get('dateFormat', 'd/m/Y')); } $txtDefaultDateFormat = new Zend_Form_Element_Text( array( 'name' => 'date_format', 'label' => 'Preferred Date Format', 'helptext' => 'Display dates according to this format. (See ' . $phpUrl . ' for possible values.) ' . 'Example result: ' . $this->getDateFormatter()->format(time(), $dateFormatValue), 'required' => !$useGlobalDateFormat, 'value' => $dateFormatValue ) ); $this->addElement($txtDefaultDateFormat); $txtDefaultDateFormat->addValidator(new DateFormatValidator()); if ($useGlobalDateFormat) { $txtDefaultDateFormat->setAttrib('disabled', '1'); } $this->addElement( 'checkbox', 'default_time_format', array( 'label' => 'Use Default Time Format', 'value' => !$prefs->has('app.timeFormat'), 'required' => !$useGlobalTimeFormat ) ); $timeFormatValue = $this->getRequest()->getParam('time_format', ''); if (empty($timeFormatValue)) { $timeFormatValue = $prefs->get('app.timeFormat', $cfg->get('timeFormat', 'g:i A')); } $txtDefaultTimeFormat = new Zend_Form_Element_Text( array( 'name' => 'time_format', 'label' => 'Preferred Time Format', 'required' => !$useGlobalTimeFormat, 'helptext' => 'Display times according to this format. (See ' . $phpUrl . ' for possible values.) ' . 'Example result: ' . $this->getDateFormatter()->format(time(), $timeFormatValue), 'value' => $timeFormatValue ) ); $txtDefaultTimeFormat->addValidator(new TimeFormatValidator()); $this->addElement($txtDefaultTimeFormat); if ($useGlobalTimeFormat) { $txtDefaultTimeFormat->setAttrib('disabled', '1'); } $this->enableAutoSubmit(array('default_time_format', 'default_date_format')); } /** * Create the general form, using the global configuration as fallback values for preferences * * @see Form::create() */ public function create() { $this->setName('form_preference_set'); $config = $this->getConfiguration(); $global = $config->global; if ($global === null) { $global = new Zend_Config(array()); } $this->addLanguageSelection($global); $this->addTimezoneSelection($global); $this->addDateFormatSettings($global); $this->setSubmitLabel('Save Changes'); $this->addElement( 'checkbox', 'showBenchmark', array( 'label' => 'Use benchmark', 'value' => $this->getUserPreferences()->get('app.showBenchmark') ) ); } /** * Return an array containing the preferences set in this form * * @return array */ public function getPreferences() { $values = $this->getValues(); return array( 'app.language' => $values['language'], 'app.timezone' => $values['timezone'], 'app.dateFormat' => $values['date_format'], 'app.timeFormat' => $values['time_format'], 'app.showBenchmark' => $values['showBenchmark'] === '1' ? true : false ); } }