1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
<?php declare(strict_types = 0);
/*
** Copyright (C) 2001-2025 Zabbix SIA
**
** This program is free software: you can redistribute it and/or modify it under the terms of
** the GNU Affero General Public License as published by the Free Software Foundation, version 3.
**
** 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 Affero General Public License for more details.
**
** You should have received a copy of the GNU Affero General Public License along with this program.
** If not, see <https://www.gnu.org/licenses/>.
**/
namespace Zabbix\Widgets\Fields;
use CAbsoluteTimeParser,
CParser,
CRelativeTimeParser;
use Zabbix\Widgets\CWidgetField;
class CWidgetFieldDatePicker extends CWidgetField {
public const DEFAULT_VIEW = \CWidgetFieldDatePickerView::class;
public const DEFAULT_VALUE = '';
private bool $is_date_only = false;
public function __construct(string $name, ?string $label = null) {
parent::__construct($name, $label);
$this
->setDefault(self::DEFAULT_VALUE)
->setMaxLength(255);
}
public function validate(bool $strict = false): array {
if ($errors = parent::validate($strict)) {
return $errors;
}
$value = $this->getValue();
if ($value === self::DEFAULT_VALUE) {
return [];
}
$absolute_time_parser = new CAbsoluteTimeParser();
if ($absolute_time_parser->parse($value) === CParser::PARSE_SUCCESS) {
$has_errors = false;
if ($this->is_date_only) {
$has_errors = $absolute_time_parser->getDateTime(true)->format('H:i:s') !== '00:00:00';
}
if (!$has_errors) {
return [];
}
}
$relative_time_parser = new CRelativeTimeParser();
if ($relative_time_parser->parse($value) === CParser::PARSE_SUCCESS) {
$has_errors = false;
if ($this->is_date_only) {
foreach ($relative_time_parser->getTokens() as $token) {
if ($token['suffix'] === 'h' || $token['suffix'] === 'm' || $token['suffix'] === 's') {
$has_errors = true;
break;
}
}
}
if (!$has_errors) {
return [];
}
}
return [
_s('Invalid parameter "%1$s": %2$s.', $this->getErrorLabel(),
$this->is_date_only ? _('a date is expected') : _('a time is expected')
)
];
}
public function setDateOnly(bool $is_date_only = true): self {
$this->is_date_only = $is_date_only;
return $this;
}
protected function getValidationRules(bool $strict = false): array {
$validation_rules = parent::getValidationRules($strict);
if (($this->getFlags() & self::FLAG_NOT_EMPTY) !== 0) {
self::setValidationRuleFlag($validation_rules, API_NOT_EMPTY);
}
return $validation_rules;
}
}
|