Merge branch 'master' into feature/link-labels-8458
Conflicts: application/views/scripts/config/application.phtml application/views/scripts/config/module.phtml application/views/scripts/config/modules.phtml library/Icinga/Web/Widget/Dashboard/Dashlet.php modules/monitoring/application/controllers/TimelineController.php
This commit is contained in:
commit
956efe5ef9
|
@ -72,6 +72,7 @@ class ConfigController extends ActionController
|
|||
$allowedActions[] = 'roles';
|
||||
}
|
||||
$this->firstAllowedAction = array_shift($allowedActions);
|
||||
$this->getTabs()->setTitle($this->translate('Config Navigation'));
|
||||
}
|
||||
|
||||
public function devtoolsAction()
|
||||
|
|
|
@ -51,6 +51,7 @@ class RolesController extends ActionController
|
|||
'label' => $this->translate('Roles'),
|
||||
'url' => 'roles'
|
||||
));
|
||||
$this->getTabs()->setTitle($this->translate('Role Configuration'));
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -1,9 +1,8 @@
|
|||
<div class="controls" data-base-target="_main">
|
||||
<?= $this->tabs->render($this); ?>
|
||||
</div>
|
||||
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="application-configuration">
|
||||
<h1 tabindex="-1" id="application-configuration">
|
||||
<?= $this->translate('General Configuration'); ?>
|
||||
</h1>
|
||||
<?php if (isset($this->messageBox)): ?>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="authentication-create">
|
||||
<h1 tabindex="-1" id="authentication-create">
|
||||
<?= $this->translate('Create New Authentication Backend'); ?>
|
||||
</h1>
|
||||
<p>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="authentication-modify">
|
||||
<h1 tabindex="-1" id="authentication-modify">
|
||||
<?= $this->translate('Edit Backend'); ?>
|
||||
</h1>
|
||||
<div>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="authentication-remove">
|
||||
<h1 tabindex="-1" id="authentication-remove">
|
||||
<?= $this->translate('Remove Backend'); ?>
|
||||
</h1>
|
||||
<div>
|
||||
|
|
|
@ -2,21 +2,10 @@
|
|||
<?= $tabs; ?>
|
||||
</div>
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="0" id="authentication-reorder">
|
||||
<?= t('Authentication Configuration'); ?>
|
||||
<h1 tabindex="-1" id="authentication-reorder">
|
||||
<?= $this->translate('Authentication Configuration'); ?>
|
||||
</h1>
|
||||
<div class="skip-links skip-links-inline">
|
||||
<nav>
|
||||
<ul>
|
||||
<li>
|
||||
<a tabindex="0" href="#authentication-reorder-form">
|
||||
<?= t('Skip To Authentication Reorder Form'); ?>
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</nav>
|
||||
</div>
|
||||
<h2 tabindex="0" id="authentication-new-backend" class="sr-only">
|
||||
<h2 tabindex="-1" id="authentication-new-backend" class="sr-only">
|
||||
<?= t('New Authentication Backend'); ?>
|
||||
</h2>
|
||||
<p>
|
||||
|
@ -24,7 +13,7 @@
|
|||
<?= $this->icon('plus'); ?><?= $this->translate('Create A New Authentication Backend'); ?>
|
||||
</a>
|
||||
</p>
|
||||
<h2 tabindex="0" id="authentication-reorder" class="sr-only">
|
||||
<h2 tabindex="-1" id="authentication-reorder" class="sr-only">
|
||||
<?= t('Reorder Authentication Backends'); ?>
|
||||
</h2>
|
||||
<div id="authentication-reorder-form">
|
||||
|
|
|
@ -1,76 +1,80 @@
|
|||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<h1><?= $this->escape($module->getTitle()) ?></h1>
|
||||
<?= $this->tabs ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<?php if (! $module): ?>
|
||||
<?= $this->translate('There is no such module installed.') ?>
|
||||
<?php return; endif ?>
|
||||
<?php
|
||||
$dependencies = $module->getDependencies();
|
||||
$restrictions = $module->getProvidedRestrictions();
|
||||
$permissions = $module->getProvidedPermissions();
|
||||
$state = $moduleData->enabled ? ($moduleData->loaded ? 'enabled' : 'failed') : 'disabled'
|
||||
|
||||
?>
|
||||
<table class="avp">
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Name')) ?></th>
|
||||
<td><?= $this->escape($module->getName()) ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th><?= $this->translate('State') ?></th>
|
||||
<td><?= $state ?><?php if ($state === 'enabled'): ?>
|
||||
<?= $this->qlink(
|
||||
$this->translate('disable'),
|
||||
'config/moduledisable',
|
||||
array('name' => $module->getName()),
|
||||
array('title' => sprintf($this->translate('Disable the %s module'), $module->getName()))
|
||||
); ?>
|
||||
<?php endif ?>
|
||||
<?php if ($state === 'disabled'): ?>
|
||||
<?= $this->qlink(
|
||||
$this->translate('enable'),
|
||||
'config/moduleenable',
|
||||
array('name' => $module->getName()),
|
||||
array('title' => sprintf($this->translate('Enable the %s module'), $module->getName()))
|
||||
); ?>
|
||||
<?php endif ?>
|
||||
</td>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Version')) ?></th>
|
||||
<td><?= $this->escape($module->getVersion()) ?></td></tr>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Description')) ?></th>
|
||||
<td><?= nl2br($this->escape($module->getDescription())) ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Dependencies')) ?></th>
|
||||
<td><?php
|
||||
|
||||
if (empty($dependencies)):
|
||||
echo $this->translate('This module has no dependencies');
|
||||
|
||||
else: foreach ($dependencies as $name => $versionString): ?>
|
||||
<strong><?= $this->escape($name) ?></strong><?php if ($versionString !== true): ?>: <?= $this->escape($versionString) ?><?php endif ?><br />
|
||||
<?php endforeach; endif ?></td>
|
||||
</tr>
|
||||
<?php if (! empty($permissions)): ?>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Permissions')) ?></th>
|
||||
<td><?php foreach ($permissions as $permission): ?>
|
||||
<strong><?= $this->escape($permission->name) ?></strong>: <?= $this->escape($permission->description) ?><br />
|
||||
<?php endforeach ?></td>
|
||||
</tr>
|
||||
<?php endif ?>
|
||||
<?php if (! empty($restrictions)): ?>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Restrictions')) ?></th>
|
||||
<td><?php foreach ($restrictions as $restriction): ?>
|
||||
<strong><?= $this->escape($restriction->name) ?></strong>: <?= $this->escape($restriction->description) ?><br />
|
||||
<?php endforeach ?></td>
|
||||
</tr>
|
||||
<?php endif ?>
|
||||
</table>
|
||||
|
||||
<h1 tabindex="-1">
|
||||
<?= $this->escape($module->getTitle()) ?>
|
||||
</h1>
|
||||
<?php if (! $module): ?>
|
||||
<?= $this->translate('There is no such module installed.') ?>
|
||||
<?php return; endif ?>
|
||||
<?php
|
||||
$dependencies = $module->getDependencies();
|
||||
$restrictions = $module->getProvidedRestrictions();
|
||||
$permissions = $module->getProvidedPermissions();
|
||||
$state = $moduleData->enabled ? ($moduleData->loaded ? 'enabled' : 'failed') : 'disabled'
|
||||
?>
|
||||
<table class="avp">
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Name')) ?></th>
|
||||
<td><?= $this->escape($module->getName()) ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th><?= $this->translate('State') ?></th>
|
||||
<td><?= $state ?><?php if ($state === 'enabled'): ?>
|
||||
<?= $this->qlink(
|
||||
$this->translate('disable'),
|
||||
'config/moduledisable',
|
||||
array('name' => $module->getName()),
|
||||
array('title' => sprintf($this->translate('Disable the %s module'), $module->getName()))
|
||||
); ?>
|
||||
<?php endif ?>
|
||||
<?php if ($state === 'disabled'): ?>
|
||||
<?= $this->qlink(
|
||||
$this->translate('enable'),
|
||||
'config/moduleenable',
|
||||
array('name' => $module->getName()),
|
||||
array('title' => sprintf($this->translate('Enable the %s module'), $module->getName()))
|
||||
); ?>
|
||||
<?php endif ?>
|
||||
</td>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Version')) ?></th>
|
||||
<td><?= $this->escape($module->getVersion()) ?></td></tr>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Description')) ?></th>
|
||||
<td><?= nl2br($this->escape($module->getDescription())) ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Dependencies')) ?></th>
|
||||
<td>
|
||||
<?php
|
||||
if (empty($dependencies)):
|
||||
echo $this->translate('This module has no dependencies');
|
||||
else: foreach ($dependencies as $name => $versionString): ?>
|
||||
<strong><?= $this->escape($name) ?></strong><?php if ($versionString !== true): ?>: <?= $this->escape($versionString) ?><?php endif ?><br />
|
||||
<?php endforeach; endif ?>
|
||||
</td>
|
||||
</tr>
|
||||
<?php if (! empty($permissions)): ?>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Permissions')) ?></th>
|
||||
<td>
|
||||
<?php foreach ($permissions as $permission): ?>
|
||||
<strong><?= $this->escape($permission->name) ?></strong>: <?= $this->escape($permission->description) ?><br />
|
||||
<?php endforeach ?>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endif ?>
|
||||
<?php if (! empty($restrictions)): ?>
|
||||
<tr>
|
||||
<th><?= $this->escape($this->translate('Restrictions')) ?></th>
|
||||
<td>
|
||||
<?php foreach ($restrictions as $restriction): ?>
|
||||
<strong><?= $this->escape($restriction->name) ?></strong>: <?= $this->escape($restriction->description) ?><br />
|
||||
<?php endforeach ?>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endif ?>
|
||||
</table>
|
||||
</div>
|
||||
|
|
|
@ -1,32 +1,32 @@
|
|||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<h1><?= $this->translate('Installed Modules') ?></h1>
|
||||
<?= $this->paginationControl($modules) ?>
|
||||
</div>
|
||||
|
||||
<div class="content">
|
||||
<table class="action" data-base-target="_next">
|
||||
<tbody>
|
||||
<?php foreach ($modules as $module): ?>
|
||||
<tr>
|
||||
<td>
|
||||
<?php if ($module->enabled && $module->loaded) {
|
||||
echo $this->icon('thumbs-up', sprintf($this->translate('Module %s is enabled'), $module->name));
|
||||
} elseif (! $module->enabled) {
|
||||
echo $this->icon('thumbs-down', sprintf($this->translate('Module %s is disabled'), $module->name));
|
||||
} else { // ! $module->loaded
|
||||
echo $this->icon('thumbs-down', sprintf($this->translate('Module %s has failed to load'), $module->name));
|
||||
}
|
||||
<h1 tabindex="-1"><?= $this->translate('Installed Modules') ?></h1>
|
||||
<table class="action" data-base-target="_next">
|
||||
<tbody>
|
||||
<?php foreach ($modules as $module): ?>
|
||||
<tr>
|
||||
<td>
|
||||
<?php if ($module->enabled && $module->loaded) {
|
||||
echo $this->icon('thumbs-up', sprintf($this->translate('Module %s is enabled'), $module->name));
|
||||
} elseif (! $module->enabled) {
|
||||
echo $this->icon('thumbs-down', sprintf($this->translate('Module %s is disabled'), $module->name));
|
||||
} else { // ! $module->loaded
|
||||
echo $this->icon('thumbs-down', sprintf($this->translate('Module %s has failed to load'), $module->name));
|
||||
}
|
||||
|
||||
echo $this->qlink(
|
||||
$module->name,
|
||||
'config/module/',
|
||||
array('name' => $module->name),
|
||||
array('title' => sprintf($this->translate('Show the overview of the %s module'), $module->name))
|
||||
); ?>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endforeach ?>
|
||||
</tbody>
|
||||
</table>
|
||||
echo $this->qlink(
|
||||
$module->name,
|
||||
'config/module/',
|
||||
array('name' => $module->name),
|
||||
array('title' => sprintf($this->translate('Show the overview of the %s module'), $module->name))
|
||||
); ?>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endforeach ?>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
|
|
@ -2,21 +2,10 @@
|
|||
<?= $tabs; ?>
|
||||
</div>
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="0" id="resource-index">
|
||||
<h1 tabindex="-1" id="resource-index">
|
||||
<?= t('Resource Configuration'); ?>
|
||||
</h1>
|
||||
<div class="skip-links skip-links-inline">
|
||||
<nav>
|
||||
<ul>
|
||||
<li>
|
||||
<a tabindex="0" href="#resource-edit-table">
|
||||
<?= t('Skip To Existing Resources'); ?>
|
||||
</a>
|
||||
</li>
|
||||
</ul>
|
||||
</nav>
|
||||
</div>
|
||||
<h2 tabindex="0" id="resource-new-resource" class="sr-only">
|
||||
<h2 tabindex="-1" id="resource-new-resource" class="sr-only">
|
||||
<?= t('Create New Resource'); ?>
|
||||
</h2>
|
||||
<p>
|
||||
|
@ -24,7 +13,7 @@
|
|||
<?= $this->icon('plus'); ?> <?= $this->translate('Create A New Resource'); ?>
|
||||
</a>
|
||||
</p>
|
||||
<h2 tabindex="0" id="resource-edit-resource" class="sr-only">
|
||||
<h2 tabindex="-1" id="resource-edit-resource" class="sr-only">
|
||||
<?= t('Edit Existing Resources'); ?>
|
||||
</h2>
|
||||
<table class="action" id="resource-edit-table">
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="resource-create">
|
||||
<h1 tabindex="-1" id="resource-create">
|
||||
<?= $this->translate('Create A New Resource'); ?>
|
||||
</h1>
|
||||
<p><?= $this->translate('Resources are entities that provide data to Icinga Web 2.'); ?></p>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="resource-edit">
|
||||
<h1 tabindex="-1" id="resource-edit">
|
||||
<?= $this->translate('Edit Existing Resource'); ?>
|
||||
</h1>
|
||||
<div>
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
<?= $this->tabs->showOnlyCloseButton() ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="0" id="resource-remove">
|
||||
<h1 tabindex="-1" id="resource-remove">
|
||||
<?= $this->translate('Remove Existing Resource'); ?>
|
||||
</h1>
|
||||
<div>
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<div class="controls">
|
||||
<?= $tabs; ?>
|
||||
</div>
|
||||
|
||||
<div class="content">
|
||||
<h1 tabindex="-1" id="preferences"><?= $this->translate('Preferences'); ?></h1>
|
||||
<?= $form; ?>
|
||||
</div>
|
|
@ -1,8 +1,10 @@
|
|||
<div class="controls" data-base-target="_main">
|
||||
<?= $tabs ?>
|
||||
<h1><?= $this->translate('Roles') ?></h1>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="-1" id="roles-index">
|
||||
<?= $this->translate('Roles') ?>
|
||||
</h1>
|
||||
<div>
|
||||
<?php /** @var \Icinga\Application\Config $roles */ if ($roles->isEmpty()): ?>
|
||||
<?= $this->translate('No roles found.') ?>
|
||||
|
@ -66,6 +68,9 @@
|
|||
</tbody>
|
||||
</table>
|
||||
<?php endif ?>
|
||||
<h2 tabindex="-1" id="roles-index-new" class="sr-only">
|
||||
<?= $this->translate('Create New Role'); ?>
|
||||
</h2>
|
||||
<a data-base-target="_next" href="<?= $this->href('roles/new') ?>">
|
||||
<?= $this->translate('Create a New Role') ?>
|
||||
</a>
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
<div class="controls">
|
||||
<?= $tabs->showOnlyCloseButton() ?>
|
||||
<h1><?= $this->translate('New Role') ?></h1>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="-1" id="roles-new">
|
||||
<?= $this->translate('New Role') ?>
|
||||
</h1>
|
||||
<?= $form ?>
|
||||
</div>
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
<div class="controls">
|
||||
<?= $tabs->showOnlyCloseButton() ?>
|
||||
<h1><?= sprintf($this->translate('Remove Role %s'), $name) ?></h1>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="-1" id="roles-remove">
|
||||
<?= sprintf($this->translate('Remove Role %s'), $name) ?>
|
||||
</h1>
|
||||
<?= $form ?>
|
||||
</div>
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
<div class="controls">
|
||||
<?= $tabs->showOnlyCloseButton() ?>
|
||||
<h1><?= sprintf($this->translate('Update Role %s'), $name) ?></h1>
|
||||
</div>
|
||||
<div class="content">
|
||||
<h1 tabindex="-1" id="roles-update">
|
||||
<?= sprintf($this->translate('Update Role %s'), $name) ?>
|
||||
</h1>
|
||||
<?= $form ?>
|
||||
</div>
|
||||
|
|
|
@ -38,11 +38,25 @@ abstract class Chart implements Drawable
|
|||
*/
|
||||
protected $palette;
|
||||
|
||||
/**
|
||||
* The title of this chart, used for providing accessibility features
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public $title;
|
||||
|
||||
/**
|
||||
* The description for this chart, mandatory for providing accessibility features
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public $description;
|
||||
|
||||
/**
|
||||
* Create a new chart object and create internal objects
|
||||
*
|
||||
* If you want to extend this class use the init() method as an extension point,
|
||||
* as this will be called at the end o fthe construct call
|
||||
* as this will be called at the end of the construct call
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
|
@ -86,7 +100,6 @@ abstract class Chart implements Drawable
|
|||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* Render this graph and return the created SVG
|
||||
*
|
||||
* @return string The SVG created by the SvgRenderer
|
||||
|
@ -105,6 +118,11 @@ abstract class Chart implements Drawable
|
|||
$this->renderer->setXAspectRatioAlignment(SVGRenderer::X_ASPECT_RATIO_MIN);
|
||||
$this->renderer->setYAspectRatioAlignment(SVGRenderer::Y_ASPECT_RATIO_MIN);
|
||||
}
|
||||
|
||||
$this->renderer->setAriaDescription($this->description);
|
||||
$this->renderer->setAriaTitle($this->title);
|
||||
$this->renderer->getCanvas()->setAriaRole('presentation');
|
||||
|
||||
$this->renderer->getCanvas()->addElement($this);
|
||||
return $this->renderer->render();
|
||||
}
|
||||
|
|
|
@ -65,7 +65,13 @@ class BarGraph extends Styleable implements Drawable
|
|||
) {
|
||||
$this->order = $order;
|
||||
$this->dataSet = $dataSet;
|
||||
|
||||
$this->tooltips = $tooltips;
|
||||
foreach ($this->tooltips as $value) {
|
||||
$ts[] = $value;
|
||||
}
|
||||
$this->tooltips = $ts;
|
||||
|
||||
$this->graphs = $graphs;
|
||||
}
|
||||
|
||||
|
|
|
@ -38,6 +38,13 @@ class LineGraph extends Styleable implements Drawable
|
|||
*/
|
||||
private $isDiscrete = false;
|
||||
|
||||
/**
|
||||
* The tooltips
|
||||
*
|
||||
* @var
|
||||
*/
|
||||
private $tooltips;
|
||||
|
||||
/**
|
||||
* The default stroke width
|
||||
* @var int
|
||||
|
@ -56,10 +63,22 @@ class LineGraph extends Styleable implements Drawable
|
|||
*
|
||||
* @param array $dataset An array of [x, y] arrays to display
|
||||
*/
|
||||
public function __construct(array $dataset)
|
||||
{
|
||||
public function __construct(
|
||||
array $dataset,
|
||||
array &$graphs,
|
||||
$order,
|
||||
array $tooltips = null
|
||||
) {
|
||||
usort($dataset, array($this, 'sortByX'));
|
||||
$this->dataset = $dataset;
|
||||
$this->graphs = $graphs;
|
||||
|
||||
$this->tooltips = $tooltips;
|
||||
foreach ($this->tooltips as $value) {
|
||||
$ts[] = $value;
|
||||
}
|
||||
$this->tooltips = $ts;
|
||||
$this->order = $order;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -142,14 +161,41 @@ class LineGraph extends Styleable implements Drawable
|
|||
$path->setAdditionalStyle('clip-path: url(#clip);');
|
||||
$path->setId($this->id);
|
||||
$group = $path->toSvg($ctx);
|
||||
if ($this->showDataPoints === true) {
|
||||
foreach ($this->dataset as $point) {
|
||||
$dot = new Circle($point[0], $point[1], $this->dotWith);
|
||||
$dot->setFill($this->strokeColor);
|
||||
|
||||
$group->appendChild($dot->toSvg($ctx));
|
||||
foreach ($this->dataset as $x => $point) {
|
||||
|
||||
if ($this->showDataPoints === true) {
|
||||
$dot = new Circle($point[0], $point[1], $this->dotWith);
|
||||
$dot->setFill($this->strokeColor);
|
||||
$group->appendChild($dot->toSvg($ctx));
|
||||
}
|
||||
|
||||
// Draw invisible circle for tooltip hovering
|
||||
$invisible = new Circle($point[0], $point[1], 20);
|
||||
$invisible->setFill($this->strokeColor);
|
||||
$invisible->setAdditionalStyle('opacity: 0.0;');
|
||||
$invisible->setAttribute('class', 'chart-data');
|
||||
if (isset($this->tooltips[$x])) {
|
||||
$data = array(
|
||||
'label' => isset($this->graphs[$this->order]['label']) ?
|
||||
strtolower($this->graphs[$this->order]['label']) : '',
|
||||
'color' => isset($this->graphs[$this->order]['color']) ?
|
||||
strtolower($this->graphs[$this->order]['color']) : '#fff'
|
||||
);
|
||||
$format = isset($this->graphs[$this->order]['tooltip'])
|
||||
? $this->graphs[$this->order]['tooltip'] : null;
|
||||
$invisible->setAttribute(
|
||||
'title',
|
||||
$this->tooltips[$x]->renderNoHtml($this->order, $data, $format)
|
||||
);
|
||||
$invisible->setAttribute(
|
||||
'data-title-rich',
|
||||
$this->tooltips[$x]->render($this->order, $data, $format)
|
||||
);
|
||||
}
|
||||
$group->appendChild($invisible->toSvg($ctx));
|
||||
}
|
||||
}
|
||||
|
||||
return $group;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -66,7 +66,7 @@ class Tooltip
|
|||
*/
|
||||
public function __construct (
|
||||
$data = array(),
|
||||
$format = '<b>{title}</b></b><br/> {value} of {sum} {label}'
|
||||
$format = '<b>{title}</b>: {value} {label}'
|
||||
) {
|
||||
$this->data = array_merge($this->data, $data);
|
||||
$this->defaultFormat = $format;
|
||||
|
|
|
@ -84,6 +84,13 @@ class GridChart extends Chart
|
|||
*/
|
||||
private $tooltips = array();
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->title = t('Grid Chart');
|
||||
$this->description = t('Contains data in a bar or line chart.');
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the current dataset has the proper structure for this chart.
|
||||
*
|
||||
|
@ -395,7 +402,12 @@ class GridChart extends Chart
|
|||
);
|
||||
break;
|
||||
case self::TYPE_LINE:
|
||||
$graphObj = new LineGraph($axis->transform($graph['data']));
|
||||
$graphObj = new LineGraph(
|
||||
$axis->transform($graph['data']),
|
||||
$graphs,
|
||||
$dataset,
|
||||
$this->tooltips
|
||||
);
|
||||
break;
|
||||
default:
|
||||
continue;
|
||||
|
|
|
@ -50,6 +50,13 @@ class PieChart extends Chart
|
|||
*/
|
||||
private $noCaption = false;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->title = t('Pie Chart');
|
||||
$this->description = t('Contains data in a pie chart.');
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test if the given pies have the correct format
|
||||
*
|
||||
|
|
|
@ -43,6 +43,13 @@ class Canvas implements Drawable
|
|||
*/
|
||||
private $rect;
|
||||
|
||||
/**
|
||||
* The aria role used to describe this canvas' purpose in the accessibility tree
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $ariaRole;
|
||||
|
||||
/**
|
||||
* Create this canvas
|
||||
*
|
||||
|
@ -111,6 +118,23 @@ class Canvas implements Drawable
|
|||
$innerContainer->appendChild($child->toSvg($ctx));
|
||||
}
|
||||
|
||||
if (isset($this->ariaRole)) {
|
||||
$outer->setAttribute('role', $this->ariaRole);
|
||||
}
|
||||
return $outer;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the aria role used to determine the meaning of this canvas in the accessibility tree
|
||||
*
|
||||
* The role 'presentation' will indicate that the purpose of this canvas is entirely decorative, while the role
|
||||
* 'img' will indicate that the canvas contains an image, with a possible title or a description. For other
|
||||
* possible roles, see http://www.w3.org/TR/wai-aria/roles
|
||||
*
|
||||
* @param $role string The aria role to set
|
||||
*/
|
||||
public function setAriaRole($role)
|
||||
{
|
||||
$this->ariaRole = $role;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -48,6 +48,27 @@ class SVGRenderer
|
|||
*/
|
||||
private $svg;
|
||||
|
||||
/**
|
||||
* The description of this SVG, useful for screen readers
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $ariaDescription;
|
||||
|
||||
/**
|
||||
* The title of this SVG, useful for screen readers
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $ariaTitle;
|
||||
|
||||
/**
|
||||
* The aria role used by this svg element
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $ariaRole = 'img';
|
||||
|
||||
/**
|
||||
* The root layer for all elements
|
||||
*
|
||||
|
@ -126,6 +147,7 @@ class SVGRenderer
|
|||
$svg = $this->document->createElement('svg');
|
||||
$svg->setAttribute('xmlns', 'http://www.w3.org/2000/svg');
|
||||
$svg->setAttribute('xmlns:xlink', 'http://www.w3.org/1999/xlink');
|
||||
$svg->setAttribute('role', $this->ariaRole);
|
||||
$svg->setAttribute('width', '100%');
|
||||
$svg->setAttribute('height', '100%');
|
||||
$svg->setAttribute(
|
||||
|
@ -150,6 +172,42 @@ class SVGRenderer
|
|||
return $svg;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add aria title and description
|
||||
*
|
||||
* Adds an aria title and desc element to the given SVG node, which are used to describe this SVG by accessibility
|
||||
* tools such as screen readers.
|
||||
*
|
||||
* @param DOMNode $svg The SVG DOMNode to which the aria attributes should be attached
|
||||
* @param $title The title text
|
||||
* @param $description The description text
|
||||
*/
|
||||
private function addAriaDescription (DOMNode $svg, $titleText, $descriptionText)
|
||||
{
|
||||
$doc = $svg->ownerDocument;
|
||||
|
||||
$titleId = $descId = '';
|
||||
if (isset ($this->ariaTitle)) {
|
||||
$titleId = 'aria-title-' . $this->stripNonAlphanumeric($titleText);
|
||||
$title = $doc->createElement('title');
|
||||
$title->setAttribute('id', $titleId);
|
||||
|
||||
$title->appendChild($doc->createTextNode($titleText));
|
||||
$svg->appendChild($title);
|
||||
}
|
||||
|
||||
if (isset ($this->ariaDescription)) {
|
||||
$descId = 'aria-desc-' . $this->stripNonAlphanumeric($descriptionText);
|
||||
$desc = $doc->createElement('desc');
|
||||
$desc->setAttribute('id', $descId);
|
||||
|
||||
$desc->appendChild($doc->createTextNode($descriptionText));
|
||||
$svg->appendChild($desc);
|
||||
}
|
||||
|
||||
$svg->setAttribute('aria-labelledby', join(' ', array($titleId, $descId)));
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialises the XML-document, SVG-element and this figure's root canvas
|
||||
*
|
||||
|
@ -172,6 +230,7 @@ class SVGRenderer
|
|||
{
|
||||
$this->createRootDocument();
|
||||
$ctx = $this->createRenderContext();
|
||||
$this->addAriaDescription($this->svg, $this->ariaTitle, $this->ariaDescription);
|
||||
$this->svg->appendChild($this->rootCanvas->toSvg($ctx));
|
||||
$this->document->formatOutput = true;
|
||||
return $this->document->saveXML();
|
||||
|
@ -232,4 +291,40 @@ class SVGRenderer
|
|||
{
|
||||
$this->yAspectRatio = $alignment;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the aria description, that is used as a title for this SVG in screen readers
|
||||
*
|
||||
* @param $text
|
||||
*/
|
||||
public function setAriaTitle($text)
|
||||
{
|
||||
$this->ariaTitle = $text;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the aria description, that is used to describe this SVG in screen readers
|
||||
*
|
||||
* @param $text
|
||||
*/
|
||||
public function setAriaDescription($text)
|
||||
{
|
||||
$this->ariaDescription = $text;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the aria role, that is used to describe the purpose of this SVG in screen readers
|
||||
*
|
||||
* @param $text
|
||||
*/
|
||||
public function setAriaRole($text)
|
||||
{
|
||||
$this->ariaRole = $text;
|
||||
}
|
||||
|
||||
|
||||
private function stripNonAlphanumeric($str)
|
||||
{
|
||||
return preg_replace('/[^A-Za-z]+/', '', $str);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -44,7 +44,6 @@ EOD;
|
|||
</noscript>
|
||||
EOD;
|
||||
|
||||
|
||||
/**
|
||||
* @var Url
|
||||
*/
|
||||
|
|
|
@ -6,7 +6,6 @@ namespace Icinga\Web\Widget\Dashboard;
|
|||
use Zend_Form_Element_Button;
|
||||
use Icinga\Web\Form;
|
||||
use Icinga\Web\Url;
|
||||
use Icinga\Web\Widget\AbstractWidget;
|
||||
use Icinga\Data\ConfigObject;
|
||||
use Icinga\Exception\IcingaException;
|
||||
|
||||
|
@ -54,7 +53,12 @@ class Dashlet extends UserWidget
|
|||
<div class="container" data-icinga-url="{URL}">
|
||||
<h1><a href="{FULL_URL}" aria-label="{TOOLTIP}" title="{TOOLTIP}" data-base-target="col1">{TITLE}</a></h1>
|
||||
<noscript>
|
||||
<iframe src="{IFRAME_URL}" style="height:100%; width:99%" frameborder="no"></iframe>
|
||||
<iframe
|
||||
src="{IFRAME_URL}"
|
||||
style="height:100%; width:99%"
|
||||
frameborder="no"
|
||||
title="{TITLE_PREFIX}{TITLE}">
|
||||
</iframe>
|
||||
</noscript>
|
||||
</div>
|
||||
EOD;
|
||||
|
@ -184,7 +188,8 @@ EOD;
|
|||
'{IFRAME_URL}',
|
||||
'{FULL_URL}',
|
||||
'{TOOLTIP}',
|
||||
'{TITLE}'
|
||||
'{TITLE}',
|
||||
'{TITLE_PREFIX}'
|
||||
);
|
||||
|
||||
$replaceTokens = array(
|
||||
|
@ -192,7 +197,8 @@ EOD;
|
|||
$iframeUrl,
|
||||
$url->getUrlWithout(array('view', 'limit')),
|
||||
sprintf($view->translate('Show %s', 'dashboard.dashlet.tooltip'), $view->escape($this->getTitle())),
|
||||
$view->escape($this->getTitle())
|
||||
$view->escape($this->getTitle()),
|
||||
$view->translate('Dashlet') . ': '
|
||||
);
|
||||
|
||||
return str_replace($searchTokens, $replaceTokens, $this->template);
|
||||
|
|
|
@ -678,20 +678,28 @@ class FilterEditor extends AbstractWidget
|
|||
public function render()
|
||||
{
|
||||
if (! $this->preservedUrl()->getParam('modifyFilter')) {
|
||||
return $this->renderSearch() . $this->shorten($this->filter, 50);
|
||||
$filterEditor = $this->renderSearch() . $this->shorten($this->filter, 50);
|
||||
} else {
|
||||
$filterEditor = $this->renderSearch()
|
||||
. '<form action="'
|
||||
. Url::fromRequest()
|
||||
. '" class="filterEditor" method="POST">'
|
||||
. '<ul class="tree widgetFilter"><li>'
|
||||
. $this->renderFilter($this->filter)
|
||||
. '</li></ul>'
|
||||
. '<div style="float: right">'
|
||||
. '<input type="submit" name="submit" value="Apply" />'
|
||||
. '<input type="submit" name="cancel" value="Cancel" />'
|
||||
. '</div>'
|
||||
. '</form>';
|
||||
}
|
||||
return $this->renderSearch()
|
||||
. '<form action="'
|
||||
. Url::fromRequest()
|
||||
. '" class="filterEditor" method="POST">'
|
||||
. '<ul class="tree widgetFilter"><li>'
|
||||
. $this->renderFilter($this->filter)
|
||||
. '</li></ul>'
|
||||
. '<div style="float: right">'
|
||||
. '<input type="submit" name="submit" value="Apply" />'
|
||||
. '<input type="submit" name="cancel" value="Cancel" />'
|
||||
. '</div>'
|
||||
. '</form>';
|
||||
|
||||
return sprintf(
|
||||
'<div class="filter-editor dontprint">'
|
||||
. '<h2 tabindex="-1" class="sr-only">%s</h2>%s</div>',
|
||||
t('Filters'),
|
||||
$filterEditor
|
||||
);
|
||||
}
|
||||
|
||||
protected function shorten($string, $length)
|
||||
|
|
|
@ -133,6 +133,13 @@ class SortBox extends AbstractWidget
|
|||
if ($this->request) {
|
||||
$form->populate($this->request->getParams());
|
||||
}
|
||||
return $form;
|
||||
|
||||
return sprintf(
|
||||
'<div class="sort-box dontprint">'
|
||||
. '<h2 tabindex="-1" class="sr-only">%s</h2>%s%s</div>',
|
||||
t('Sort Criteria'),
|
||||
t('Sort by'),
|
||||
(string) $form
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -19,6 +19,7 @@ class Tabs extends AbstractWidget implements Countable
|
|||
* @var string
|
||||
*/
|
||||
private $baseTpl = <<< 'EOT'
|
||||
{HEADER}
|
||||
<ul class="tabs">
|
||||
{TABS}
|
||||
{DROPDOWN}
|
||||
|
@ -26,6 +27,13 @@ class Tabs extends AbstractWidget implements Countable
|
|||
</ul>
|
||||
EOT;
|
||||
|
||||
/**
|
||||
* Template used for the header
|
||||
*
|
||||
* @type string
|
||||
*/
|
||||
private $headerTpl = '<h2 class="sr-only">{TITLE}</h2>';
|
||||
|
||||
/**
|
||||
* Template used for the tabs dropdown
|
||||
*
|
||||
|
@ -87,6 +95,13 @@ EOT;
|
|||
*/
|
||||
private $closeTab = true;
|
||||
|
||||
/**
|
||||
* Title of the tab navigation
|
||||
*
|
||||
* @type string
|
||||
*/
|
||||
private $title;
|
||||
|
||||
/**
|
||||
* Set whether the current tab is closable
|
||||
*/
|
||||
|
@ -309,11 +324,21 @@ EOT;
|
|||
}
|
||||
$close = $this->closeTab ? $this->renderCloseTab() : '';
|
||||
|
||||
$html = $this->baseTpl;
|
||||
$html = str_replace('{TABS}', $tabs, $html);
|
||||
$html = str_replace('{DROPDOWN}', $drop, $html);
|
||||
$html = str_replace('{CLOSE}', $close, $html);
|
||||
return $html;
|
||||
return str_replace(
|
||||
array(
|
||||
'{TABS}',
|
||||
'{DROPDOWN}',
|
||||
'{CLOSE}',
|
||||
'{HEADER}'
|
||||
),
|
||||
array(
|
||||
$tabs,
|
||||
$drop,
|
||||
$close,
|
||||
$this->renderHeader()
|
||||
),
|
||||
$this->baseTpl
|
||||
);
|
||||
}
|
||||
|
||||
public function __toString()
|
||||
|
@ -372,4 +397,30 @@ EOT;
|
|||
$tabextension->apply($this);
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the title of the tab navigation
|
||||
*
|
||||
* @param string $title
|
||||
* @return self
|
||||
*/
|
||||
public function setTitle($title)
|
||||
{
|
||||
$this->title = $title;
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Render the title into the header template
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function renderHeader()
|
||||
{
|
||||
if (! $this->title) {
|
||||
return '';
|
||||
}
|
||||
|
||||
return str_replace('{TITLE}', $this->title, $this->headerTpl);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -44,7 +44,7 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Alert Summary'),
|
||||
'url' => Url::fromRequest()
|
||||
)
|
||||
)->activate('alertsummary');
|
||||
)->activate('alertsummary')->setTitle($this->translate('Alertsummary Navigation'));
|
||||
$this->view->title = $this->translate('Alert Summary');
|
||||
|
||||
$this->view->intervalBox = $this->createIntervalBox();
|
||||
|
@ -324,6 +324,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
public function createHealingChart()
|
||||
{
|
||||
$gridChart = new GridChart();
|
||||
$gridChart->title = t('Healing Chart');
|
||||
$gridChart->description = t('Notifications and average reaction time per hour.');
|
||||
|
||||
$gridChart->alignTopLeft();
|
||||
$gridChart->setAxisLabel($this->createPeriodDescription(), mt('monitoring', 'Notifications'))
|
||||
|
@ -427,7 +429,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Notifications'),
|
||||
'color' => '#07C0D9',
|
||||
'data' => $notifications,
|
||||
'showPoints' => true
|
||||
'showPoints' => true,
|
||||
'tooltip' => '<b>{title}:</b> {value} {label}'
|
||||
)
|
||||
);
|
||||
|
||||
|
@ -436,7 +439,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Avg (min)'),
|
||||
'color' => '#ffaa44',
|
||||
'data' => $dAvg,
|
||||
'showPoints' => true
|
||||
'showPoints' => true,
|
||||
'tooltip' => t('<b>{title}:</b> {value}m min. reaction time')
|
||||
)
|
||||
);
|
||||
|
||||
|
@ -445,7 +449,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Max (min)'),
|
||||
'color' => '#ff5566',
|
||||
'data' => $dMax,
|
||||
'showPoints' => true
|
||||
'showPoints' => true,
|
||||
'tooltip' => t('<b>{title}:</b> {value}m max. reaction time')
|
||||
)
|
||||
);
|
||||
|
||||
|
@ -460,6 +465,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
public function createDefectImage()
|
||||
{
|
||||
$gridChart = new GridChart();
|
||||
$gridChart->title = t('Defect Chart');
|
||||
$gridChart->description = t('Notifications and defects per hour');
|
||||
|
||||
$gridChart->alignTopLeft();
|
||||
$gridChart->setAxisLabel($this->createPeriodDescription(), mt('monitoring', 'Notifications'))
|
||||
|
@ -472,7 +479,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Notifications'),
|
||||
'color' => '#07C0D9',
|
||||
'data' => $this->notificationData,
|
||||
'showPoints' => true
|
||||
'showPoints' => true,
|
||||
'tooltip' => '<b>{title}:</b> {value} {label}'
|
||||
)
|
||||
);
|
||||
|
||||
|
@ -481,7 +489,8 @@ class Monitoring_AlertsummaryController extends Controller
|
|||
'label' => $this->translate('Defects'),
|
||||
'color' => '#ff5566',
|
||||
'data' => $this->problemData,
|
||||
'showPoints' => true
|
||||
'showPoints' => true,
|
||||
'tooltip' => '<b>{title}:</b> {value} {label}'
|
||||
)
|
||||
);
|
||||
|
||||
|
|
|
@ -236,6 +236,9 @@ class Monitoring_ChartController extends Controller
|
|||
$unknownBars[] = array($servicegroup->servicegroup, $servicegroup->services_unknown_unhandled);
|
||||
}
|
||||
$this->view->chart = new GridChart();
|
||||
$this->view->chart->title = t('Service Group Chart');
|
||||
$this->view->chart->description = t('Contains service states for each service group.');
|
||||
|
||||
$this->view->chart->alignTopLeft();
|
||||
$this->view->chart->setAxisLabel('', mt('monitoring', 'Services'))
|
||||
->setXAxis(new StaticAxis())
|
||||
|
@ -292,6 +295,9 @@ class Monitoring_ChartController extends Controller
|
|||
}
|
||||
$tooltip = mt('monitoring', '<b>{title}:</b><br> {value} of {sum} hosts are {label}');
|
||||
$this->view->chart = new GridChart();
|
||||
$this->view->chart->title = t('Host Group Chart');
|
||||
$this->view->chart->description = t('Contains host states of each service group.');
|
||||
|
||||
$this->view->chart->alignTopLeft();
|
||||
$this->view->chart->setAxisLabel('', mt('monitoring', 'Hosts'))
|
||||
->setXAxis(new StaticAxis())
|
||||
|
|
|
@ -726,6 +726,7 @@ class Monitoring_ListController extends Controller
|
|||
private function createTabs()
|
||||
{
|
||||
$tabs = $this->getTabs();
|
||||
$tabs->setTitle($this->translate('Monitoring Navigation'));
|
||||
if (in_array($this->_request->getActionName(), array(
|
||||
'hosts',
|
||||
'services',
|
||||
|
|
|
@ -29,7 +29,7 @@ class Monitoring_ProcessController extends Controller
|
|||
'label' => $this->translate('Monitoring Health'),
|
||||
'url' =>'monitoring/process/info'
|
||||
)
|
||||
);
|
||||
)->setTitle($this->translate('Process Information'));
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -22,7 +22,7 @@ class Monitoring_TimelineController extends Controller
|
|||
'label' => $this->translate('Timeline'),
|
||||
'url' => Url::fromRequest()
|
||||
)
|
||||
)->activate('timeline');
|
||||
)->activate('timeline')->setTitle($this->translate('Timeline Navigation'));
|
||||
$this->view->title = $this->translate('Timeline');
|
||||
|
||||
// TODO: filter for hard_states (precedence adjustments necessary!)
|
||||
|
|
|
@ -43,8 +43,11 @@ class BackendConfigForm extends ConfigForm
|
|||
{
|
||||
$resources = array();
|
||||
foreach ($resourceConfig as $name => $resource) {
|
||||
if ($resource->type === 'db' || $resource->type === 'livestatus') {
|
||||
$resources[$resource->type === 'db' ? 'ido' : 'livestatus'][$name] = $name;
|
||||
// if ($resource->type === 'db' || $resource->type === 'livestatus') {
|
||||
// $resources[$resource->type === 'db' ? 'ido' : 'livestatus'][$name] = $name;
|
||||
// }
|
||||
if ($resource->type === 'db') {
|
||||
$resources['ido'][$name] = $name;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -183,13 +186,19 @@ class BackendConfigForm extends ConfigForm
|
|||
{
|
||||
$resourceType = isset($formData['type']) ? $formData['type'] : key($this->resources);
|
||||
|
||||
if ($resourceType === 'livestatus') {
|
||||
throw new ConfigurationError(
|
||||
'We\'ve disabled livestatus support for now because it\'s not feature complete yet'
|
||||
);
|
||||
}
|
||||
|
||||
$resourceTypes = array();
|
||||
if ($resourceType === 'ido' || array_key_exists('ido', $this->resources)) {
|
||||
$resourceTypes['ido'] = 'IDO Backend';
|
||||
}
|
||||
if ($resourceType === 'livestatus' || array_key_exists('livestatus', $this->resources)) {
|
||||
$resourceTypes['livestatus'] = 'Livestatus';
|
||||
}
|
||||
// if ($resourceType === 'livestatus' || array_key_exists('livestatus', $this->resources)) {
|
||||
// $resourceTypes['livestatus'] = 'Livestatus';
|
||||
// }
|
||||
|
||||
$this->addElement(
|
||||
'checkbox',
|
||||
|
|
|
@ -51,7 +51,7 @@ class BackendPage extends Form
|
|||
if (Platform::hasMysqlSupport() || Platform::hasPostgresqlSupport()) {
|
||||
$resourceTypes['ido'] = 'IDO';
|
||||
}
|
||||
$resourceTypes['livestatus'] = 'Livestatus';
|
||||
// $resourceTypes['livestatus'] = 'Livestatus';
|
||||
|
||||
$this->addElement(
|
||||
'select',
|
||||
|
|
|
@ -1,6 +1,9 @@
|
|||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em;" class="dontprint">
|
||||
<h2 tabindex="-1" class="sr-only">
|
||||
<?= $this->translate('Filters'); ?>
|
||||
</h2>
|
||||
<?= $intervalBox; ?>
|
||||
</div>
|
||||
<?= $this->widget('limiter') ?>
|
||||
|
@ -8,25 +11,33 @@
|
|||
</div>
|
||||
|
||||
<div class="content alertsummary">
|
||||
<!-- <h1><?= $this->translate('Alert summary'); ?></h1> -->
|
||||
<h1 tabindex="-1">
|
||||
<?= $this->translate('Alert summary'); ?>
|
||||
</h1>
|
||||
|
||||
<div class="hbox">
|
||||
<div class="hbox-item">
|
||||
<h2><?= $this->translate('Notifications and Problems'); ?></h2>
|
||||
<h2 tabindex="-1" id="alertsummary-notifications">
|
||||
<?= $this->translate('Notifications and Problems'); ?>
|
||||
</h2>
|
||||
<div style="width: 400px; height: 400px;">
|
||||
<?= $defectChart->render(); ?>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="hbox-item">
|
||||
<h2><?= $this->translate('Time to Reaction (Ack, Recover)'); ?></h2>
|
||||
<h2 tabindex="-1" id="alertsummary-reaction-time">
|
||||
<?= $this->translate('Time to Reaction (Ack, Recover)'); ?>
|
||||
</h2>
|
||||
<div style="width: 400px; height: 400px;">
|
||||
<?= $healingChart->render(); ?>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<h2><?= $this->translate('Trend'); ?></h2>
|
||||
<h2 tabindex="-1" id="alertsummary-trend">
|
||||
<?= $this->translate('Trend'); ?>
|
||||
</h2>
|
||||
|
||||
<div class="alertsummary-flex-container">
|
||||
<div class="alertsummary-flex">
|
||||
|
@ -53,7 +64,9 @@
|
|||
</div>
|
||||
|
||||
<?php if ($this->recentAlerts): ?>
|
||||
<h1><?= $this->translate('Top 5 Recent Alerts'); ?></h1>
|
||||
<h2 tabindex="-1" id="alertsummary-top5">
|
||||
<?= $this->translate('Top 5 Recent Alerts'); ?>
|
||||
</h2>
|
||||
|
||||
<div class="alertsummary-flex-container">
|
||||
<div class="alertsummary-flex">
|
||||
|
@ -66,7 +79,9 @@
|
|||
</div>
|
||||
<?php endif; ?>
|
||||
|
||||
<h1><?= $this->translate('History'); ?></h1>
|
||||
<h2 tabindex="-1" id="alertsummary-history">
|
||||
<?= $this->translate('History'); ?>
|
||||
</h2>
|
||||
<div class="alertsummary-flex-container">
|
||||
<div class="alertsummary-flex">
|
||||
<?= $this->partial('list/notifications.phtml', array(
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
<?= $this->render('partials/host/servicesummary.phtml') ?>
|
||||
</div>
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="-1"><?= $this->translate('Host Detail Information') ?></h1>
|
||||
<?= $this->render('show/components/output.phtml') ?>
|
||||
<?= $this->render('show/components/grapher.phtml') ?>
|
||||
|
||||
|
|
|
@ -1,15 +1,14 @@
|
|||
<?php if (false === $this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs->render($this); ?>
|
||||
<div style="margin: 1em" class="dontprint">
|
||||
<?= $this->translate('Sort by'); ?> <?= $this->sortControl->render($this); ?>
|
||||
</div>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $comments->count())); ?>
|
||||
<?= $this->paginationControl($comments, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<?= $this->sortControl ?>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $comments->count())); ?>
|
||||
<?= $this->paginationControl($comments, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div class="content">
|
||||
<h1 tabindex="-1"><?= $this->translate('Comments') ?></h1>
|
||||
<?php if (count($comments) === 0): ?>
|
||||
<?= $this->translate('No comments matching the filter'); ?>
|
||||
</div>
|
||||
|
|
|
@ -4,6 +4,9 @@
|
|||
</div>
|
||||
<?php endif ?>
|
||||
<div class="content">
|
||||
<h1 tabindex="-1">
|
||||
<?= $this->translate('Contact Groups'); ?>
|
||||
</h1>
|
||||
<div class="boxview" data-base-target="_next">
|
||||
|
||||
<?php
|
||||
|
|
|
@ -1,12 +1,14 @@
|
|||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em">
|
||||
<?= $this->sortControl->render($this); ?>
|
||||
<?php if (false === $this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<?= $this->sortControl ?>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $contacts->count())); ?>
|
||||
<?= $this->paginationControl($contacts, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<?= $this->paginationControl($contacts, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div data-base-target="_next" class="content contacts">
|
||||
<h1 tabindex="-1"><?= $this->translate('Contacts') ?></h1>
|
||||
<?php
|
||||
if (count($contacts) === 0) {
|
||||
echo $this->translate('No contacts matching the filter');
|
||||
|
|
|
@ -4,23 +4,17 @@ use Icinga\Module\Monitoring\Object\Host;
|
|||
use Icinga\Module\Monitoring\Object\Service;
|
||||
|
||||
?>
|
||||
|
||||
<?php if (false === $this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs->render($this); ?>
|
||||
<div style="margin: 1em" class="dontprint">
|
||||
<?= $this->translate('Sort by'); ?> <?= $this->sortControl->render($this); ?>
|
||||
<?php if (! $this->filterEditor): ?>
|
||||
<?= $this->filterPreview ?>
|
||||
<?php endif; ?>
|
||||
</div>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $downtimes->count())); ?>
|
||||
<?= $this->paginationControl($downtimes, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<?= $this->sortControl ?>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $downtimes->count())); ?>
|
||||
<?= $this->paginationControl($downtimes, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div class="content">
|
||||
<?= $this->filterEditor ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Downtimes'); ?></h1>
|
||||
<?php if (count($downtimes) === 0): ?>
|
||||
<?= $this->translate('No active downtimes'); ?>
|
||||
</div>
|
||||
|
|
|
@ -2,18 +2,21 @@
|
|||
use Icinga\Data\Filter\Filter;
|
||||
use Icinga\Web\Widget\Chart\HistoryColorGrid;
|
||||
?>
|
||||
|
||||
|
||||
<? if (! $compact): ?>
|
||||
<?php if (! $compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs->render($this); ?>
|
||||
<div class="fake-controls">
|
||||
<h2 tabindex="-1" class="sr-only">
|
||||
<?= $this->translate('Filters'); ?>
|
||||
</h2>
|
||||
<?= $form ?>
|
||||
</div>
|
||||
</div>
|
||||
<? endif; ?>
|
||||
|
||||
<div class="content" data-base-target="_next">
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="-1"><?= $this->translate('Event Grid'); ?></h1>
|
||||
<?php else: ?>
|
||||
<div class="content" data-base-target="_next">
|
||||
<?php endif; ?>
|
||||
<?php
|
||||
|
||||
$settings = array(
|
||||
|
|
|
@ -4,24 +4,21 @@ use Icinga\Module\Monitoring\Object\Host;
|
|||
use Icinga\Module\Monitoring\Object\Service;
|
||||
|
||||
?>
|
||||
|
||||
<?php if (false === $this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em" class="dontprint">
|
||||
<div style="float: right">
|
||||
<?= $this->translate('Sort by') ?> <?= $this->sortControl ?>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<?= $this->sortControl ?>
|
||||
<?= $this->widget('limiter', array('url' => $this->url, 'max' => $this->history->count())); ?>
|
||||
<?= $this->paginationControl($history, null, null, array('preserve' => $this->preserve)); ?>
|
||||
|
||||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div class="content">
|
||||
<?= $this->filterEditor ?>
|
||||
<?= $this->filterEditor ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Event History') ?></h1>
|
||||
<?php else: ?>
|
||||
<div class="content">
|
||||
<?php endif; ?>
|
||||
|
||||
|
||||
<?php if (empty($history)): ?>
|
||||
<?= $this->translate('No history events matching the filter') ?>
|
||||
</div>
|
||||
|
|
|
@ -3,14 +3,13 @@
|
|||
<?php else: ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em;" class="dontprint">
|
||||
<?= $this->translate('Sort by'); ?> <?= $this->sortControl->render($this); ?>
|
||||
</div>
|
||||
<?= $this->sortControl->render($this); ?>
|
||||
<?= $this->widget('limiter')->setMaxLimit(count($hostgroups)); ?>
|
||||
<?= $this->paginationControl($hostgroups, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<?= $this->filterEditor; ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Host Groups') ?></h1>
|
||||
<?php endif ?>
|
||||
<?php
|
||||
if (count($hostgroups) === 0) {
|
||||
|
|
|
@ -9,9 +9,8 @@ if ($this->compact): ?>
|
|||
<div style="margin: 1em;" class="dontprint">
|
||||
<?= $this->render('list/components/selectioninfo.phtml') ?>
|
||||
<?= $this->render('list/components/hostssummary.phtml') ?>
|
||||
<?= $this->translate('Sort by') ?> <?= $this->sortControl->render($this) ?>
|
||||
</div>
|
||||
|
||||
<?= $this->sortControl->render($this) ?>
|
||||
<?= $this->widget('limiter')->setMaxLimit($this->hosts->count()) ?>
|
||||
<?= $this->paginationControl($hosts, null, null, array('preserve' => $this->preserve)) ?>
|
||||
<?= $this->selectionToolbar('multi', $this->href('monitoring/hosts/show?' . $this->filter->toQueryString())) ?>
|
||||
|
@ -19,6 +18,7 @@ if ($this->compact): ?>
|
|||
|
||||
<div class="content">
|
||||
<?= $this->filterEditor ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Hosts') ?></h1>
|
||||
<?php
|
||||
|
||||
endif;
|
||||
|
@ -31,7 +31,6 @@ if ($hosts->count() === 0) {
|
|||
return;
|
||||
}
|
||||
?>
|
||||
|
||||
<table
|
||||
data-base-target="_next"
|
||||
class="action multiselect"
|
||||
|
|
|
@ -4,19 +4,18 @@ use Icinga\Module\Monitoring\Object\Host;
|
|||
use Icinga\Module\Monitoring\Object\Service;
|
||||
|
||||
?>
|
||||
|
||||
<?php if (! $this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div class="dontprint" style="margin: 1em;">
|
||||
<?= $this->translate('Sort by') ?> <?= $this->sortControl->render($this) ?>
|
||||
</div>
|
||||
<?= $this->sortControl->render($this) ?>
|
||||
<?= $this->widget('limiter') ?>
|
||||
<?= $this->paginationControl($notifications, null, null, array('preserve' => $this->preserve)) ?>
|
||||
</div>
|
||||
<?php endif ?>
|
||||
|
||||
<div class="content">
|
||||
<h1 tabindex="-1"><?= $this->translate('Notifications'); ?></h1>
|
||||
<?php else: ?>
|
||||
<div class="content">
|
||||
<?php endif ?>
|
||||
<?php if (count($notifications) === 0): ?>
|
||||
<?= $this->translate('No notifications matching the filter') ?>
|
||||
<?php return; endif ?>
|
||||
|
|
|
@ -6,12 +6,11 @@ use Icinga\Module\Monitoring\Object\Service;
|
|||
<?php if (!$this->compact): ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs; ?>
|
||||
<div style="margin: 1em;" class="dontprint">
|
||||
<?= $this->translate('Sort by'); ?> <?= $this->sortControl; ?>
|
||||
</div>
|
||||
<?= $this->sortControl; ?>
|
||||
</div>
|
||||
<?php endif ?>
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="-1"><?= $this->translate('Service Grid') ?></h1>
|
||||
<table class="pivot servicestates">
|
||||
<?php
|
||||
$hasHeader = false;
|
||||
|
|
|
@ -3,14 +3,13 @@
|
|||
<?php else: ?>
|
||||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em;" class="dontprint">
|
||||
<?= $this->translate('Sort by'); ?> <?= $this->sortControl->render($this); ?>
|
||||
</div>
|
||||
<?= $this->sortControl->render($this); ?>
|
||||
<?= $this->widget('limiter')->setMaxLimit(count($servicegroups)); ?>
|
||||
<?= $this->paginationControl($servicegroups, null, null, array('preserve' => $this->preserve)); ?>
|
||||
</div>
|
||||
<div class="content">
|
||||
<?= $this->filterEditor; ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Service Groups') ?></h1>
|
||||
<?php endif ?>
|
||||
<?php
|
||||
if (count($servicegroups) === 0) {
|
||||
|
|
|
@ -10,10 +10,8 @@ if (!$this->compact): ?>
|
|||
<div style="margin: 1em;" class="dontprint">
|
||||
<?= $this->render('list/components/selectioninfo.phtml') ?>
|
||||
<?= $this->render('list/components/servicesummary.phtml') ?>
|
||||
<div style="float: right">
|
||||
<?= $this->translate('Sort by') ?> <?= $this->sortControl ?>
|
||||
</div>
|
||||
</div>
|
||||
<?= $this->sortControl ?>
|
||||
<?php if ($this->limit === 0): ?>
|
||||
<?= $this->widget('limiter') ?>
|
||||
<?php else: ?>
|
||||
|
@ -24,6 +22,7 @@ if (!$this->compact): ?>
|
|||
|
||||
<div class="content">
|
||||
<?= $this->filterEditor ?>
|
||||
<h1 tabindex="-1"><?= $this->translate('Services') ?></h1>
|
||||
<?php else: ?>
|
||||
|
||||
<div class="content">
|
||||
|
|
|
@ -3,7 +3,9 @@
|
|||
<?php endif ?>
|
||||
<?php if (($hostCount = count($objects)) > 0): ?>
|
||||
<div class="hbox-item">
|
||||
<strong><?= sprintf($this->translatePlural('Host (%u)', 'Hosts (%u)', $hostCount), $hostCount); ?></strong>
|
||||
<h1 tabindex="-1">
|
||||
<?= sprintf($this->translatePlural('Host (%u)', 'Hosts (%u)', $hostCount), $hostCount); ?>
|
||||
</h1>
|
||||
</div>
|
||||
<div class="hbox-item">
|
||||
<?= $hostStatesPieChart; ?>
|
||||
|
|
|
@ -4,7 +4,9 @@
|
|||
<?php if (($serviceCount = count($objects)) > 0): ?>
|
||||
<div class="hbox">
|
||||
<div class="hbox-item" style="width: 6em;">
|
||||
<strong><?= sprintf($this->translatePlural('Service (%u)', 'Services (%u)', $serviceCount), $serviceCount); ?></strong>
|
||||
<h1 tabindex="-1">
|
||||
<?= sprintf($this->translatePlural('Service (%u)', 'Services (%u)', $serviceCount), $serviceCount); ?>
|
||||
</h1>
|
||||
</div>
|
||||
<div class="hbox-item">
|
||||
<?= $serviceStatesPieChart; ?>
|
||||
|
|
|
@ -9,15 +9,23 @@ $cp = $this->checkPerformance()->create($this->checkperformance);
|
|||
</div>
|
||||
|
||||
<div class="content processinfo">
|
||||
<h1 tabindex="-1">
|
||||
<?= $this->translate('Monitoring Health'); ?>
|
||||
</h1>
|
||||
|
||||
<div class="boxview">
|
||||
|
||||
<div class="box left">
|
||||
<h2><?= $this->translate('Feature Commands') ?></h2>
|
||||
<h2 tabindex="-1" id="process-feature-command">
|
||||
<?= $this->translate('Feature Commands') ?>
|
||||
</h2>
|
||||
<?= $this->toggleFeaturesForm ?>
|
||||
</div>
|
||||
|
||||
<div class="box left">
|
||||
<h2><?= $this->translate('Process Info') ?></h2>
|
||||
<h2 tabindex="-1" id="process-process-info">
|
||||
<?= $this->translate('Process Info') ?>
|
||||
</h2>
|
||||
<table class="avp">
|
||||
<tbody>
|
||||
<tr>
|
||||
|
@ -68,9 +76,13 @@ $cp = $this->checkPerformance()->create($this->checkperformance);
|
|||
</div>
|
||||
|
||||
<div class="box left">
|
||||
<h2><?= $this->translate('Performance Info') ?></h2>
|
||||
<h2 tabindex="-1" id="process-performance-info">
|
||||
<?= $this->translate('Performance Info') ?>
|
||||
</h2>
|
||||
|
||||
<h3><?= $this->translate('Object summaries') ?></h3>
|
||||
<h3 tabindex="-1" id="process-object-summaries">
|
||||
<?= $this->translate('Object summaries') ?>
|
||||
</h3>
|
||||
<table class="avp">
|
||||
<thead>
|
||||
<tr>
|
||||
|
@ -118,7 +130,9 @@ $cp = $this->checkPerformance()->create($this->checkperformance);
|
|||
</tbody>
|
||||
</table>
|
||||
|
||||
<h3><?= $this->translate('Active checks') ?></h3>
|
||||
<h3 tabindex="-1" id="process-active-checks">
|
||||
<?= $this->translate('Active checks') ?>
|
||||
</h3>
|
||||
<table class="avp">
|
||||
<thead>
|
||||
<tr>
|
||||
|
@ -148,7 +162,9 @@ $cp = $this->checkPerformance()->create($this->checkperformance);
|
|||
</tbody>
|
||||
</table>
|
||||
|
||||
<h3><?= $this->translate('Passive checks') ?></h3>
|
||||
<h3 tabindex="-1" id="process-passive-checks">
|
||||
<?= $this->translate('Passive checks') ?>
|
||||
</h3>
|
||||
<table class="avp">
|
||||
<tbody>
|
||||
<tr>
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
</div>
|
||||
<?php endif ?>
|
||||
<div class="content tactical">
|
||||
<h1 tabindex="-1"><?= $this->translate('Tactical Overview') ?></h1>
|
||||
<div class="boxview" data-base-target="_next">
|
||||
<?php if ($this->statusSummary->hosts_down || $this->statusSummary->hosts_unreachable): ?>
|
||||
<?= $this->render('tactical/components/problem_hosts.phtml'); ?>
|
||||
|
|
|
@ -10,6 +10,9 @@ $firstRow = !$beingExtended;
|
|||
<div class="controls">
|
||||
<?= $this->tabs ?>
|
||||
<div style="margin: 1em;" class="dontprint">
|
||||
<h2 tabindex="-1" class="sr-only">
|
||||
<?= $this->translate('Filters') ?>
|
||||
</h2>
|
||||
<?= $intervalBox; ?>
|
||||
</div>
|
||||
<div style="margin: 1em;" class="timeline-legend">
|
||||
|
@ -22,6 +25,7 @@ $firstRow = !$beingExtended;
|
|||
</div>
|
||||
</div>
|
||||
<div class="content" data-base-target="_next">
|
||||
<h1 tabindex="-1"><?= $this->translate('Timeline'); ?></h1>
|
||||
<div class="timeline">
|
||||
<?php endif ?>
|
||||
<?php if ($switchedContext): ?>
|
||||
|
|
|
@ -198,3 +198,8 @@ hr.command-separator {
|
|||
border: none;
|
||||
border-bottom: 2px solid @colorPetrol;
|
||||
}
|
||||
|
||||
.sort-box {
|
||||
float: right;
|
||||
margin-right: 1em;
|
||||
}
|
|
@ -270,7 +270,7 @@ a:focus {
|
|||
|
||||
/* Accessibility Skip Links */
|
||||
.skip-links {
|
||||
position: absolute;
|
||||
position: relative;
|
||||
opacity: 1;
|
||||
ul {
|
||||
list-style-type: none;
|
||||
|
@ -286,7 +286,6 @@ a:focus {
|
|||
left: -999em;
|
||||
box-sizing: content-box;
|
||||
width: 10.4em !important;
|
||||
top: 0em;
|
||||
text-align: left !important;
|
||||
padding: 0.8em;
|
||||
background-color: white;
|
||||
|
@ -301,5 +300,8 @@ a:focus {
|
|||
}
|
||||
}
|
||||
.skip-links-inline {
|
||||
margin-top: -3.5em;
|
||||
ul > li > a {
|
||||
width: 14em !important;
|
||||
top: -3em;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
var $el = $(this);
|
||||
$el.attr('title', $el.data('title-rich') || $el.attr('title'));
|
||||
});
|
||||
$('svg rect.chart-data[title]', el).tipsy({ gravity: 'se', html: true });
|
||||
$('svg .chart-data', el).tipsy({ gravity: 'se', html: true });
|
||||
$('.historycolorgrid a[title]', el).tipsy({ gravity: 's', offset: 2 });
|
||||
$('img.icon[title]', el).tipsy({ gravity: $.fn.tipsy.autoNS, offset: 2 });
|
||||
$('[title]', el).tipsy({ gravity: $.fn.tipsy.autoNS, delayIn: 500 });
|
||||
|
|
|
@ -337,21 +337,29 @@
|
|||
handleAnchor: function(query) {
|
||||
var $element = $(query);
|
||||
if ($element.length > 0) {
|
||||
// Try to find the first header. It is more pleasant to users
|
||||
// to select the header instead a container
|
||||
var $header = $element.find(':header:first');
|
||||
if ($header.length > 0) {
|
||||
$element = $header;
|
||||
} else {
|
||||
var $input = $element.find(':header:first');
|
||||
if ($input.length > 0) {
|
||||
$element = $input
|
||||
}
|
||||
// TODO(mh): Some elements are missing to place the right focus
|
||||
// This is a fixed workarround until all header took place
|
||||
|
||||
var $item = $element.find(':header:first').nextUntil(':header:first').next();
|
||||
if ($item.length > 0) {
|
||||
$element = $item;
|
||||
}
|
||||
|
||||
/*
|
||||
var focusQueries = ['h1:first', ':header:first', ':input:first'];
|
||||
$.each(focusQueries, function(index,q) {
|
||||
var $item = $element.find(q);
|
||||
if ($item.length > 0) {
|
||||
$element = $item;
|
||||
return false;
|
||||
}
|
||||
});
|
||||
*/
|
||||
|
||||
// If we want to focus an element which has no tabindex
|
||||
// add one that we can focus is
|
||||
if ($element.prop('tabindex') < 0) {
|
||||
$element.prop('tabindex', 0);
|
||||
$element.prop('tabindex', '-1');
|
||||
}
|
||||
$element.focus();
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue