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
|
<?php
/*
** Zabbix
** Copyright (C) 2001-2016 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.
**/
$widget = (new CWidget())
->setTitle(_('Regular expressions'))
->setControls((new CForm())
->cleanItems()
->addItem((new CList())
->addItem(makeAdministrationGeneralMenu('adm.regexps.php'))
->addItem(new CSubmit('form', _('New regular expression')))
)
);
$form = (new CForm())->setName('regularExpressionsForm');
$regExpTable = (new CTableInfo())
->setHeader([
(new CColHeader(
(new CCheckBox('all_regexps'))->onClick("checkAll('".$form->getName()."', 'all_regexps', 'regexpids');")
))->addClass(ZBX_STYLE_CELL_WIDTH),
_('Name'),
_('Expressions')
]);
$expressions = [];
$values = [];
foreach($data['db_exps'] as $exp) {
if (!isset($expressions[$exp['regexpid']])) {
$values[$exp['regexpid']] = 1;
}
else {
$values[$exp['regexpid']]++;
}
if (!isset($expressions[$exp['regexpid']])) {
$expressions[$exp['regexpid']] = new CTable();
}
$expressions[$exp['regexpid']]->addRow([
new CCol($values[$exp['regexpid']]),
new CCol(' » '),
new CCol($exp['expression']),
new CCol(' ['.expression_type2str($exp['expression_type']).']')
]);
}
foreach($data['regexps'] as $regexpid => $regexp) {
$regExpTable->addRow([
new CCheckBox('regexpids['.$regexp['regexpid'].']', $regexp['regexpid']),
new CLink($regexp['name'], 'adm.regexps.php?form=update'.'®expid='.$regexp['regexpid']),
isset($expressions[$regexpid]) ? $expressions[$regexpid] : ''
]);
}
// append table to form
$form->addItem([
$regExpTable,
new CActionButtonList('action', 'regexpids', [
'regexp.massdelete' => ['name' => _('Delete'), 'confirm' => _('Delete selected regular expressions?')]
])
]);
// append form to widget
$widget->addItem($form);
return $widget;
|