2009-10-17 17:19:16 +02:00
|
|
|
<?php
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2009-10-17 17:19:16 +02:00
|
|
|
// Please see http://pandorafms.org for full contribution list
|
|
|
|
// 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 for version 2.
|
|
|
|
// 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.
|
|
|
|
// Load global variables
|
2010-03-03 18:10:37 +01:00
|
|
|
global $config;
|
2009-10-17 17:19:16 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
require_once 'include/functions_custom_graphs.php';
|
2009-10-17 17:19:16 +02:00
|
|
|
|
|
|
|
// Check user credentials
|
2019-01-30 16:18:44 +01:00
|
|
|
check_login();
|
2009-10-17 17:19:16 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$report_r = check_acl($config['id_user'], 0, 'RR');
|
|
|
|
$report_w = check_acl($config['id_user'], 0, 'RW');
|
|
|
|
$report_m = check_acl($config['id_user'], 0, 'RM');
|
2018-03-02 13:13:55 +01:00
|
|
|
|
2016-09-08 16:06:12 +02:00
|
|
|
if (!$report_r && !$report_w && !$report_m) {
|
2019-01-30 16:18:44 +01:00
|
|
|
db_pandora_audit(
|
|
|
|
'ACL Violation',
|
|
|
|
'Trying to access Inventory Module Management'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
2009-10-17 17:19:16 +02:00
|
|
|
}
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
|
|
|
|
|
2018-03-02 13:13:55 +01:00
|
|
|
$access = ($report_r == true) ? 'RR' : (($report_w == true) ? 'RW' : (($report_m == true) ? 'RM' : 'RR'));
|
|
|
|
|
2012-02-24 14:29:22 +01:00
|
|
|
$activeTab = get_parameter('tab', 'main');
|
|
|
|
|
|
|
|
$enterpriseEnable = false;
|
|
|
|
if (enterprise_include_once('include/functions_reporting.php') !== ENTERPRISE_NOT_HOOK) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$enterpriseEnable = true;
|
2012-02-24 14:29:22 +01:00
|
|
|
}
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$buttons['graph_list'] = [
|
|
|
|
'active' => true,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="index.php?sec=reporting&sec2=godmode/reporting/graphs">'.html_print_image(
|
|
|
|
'images/list.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Graph list'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-01-30 16:18:44 +01:00
|
|
|
];
|
2013-04-25 Miguel de Dios <miguel.dedios@artica.es>
* godmode/events/custom_events.php,
godmode/massive/massive_enable_disable_alerts.php,
godmode/massive/massive_edit_agents.php,
godmode/massive/massive_delete_modules.php,
godmode/massive/massive_add_action_alerts.php,
godmode/massive/massive_delete_profiles.php,
godmode/massive/massive_delete_alerts.php,
godmode/groups/modu_group_list.php, godmode/groups/group_list.php,
godmode/reporting/graph_builder.php, godmode/reporting/graphs.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php, include/functions_ui.php,
include/functions_graph.php: improved the source code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@8057 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-04-25 12:16:41 +02:00
|
|
|
|
2015-06-08 11:05:19 +02:00
|
|
|
if ($enterpriseEnable) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$buttons = reporting_enterprise_add_template_graph_tabs($buttons);
|
2012-02-24 14:29:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$subsection = '';
|
2013-04-25 Miguel de Dios <miguel.dedios@artica.es>
* godmode/events/custom_events.php,
godmode/massive/massive_enable_disable_alerts.php,
godmode/massive/massive_edit_agents.php,
godmode/massive/massive_delete_modules.php,
godmode/massive/massive_add_action_alerts.php,
godmode/massive/massive_delete_profiles.php,
godmode/massive/massive_delete_alerts.php,
godmode/groups/modu_group_list.php, godmode/groups/group_list.php,
godmode/reporting/graph_builder.php, godmode/reporting/graphs.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php, include/functions_ui.php,
include/functions_graph.php: improved the source code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@8057 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-04-25 12:16:41 +02:00
|
|
|
switch ($activeTab) {
|
2019-01-30 16:18:44 +01:00
|
|
|
case 'main':
|
|
|
|
$buttons['graph_list']['active'] = true;
|
|
|
|
$subsection = ' » '.__('Graph list');
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$subsection = reporting_enterprise_add_graph_template_subsection($activeTab, $buttons);
|
|
|
|
break;
|
2013-04-25 Miguel de Dios <miguel.dedios@artica.es>
* godmode/events/custom_events.php,
godmode/massive/massive_enable_disable_alerts.php,
godmode/massive/massive_edit_agents.php,
godmode/massive/massive_delete_modules.php,
godmode/massive/massive_add_action_alerts.php,
godmode/massive/massive_delete_profiles.php,
godmode/massive/massive_delete_alerts.php,
godmode/groups/modu_group_list.php, godmode/groups/group_list.php,
godmode/reporting/graph_builder.php, godmode/reporting/graphs.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php, include/functions_ui.php,
include/functions_graph.php: improved the source code.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@8057 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2013-04-25 12:16:41 +02:00
|
|
|
}
|
2012-02-23 16:55:51 +01:00
|
|
|
|
2012-02-24 14:29:22 +01:00
|
|
|
switch ($activeTab) {
|
2019-01-30 16:18:44 +01:00
|
|
|
case 'main':
|
|
|
|
include_once 'godmode/reporting/graphs.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
reporting_enterprise_select_graph_template_tab($activeTab);
|
|
|
|
break;
|
2012-02-24 14:29:22 +01:00
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-10-07 12:44:00 +02:00
|
|
|
if ($enterpriseEnable) {
|
|
|
|
$buttons['graph_container'] = [
|
|
|
|
'active' => false,
|
2021-03-11 15:40:23 +01:00
|
|
|
'text' => '<a href="index.php?sec=reporting&sec2=godmode/reporting/graph_container">'.html_print_image(
|
|
|
|
'images/graph-container.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Graphs containers'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>',
|
2019-10-07 12:44:00 +02:00
|
|
|
];
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
$delete_graph = (bool) get_parameter('delete_graph');
|
|
|
|
$view_graph = (bool) get_parameter('view_graph');
|
|
|
|
$id = (int) get_parameter('id');
|
|
|
|
$multiple_delete = (bool) get_parameter('multiple_delete', 0);
|
2009-10-17 17:19:16 +02:00
|
|
|
|
2010-03-04 17:08:09 +01:00
|
|
|
// Header
|
2019-01-30 16:18:44 +01:00
|
|
|
ui_print_page_header(__('Reporting').' » '.__('Custom graphs'), 'images/chart.png', false, '', false, $buttons);
|
2010-03-04 17:08:09 +01:00
|
|
|
|
2009-10-17 17:19:16 +02:00
|
|
|
// Delete module SQL code
|
|
|
|
if ($delete_graph) {
|
2020-10-22 12:00:44 +02:00
|
|
|
$graph_group = db_get_value('id_group', 'tgraph', 'id_graph', $id);
|
|
|
|
|
|
|
|
if (check_acl_restricted_all($config['id_user'], $graph_group, 'RW')
|
|
|
|
|| check_acl_restricted_all($config['id_user'], $graph_group, 'RM')
|
|
|
|
) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$exist = db_get_value('id_graph', 'tgraph_source', 'id_graph', $id);
|
|
|
|
if ($exist) {
|
|
|
|
$result = db_process_sql_delete('tgraph_source', ['id_graph' => $id]);
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
$result = ui_print_success_message(__('Successfully deleted'));
|
|
|
|
} else {
|
|
|
|
$result = ui_print_error_message(__('Not deleted. Error deleting data'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$result = db_process_sql_delete('tgraph', ['id_graph' => $id]);
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
db_pandora_audit('Report management', "Delete graph #$id");
|
|
|
|
$result = ui_print_success_message(__('Successfully deleted'));
|
|
|
|
} else {
|
|
|
|
db_pandora_audit('Report management', "Fail try to delete graph #$id");
|
|
|
|
$result = ui_print_error_message(__('Not deleted. Error deleting data'));
|
|
|
|
}
|
|
|
|
|
|
|
|
echo $result;
|
|
|
|
} else {
|
|
|
|
db_pandora_audit('ACL Violation', 'Trying to delete a graph from access graph builder');
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
exit;
|
|
|
|
}
|
2009-10-17 17:19:16 +02:00
|
|
|
}
|
|
|
|
|
2012-02-23 16:55:51 +01:00
|
|
|
if ($multiple_delete) {
|
2019-01-30 16:18:44 +01:00
|
|
|
$ids = (array) get_parameter('delete_multiple', []);
|
|
|
|
|
|
|
|
foreach ($ids as $id) {
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tgraph',
|
|
|
|
['id_graph' => $id]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($result === false) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($result !== false) {
|
|
|
|
$result = true;
|
|
|
|
} else {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$str_ids = implode(',', $ids);
|
|
|
|
if ($result) {
|
|
|
|
db_pandora_audit('Report management', "Multiple delete graph: $str_ids");
|
|
|
|
} else {
|
|
|
|
db_pandora_audit('Report management', "Fail try to delete graphs: $str_ids");
|
|
|
|
}
|
|
|
|
|
|
|
|
ui_print_result_message(
|
|
|
|
$result,
|
|
|
|
__('Successfully deleted'),
|
|
|
|
__('Not deleted. Error deleting data')
|
|
|
|
);
|
2012-02-23 16:55:51 +01:00
|
|
|
}
|
2012-08-02 Miguel de Dios <miguel.dedios@artica.es>
* pandoradb_data.sql, pandoradb.data.postgreSQL.sql,
pandoradb.data.oracle.sql, include/functions_config.php: fixed the
"list_ACL_IPs_for_API" update.
* operation/events/events_marquee.php, godmode/setup/setup.php,
godmode/reporting/graph_builder.php,
godmode/reporting/map_builder.php, godmode/reporting/graphs.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_template.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php,
godmode/alerts/configure_alert_command.php,
godmode/alerts/alert_actions.php,
godmode/alerts/alert_list.builder.php,
godmode/alerts/configure_alert_special_days.php,
include/functions_api.php, include/functions_ui.php,
include/functions_netflow.php, include/functions_alerts.php,
include/functions_menu.php, include/functions_messages.php: cleaned
source code style.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@6846 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2012-08-03 14:48:09 +02:00
|
|
|
|
2012-12-28 18:06:17 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$id_group = (int) get_parameter('id_group', 0);
|
|
|
|
$search = trim(get_parameter('search', ''));
|
2019-01-30 16:18:44 +01:00
|
|
|
$graphs = custom_graphs_get_user($config['id_user'], false, true, $access);
|
|
|
|
$offset = (int) get_parameter('offset');
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux = new stdClass();
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux->width = '100%';
|
|
|
|
$table_aux->class = 'databox filters';
|
|
|
|
$table_aux->cellpadding = 0;
|
|
|
|
$table_aux->cellspacing = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux->colspan[0][0] = 4;
|
|
|
|
$table_aux->data[0][0] = '<b>'.__('Group').'</b>';
|
2019-04-02 13:42:30 +02:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux->data[0][1] = html_print_select_groups(false, $access, true, 'id_group', $id_group, '', '', '', true, false, true, '', false, '', false, false, 'id_grupo', $strict_user).'<br>';
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux->data[0][2] = '<b>'.__('Free text for search: ').ui_print_help_tip(
|
|
|
|
__('Search by report name or description, list matches.'),
|
|
|
|
true
|
|
|
|
).'</b>';
|
|
|
|
$table_aux->data[0][3] = html_print_input_text('search', $search, '', 30, '', true);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table_aux->data[0][6] = html_print_submit_button(__('Search'), 'search_submit', false, 'class="sub upd"', true);
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
if (is_metaconsole()) {
|
|
|
|
$filter = "<form class ='' action='index.php?sec=reporting&sec2=godmode/reporting/graphs&id_group=$id_group&pure=$pure'
|
|
|
|
method='post'>";
|
|
|
|
$filter .= html_print_table($table_aux, true);
|
|
|
|
$filter .= '</form>';
|
|
|
|
ui_toggle($filter, __('Show Option'));
|
|
|
|
} else {
|
|
|
|
echo "<form action='index.php?sec=reporting&sec2=godmode/reporting/graphs&id_group=$id_group&pure=$pure'
|
|
|
|
method='post'>";
|
|
|
|
html_print_table($table_aux);
|
|
|
|
echo '</form>';
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
// Show only selected groups.
|
|
|
|
if ($id_group > 0) {
|
|
|
|
$group = ["$id_group" => $id_group];
|
|
|
|
} else {
|
|
|
|
$group = false;
|
2019-04-02 13:42:30 +02:00
|
|
|
}
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$own_info = get_user_info($config['id_user']);
|
|
|
|
if ($own_info['is_admin'] || check_acl($config['id_user'], 0, 'RM')) {
|
|
|
|
$return_all_group = true;
|
|
|
|
} else {
|
|
|
|
$return_all_group = false;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
if ($search != '') {
|
|
|
|
$filter = [
|
|
|
|
'name' => $search_name,
|
|
|
|
'order' => 'name',
|
|
|
|
];
|
|
|
|
} else {
|
|
|
|
$filter = ['order' => 'name'];
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
// Fix : group filter was not working
|
|
|
|
// Show only selected groups.
|
|
|
|
if ($id_group > 0) {
|
|
|
|
$group = ["$id_group" => $id_group];
|
|
|
|
$filter['id_group'] = $id_group;
|
|
|
|
} else {
|
|
|
|
$group = false;
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
// Filter normal and metaconsole reports.
|
|
|
|
if ($config['metaconsole'] == 1 && defined('METACONSOLE')) {
|
|
|
|
$filter['metaconsole'] = 1;
|
|
|
|
} else {
|
|
|
|
$filter['metaconsole'] = 0;
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
if ($id_group != null || $search != null) {
|
|
|
|
$graphs = custom_graphs_search($id_group, $search);
|
2019-01-30 16:18:44 +01:00
|
|
|
}
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
ui_pagination(count($graphs));
|
|
|
|
|
|
|
|
if (!empty($graphs)) {
|
|
|
|
$table = new stdClass();
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->class = 'info_table';
|
|
|
|
$table->cellpadding = 0;
|
|
|
|
$table->cellspacing = 0;
|
|
|
|
$table->align = [];
|
|
|
|
$table->head = [];
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table->head[0] = __('Graph name');
|
|
|
|
$table->head[1] = __('Description');
|
|
|
|
$table->head[2] = __('Number of Graphs');
|
|
|
|
$table->head[3] = __('Group');
|
|
|
|
$table->size[0] = '30%';
|
|
|
|
$table->size[2] = '200px';
|
|
|
|
$table->size[3] = '200px';
|
|
|
|
$table->align[2] = 'left';
|
|
|
|
$table->align[3] = 'left';
|
|
|
|
$op_column = false;
|
|
|
|
if ($report_w || $report_m) {
|
|
|
|
$op_column = true;
|
|
|
|
$table->align[4] = 'left';
|
|
|
|
$table->head[4] = __('Op.');
|
|
|
|
$table->size[4] = '90px';
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2019-09-09 21:02:53 +02:00
|
|
|
if ($report_w || $report_m) {
|
|
|
|
$table->align[5] = 'left';
|
|
|
|
$table->head[5] = html_print_checkbox('all_delete', 0, false, true, false);
|
|
|
|
$table->size[5] = '20px';
|
|
|
|
}
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
$table->data = [];
|
|
|
|
|
|
|
|
$result_graphs = array_slice($graphs, $offset, $config['block_size']);
|
|
|
|
|
|
|
|
foreach ($result_graphs as $graph) {
|
|
|
|
$data = [];
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[0] = '<a href="index.php?sec=reporting&sec2=operation/reporting/graph_viewer&view_graph=1&id='.$graph['id_graph'].'">'.ui_print_truncate_text(
|
|
|
|
$graph['name'],
|
|
|
|
70
|
|
|
|
).'</a>';
|
2019-05-14 18:15:23 +02:00
|
|
|
|
|
|
|
$data[1] = ui_print_truncate_text($graph['description'], 70);
|
|
|
|
|
|
|
|
$data[2] = $graph['graphs_count'];
|
|
|
|
$data[3] = ui_print_group_icon($graph['id_group'], true);
|
|
|
|
|
|
|
|
$data[4] = '';
|
|
|
|
$table->cellclass[][4] = 'action_buttons';
|
2021-03-11 15:40:23 +01:00
|
|
|
if (($report_w || $report_m)) {
|
|
|
|
$data[4] = '<a href="index.php?sec=reporting&sec2=godmode/reporting/graph_builder&edit_graph=1&id='.$graph['id_graph'].'">'.html_print_image(
|
|
|
|
'images/config.png',
|
|
|
|
true,
|
|
|
|
['class' => 'invert_filter']
|
|
|
|
).'</a>';
|
2019-05-14 18:15:23 +02:00
|
|
|
}
|
|
|
|
|
2020-10-22 12:00:44 +02:00
|
|
|
$data[5] = '';
|
|
|
|
if (check_acl_restricted_all($config['id_user'], $graph['id_group'], 'RM')) {
|
2019-05-14 18:15:23 +02:00
|
|
|
$data[4] .= '<a href="index.php?sec=reporting&sec2=godmode/reporting/graphs&delete_graph=1&id='.$graph['id_graph'].'" onClick="if (!confirm(\''.__('Are you sure?').'\'))
|
2021-03-11 15:40:23 +01:00
|
|
|
return false;">'.html_print_image(
|
|
|
|
'images/cross.png',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'alt' => __('Delete'),
|
|
|
|
'title' => __('Delete'),
|
|
|
|
'class' => 'invert_filter',
|
|
|
|
]
|
|
|
|
).'</a>';
|
|
|
|
|
|
|
|
$data[5] .= html_print_checkbox_extended(
|
|
|
|
'delete_multiple[]',
|
|
|
|
$graph['id_graph'],
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
'class="check_deletemrgn_lft_2px"',
|
|
|
|
true
|
|
|
|
);
|
2019-09-09 21:02:53 +02:00
|
|
|
}
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
array_push($table->data, $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (!empty($result_graphs)) {
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<form method='post' action='index.php?sec=reporting&sec2=godmode/reporting/graphs'>";
|
|
|
|
html_print_input_hidden('multiple_delete', 1);
|
|
|
|
html_print_table($table);
|
|
|
|
ui_pagination(count($graphs), false, 0, 0, false, 'offset', true, 'pagination-bottom');
|
|
|
|
echo "<div class='right'>";
|
2019-01-30 16:18:44 +01:00
|
|
|
html_print_submit_button(__('Delete'), 'delete_btn', false, 'class="sub delete"');
|
2019-05-14 18:15:23 +02:00
|
|
|
echo '</form>';
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
echo "<div class='right'>";
|
2019-05-14 18:15:23 +02:00
|
|
|
if ($report_w || $report_m) {
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<form method="post" class="right" action="index.php?sec=reporting&sec2=godmode/reporting/graph_builder">';
|
|
|
|
html_print_submit_button(__('Create graph'), 'create', false, 'class="sub next mrgn_right_5px"');
|
2019-05-14 18:15:23 +02:00
|
|
|
echo '</form>';
|
|
|
|
}
|
2019-01-30 16:18:44 +01:00
|
|
|
|
2021-03-15 14:38:20 +01:00
|
|
|
echo '</div>';
|
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
echo '</div>';
|
|
|
|
} else {
|
2019-11-21 18:21:46 +01:00
|
|
|
include_once $config['homedir'].'/general/first_task/custom_graphs.php';
|
2019-05-14 18:15:23 +02:00
|
|
|
}
|
2012-02-28 17:08:30 +01:00
|
|
|
|
2019-05-14 18:15:23 +02:00
|
|
|
?>
|
2012-02-23 16:55:51 +01:00
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$( document ).ready(function() {
|
|
|
|
|
|
|
|
$('[id^=checkbox-delete_multiple]').change(function(){
|
|
|
|
if($(this).parent().parent().hasClass('checkselected')){
|
|
|
|
$(this).parent().parent().removeClass('checkselected');
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
$(this).parent().parent().addClass('checkselected');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$('[id^=checkbox-all_delete]').change(function(){
|
|
|
|
if ($("#checkbox-all_delete").prop("checked")) {
|
|
|
|
$('[id^=checkbox-delete_multiple]').parent().parent().addClass('checkselected');
|
|
|
|
$(".check_delete").prop("checked", true);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
$('[id^=checkbox-delete_multiple]').parent().parent().removeClass('checkselected');
|
|
|
|
$(".check_delete").prop("checked", false);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2012-02-23 16:55:51 +01:00
|
|
|
</script>
|
2018-09-13 16:07:40 +02:00
|
|
|
|