You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zabbix/ui/app/views/monitoring.host.dashboard.v...

231 lines
7.1 KiB

1 year ago
<?php
/*
** Zabbix
** Copyright (C) 2001-2023 Zabbix SIA
**
** 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.
**/
/**
* @var CView $this
* @var array $data
*/
if (array_key_exists('error', $data)) {
show_error_message($data['error']);
}
if (array_key_exists('no_data', $data)) {
(new CHtmlPage())
->setTitle(_('Dashboards'))
->setDocUrl(CDocHelper::getUrl(CDocHelper::MONITORING_HOST_DASHBOARD_VIEW))
->addItem(new CTableInfo())
->show();
return;
}
$this->addJsFile('flickerfreescreen.js');
$this->addJsFile('gtlc.js');
$this->addJsFile('leaflet.js');
$this->addJsFile('leaflet.markercluster.js');
$this->addJsFile('class.dashboard.js');
$this->addJsFile('class.dashboard.page.js');
$this->addJsFile('class.dashboard.widget.placeholder.js');
$this->addJsFile('class.geomaps.js');
$this->addJsFile('class.widget-base.js');
$this->addJsFile('class.widget.js');
$this->addJsFile('class.widget.inaccessible.js');
$this->addJsFile('class.widget.iterator.js');
$this->addJsFile('class.widget.paste-placeholder.js');
$this->addJsFile('class.form.fieldset.collapsible.js');
$this->addJsFile('class.calendar.js');
$this->addJsFile('layout.mode.js');
$this->addJsFile('class.csvggraph.js');
$this->addJsFile('class.svg.canvas.js');
$this->addJsFile('class.svg.map.js');
$this->addJsFile('class.csvggauge.js');
$this->addJsFile('class.sortable.js');
$this->includeJsFile('monitoring.host.dashboard.view.js.php');
$this->addCssFile('assets/styles/vendors/Leaflet/Leaflet/leaflet.css');
$this->enableLayoutModes();
$web_layout_mode = $this->getLayoutMode();
$html_page = (new CHtmlPage())
->setTitle(_('Host dashboards'))
->setWebLayoutMode($web_layout_mode)
->setDocUrl(CDocHelper::getUrl(CDocHelper::MONITORING_HOST_DASHBOARD_VIEW))
->setControls(
(new CTag('nav', true))
->addItem(
(new CList())->addItem(get_icon('kioskmode', ['mode' => $web_layout_mode]))
)
->setAttribute('aria-label', _('Content controls'))
)
->setKioskModeControls(
(count($data['dashboard']['pages']) > 1)
? (new CList())
->addClass(ZBX_STYLE_DASHBOARD_KIOSKMODE_CONTROLS)
->addItem(
(new CSimpleButton())
->addClass(ZBX_ICON_CHEVRON_LEFT)
->addClass(ZBX_STYLE_BTN_DASHBOARD_KIOSKMODE_PREVIOUS_PAGE)
->setTitle(_('Previous page'))
)
->addItem(
(new CSimpleButton())
->addClass(ZBX_ICON_PAUSE)
->addClass(ZBX_STYLE_BTN_DASHBOARD_KIOSKMODE_TOGGLE_SLIDESHOW)
->setTitle(($data['dashboard']['dashboardid'] !== null && $data['dashboard']['auto_start'] == 1)
? _s('Stop slideshow')
: _s('Start slideshow')
)
->addClass(
($data['dashboard']['dashboardid'] !== null && $data['dashboard']['auto_start'] == 1)
? 'slideshow-state-started'
: 'slideshow-state-stopped'
)
)
->addItem(
(new CSimpleButton())
->addClass(ZBX_ICON_CHEVRON_RIGHT)
->addClass(ZBX_STYLE_BTN_DASHBOARD_KIOSKMODE_NEXT_PAGE)
->setTitle(_('Next page'))
)
: null
);
$navigation = (new CDiv())
->addClass(ZBX_STYLE_HOST_DASHBOARD_HEADER_NAVIGATION)
->addItem(
(new CList())->addItem(
new CBreadcrumbs([
(new CSpan())->addItem(
new CLink(_('All hosts'), (new CUrl('zabbix.php'))->setArgument('action', 'host.view'))
),
(new CSpan())->addItem($data['host']['name'])
])
)
);
if ($web_layout_mode != ZBX_LAYOUT_KIOSKMODE) {
$dashboard_tabs = (new CDiv())
->addClass(ZBX_STYLE_HOST_DASHBOARD_NAVIGATION)
->addItem(
(new CDiv())
->addClass(ZBX_STYLE_HOST_DASHBOARD_NAVIGATION_CONTROLS)
->addItem((new CButtonIcon(ZBX_ICON_CHEVRON_LEFT, _('Previous dashboard')))
->addClass(ZBX_STYLE_BTN_HOST_DASHBOARD_PREVIOUS_DASHBOARD)
)
)
->addItem((new CDiv())->addClass(ZBX_STYLE_HOST_DASHBOARD_NAVIGATION_TABS))
->addItem(
(new CDiv())
->addClass(ZBX_STYLE_HOST_DASHBOARD_NAVIGATION_CONTROLS)
->addItem([
(new CButtonIcon(ZBX_ICON_CHEVRON_DOWN, _('Dashboard list')))
->addClass(ZBX_STYLE_BTN_HOST_DASHBOARD_LIST),
(new CButtonIcon(ZBX_ICON_CHEVRON_RIGHT, _('Next dashboard')))
->addClass(ZBX_STYLE_BTN_HOST_DASHBOARD_NEXT_DASHBOARD)
])
);
$navigation->addItem($dashboard_tabs);
}
if ($data['has_time_selector']) {
$navigation->addItem(
(new CFilter())
->setProfile($data['time_period']['profileIdx'], $data['time_period']['profileIdx2'])
->setActiveTab($data['active_tab'])
->addTimeSelector($data['time_period']['from'], $data['time_period']['to'],
$web_layout_mode != ZBX_LAYOUT_KIOSKMODE
)
);
}
$html_page->addItem($navigation);
if (count($data['dashboard']['pages']) > 1
|| (count($data['dashboard']['pages']) == 1 && $data['dashboard']['pages'][0]['widgets'])) {
$dashboard = (new CDiv())->addClass(ZBX_STYLE_DASHBOARD);
if (count($data['dashboard']['pages']) > 1) {
$dashboard->addClass(ZBX_STYLE_DASHBOARD_IS_MULTIPAGE);
}
if ($web_layout_mode != ZBX_LAYOUT_KIOSKMODE) {
$dashboard->addItem(
(new CDiv())
->addClass(ZBX_STYLE_DASHBOARD_NAVIGATION)
->addItem((new CDiv())->addClass(ZBX_STYLE_DASHBOARD_NAVIGATION_TABS))
->addItem(
(new CDiv())
->addClass(ZBX_STYLE_DASHBOARD_NAVIGATION_CONTROLS)
->addItem([
(new CButtonIcon(ZBX_ICON_CHEVRON_LEFT, _('Previous page')))
->addClass(ZBX_STYLE_BTN_DASHBOARD_PREVIOUS_PAGE)
->setEnabled(false),
(new CButtonIcon(ZBX_ICON_CHEVRON_RIGHT, _('Next page')))
->addClass(ZBX_STYLE_BTN_DASHBOARD_NEXT_PAGE)
->setEnabled(false),
(new CSimpleButton([
(new CSpan(_s('Start slideshow')))->addClass('slideshow-state-stopped'),
(new CSpan(_s('Stop slideshow')))->addClass('slideshow-state-started')
]))
->addClass(ZBX_STYLE_BTN_DASHBOARD_TOGGLE_SLIDESHOW)
->addClass(ZBX_STYLE_BTN_ALT)
->addClass(
($data['dashboard']['dashboardid'] !== null && $data['dashboard']['auto_start'] == 1)
? 'slideshow-state-started'
: 'slideshow-state-stopped'
)
])
)
);
}
$dashboard->addItem(
(new CDiv())->addClass(ZBX_STYLE_DASHBOARD_GRID)
);
$html_page
->addItem($dashboard)
->show();
}
else {
$html_page
->addItem(new CTableInfo())
->show();
}
(new CScriptTag('
view.init('.json_encode([
'host' => $data['host'],
'dashboard' => $data['dashboard'],
'widget_defaults' => $data['widget_defaults'],
'configuration_hash' => $data['configuration_hash'],
'time_period' => $data['time_period'],
'web_layout_mode' => $web_layout_mode,
'host_dashboards' => $data['host_dashboards']
]).');
'))
->setOnDocumentReady()
->show();