1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
|
<?php
/*
** Zabbix
** Copyright (C) 2001-2021 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
*/
$widget = (new CWidget())
->setTitle(_('Maintenance periods'))
->setControls(
(new CTag('nav', true, new CRedirectButton(_('Create maintenance period'), (new CUrl('maintenance.php'))
->removeArgument('maintenanceid')
->setArgument('form', 'create')
->getUrl()
)))->setAttribute('aria-label', _('Content controls'))
)
->addItem((new CFilter(new CUrl('maintenance.php')))
->setProfile($data['profileIdx'])
->setActiveTab($data['active_tab'])
->addFilterTab(_('Filter'), [
(new CFormList())
->addRow(
(new CLabel(_('Host groups'), 'filter_groups__ms')),
(new CMultiSelect([
'name' => 'filter_groups[]',
'object_name' => 'hostGroup',
'data' => $data['filter']['groups'],
'popup' => [
'parameters' => [
'srctbl' => 'host_groups',
'srcfld1' => 'groupid',
'dstfrm' => 'zbx_filter',
'dstfld1' => 'filter_groups_',
'editable' => 1
]
]
]))->setWidth(ZBX_TEXTAREA_MEDIUM_WIDTH)
)
->addRow(_('Name'),
(new CTextBox('filter_name', $data['filter']['name']))->setWidth(ZBX_TEXTAREA_MEDIUM_WIDTH)
),
(new CFormList())->addRow(_('State'),
(new CRadioButtonList('filter_status', (int) $data['filter']['status']))
->addValue(_('Any'), -1)
->addValue(_x('Active', 'maintenance status'), MAINTENANCE_STATUS_ACTIVE)
->addValue(_x('Approaching', 'maintenance status'), MAINTENANCE_STATUS_APPROACH)
->addValue(_x('Expired', 'maintenance status'), MAINTENANCE_STATUS_EXPIRED)
->setModern(true)
)
])
);
// create form
$maintenanceForm = (new CForm())->setName('maintenanceForm');
// create table
$url = (new CUrl('maintenance.php'))->getUrl();
$maintenanceTable = (new CTableInfo())
->setHeader([
(new CColHeader(
(new CCheckBox('all_maintenances'))->onClick("checkAll('".$maintenanceForm->getName()."', 'all_maintenances', 'maintenanceids');")
))->addClass(ZBX_STYLE_CELL_WIDTH),
make_sorting_header(_('Name'), 'name', $this->data['sort'], $this->data['sortorder'], $url),
make_sorting_header(_('Type'), 'maintenance_type', $this->data['sort'], $this->data['sortorder'], $url),
make_sorting_header(_('Active since'), 'active_since', $this->data['sort'], $this->data['sortorder'], $url),
make_sorting_header(_('Active till'), 'active_till', $this->data['sort'], $this->data['sortorder'], $url),
_('State'),
_('Description')
]);
foreach ($this->data['maintenances'] as $maintenance) {
$maintenanceid = $maintenance['maintenanceid'];
switch ($maintenance['status']) {
case MAINTENANCE_STATUS_EXPIRED:
$maintenanceStatus = (new CSpan(_x('Expired', 'maintenance status')))->addClass(ZBX_STYLE_RED);
break;
case MAINTENANCE_STATUS_APPROACH:
$maintenanceStatus = (new CSpan(_x('Approaching', 'maintenance status')))->addClass(ZBX_STYLE_ORANGE);
break;
case MAINTENANCE_STATUS_ACTIVE:
$maintenanceStatus = (new CSpan(_x('Active', 'maintenance status')))->addClass(ZBX_STYLE_GREEN);
break;
}
$maintenanceTable->addRow([
new CCheckBox('maintenanceids['.$maintenanceid.']', $maintenanceid),
new CLink($maintenance['name'], 'maintenance.php?form=update&maintenanceid='.$maintenanceid),
$maintenance['maintenance_type'] ? _('No data collection') : _('With data collection'),
zbx_date2str(DATE_TIME_FORMAT, $maintenance['active_since']),
zbx_date2str(DATE_TIME_FORMAT, $maintenance['active_till']),
$maintenanceStatus,
$maintenance['description']
]);
}
// append table to form
$maintenanceForm->addItem([
$maintenanceTable,
$this->data['paging'],
new CActionButtonList('action', 'maintenanceids', [
'maintenance.massdelete' => ['name' => _('Delete'), 'confirm' => _('Delete selected maintenance periods?')]
])
]);
// append form to widget
$widget->addItem($maintenanceForm);
$widget->show();
|