2013-09-09 13:55:29 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
/**
|
2013-10-23 15:10:33 +02:00
|
|
|
* This file is part of Icinga Web 2.
|
2013-09-09 13:55:29 +02:00
|
|
|
*
|
2013-10-23 15:10:33 +02:00
|
|
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
2013-09-09 13:55:29 +02:00
|
|
|
* Copyright (C) 2013 Icinga Development Team
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @copyright 2013 Icinga Development Team <info@icinga.org>
|
|
|
|
* @license http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2
|
|
|
|
* @author Icinga Development Team <info@icinga.org>
|
2013-10-23 15:10:33 +02:00
|
|
|
*
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Chart;
|
|
|
|
|
2013-09-25 16:32:28 +02:00
|
|
|
use \DOMElement;
|
|
|
|
use \Icinga\Chart\Palette;
|
|
|
|
use \Icinga\Chart\Primitive\Canvas;
|
|
|
|
use \Icinga\Chart\Primitive\Drawable;
|
|
|
|
use \Icinga\Chart\Primitive\Rect;
|
|
|
|
use \Icinga\Chart\Primitive\Text;
|
|
|
|
use \Icinga\Chart\Render\LayoutBox;
|
|
|
|
use \Icinga\Chart\Render\RenderContext;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Drawable for creating a Graph Legend on the bottom of a graph.
|
|
|
|
*
|
|
|
|
* Usually used by the GridChart class internally.
|
|
|
|
*/
|
2013-09-09 13:55:29 +02:00
|
|
|
class Legend implements Drawable
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
2013-09-21 17:35:18 +02:00
|
|
|
* Internal counter for unnamed label identifiers
|
2013-09-09 13:55:29 +02:00
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* @var int
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
2013-09-21 17:35:18 +02:00
|
|
|
private $internalCtr = 0;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* Content of this legend
|
2013-09-09 13:55:29 +02:00
|
|
|
*
|
2013-09-21 17:35:18 +02:00
|
|
|
* @var array
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
2013-09-21 17:35:18 +02:00
|
|
|
private $dataset = array();
|
2013-09-09 13:55:29 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the content to be displayed by this legend
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param array $dataset An array of datasets in the form they are provided to the graphing implementation
|
2013-09-09 13:55:29 +02:00
|
|
|
*/
|
|
|
|
public function addDataset(array $dataset)
|
|
|
|
{
|
|
|
|
if (!isset($dataset['label'])) {
|
|
|
|
$dataset['label'] = 'Dataset ' . (++$this->internalCtr);
|
|
|
|
}
|
2013-09-21 17:35:18 +02:00
|
|
|
if (!isset($dataset['color'])) {
|
|
|
|
return;
|
|
|
|
}
|
2013-09-09 13:55:29 +02:00
|
|
|
$this->dataset[$dataset['color']] = $dataset['label'];
|
|
|
|
}
|
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
/**
|
|
|
|
* Render the legend to an SVG object
|
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @param RenderContext $ctx The context to use for rendering this legend
|
2013-09-21 17:35:18 +02:00
|
|
|
*
|
2013-09-25 16:32:28 +02:00
|
|
|
* @return DOMElement The SVG representation of this legend
|
2013-09-21 17:35:18 +02:00
|
|
|
*/
|
|
|
|
public function toSvg(RenderContext $ctx)
|
2013-09-09 13:55:29 +02:00
|
|
|
{
|
2013-09-21 17:35:18 +02:00
|
|
|
$outer = new Canvas('legend', new LayoutBox(0, 90, 100, 100));
|
|
|
|
$outer->getLayout()->setPadding(2, 2, 2, 2);
|
|
|
|
$nrOfColumns = 4;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
$leftstep = 100 / $nrOfColumns;
|
|
|
|
$topstep = 10 / $nrOfColumns + 2;
|
2013-09-09 13:55:29 +02:00
|
|
|
|
2013-09-21 17:35:18 +02:00
|
|
|
$top = 0;
|
|
|
|
$left = 0;
|
|
|
|
$lastLabelEndPos = -1;
|
2013-09-09 13:55:29 +02:00
|
|
|
foreach ($this->dataset as $color => $text) {
|
2013-09-21 17:35:18 +02:00
|
|
|
// Make sure labels don't overlap each other
|
|
|
|
while ($lastLabelEndPos >= $left) {
|
|
|
|
$left += $leftstep;
|
|
|
|
}
|
|
|
|
// When a label is longer than the available space, use the next line
|
|
|
|
if ($left + strlen($text) > 100) {
|
|
|
|
$top += $topstep;
|
|
|
|
$left = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
$colorBox = new Rect($left, $top, 2, 2);
|
2013-09-25 16:32:28 +02:00
|
|
|
$colorBox->setFill($color)->setStrokeWidth(2);
|
|
|
|
$colorBox->keepRatio();
|
2013-09-09 13:55:29 +02:00
|
|
|
$outer->addElement($colorBox);
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
$textBox = new Text($left+5, $top+2, $text);
|
|
|
|
$textBox->setFontSize('2em');
|
2013-09-09 13:55:29 +02:00
|
|
|
$outer->addElement($textBox);
|
2013-09-21 17:35:18 +02:00
|
|
|
|
|
|
|
// readjust layout
|
|
|
|
$lastLabelEndPos = $left + strlen($text);
|
|
|
|
$left += $leftstep;
|
2013-09-09 13:55:29 +02:00
|
|
|
}
|
|
|
|
$svg = $outer->toSvg($ctx);
|
|
|
|
return $svg;
|
|
|
|
}
|
|
|
|
}
|