2013-07-16 15:39:47 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Web\Form\Element;
|
|
|
|
|
2013-08-30 17:42:39 +02:00
|
|
|
use Icinga\Web\Form\Validator\DateTimeValidator;
|
2014-08-27 12:24:11 +02:00
|
|
|
use \Zend_Form_Element_Text;
|
|
|
|
use \Zend_Form_Element;
|
|
|
|
use \Icinga\Util\DateTimeFactory;
|
2013-07-16 15:39:47 +02:00
|
|
|
|
2013-08-06 19:05:16 +02:00
|
|
|
/**
|
2013-08-12 13:56:14 +02:00
|
|
|
* Datetime form element which returns the input as Unix timestamp after the input has been proven valid. Utilizes
|
|
|
|
* DateTimeFactory to ensure time zone awareness
|
|
|
|
*
|
|
|
|
* @see isValid()
|
2013-08-06 19:05:16 +02:00
|
|
|
*/
|
2013-08-30 17:42:39 +02:00
|
|
|
class DateTimePicker extends Zend_Form_Element_Text
|
2013-07-16 15:39:47 +02:00
|
|
|
{
|
2013-10-20 15:30:49 +02:00
|
|
|
/**
|
2013-10-21 11:32:24 +02:00
|
|
|
* Default format used my js picker
|
2013-10-20 15:30:49 +02:00
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
public $defaultFormat = 'Y-m-d H:i:s';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* JS picker support on or off
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
public $jspicker = true;
|
|
|
|
|
2013-07-16 15:39:47 +02:00
|
|
|
/**
|
2013-08-07 01:47:32 +02:00
|
|
|
* View helper to use
|
2013-07-16 15:39:47 +02:00
|
|
|
* @var string
|
|
|
|
*/
|
2013-08-07 01:47:32 +02:00
|
|
|
public $helper = 'formDateTime';
|
2013-08-07 17:14:58 +02:00
|
|
|
|
2013-08-30 17:42:39 +02:00
|
|
|
/**
|
|
|
|
* The validator used for datetime validation
|
|
|
|
* @var DateTimeValidator
|
|
|
|
*/
|
|
|
|
private $dateValidator;
|
|
|
|
|
2013-08-07 17:14:58 +02:00
|
|
|
/**
|
2013-08-27 16:00:45 +02:00
|
|
|
* Valid formats to check user input against
|
|
|
|
* @var array
|
|
|
|
*/
|
2013-10-20 15:30:49 +02:00
|
|
|
public $patterns = array();
|
2013-08-27 16:00:45 +02:00
|
|
|
|
|
|
|
/**
|
2013-08-30 17:42:39 +02:00
|
|
|
* Create a new DateTimePicker
|
2013-08-07 17:14:58 +02:00
|
|
|
*
|
2013-08-30 17:42:39 +02:00
|
|
|
* @param array|string|\Zend_Config $spec
|
|
|
|
* @param null $options
|
|
|
|
* @see Zend_Form_Element::__construct()
|
2013-08-07 17:14:58 +02:00
|
|
|
*/
|
2013-08-30 17:42:39 +02:00
|
|
|
public function __construct($spec, $options = null)
|
2013-08-07 17:14:58 +02:00
|
|
|
{
|
2013-08-30 17:42:39 +02:00
|
|
|
parent::__construct($spec, $options);
|
2013-10-20 15:30:49 +02:00
|
|
|
|
|
|
|
$this->patterns[] = $this->defaultFormat;
|
|
|
|
|
2013-08-30 17:42:39 +02:00
|
|
|
$this->dateValidator = new DateTimeValidator($this->patterns);
|
|
|
|
$this->addValidator($this->dateValidator);
|
2013-08-07 17:14:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate filtered date/time strings
|
|
|
|
*
|
2013-08-27 16:00:45 +02:00
|
|
|
* Expects one or more valid formats being set in $this->patterns. Sets element value as Unix timestamp
|
|
|
|
* if the input is considered valid. Utilizes DateTimeFactory to ensure time zone awareness.
|
2013-08-07 17:14:58 +02:00
|
|
|
*
|
|
|
|
* @param string $value
|
|
|
|
* @param mixed $context
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValid($value, $context = null)
|
|
|
|
{
|
2013-08-30 17:42:39 +02:00
|
|
|
// Overwrite the internal validator to use
|
2013-08-07 17:14:58 +02:00
|
|
|
|
2013-08-30 17:42:39 +02:00
|
|
|
if (!parent::isValid($value, $context)) {
|
2013-08-07 17:14:58 +02:00
|
|
|
return false;
|
|
|
|
}
|
2013-08-30 17:42:39 +02:00
|
|
|
$pattern = $this->dateValidator->getValidPattern();
|
|
|
|
if (!$pattern) {
|
|
|
|
$this->setValue($value);
|
|
|
|
return true;
|
2013-08-07 17:14:58 +02:00
|
|
|
}
|
2013-08-30 17:42:39 +02:00
|
|
|
$this->setValue(DateTimeFactory::parse($value, $pattern)->getTimestamp());
|
2013-08-07 17:14:58 +02:00
|
|
|
return true;
|
|
|
|
}
|
2013-10-20 15:30:49 +02:00
|
|
|
|
|
|
|
public function enableJsPicker()
|
|
|
|
{
|
|
|
|
$this->jspicker = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function disableJsPicker()
|
|
|
|
{
|
|
|
|
$this->jspicker = false;
|
|
|
|
}
|
2013-07-17 14:08:07 +02:00
|
|
|
}
|