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
|
<?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/>.
**/
class CBarGauge extends CTag {
private array $thresholds = [];
public function __construct() {
parent::__construct('z-bar-gauge', true);
}
/**
* @param int|float $value
* @param string $fill
*
* @return CBarGauge
*/
public function addThreshold($value, string $fill): self {
$this->thresholds[] = [
'value' => $value,
'fill' => $fill
];
return $this;
}
/**
* Selected option value. If no value is set, first available option will be preselected client at side.
*
* @param mixed $value
*
* @return CBarGauge
*/
public function setValue($value): self {
$this->setAttribute('value', $value);
return $this;
}
/**
* @param int|string $width
*
* @return self
*/
public function setWidth($width): self {
$this->setAttribute('width', $width);
return $this;
}
public function toString($destroy = true) {
foreach ($this->thresholds as $threshold) {
$this->addItem(
(new CTag('threshold', true))
->setAttribute('value', $threshold['value'])
->setAttribute('fill', $threshold['fill'])
);
}
return parent::toString($destroy);
}
}
|