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
|
<?php declare(strict_types = 0);
/*
** Copyright (C) 2001-2025 Zabbix SIA
**
** This program is free software: you can redistribute it and/or modify it under the terms of
** the GNU Affero General Public License as published by the Free Software Foundation, version 3.
**
** 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 Affero General Public License for more details.
**
** You should have received a copy of the GNU Affero General Public License along with this program.
** If not, see <https://www.gnu.org/licenses/>.
**/
/**
* @var CView $this
*/
?>
<script type="text/x-jquery-tmpl" id="filter-tag-row-tmpl">
<?= CTagFilterFieldHelper::getTemplate(); ?>
</script>
<script>
const view = {
init({checkbox_hash, form_name}) {
this.checkbox_hash = checkbox_hash;
this.form = document.forms[form_name];
$('#filter-tags')
.dynamicRows({template: '#filter-tag-row-tmpl'})
.on('afteradd.dynamicRows', function() {
const rows = this.querySelectorAll('.form_row');
new CTagFilterItem(rows[rows.length - 1]);
});
// Init existing fields once loaded.
document.querySelectorAll('#filter-tags .form_row').forEach(row => new CTagFilterItem(row));
this.form.addEventListener('click', (e) => {
const target = e.target;
if (target.classList.contains('js-edit-host')) {
this.editHost(e, target.dataset.hostid);
}
else if (target.classList.contains('js-edit-template')) {
this.editTemplate(e, target.dataset.hostid);
}
});
},
editHost(e, hostid) {
e.preventDefault();
const host_data = {hostid};
this.openHostPopup(host_data);
},
openHostPopup(host_data) {
const original_url = location.href;
const overlay = PopUp('popup.host.edit', host_data, {
dialogueid: 'host_edit',
dialogue_class: 'modal-popup-large',
prevent_navigation: true
});
overlay.$dialogue[0].addEventListener('dialogue.submit', this.events.elementSuccess, {once: true});
overlay.$dialogue[0].addEventListener('dialogue.close', () => {
history.replaceState({}, '', original_url);
}, {once: true});
},
editTemplate(e, templateid) {
e.preventDefault();
const template_data = {templateid};
this.openTemplatePopup(template_data);
},
openTemplatePopup(template_data) {
const overlay = PopUp('template.edit', template_data, {
dialogueid: 'templates-form',
dialogue_class: 'modal-popup-large',
prevent_navigation: true
});
overlay.$dialogue[0].addEventListener('dialogue.submit', this.events.elementSuccess, {once: true});
},
events: {
elementSuccess(e) {
const data = e.detail;
if ('success' in data) {
postMessageOk(data.success.title);
if ('messages' in data.success) {
postMessageDetails('success', data.success.messages);
}
}
uncheckTableRows('httpconf_'+ view.checkbox_hash, [], false);
location.href = location.href;
}
}
};
</script>
|