316 lines
7.3 KiB
PHP
316 lines
7.3 KiB
PHP
<?php
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
|
|
|
namespace Icinga\Web\Widget\Dashboard;
|
|
|
|
use Icinga\Web\Url;
|
|
use Icinga\Data\ConfigObject;
|
|
use Icinga\Exception\IcingaException;
|
|
|
|
/**
|
|
* A dashboard pane dashlet
|
|
*
|
|
* This is the element displaying a specific view in icinga2web
|
|
*
|
|
*/
|
|
class Dashlet extends UserWidget
|
|
{
|
|
/**
|
|
* The url of this Dashlet
|
|
*
|
|
* @var Url|null
|
|
*/
|
|
private $url;
|
|
|
|
private $name;
|
|
|
|
/**
|
|
* The title being displayed on top of the dashlet
|
|
* @var
|
|
*/
|
|
private $title;
|
|
|
|
/**
|
|
* The pane containing this dashlet, needed for the 'remove button'
|
|
* @var Pane
|
|
*/
|
|
private $pane;
|
|
|
|
/**
|
|
* The disabled option is used to "delete" default dashlets provided by modules
|
|
*
|
|
* @var bool
|
|
*/
|
|
private $disabled = false;
|
|
|
|
/**
|
|
* The progress label being used
|
|
*
|
|
* @var string
|
|
*/
|
|
private $progressLabel;
|
|
|
|
/**
|
|
* The template string used for rendering this widget
|
|
*
|
|
* @var string
|
|
*/
|
|
private $template =<<<'EOD'
|
|
|
|
<div class="container" data-icinga-url="{URL}">
|
|
<h1><a href="{FULL_URL}" aria-label="{TOOLTIP}" title="{TOOLTIP}" data-base-target="col1">{TITLE}</a></h1>
|
|
<p class="progress-label">{PROGRESS_LABEL}<span>.</span><span>.</span><span>.</span></p>
|
|
<noscript>
|
|
<div class="iframe-container">
|
|
<iframe
|
|
src="{IFRAME_URL}"
|
|
frameborder="no"
|
|
title="{TITLE_PREFIX}{TITLE}">
|
|
</iframe>
|
|
</div>
|
|
</noscript>
|
|
</div>
|
|
EOD;
|
|
|
|
/**
|
|
* The template string used for rendering this widget in case of an error
|
|
*
|
|
* @var string
|
|
*/
|
|
private $errorTemplate = <<<'EOD'
|
|
|
|
<div class="container">
|
|
<h1 title="{TOOLTIP}">{TITLE}</h1>
|
|
<p class="error-message">{ERROR_MESSAGE}</p>
|
|
</div>
|
|
EOD;
|
|
|
|
/**
|
|
* Create a new dashlet displaying the given url in the provided pane
|
|
*
|
|
* @param string $title The title to use for this dashlet
|
|
* @param Url|string $url The url this dashlet uses for displaying information
|
|
* @param Pane $pane The pane this Dashlet will be added to
|
|
*/
|
|
public function __construct($title, $url, Pane $pane)
|
|
{
|
|
$this->name = $title;
|
|
$this->title = $title;
|
|
$this->pane = $pane;
|
|
$this->url = $url;
|
|
}
|
|
|
|
public function setName($name)
|
|
{
|
|
$this->name = $name;
|
|
return $this;
|
|
}
|
|
|
|
public function getName()
|
|
{
|
|
return $this->name;
|
|
}
|
|
|
|
/**
|
|
* Retrieve the dashlets title
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getTitle()
|
|
{
|
|
return $this->title;
|
|
}
|
|
|
|
/**
|
|
* @param string $title
|
|
*/
|
|
public function setTitle($title)
|
|
{
|
|
$this->title = $title;
|
|
}
|
|
|
|
/**
|
|
* Retrieve the dashlets url
|
|
*
|
|
* @return Url|null
|
|
*/
|
|
public function getUrl()
|
|
{
|
|
if ($this->url !== null && ! $this->url instanceof Url) {
|
|
$this->url = Url::fromPath($this->url);
|
|
}
|
|
return $this->url;
|
|
}
|
|
|
|
/**
|
|
* Set the dashlets URL
|
|
*
|
|
* @param string|Url $url The url to use, either as an Url object or as a path
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setUrl($url)
|
|
{
|
|
$this->url = $url;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set the disabled property
|
|
*
|
|
* @param boolean $disabled
|
|
*/
|
|
public function setDisabled($disabled)
|
|
{
|
|
$this->disabled = $disabled;
|
|
}
|
|
|
|
/**
|
|
* Get the disabled property
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function getDisabled()
|
|
{
|
|
return $this->disabled;
|
|
}
|
|
|
|
/**
|
|
* Set the progress label to use
|
|
*
|
|
* @param string $label
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function setProgressLabel($label)
|
|
{
|
|
$this->progressLabel = $label;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Return the progress label to use
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getProgressLabe()
|
|
{
|
|
if ($this->progressLabel === null) {
|
|
return $this->view()->translate('Loading');
|
|
}
|
|
|
|
return $this->progressLabel;
|
|
}
|
|
|
|
/**
|
|
* Return this dashlet's structure as array
|
|
*
|
|
* @return array
|
|
*/
|
|
public function toArray()
|
|
{
|
|
$array = array(
|
|
'url' => $this->getUrl()->getRelativeUrl(),
|
|
'title' => $this->getTitle()
|
|
);
|
|
if ($this->getDisabled() === true) {
|
|
$array['disabled'] = 1;
|
|
}
|
|
return $array;
|
|
}
|
|
|
|
/**
|
|
* @see Widget::render()
|
|
*/
|
|
public function render()
|
|
{
|
|
if ($this->disabled === true) {
|
|
return '';
|
|
}
|
|
|
|
$view = $this->view();
|
|
|
|
if (! $this->url) {
|
|
$searchTokens = array(
|
|
'{TOOLTIP}',
|
|
'{TITLE}',
|
|
'{ERROR_MESSAGE}'
|
|
);
|
|
|
|
$replaceTokens = array(
|
|
sprintf($view->translate('Show %s', 'dashboard.dashlet.tooltip'), $view->escape($this->getTitle())),
|
|
$view->escape($this->getTitle()),
|
|
$view->escape(
|
|
sprintf($view->translate('Cannot create dashboard dashlet "%s" without valid URL'), $this->title)
|
|
)
|
|
);
|
|
|
|
return str_replace($searchTokens, $replaceTokens, $this->errorTemplate);
|
|
}
|
|
|
|
$url = $this->getUrl();
|
|
$url->setParam('showCompact', true);
|
|
$iframeUrl = clone $url;
|
|
$iframeUrl->setParam('isIframe');
|
|
|
|
$searchTokens = array(
|
|
'{URL}',
|
|
'{IFRAME_URL}',
|
|
'{FULL_URL}',
|
|
'{TOOLTIP}',
|
|
'{TITLE}',
|
|
'{TITLE_PREFIX}',
|
|
'{PROGRESS_LABEL}'
|
|
);
|
|
|
|
$replaceTokens = array(
|
|
$url,
|
|
$iframeUrl,
|
|
$url->getUrlWithout(array('showCompact', 'limit')),
|
|
sprintf($view->translate('Show %s', 'dashboard.dashlet.tooltip'), $view->escape($this->getTitle())),
|
|
$view->escape($this->getTitle()),
|
|
$view->translate('Dashlet') . ': ',
|
|
$this->getProgressLabe()
|
|
);
|
|
|
|
return str_replace($searchTokens, $replaceTokens, $this->template);
|
|
}
|
|
|
|
/**
|
|
* Create a @see Dashlet instance from the given Zend config, using the provided title
|
|
*
|
|
* @param $title The title for this dashlet
|
|
* @param ConfigObject $config The configuration defining url, parameters, height, width, etc.
|
|
* @param Pane $pane The pane this dashlet belongs to
|
|
*
|
|
* @return Dashlet A newly created Dashlet for use in the Dashboard
|
|
*/
|
|
public static function fromIni($title, ConfigObject $config, Pane $pane)
|
|
{
|
|
$height = null;
|
|
$width = null;
|
|
$url = $config->get('url');
|
|
$parameters = $config->toArray();
|
|
unset($parameters['url']); // otherwise there's an url = parameter in the Url
|
|
|
|
$cmp = new Dashlet($title, Url::fromPath($url, $parameters), $pane);
|
|
return $cmp;
|
|
}
|
|
|
|
/**
|
|
* @param \Icinga\Web\Widget\Dashboard\Pane $pane
|
|
*/
|
|
public function setPane(Pane $pane)
|
|
{
|
|
$this->pane = $pane;
|
|
}
|
|
|
|
/**
|
|
* @return \Icinga\Web\Widget\Dashboard\Pane
|
|
*/
|
|
public function getPane()
|
|
{
|
|
return $this->pane;
|
|
}
|
|
}
|