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.
185 lines
6.1 KiB
185 lines
6.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.
|
||
|
**/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Class CActionButtonList
|
||
|
*
|
||
|
* Implements wrapper to handle output of mass action buttons as used in list views.
|
||
|
*/
|
||
|
class CActionButtonList extends CObject {
|
||
|
|
||
|
/**
|
||
|
* CSubmit instances.
|
||
|
*
|
||
|
* @var CSubmit[]
|
||
|
*/
|
||
|
protected $buttons;
|
||
|
|
||
|
/**
|
||
|
* Name of parameter which will hold values of checked checkboxes.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $checkboxes_name;
|
||
|
|
||
|
/**
|
||
|
* Prefix for sessionStorage used for remembering which checkboxes have been checked when navigating between pages.
|
||
|
*
|
||
|
* @var string|null
|
||
|
*/
|
||
|
protected $name_prefix = null;
|
||
|
|
||
|
/**
|
||
|
* Element that is used to show number of selected checkboxes.
|
||
|
*
|
||
|
* @var CObject
|
||
|
*/
|
||
|
protected $selected_count_element = null;
|
||
|
|
||
|
/**
|
||
|
* @param string $action_name Name of submit buttons.
|
||
|
* @param string $checkboxes_name Name of parameter into which checked checkboxes will be put in.
|
||
|
* @param array $buttons_data Buttons data array.
|
||
|
* @param string|null $name_prefix Prefix for sessionStorage used for storing currently selected
|
||
|
* checkboxes.
|
||
|
*
|
||
|
* $buttons_data = [[
|
||
|
* 'name' => (string) Button caption.
|
||
|
* 'confirm_singular' => (string) Confirmation text in the singular (optional). If this is provided,
|
||
|
* 'confirm_plural' also must be provided.
|
||
|
* 'confirm_plural' => (string) Confirmation text in the plural (optional). If this is provided,
|
||
|
* 'confirm_singular' also must be provided.
|
||
|
* 'redirect' => (string) Redirect URL (optional).
|
||
|
* 'csrf_token' => (string) CSRF token (optional).
|
||
|
* 'disabled' => (bool) Set button state disabled (optional).
|
||
|
* 'attributes' => (array) Set additional HTML attributes where array key is attribute name array
|
||
|
* value is the attribute value.
|
||
|
* 'content' => (CTag) A HTML tag. For example a CButton wrapped in CList object.
|
||
|
* ]]
|
||
|
*/
|
||
|
function __construct($action_name, $checkboxes_name, array $buttons_data, $name_prefix = null) {
|
||
|
$this->checkboxes_name = $checkboxes_name;
|
||
|
$this->name_prefix = $name_prefix;
|
||
|
|
||
|
foreach ($buttons_data as $action => $button_data) {
|
||
|
if (array_key_exists('content', $button_data)) {
|
||
|
$button = $button_data['content'];
|
||
|
}
|
||
|
else {
|
||
|
$button = (new CSubmit($action_name, $button_data['name']))
|
||
|
->addClass(ZBX_STYLE_BTN_ALT)
|
||
|
->removeAttribute('id');
|
||
|
|
||
|
if (array_key_exists('attributes', $button_data) && is_array($button_data['attributes'])
|
||
|
&& $button_data['attributes']) {
|
||
|
foreach ($button_data['attributes'] as $attr_name => $attr_value) {
|
||
|
$button->setAttribute($attr_name, $attr_value);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (array_key_exists('redirect', $button_data)) {
|
||
|
$on_click_action = 'const form = this.closest("form");' .
|
||
|
/*
|
||
|
* Save the original form action
|
||
|
* Function getAttribute()/setAttribute() is used instead of .action, because there are many
|
||
|
* buttons with name 'action' and .action selects these buttons.
|
||
|
*/
|
||
|
'if (!form.dataset.action) {
|
||
|
form.dataset.action = form.getAttribute("action");
|
||
|
}
|
||
|
form.setAttribute("action", this.dataset.redirect);';
|
||
|
|
||
|
$button
|
||
|
// Removing parameters not to conflict with the redirecting URL.
|
||
|
->removeAttribute('name')
|
||
|
->removeAttribute('value')
|
||
|
->setAttribute('data-redirect', $button_data['redirect']);
|
||
|
}
|
||
|
else {
|
||
|
$on_click_action = 'const form = this.closest("form");'.
|
||
|
// Restore the original form action, if previously saved.
|
||
|
'if (form.dataset.action) {
|
||
|
form.setAttribute("action", form.dataset.action);
|
||
|
}';
|
||
|
|
||
|
$button
|
||
|
->setAttribute('value', $action);
|
||
|
}
|
||
|
|
||
|
if (array_key_exists('csrf_token', $button_data)) {
|
||
|
$on_click_action .= 'create_var(form,"'.CCsrfTokenHelper::CSRF_TOKEN_NAME.'", "'.
|
||
|
$button_data['csrf_token'].'", false);';
|
||
|
}
|
||
|
|
||
|
$button->onClick($on_click_action);
|
||
|
|
||
|
if (array_key_exists('disabled', $button_data)) {
|
||
|
$button
|
||
|
->setEnabled(!$button_data['disabled'])
|
||
|
->setAttribute('data-disabled', $button_data['disabled']);
|
||
|
}
|
||
|
|
||
|
if (array_key_exists('confirm_singular', $button_data)
|
||
|
&& array_key_exists('confirm_plural', $button_data)) {
|
||
|
$button->setAttribute('confirm_singular', $button_data['confirm_singular']);
|
||
|
$button->setAttribute('confirm_plural', $button_data['confirm_plural']);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$this->buttons[$action] = $button;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns current element for showing how many checkboxes are selected. If currently no
|
||
|
* element exists, constructs and returns default one.
|
||
|
*
|
||
|
* @return CObject
|
||
|
*/
|
||
|
public function getSelectedCountElement() {
|
||
|
if (!$this->selected_count_element) {
|
||
|
$this->selected_count_element = (new CSpan('0 '._('selected')))
|
||
|
->setId('selected_count')
|
||
|
->addClass(ZBX_STYLE_SELECTED_ITEM_COUNT);
|
||
|
}
|
||
|
|
||
|
return $this->selected_count_element;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets string representation of action button list.
|
||
|
*
|
||
|
* @param bool $destroy
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function toString($destroy = true) {
|
||
|
zbx_add_post_js('chkbxRange.pageGoName = '.json_encode($this->checkboxes_name).';');
|
||
|
zbx_add_post_js('chkbxRange.prefix = '.json_encode($this->name_prefix).';');
|
||
|
|
||
|
$this->items[] = (new CDiv([$this->getSelectedCountElement(), $this->buttons]))
|
||
|
->setId('action_buttons')
|
||
|
->addClass(ZBX_STYLE_ACTION_BUTTONS);
|
||
|
|
||
|
return parent::toString($destroy);
|
||
|
}
|
||
|
}
|