You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
4.6 KiB
208 lines
4.6 KiB
1 year ago
|
<?php
|
||
|
/*
|
||
|
** Zabbix
|
||
|
** Copyright (C) 2001-2023 Zabbix SIA
|
||
|
**
|
||
|
** This program is free software; you can redistribute it and/or modify
|
||
|
** it under the terms of the GNU General Public License as published by
|
||
|
** the Free Software Foundation; either version 2 of the License, or
|
||
|
** (at your option) any later version.
|
||
|
**
|
||
|
** This program is distributed in the hope that it will be useful,
|
||
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
** GNU General Public License for more details.
|
||
|
**
|
||
|
** You should have received a copy of the GNU General Public License
|
||
|
** along with this program; if not, write to the Free Software
|
||
|
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
**/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Class to create a date textbox and calendar button.
|
||
|
*/
|
||
|
class CDateSelector extends CTag {
|
||
|
/**
|
||
|
* Default CSS class name for HTML root element.
|
||
|
*/
|
||
|
const ZBX_STYLE_CLASS = 'calendar-control';
|
||
|
|
||
|
/**
|
||
|
* Input name.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $name = '';
|
||
|
|
||
|
/**
|
||
|
* Default date format.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $date_format = ZBX_FULL_DATE_TIME;
|
||
|
|
||
|
/**
|
||
|
* Set aria-required to textbox.
|
||
|
*
|
||
|
* @var bool
|
||
|
*/
|
||
|
private $is_required = false;
|
||
|
|
||
|
/**
|
||
|
* Placeholder for date textbox field.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $placeholder = null;
|
||
|
|
||
|
/**
|
||
|
* Date and time set from view. Absolute (Y-m-d H:i:s) or relative time (now+1d, now/M ...).
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
private $value = null;
|
||
|
|
||
|
/**
|
||
|
* Readonly state of HTML element.
|
||
|
*
|
||
|
* @var bool
|
||
|
*/
|
||
|
private $readonly = false;
|
||
|
|
||
|
/**
|
||
|
* Enabled or disabled state of HTML element.
|
||
|
*
|
||
|
* @var bool
|
||
|
*/
|
||
|
private $enabled = true;
|
||
|
|
||
|
/**
|
||
|
* Maxlength attribute of the input field. Aligned with the date format by default.
|
||
|
*
|
||
|
* @var int
|
||
|
*/
|
||
|
private $maxlength;
|
||
|
|
||
|
/**
|
||
|
* Create array with all inputs required for date selection and calendar.
|
||
|
*
|
||
|
* @param string $name Textbox field name and calendar name prefix.
|
||
|
* @param string $value Date and time set from view. Absolute (Y-m-d H:i:s) or relative time (now+1d, now/M ...).
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function __construct(string $name = 'calendar', $value = null) {
|
||
|
parent::__construct('div', true);
|
||
|
|
||
|
$this->name = $name;
|
||
|
$this->value = $value;
|
||
|
$this->addClass(static::ZBX_STYLE_CLASS);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set or reset element 'aria-required' attribute to textbox (not the container).
|
||
|
*
|
||
|
* @param bool $is_required True to set field as required or false if field is not required.
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setAriaRequired($is_required = false) {
|
||
|
$this->is_required = $is_required;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set date format which calendar will return upon selection.
|
||
|
*
|
||
|
* @param string $format Date and time format. Usually Y-m-d H:i:s or Y-m-d H:i
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setDateFormat($format) {
|
||
|
$this->date_format = $format;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add placeholder to date textbox field.
|
||
|
*
|
||
|
* @param string $text Placeholder text for date textbox field.
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setPlaceholder($text) {
|
||
|
$this->placeholder = $text;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Enable or disable readonly mode for the element.
|
||
|
*
|
||
|
* @param bool $value
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setReadonly(bool $value): self {
|
||
|
$this->readonly = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set enabled or disabled state to field.
|
||
|
*
|
||
|
* @param bool $enabled Field state.
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setEnabled($enabled) {
|
||
|
$this->enabled = $enabled;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set non-default maxlength attribute to the input field.
|
||
|
*
|
||
|
* @param int $maxlength
|
||
|
*
|
||
|
* @return CDateSelector
|
||
|
*/
|
||
|
public function setMaxLength(int $maxlength) {
|
||
|
$this->maxlength = $maxlength;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets string representation of date textbox and calendar button.
|
||
|
*
|
||
|
* @param bool $destroy
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function toString($destroy = true) {
|
||
|
$this
|
||
|
->addItem(
|
||
|
(new CTextBox($this->name, $this->value))
|
||
|
->setId($this->name)
|
||
|
->setAttribute('placeholder', $this->placeholder)
|
||
|
->setAttribute('maxlength', $this->maxlength ?? strlen(date($this->date_format)))
|
||
|
->setAriaRequired($this->is_required)
|
||
|
->setEnabled($this->enabled)
|
||
|
->setReadonly($this->readonly)
|
||
|
)
|
||
|
->addItem((new CButton($this->name.'_calendar'))
|
||
|
->addClass(ZBX_STYLE_BTN_ICON)
|
||
|
->addClass(ZBX_ICON_CALENDAR)
|
||
|
->setEnabled($this->enabled && !$this->readonly)
|
||
|
->onClick('toggleCalendar(this, "'.$this->name.'", "'.$this->date_format.'");'));
|
||
|
|
||
|
return parent::toString($destroy);
|
||
|
}
|
||
|
}
|