加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
color_templates.php 24.19 KB
一键复制 编辑 原始数据 按行查看 历史
TheWitness 提交于 2021-02-22 20:02 . Update copyrights
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719
<?php
/*
+-------------------------------------------------------------------------+
| Copyright (C) 2004-2021 The Cacti Group |
| |
| 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. |
+-------------------------------------------------------------------------+
| Cacti: The Complete RRDtool-based Graphing Solution |
+-------------------------------------------------------------------------+
| This code is designed, written, and maintained by the Cacti Group. See |
| about.php and/or the AUTHORS file for specific developer information. |
+-------------------------------------------------------------------------+
| http://www.cacti.net/ |
+-------------------------------------------------------------------------+
*/
include_once('./include/auth.php');
$aggregate_actions = array(
1 => __('Delete'),
2 => __('Duplicate'),
3 => __('Sync Aggregates')
);
/* set default action */
set_default_action();
switch (get_request_var('action')) {
case 'save':
aggregate_color_form_save();
break;
case 'actions':
aggregate_color_form_actions();
break;
case 'template_edit':
top_header();
aggregate_color_template_edit();
bottom_footer();
break;
default:
top_header();
aggregate_color_template();
bottom_footer();
break;
}
/** draw_color_template_items_list - draws a nicely formatted list of color items for display
* on an edit form
* @param array $item_list - an array representing the list of color items. this array should
* come directly from the output of db_fetch_assoc()
* @param string $filename - the filename to use when referencing any external url
* @param string $url_data - any extra GET url information to pass on when referencing any
* external url
* @param bool $disable_controls - whether to hide all edit/delete functionality on this form
*/
function draw_color_template_items_list($item_list, $filename, $url_data, $disable_controls) {
global $config;
global $struct_color_template_item;
$display_text = array(
array('display' => __('Color Item'), 'align' => 'left', 'nohide' => true),
array('display' => __('Color'), 'align' => 'left', 'nohide' => true),
array('display' => __('Hex'), 'align' => 'left', 'nohide' => true),
);
html_header($display_text, 2);
$i = 1;
$total_items = cacti_sizeof($item_list);
if (cacti_sizeof($item_list)) {
foreach ($item_list as $item) {
/* alternating row color */
form_alternate_row('line' . $item['color_template_item_id'], true, true);
print '<td>';
if ($disable_controls == false) {
print "<a class='linkEditMain' href='" . html_escape($filename . '?action=item_edit&color_template_item_id=' . $item['color_template_item_id'] . "&$url_data") . "'>";
}
print __('Item # %d', $i);
if ($disable_controls == false) {
print '</a>';
}
print "</td>\n";
print "<td style='" . ((isset($item['hex'])) ? "background-color:#" . $item['hex'] . ";'" : "") . "></td>\n";
print "<td>" . $item['hex'] . "</td>\n";
if ($disable_controls == false) {
print "<td class='right nowrap'>";
if (read_config_option('drag_and_drop') == '') {
if ($i < $total_items && $total_items > 1) {
echo '<a class="pic fa fa-caret-down moveArrow" href="' . html_escape('color_templates_items.php?action=item_movedown&color_template_item_id=' . $item['color_template_item_id'] . '&color_template_id=' . $item['color_template_id']) . '" title="' . __esc('Move Down') . '"></a>';
} else {
echo '<span class="moveArrowNone"></span>';
}
if ($i > 1 && $i <= $total_items) {
echo '<a class="pic fa fa-caret-up moveArrow" href="' . html_escape('color_templates_items.php?action=item_moveup&color_template_item_id=' . $item['color_template_item_id'] . '&color_template_id=' . $item['color_template_id']) . '" title="' . __esc('Move Up') . '"></a>';
} else {
echo '<span class="moveArrowNone"></span>';
}
}
print "<a class='delete deleteMarker fa fa-times' id='" . $item['color_template_id'] . '_' . $item['color_template_item_id'] . "' title='" . __esc('Delete') . "'></a>";
print "</td>\n";
}
form_end_row();
$i++;
}
} else {
print "<tr><td colspan='7'><em>" . __('No Items') . "</em></td></tr>";
}
}
/* --------------------------
The Save Function
-------------------------- */
/**
* aggregate_color_form_save the save function
*/
function aggregate_color_form_save() {
if (isset_request_var('save_component_color')) {
if (isset_request_var('color_template_id')) {
$save1['color_template_id'] = get_nfilter_request_var('color_template_id');
} else {
$save1['color_template_id'] = 0;
}
$save1['name'] = form_input_validate(get_nfilter_request_var('name'), 'name', '', false, 3);
cacti_log('Saved ID: ' . $save1['color_template_id'] . ' Name: ' . $save1['name'], false, 'AGGREGATE', POLLER_VERBOSITY_DEBUG);
if (!is_error_message()) {
$color_template_id = sql_save($save1, 'color_templates', 'color_template_id');
cacti_log('Saved ID: ' . $color_template_id, false, 'AGGREGATE', POLLER_VERBOSITY_DEBUG);
if ($color_template_id) {
raise_message(1);
} else {
raise_message(2);
}
}
}
header('Location: color_templates.php?action=template_edit&color_template_id=' . (empty($color_template_id) ? get_nfilter_request_var('color_template_id') : $color_template_id));
}
/* ------------------------
The 'actions' function
------------------------ */
/**
* aggregate_color_form_actions the action function
*/
function aggregate_color_form_actions() {
global $aggregate_actions, $config;
include_once($config['base_path'] . '/lib/api_aggregate.php');
/* ================= input validation ================= */
get_filter_request_var('drp_action');
/* ==================================================== */
/* if we are to save this form, instead of display it */
if (isset_request_var('selected_items')) {
$selected_items = sanitize_unserialize_selected_items(get_nfilter_request_var('selected_items'));
if ($selected_items != false) {
if (get_request_var('drp_action') == '1') { /* delete */
db_execute('DELETE FROM color_templates WHERE ' . array_to_sql_or($selected_items, 'color_template_id'));
db_execute('DELETE FROM color_template_items WHERE ' . array_to_sql_or($selected_items, 'color_template_id'));
} elseif (get_nfilter_request_var('drp_action') == '2') { // duplicate
for ($i=0;($i<cacti_count($selected_items));$i++) {
duplicate_color_template($selected_items[$i], get_nfilter_request_var('title_format'));
}
} elseif (get_nfilter_request_var('drp_action') == '3') { // sync templates
for ($i=0;($i<cacti_count($selected_items));$i++) {
sync_color_templates($selected_items[$i]);
}
}
}
header('Location: color_templates.php');
exit;
}
/* setup some variables */
$color_list = ''; $i = 0;
/* loop through each of the color templates selected on the previous page and get more info about them */
foreach ($_POST as $var => $val) {
if (preg_match('/^chk_([0-9]+)$/', $var, $matches)) {
/* ================= input validation ================= */
input_validate_input_number($matches[1]);
/* ==================================================== */
$name = db_fetch_cell_prepared('SELECT name
FROM color_templates
WHERE color_template_id = ?',
array($matches[1]));
$color_list .= '<li>' . html_escape($name) . '</li>';
$color_array[] = $matches[1];
}
}
top_header();
form_start('color_templates.php');
html_start_box($aggregate_actions[get_nfilter_request_var('drp_action')], '60%', '', '3', 'center', '');
if (isset($color_array) && cacti_sizeof($color_array)) {
if (get_request_var('drp_action') == '1') { /* delete */
print "<tr>
<td class='textArea'>
<p>" . __n('Click \'Continue\' to delete the following Color Template', 'Click \'Continue\' to delete following Color Templates', cacti_sizeof($color_array)) . "</p>
<div class='itemlist'><ul>$color_list</ul></div>
</td>
</tr>";
$save_html = "<input type='button' class='ui-button ui-corner-all ui-widget' value='" . __esc('Cancel') . "' onClick='cactiReturnTo()'>&nbsp;<input type='submit' class='ui-button ui-corner-all ui-widget' value='" . __esc('Continue') . "' title='" . __n('Delete Color Template', 'Delete Color Templates', cacti_sizeof($color_array)) . "'>";
} elseif (get_request_var('drp_action') == '2') { // duplicate
print "<tr>
<td class='textArea'>
<p>" . __n('Click \'Continue\' to duplicate the following Color Template. You can optionally change the title format for the new color template.', 'Click \'Continue\' to duplicate following Color Templates. You can optionally change the title format for the new color templates.', cacti_sizeof($color_array)) . "</p>
<div class='itemlist'><ul>$color_list</ul></div>
<p>" . __('Title Format:') . '<br>';
form_text_box('title_format', '<template_title> (1)', '', '255', '30', 'text');
print "</p>
</td>
</tr>";
$save_html = "<input type='button' class='ui-button ui-corner-all ui-widget' value='" . __esc('Cancel') . "' onClick='cactiReturnTo()'>&nbsp;<input type='submit' class='ui-button ui-corner-all ui-widget' value='" . __esc('Continue') . "' title='" . __n('Duplicate Color Template', 'Duplicate Color Templates', cacti_sizeof($color_array)) . "'>";
} elseif (get_request_var('drp_action') == '3') { // sync
print "<tr>
<td class='textArea'>
<p>" . __n('Click \'Continue\' to Synchronize all Aggregate Graphs with the selected Color Template.', 'Click \'Continue\' to Syncrhonize all Aggregate Graphs with the selected Color Templates.', cacti_sizeof($color_array)) . "</p>
<div class='itemlist'><ul>$color_list</ul></div></p>
</td>
</tr>";
$save_html = "<input type='button' class='ui-button ui-corner-all ui-widget' value='" . __esc('Cancel') . "' onClick='cactiReturnTo()'>&nbsp;<input type='submit' class='ui-button ui-corner-all ui-widget' value='" . __esc('Continue') . "' title='" . __n('Synchronize Color Template', 'Synchronize Color Templates', cacti_sizeof($color_array)) . "'>";
}
} else {
raise_message(40);
header('Location: color_templates.php');
exit;
}
print "<tr>
<td class='saveRow'>
<input type='hidden' name='action' value='actions'>
<input type='hidden' name='selected_items' value='" . (isset($color_array) ? serialize($color_array) : '') . "'>
<input type='hidden' name='drp_action' value='" . get_request_var('drp_action') . "'>
$save_html
</td>
</tr>\n";
html_end_box();
form_end();
bottom_footer();
}
/**
* aggregate_color_item show all color template items
*/
function aggregate_color_item() {
global $config;
/* ================= input validation ================= */
get_filter_request_var('color_template_id');
/* ==================================================== */
if (isempty_request_var('color_template_id')) {
$template_item_list = array();
$header_label = __('Color Template Items [new]');
} else {
$template_item_list = db_fetch_assoc_prepared('SELECT
cti.color_template_id, cti.color_template_item_id, cti.sequence, colors.hex
FROM color_template_items AS cti
LEFT JOIN colors
ON cti.color_id=colors.id
WHERE cti.color_template_id = ?
ORDER BY cti.sequence ASC',
array(get_request_var('color_template_id')));
$name = db_fetch_cell_prepared('SELECT name
FROM color_templates
WHERE color_template_id = ?',
array(get_request_var('color_template_id')));
$header_label = __esc('Color Template Items [edit: %s]', $name);
}
html_start_box($header_label, '100%', '', '3', 'center', 'color_templates_items.php?action=item_edit&color_template_id=' . html_escape_request_var('color_template_id'));
draw_color_template_items_list($template_item_list, 'color_templates_items.php', 'color_template_id=' . html_escape_request_var('color_template_id'), false);
html_end_box();
?>
<script type='text/javascript'>
$(function() {
$('#color_templates_template_edit2_child').attr('id', 'color_item');
$('.cdialog').remove();
$('#main').append("<div class='cdialog' id='cdialog'></div>");
<?php if (read_config_option('drag_and_drop') == 'on') { ?>
$('#color_item').tableDnD({
onDrop: function(table, row) {
loadUrl({
url:'color_templates_items.php?action=ajax_dnd&id=<?php isset_request_var('color_template_id') ? print get_request_var('color_template_id') : print 0;?>&'+$.tableDnD.serialize()
})
}
});
<?php } ?>
$('.delete').click(function(event) {
event.preventDefault();
id = $(this).attr('id').split('_');
request = 'color_templates_items.php?action=item_remove_confirm&id='+id[0]+'&color_id='+id[1];
$.get(request)
.done(function(data) {
$('#cdialog').html(data);
applySkin();
$('#cdialog').dialog({
title: '<?php print __('Delete Color Item');?>',
close: function () { $('.delete').blur(); $('.selectable').removeClass('selected'); },
minHeight: 80,
minWidth: 500
});
})
.fail(function(data) {
getPresentHTTPError(data);
});
}).css('cursor', 'pointer');
});
</script>
<?php
}
/* ----------------------------
template - Color Templates
---------------------------- */
/**
* aggregate_color_template_edit edit the color template
*/
function aggregate_color_template_edit() {
global $config, $image_types, $fields_color_template_template_edit, $struct_aggregate;
include_once($config['base_path'] . '/lib/api_aggregate.php');
/* ================= input validation ================= */
get_filter_request_var('color_template_id');
/* ==================================================== */
if (!isempty_request_var('color_template_id')) {
$template = db_fetch_row_prepared('SELECT * FROM color_templates WHERE color_template_id = ?', array(get_request_var('color_template_id')));
$header_label = __esc('Color Template [edit: %s]', $template['name']);
} else {
$header_label = __('Color Template [new]');
}
form_start('color_templates.php', 'color_template_edit');
html_start_box($header_label, '100%', true, '3', 'center', '');
draw_edit_form(
array(
'config' => array('no_form_tag' => true),
'fields' => inject_form_variables($fields_color_template_template_edit, (isset($template) ? $template : array()))
)
);
html_end_box(true, true);
form_hidden_box('color_template_id', (isset($template['color_template_id']) ? $template['color_template_id'] : '0'), '');
form_hidden_box('save_component_color', '1', '');
/* color item list goes here */
if (!isempty_request_var('color_template_id')) {
aggregate_color_item();
}
form_save_button('color_templates.php', 'return', 'color_template_id');
}
function sync_color_templates($color_template) {
global $config;
include_once($config['base_path'] . '/lib/api_aggregate.php');
$name = db_fetch_cell_prepared('SELECT name
FROM color_templates
WHERE color_template_id = ?',
array($color_template));
$aggregate_templates = array_rekey(
db_fetch_assoc_prepared('SELECT DISTINCT aggregate_template_id
FROM aggregate_graph_templates_item
WHERE color_template = ?',
array($color_template)),
'aggregate_template_id', 'aggregate_template_id'
);
$found = false;
$templates = 0;
$graphs = 0;
if (cacti_sizeof($aggregate_templates)) {
$found = true;
$templates = cacti_sizeof($aggregate_templates);
foreach($aggregate_templates as $id) {
push_out_aggregates($id);
}
}
$aggregate_graphs = db_fetch_assoc_prepared('SELECT DISTINCT ag.aggregate_template_id, ag.local_graph_id
FROM aggregate_graphs_graph_item AS agi
LEFT JOIN aggregate_graphs AS ag
ON ag.id=agi.aggregate_graph_id
WHERE (ag.aggregate_template_id > 0 AND ag.template_propogation = "")
OR ag.aggregate_template_id = 0
AND agi.color_template = ?',
array($color_template));
if (cacti_sizeof($aggregate_graphs)) {
$found = true;
$graphs = cacti_sizeof($aggregate_graphs);
foreach($aggregate_templates as $id) {
push_out_aggregates($id['aggregate_template_id'], $id['local_graph_id']);
}
}
if ($found) {
raise_message('color_template_sync', __('Color Template \'%s\' had %d Aggregate Templates pushed out and %d Non-Templated Aggregates pushed out', $name, $templates, $graphs), MESSAGE_LEVEL_INFO);
} else {
raise_message('color_template_sync', __('Color Template \'%s\' had no Aggregate Templates or Graphs using this Color Template.', $name, $templates, $graphs), MESSAGE_LEVEL_INFO);
}
}
/**
* aggregate_color_template maintain color templates
*/
function aggregate_color_template() {
global $aggregate_actions, $item_rows, $config;
include_once($config['base_path'] . '/lib/api_aggregate.php');
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_DEFAULT,
'pageset' => true,
'default' => ''
),
'sort_column' => array(
'filter' => FILTER_CALLBACK,
'default' => 'name',
'options' => array('options' => 'sanitize_search_string')
),
'sort_direction' => array(
'filter' => FILTER_CALLBACK,
'default' => 'ASC',
'options' => array('options' => 'sanitize_search_string')
),
'has_graphs' => array(
'filter' => FILTER_VALIDATE_REGEXP,
'options' => array('options' => array('regexp' => '(true|false)')),
'pageset' => true,
'default' => read_config_option('default_has') == 'on' ? 'true':'false'
)
);
validate_store_request_vars($filters, 'sess_ct');
/* ================= input validation ================= */
if (get_request_var('rows') == -1) {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
form_start('color_templates.php', 'form_template');
html_start_box(__('Color Templates'), '100%', '', '3', 'center', 'color_templates.php?action=template_edit');
$filter_html = '<tr class="even">
<td>
<table class="filterTable">
<tr>
<td>
' . __('Search') . '
</td>
<td>
<input type="text" class="ui-state-default ui-corner-all" id="filter" size="25" value="' . html_escape_request_var('filter') . '">
</td>
<td>
' . __('Color Templates') . '
</td>
<td>
<select id="rows" onChange="applyFilter()">
<option value="-1" ';
if (get_request_var('rows') == '-1') {
$filter_html .= 'selected';
}
$filter_html .= '>' . __('Default') . '</option>';
if (cacti_sizeof($item_rows)) {
foreach ($item_rows as $key => $value) {
$filter_html .= "<option value='" . $key . "'";
if (get_request_var('rows') == $key) {
$filter_html .= ' selected';
}
$filter_html .= '>' . $value . "</option>\n";
}
}
$filter_html .= ' </select>
</td>
<td>
<span>
<input type="checkbox" id="has_graphs" ' . (get_request_var('has_graphs') == 'true' ? 'checked':'') . ' onChange="applyFilter()">
<label for="has_graphs">' . __('Has Graphs') . '</label>
</span>
</td>
<td>
<span>
<input type="button" class="ui-button ui-corner-all ui-widget" id="refresh" value="' . __esc('Go') . '">
<input type="button" class="ui-button ui-corner-all ui-widget" id="clear" value="' . __esc('Clear') . '">
</span>
</td>
</tr>
</table>
</td>
</tr>';
print $filter_html;
html_end_box();
form_end();
/* form the 'where' clause for our main sql query */
$sql_where = '';
if (get_request_var('filter') != '') {
$sql_where = 'WHERE (ct.name LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . ')';
}
if (get_request_var('has_graphs') == 'true') {
$sql_where .= ($sql_where != '' ? ' AND ' : 'WHERE ') . ' (templates>0 OR graphs>0)';
}
$total_rows = db_fetch_cell("SELECT
COUNT(ct.color_template_id)
FROM color_templates AS ct
LEFT JOIN (
SELECT color_template, COUNT(*) AS templates
FROM aggregate_graph_templates_item
GROUP BY color_template
) AS templates
ON ct.color_template_id=templates.color_template
LEFT JOIN (
SELECT color_template, COUNT(*) AS graphs
FROM aggregate_graphs_graph_item
GROUP BY color_template
) AS graphs
ON ct.color_template_id=graphs.color_template
$sql_where");
$sql_order = get_order_string();
$sql_limit = ' LIMIT ' . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$template_list = db_fetch_assoc("SELECT
ct.color_template_id, ct.name, templates.templates, graphs.graphs
FROM color_templates AS ct
LEFT JOIN (
SELECT color_template, COUNT(*) AS templates
FROM aggregate_graph_templates_item
GROUP BY color_template
) AS templates
ON ct.color_template_id=templates.color_template
LEFT JOIN (
SELECT color_template, COUNT(*) AS graphs
FROM aggregate_graphs_graph_item
GROUP BY color_template
) AS graphs
ON ct.color_template_id=graphs.color_template
$sql_where
$sql_order
$sql_limit");
$nav = html_nav_bar('color_templates.php', MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 5, __('Color Templates'), 'page', 'main');
form_start('color_templates.php', 'chk');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
$display_text = array(
'name' => array(__('Template Title'), 'ASC'),
'nosort' => array('display' => __('Deletable'), 'align' => 'right', 'tip' => __('Color Templates that are in use cannot be Deleted. In use is defined as being referenced by an Aggregate Template.')),
'graphs' => array('display' => __('Graphs'), 'align' => 'right', 'sort' => 'DESC'),
'templates' => array('display' => __('Templates'), 'align' => 'right', 'sort' => 'DESC')
);
html_header_sort_checkbox($display_text, get_request_var('sort_column'), get_request_var('sort_direction'), false);
if (cacti_sizeof($template_list)) {
foreach ($template_list as $template) {
if ($template['templates'] > 0) {
$disabled = true;
} else {
$disabled = false;
}
form_alternate_row('line' . $template['color_template_id'], true);
form_selectable_cell(filter_value($template['name'], get_request_var('filter'), 'color_templates.php?action=template_edit&color_template_id=' . $template['color_template_id'] . '&page=1'), $template['color_template_id']);
form_selectable_cell($disabled ? __('No'):__('Yes'), $template['color_template_id'], '', 'right');
form_selectable_cell(number_format_i18n($template['graphs']), $template['color_template_id'], '', 'right');
form_selectable_cell(number_format_i18n($template['templates']), $template['color_template_id'], '', 'right');
form_checkbox_cell($template['name'], $template['color_template_id'], $disabled);
form_end_row();
}
} else {
print "<tr class='tableRow'><td colspan='" . (cacti_sizeof($display_text)+1) . "'><em>" . __('No Color Templates Found') ."</em></td></tr>\n";
}
html_end_box(false);
if (cacti_sizeof($template_list)) {
print $nav;
}
/* draw the dropdown containing a list of available actions for this form */
draw_actions_dropdown($aggregate_actions);
form_end();
?>
<script type='text/javascript'>
function applyFilter() {
strURL = 'color_templates.php';
strURL += '?rows=' + $('#rows').val();
strURL += '&filter=' + $('#filter').val();
strURL += '&has_graphs=' + $('#has_graphs').is(':checked');
loadUrl({url:strURL})
}
function clearFilter() {
strURL = 'color_templates.php?clear=1';
loadUrl({url:strURL})
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#filter').change(function() {
applyFilter();
});
$('#form_template').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
<?php
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化