mirror of
https://github.com/Icinga/icingaweb2.git
synced 2025-07-28 08:14:03 +02:00
Merge branch 'feature/svg-inline-renderer-5679'
This commit is contained in:
commit
6167e6a4f8
@ -40,7 +40,6 @@ use \Icinga\Chart\SVGRenderer;
|
|||||||
*/
|
*/
|
||||||
abstract class Chart implements Drawable
|
abstract class Chart implements Drawable
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* SVG renderer that handles
|
* SVG renderer that handles
|
||||||
*
|
*
|
||||||
|
@ -254,7 +254,7 @@ class GridChart extends Chart
|
|||||||
*/
|
*/
|
||||||
protected function init()
|
protected function init()
|
||||||
{
|
{
|
||||||
$this->renderer = new SVGRenderer(13, 10);
|
$this->renderer = new SVGRenderer(100, 100);
|
||||||
$this->setAxis(Axis::createLinearAxis());
|
$this->setAxis(Axis::createLinearAxis());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
123
library/Icinga/Chart/Inline/Inline.php
Normal file
123
library/Icinga/Chart/Inline/Inline.php
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
<?php
|
||||||
|
// @codingStandardsIgnoreStart
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
/**
|
||||||
|
* This file is part of Icinga Web 2.
|
||||||
|
*
|
||||||
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* @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>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
|
||||||
|
namespace Icinga\Chart\Inline;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class to render and inline chart directly from the request params.
|
||||||
|
*
|
||||||
|
* When rendering huge amounts of inline charts it is too expensive
|
||||||
|
* to bootstrap the complete application for ever single chart and
|
||||||
|
* we need to be able render Charts in a compact environment without
|
||||||
|
* the other Icinga classes.
|
||||||
|
*
|
||||||
|
* Class Inline
|
||||||
|
* @package Icinga\Chart\Inline
|
||||||
|
*/
|
||||||
|
class Inline {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The data displayed in this chart
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $data;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The colors used to display this chart
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $colors = array(
|
||||||
|
'#00FF00', // OK
|
||||||
|
'#FFFF00', // Warning
|
||||||
|
'#FF0000', // Critical
|
||||||
|
'#E066FF' // Unreachable
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The labels displayed on this chart
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $labels = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height in percent
|
||||||
|
*
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
protected $height = 20;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The width in percent
|
||||||
|
*
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
protected $width = 20;
|
||||||
|
|
||||||
|
protected function sanitizeStringArray(array $arr)
|
||||||
|
{
|
||||||
|
$sanitized = array();
|
||||||
|
foreach ($arr as $key => $value) {
|
||||||
|
$sanitized[$key] = htmlspecialchars($value);
|
||||||
|
}
|
||||||
|
return $sanitized;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Populate the properties from the current request.
|
||||||
|
*/
|
||||||
|
public function initFromRequest()
|
||||||
|
{
|
||||||
|
$this->data = explode(',', $_GET['data']);
|
||||||
|
foreach ($this->data as $key => $value) {
|
||||||
|
$this->data[$key] = (int)$value;
|
||||||
|
}
|
||||||
|
for ($i = 0; $i < sizeof($this->data); $i++) {
|
||||||
|
$this->labels[] = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (array_key_exists('this->colors', $_GET)) {
|
||||||
|
$this->colors = $this->sanitizeStringArray(explode(',', $_GET['colors']));
|
||||||
|
}
|
||||||
|
while (sizeof($this->colors) < sizeof($this->data)) {
|
||||||
|
$this->colors[] = '#FEFEFE';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (array_key_exists('width', $_GET)) {
|
||||||
|
$this->width = (int)$_GET['width'];
|
||||||
|
}
|
||||||
|
if (array_key_exists('height', $_GET)) {
|
||||||
|
$this->height = (int)$_GET['height'];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
48
library/Icinga/Chart/Inline/PieChart.php
Normal file
48
library/Icinga/Chart/Inline/PieChart.php
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
// @codingStandardsIgnoreStart
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
/**
|
||||||
|
* This file is part of Icinga Web 2.
|
||||||
|
*
|
||||||
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* @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>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
|
||||||
|
namespace Icinga\Chart\Inline;
|
||||||
|
|
||||||
|
use Icinga\Chart\PieChart as PieChartRenderer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Draw an inline pie-chart directly from the available request parameters.
|
||||||
|
*/
|
||||||
|
class PieChart extends Inline {
|
||||||
|
public function render()
|
||||||
|
{
|
||||||
|
$pie = new PieChartRenderer();
|
||||||
|
$pie->drawPie(array(
|
||||||
|
'data' => $this->data, 'colors' => $this->colors, 'labels' => $this->labels
|
||||||
|
));
|
||||||
|
$pie->setWidth($this->width)->setHeight($this->height);
|
||||||
|
echo $pie->render();
|
||||||
|
}
|
||||||
|
}
|
@ -76,6 +76,46 @@ class PieChart extends Chart
|
|||||||
*/
|
*/
|
||||||
private $noCaption = false;
|
private $noCaption = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scaling level of the rendered svgs width in percent.
|
||||||
|
*
|
||||||
|
* @var float
|
||||||
|
*/
|
||||||
|
private $width = 100;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scaling level of the rendered svgs height in percent.
|
||||||
|
*
|
||||||
|
* @var int
|
||||||
|
*/
|
||||||
|
private $height = 100;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the size of the rendered pie-chart svg.
|
||||||
|
*
|
||||||
|
* @param $width int The width in percent.
|
||||||
|
*
|
||||||
|
* @return self Fluent interface
|
||||||
|
*/
|
||||||
|
public function setWidth($width)
|
||||||
|
{
|
||||||
|
$this->width = $width;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the size of the rendered pie-chart svg.
|
||||||
|
*
|
||||||
|
* @param $height int The height in percent.
|
||||||
|
*
|
||||||
|
* @return self Fluent interface
|
||||||
|
*/
|
||||||
|
public function setHeight($height)
|
||||||
|
{
|
||||||
|
$this->height = $height;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test if the given pies have the correct format
|
* Test if the given pies have the correct format
|
||||||
*
|
*
|
||||||
@ -96,7 +136,7 @@ class PieChart extends Chart
|
|||||||
*/
|
*/
|
||||||
protected function build()
|
protected function build()
|
||||||
{
|
{
|
||||||
$this->renderer = new SVGRenderer(($this->type === self::STACKED) ? 1 : count($this->pies), 1);
|
$this->renderer = new SVGRenderer(($this->type === self::STACKED) ? $this->width : count($this->pies)*$this->width, $this->width);
|
||||||
foreach ($this->pies as &$pie) {
|
foreach ($this->pies as &$pie) {
|
||||||
$this->normalizeDataSet($pie);
|
$this->normalizeDataSet($pie);
|
||||||
}
|
}
|
||||||
|
@ -80,7 +80,6 @@ class SVGRenderer
|
|||||||
*/
|
*/
|
||||||
private $height = 100;
|
private $height = 100;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create the root document and the SVG root node
|
* Create the root document and the SVG root node
|
||||||
*/
|
*/
|
||||||
@ -96,10 +95,8 @@ class SVGRenderer
|
|||||||
$this->document = $implementation->createDocument(null, null, $docType);
|
$this->document = $implementation->createDocument(null, null, $docType);
|
||||||
$this->svg = $this->createOuterBox();
|
$this->svg = $this->createOuterBox();
|
||||||
$this->document->appendChild($this->svg);
|
$this->document->appendChild($this->svg);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create the outer SVG box containing the root svg element and namespace and return it
|
* Create the outer SVG box containing the root svg element and namespace and return it
|
||||||
*
|
*
|
||||||
@ -111,8 +108,8 @@ class SVGRenderer
|
|||||||
$svg = $this->document->createElement('svg');
|
$svg = $this->document->createElement('svg');
|
||||||
$svg->setAttribute('xmlns', 'http://www.w3.org/2000/svg');
|
$svg->setAttribute('xmlns', 'http://www.w3.org/2000/svg');
|
||||||
$svg->setATtribute('xmlns:xlink', 'http://www.w3.org/1999/xlink');
|
$svg->setATtribute('xmlns:xlink', 'http://www.w3.org/1999/xlink');
|
||||||
$svg->setAttribute("width", "100%");
|
$svg->setAttribute('width', $this->width . '%');
|
||||||
$svg->setAttribute("height", "100%");
|
$svg->setAttribute('height', $this->width . '%');
|
||||||
$svg->setAttribute(
|
$svg->setAttribute(
|
||||||
'viewBox',
|
'viewBox',
|
||||||
sprintf(
|
sprintf(
|
||||||
|
126
library/Icinga/Web/Widget/Chart/PieChart.php
Normal file
126
library/Icinga/Web/Widget/Chart/PieChart.php
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
<?php
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
/**
|
||||||
|
* This file is part of Icinga Web 2.
|
||||||
|
*
|
||||||
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* @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>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
|
||||||
|
namespace Icinga\Web\Widget\Chart;
|
||||||
|
|
||||||
|
use Icinga\Web\Widget\Widget;
|
||||||
|
use Icinga\Web\Url;
|
||||||
|
|
||||||
|
use \Zend_View_Abstract;
|
||||||
|
|
||||||
|
class PieChart implements Widget {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The template string used for rendering this widget
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $template =<<<'EOD'
|
||||||
|
|
||||||
|
<div data-icinga-component="app/piechart">
|
||||||
|
<img class='inlinepie' src="{url}" width={width} height={height}> </img>
|
||||||
|
</div>
|
||||||
|
EOD;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var \Icinga\Web\Url
|
||||||
|
*/
|
||||||
|
private $url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The width of the rendered chart
|
||||||
|
*
|
||||||
|
* @var int The value in percent
|
||||||
|
*/
|
||||||
|
private $width = 25;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The height of the rendered chart
|
||||||
|
*
|
||||||
|
* @var int The value in perecent
|
||||||
|
*/
|
||||||
|
private $height = 25;
|
||||||
|
|
||||||
|
public function setData($data)
|
||||||
|
{
|
||||||
|
$this->url->setParam('data', implode(',', $data));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setLabels($labels = null)
|
||||||
|
{
|
||||||
|
$this->url->setParam('labels', implode(',', $labels));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setColors($colors = null)
|
||||||
|
{
|
||||||
|
$this->url->setParam('colors', implode(',', $colors));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setHeight($height)
|
||||||
|
{
|
||||||
|
$this->height = $height;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setWidth($width)
|
||||||
|
{
|
||||||
|
$this->width = $width;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __construct(array $data)
|
||||||
|
{
|
||||||
|
$this->url = Url::fromPath('svg/piechart.svg');
|
||||||
|
if (array_key_exists('data', $data)) {
|
||||||
|
$this->data = $data['data'];
|
||||||
|
if (array_key_exists('labels', $data)) {
|
||||||
|
$this->labels = $data['labels'];
|
||||||
|
}
|
||||||
|
if (array_key_exists('colors', $data)) {
|
||||||
|
$this->colors = $data['colors'];
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$this->setData($data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Renders this widget via the given view and returns the
|
||||||
|
* HTML as a string
|
||||||
|
*
|
||||||
|
* @param \Zend_View_Abstract $view
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function render(Zend_View_Abstract $view)
|
||||||
|
{
|
||||||
|
$template = $this->template;
|
||||||
|
$template = preg_replace('{{url}}', $this->url->getAbsoluteUrl(), $template);
|
||||||
|
$template = preg_replace('{{width}}', $this->width, $template);
|
||||||
|
$template = preg_replace('{{height}}', $this->height, $template);
|
||||||
|
return $template;
|
||||||
|
}
|
||||||
|
}
|
@ -36,6 +36,7 @@ use Icinga\Web\Hook;
|
|||||||
use Icinga\Web\Widget\Tabextension\DashboardAction;
|
use Icinga\Web\Widget\Tabextension\DashboardAction;
|
||||||
use Icinga\Web\Widget\Tabextension\OutputFormat;
|
use Icinga\Web\Widget\Tabextension\OutputFormat;
|
||||||
use Icinga\Web\Widget\Tabs;
|
use Icinga\Web\Widget\Tabs;
|
||||||
|
use Icinga\Web\Widget\Chart\PieChart;
|
||||||
use Icinga\Module\Monitoring\Backend;
|
use Icinga\Module\Monitoring\Backend;
|
||||||
use Icinga\Web\Widget\SortBox;
|
use Icinga\Web\Widget\SortBox;
|
||||||
use Icinga\Web\Widget\FilterBox;
|
use Icinga\Web\Widget\FilterBox;
|
||||||
@ -171,6 +172,8 @@ class Monitoring_ListController extends MonitoringController
|
|||||||
'host_last_check' => 'Last Host Check'
|
'host_last_check' => 'Last Host Check'
|
||||||
));
|
));
|
||||||
|
|
||||||
|
$this->view->piechart =
|
||||||
|
new PieChart(array(1,3,4,2));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
5
public/js/vendor/bootstrap/jquery.sparkline.min.js
vendored
Normal file
5
public/js/vendor/bootstrap/jquery.sparkline.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
52
public/svg/chart.php
Normal file
52
public/svg/chart.php
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
<?php
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
/**
|
||||||
|
* This file is part of Icinga Web 2.
|
||||||
|
*
|
||||||
|
* Icinga Web 2 - Head for multiple monitoring backends.
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* @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>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
// {{{ICINGA_LICENSE_HEADER}}}
|
||||||
|
|
||||||
|
use Icinga\Chart\Inline\PieChart;
|
||||||
|
use Icinga\Application\Loader;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Use only autoloader and do not bootstrap EmbeddedWeb to improve performance
|
||||||
|
* of svg rendering
|
||||||
|
*/
|
||||||
|
require_once dirname(__FILE__) . '/../../library/Icinga/Application/Loader.php';
|
||||||
|
$loader = new Loader();
|
||||||
|
$loader->registerNamespace('Icinga', dirname(__FILE__) . '/../../library/Icinga');
|
||||||
|
$loader->register();
|
||||||
|
|
||||||
|
if (!array_key_exists('data', $_GET)) {
|
||||||
|
die;
|
||||||
|
}
|
||||||
|
header('Content-Type: image/svg+xml');
|
||||||
|
|
||||||
|
|
||||||
|
$pie = new PieChart();
|
||||||
|
$pie->initFromRequest();
|
||||||
|
echo $pie->render();
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user