2013-07-16 15:39:47 +02:00
|
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
2013-07-16 15:39:47 +02:00
|
|
|
|
|
|
|
|
|
namespace Icinga\Web\Form\Element;
|
|
|
|
|
|
2014-10-06 10:21:17 +02:00
|
|
|
|
use Icinga\Web\Form\FormElement;
|
2014-04-16 16:41:23 +02:00
|
|
|
|
|
2013-07-16 15:39:47 +02:00
|
|
|
|
/**
|
2014-09-02 16:48:54 +02:00
|
|
|
|
* A number input control
|
2013-07-16 15:39:47 +02:00
|
|
|
|
*/
|
2014-10-06 10:21:17 +02:00
|
|
|
|
class Number extends FormElement
|
2013-07-16 15:39:47 +02:00
|
|
|
|
{
|
2014-04-16 16:41:23 +02:00
|
|
|
|
/**
|
2014-09-02 16:48:54 +02:00
|
|
|
|
* Form view helper to use for rendering
|
2014-04-16 16:41:23 +02:00
|
|
|
|
*
|
2014-09-02 16:48:54 +02:00
|
|
|
|
* @var string
|
2014-04-16 16:41:23 +02:00
|
|
|
|
*/
|
2014-09-02 16:48:54 +02:00
|
|
|
|
public $helper = 'formNumber';
|
2014-04-16 16:41:23 +02:00
|
|
|
|
|
2014-09-03 14:39:42 +02:00
|
|
|
|
/**
|
|
|
|
|
* The expected lower bound for the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @var float|null
|
|
|
|
|
*/
|
|
|
|
|
protected $min;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The expected upper bound for the element’s
|
|
|
|
|
*
|
|
|
|
|
* @var float|null
|
|
|
|
|
*/
|
|
|
|
|
protected $max;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The value granularity of the element’s value
|
|
|
|
|
*
|
|
|
|
|
* Normally, number input controls are limited to an accuracy of integer values.
|
|
|
|
|
*
|
|
|
|
|
* @var float|string|null
|
|
|
|
|
*/
|
|
|
|
|
protected $step;
|
|
|
|
|
|
2014-09-02 16:48:54 +02:00
|
|
|
|
/**
|
|
|
|
|
* (non-PHPDoc)
|
|
|
|
|
* @see \Zend_Form_Element::init() For the method documentation.
|
|
|
|
|
*/
|
|
|
|
|
public function init()
|
|
|
|
|
{
|
2018-04-12 14:25:10 +02:00
|
|
|
|
if ($this->min !== null || $this->max !== null) {
|
|
|
|
|
$this->addValidator('Between', true, array(
|
|
|
|
|
'min' => $this->min === null ? -INF : $this->min,
|
|
|
|
|
'max' => $this->max === null ? INF : $this->max,
|
|
|
|
|
'inclusive' => true
|
|
|
|
|
));
|
2014-09-03 14:39:42 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Set the expected lower bound for the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @param float $min
|
|
|
|
|
*
|
|
|
|
|
* @return $this
|
|
|
|
|
*/
|
|
|
|
|
public function setMin($min)
|
|
|
|
|
{
|
|
|
|
|
$this->min = (float) $min;
|
|
|
|
|
return $this;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the expected lower bound for the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @return float|null
|
|
|
|
|
*/
|
|
|
|
|
public function getMin()
|
|
|
|
|
{
|
|
|
|
|
return $this->min;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Set the expected upper bound for the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @param float $max
|
|
|
|
|
*
|
|
|
|
|
* @return $this
|
|
|
|
|
*/
|
|
|
|
|
public function setMax($max)
|
|
|
|
|
{
|
2018-04-12 14:25:10 +02:00
|
|
|
|
$this->max = (float) $max;
|
2014-09-03 14:39:42 +02:00
|
|
|
|
return $this;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the expected upper bound for the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @return float|null
|
|
|
|
|
*/
|
|
|
|
|
public function getMax()
|
|
|
|
|
{
|
|
|
|
|
return $this->max;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Set the value granularity of the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @param float|string $step
|
|
|
|
|
*
|
|
|
|
|
* @return $this
|
|
|
|
|
*/
|
|
|
|
|
public function setStep($step)
|
|
|
|
|
{
|
|
|
|
|
if ($step !== 'any') {
|
|
|
|
|
$step = (float) $step;
|
|
|
|
|
}
|
|
|
|
|
$this->step = $step;
|
|
|
|
|
return $this;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get the value granularity of the element’s value
|
|
|
|
|
*
|
|
|
|
|
* @return float|string|null
|
|
|
|
|
*/
|
|
|
|
|
public function getStep()
|
|
|
|
|
{
|
|
|
|
|
return $this->step;
|
2014-04-16 16:41:23 +02:00
|
|
|
|
}
|
2014-11-18 10:29:28 +01:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* (non-PHPDoc)
|
|
|
|
|
* @see \Zend_Form_Element::isValid() For the method documentation.
|
|
|
|
|
*/
|
|
|
|
|
public function isValid($value, $context = null)
|
|
|
|
|
{
|
2015-03-11 08:00:20 +01:00
|
|
|
|
$this->setValue($value);
|
|
|
|
|
$value = $this->getValue();
|
2017-08-17 13:20:51 +02:00
|
|
|
|
if ($value !== null && $value !== '' && ! is_numeric($value)) {
|
2015-09-07 16:57:09 +02:00
|
|
|
|
$this->addError(sprintf(t('\'%s\' is not a valid number'), $value));
|
2014-11-18 10:29:28 +01:00
|
|
|
|
return false;
|
|
|
|
|
}
|
2015-03-11 08:00:20 +01:00
|
|
|
|
return parent::isValid($value, $context);
|
2014-11-18 10:29:28 +01:00
|
|
|
|
}
|
2013-07-16 15:39:47 +02:00
|
|
|
|
}
|