From eb271a93eb76b9ec77da25d8ee55449956596f2e Mon Sep 17 00:00:00 2001 From: Tatiana Llorente Date: Wed, 18 Sep 2019 15:32:36 +0200 Subject: [PATCH 1/2] Added button for export to csv - #4642 --- pandora_console/include/functions.php | 60 ++++++++ pandora_console/include/functions_html.php | 1 - .../incidents/integriaims_export_csv.php | 138 ++++++++++++++++++ .../incidents/list_integriaims_incidents.php | 100 +++++++------ 4 files changed, 255 insertions(+), 44 deletions(-) create mode 100644 pandora_console/operation/incidents/integriaims_export_csv.php diff --git a/pandora_console/include/functions.php b/pandora_console/include/functions.php index b9a1cdde92..c2d2714d46 100644 --- a/pandora_console/include/functions.php +++ b/pandora_console/include/functions.php @@ -5597,3 +5597,63 @@ function ui_print_integria_incident_priority($priority, $priority_label) return $output; } + + +/** + * Get tickets from Integria IMS. + * + * @param array $tickets_filters Filters to send to API. + * + * @return array Tickets returned by API call. + */ +function get_tickets_integriaims($tickets_filters) +{ + global $config; + + // Filters. + $incident_text = $tickets_filters['incident_text']; + $incident_status = $tickets_filters['incident_status']; + $incident_group = $tickets_filters['incident_group']; + $incident_owner = $tickets_filters['incident_owner']; + $incident_creator = $tickets_filters['incident_creator']; + $incident_priority = $tickets_filters['incident_priority']; + $incident_resolution = $tickets_filters['incident_resolution']; + $incident_date = $tickets_filters['incident_date']; + + // API call. + $result_api_call_list = integria_api_call( + $config['integria_hostname'], + $config['integria_user'], + $config['integria_pass'], + $config['integria_api_pass'], + 'get_incidents', + [ + $incident_text, + $incident_status, + $incident_group, + $incident_priority, + '0', + $incident_owner, + $incident_creator, + ] + ); + + // Return array of api call 'get_incidents'. + $array_get_incidents = []; + get_array_from_csv_data_all($result_api_call_list, $array_get_incidents); + + // Modify $array_get_incidents if filter for resolution exists. + $filter_resolution = []; + foreach ($array_get_incidents as $key => $value) { + if ($incident_resolution !== '' && ($array_get_incidents[$key][12] == $incident_resolution)) { + $filter_resolution[$key] = $array_get_incidents[$key]; + continue; + } + } + + if ($incident_resolution !== '') { + $array_get_incidents = $filter_resolution; + } + + return $array_get_incidents; +} diff --git a/pandora_console/include/functions_html.php b/pandora_console/include/functions_html.php index 9c3f96f53a..f006520b38 100644 --- a/pandora_console/include/functions_html.php +++ b/pandora_console/include/functions_html.php @@ -3423,7 +3423,6 @@ function html_print_autocomplete_users_from_integria( timeout: 10000, dataType: "json", success: function (data) { - console.log(data); temp = []; $.each(data, function (id, module) { temp.push({ diff --git a/pandora_console/operation/incidents/integriaims_export_csv.php b/pandora_console/operation/incidents/integriaims_export_csv.php new file mode 100644 index 0000000000..c474b3eb94 --- /dev/null +++ b/pandora_console/operation/incidents/integriaims_export_csv.php @@ -0,0 +1,138 @@ + $value) { + // Status. + if ($tickets_csv_array[$key][6] == 0) { + $tickets_csv_array[$key][6] = 'None'; + } else { + $tickets_csv_array[$key][6] = $status_incident[$tickets_csv_array[$key][6]]; + } + + // Priority. + $tickets_csv_array[$key][7] = $priority_incident[$tickets_csv_array[$key][7]]; + + // Group. + $tickets_csv_array[$key][8] = $group_incident[$tickets_csv_array[$key][8]]; + + // Resolution. + if ($tickets_csv_array[$key][12] == 0) { + $tickets_csv_array[$key][12] = 'None'; + } else { + $tickets_csv_array[$key][12] = $resolution_incident[$tickets_csv_array[$key][12]]; + } + + $tickets_csv_array_filter[$key] = [ + 'id_incidencia' => $tickets_csv_array[$key][0], + 'titulo' => $tickets_csv_array[$key][3], + 'id_grupo' => $tickets_csv_array[$key][8], + 'estado_resolution' => $tickets_csv_array[$key][6].' / '.$tickets_csv_array[$key][12], + 'prioridad' => $tickets_csv_array[$key][7], + 'actualizacion' => $tickets_csv_array[$key][9], + 'id_creator' => $tickets_csv_array[$key][10], + 'owner' => $tickets_csv_array[$key][5], + ]; +} + + +// Header for CSV file. +$header = [ + __('ID Ticket'), + __('Title'), + __('Group/Company'), + __('Status/Resolution'), + __('Priority'), + __('Updated/Started'), + __('Creator'), + __('Owner'), +]; + +$header_csv = ''; +foreach ($header as $key => $value) { + $header_csv .= $value.','; +} + +$header_csv = io_safe_output($header_csv).PHP_EOL; + + +// Join header and content. +$tickets_csv = ''; +foreach ($tickets_csv_array_filter as $key => $value) { + $tickets_csv .= implode(',', $tickets_csv_array_filter[$key]).PHP_EOL; +} + +$tickets_csv = $header_csv.$tickets_csv; + + +// Create csv file. +$filename = 'tickets_export-'.date('Ymd').'-'.date('His').'.csv'; + +ob_clean(); + +header('Content-Type: text/csv; charset=utf-8'); +header('Content-Disposition: attachment; filename='.$filename); + +// BOM. +echo pack('C*', 0xEF, 0xBB, 0xBF); + +// CSV file. +echo io_safe_output($tickets_csv); diff --git a/pandora_console/operation/incidents/list_integriaims_incidents.php b/pandora_console/operation/incidents/list_integriaims_incidents.php index fc57a5b08f..41323ae91e 100644 --- a/pandora_console/operation/incidents/list_integriaims_incidents.php +++ b/pandora_console/operation/incidents/list_integriaims_incidents.php @@ -40,7 +40,7 @@ if ($has_connection === false) { } // Get parameters for filters. -$incident_text = (string) get_parameter('text_filter', ''); +$incident_text = (string) get_parameter('incident_text', ''); $incident_status = (int) get_parameter('incident_status', 0); $incident_group = (int) get_parameter('incident_group', 1); $incident_owner = (string) get_parameter('incident_owner', ''); @@ -109,7 +109,7 @@ $table->cellspacing = '0'; $table->data = []; $table->data[0][0] = __('Text filter'); -$table->data[0][1] = html_print_input_text('text_filter', $text_filter, '', 20, 40, true); +$table->data[0][1] = html_print_input_text('incident_text', $incident_text, '', 30, 100, true); $table->data[0][2] = __('Status'); $table->data[0][3] = html_print_select( @@ -163,17 +163,64 @@ $table->data[2][1] = html_print_select( // TODO: field type date. $table->data[2][2] = __('Date'); -$table->data[2][3] = 'FECHA'; +$table->data[2][3] = html_print_input_text_extended( + 'created_from', + '', + 'created_from', + '', + 12, + 50, + false, + '', + 'placeholder="'.__('Created from').'"', + true +); +$table->data[2][3] .= html_print_input_text_extended( + 'created_to', + '', + 'created_to', + '', + 12, + 50, + false, + '', + 'style="margin-left:5px;" placeholder="'.__('Created to').'"', + true +); // TODO: image of Integria IMS. $table->data[2][4] = 'Imagen:'; $table->data[2][5] = 'IMAGEN'; +// Send filters to get_tickets_integriaims(). +$tickets_filters = [ + 'incident_text' => $incident_text, + 'incident_status' => $incident_status, + 'incident_group' => $incident_group, + 'incident_owner' => $incident_owner, + 'incident_creator' => $incident_creator, + 'incident_priority' => $incident_priority, + 'incident_resolution' => $incident_resolution, + 'incident_date' => $incident_date, +]; + +// Data to export to csv file. +$decode_csv = base64_encode(json_encode($tickets_filters)); + + +// ---- PRINT TABLE FILTERS ---- $integria_incidents_form = '
'; $integria_incidents_form .= html_print_table($table, true); $integria_incidents_form .= '
'; -$integria_incidents_form .= '
'.html_print_submit_button(__('Export to CSV'), 'csv_button', false, 'class="sub next"', true).'
'; +$integria_incidents_form .= '
'.html_print_button( + __('Export to CSV'), + 'csv_export', + false, + "location.href='operation/incidents/integriaims_export_csv.php?tickets_filters=$decode_csv'", + 'class="sub next"', + true +).'
'; $integria_incidents_form .= '
'.html_print_submit_button(__('Filter'), 'filter_button', false, 'class="sub filter"', true).'
'; $integria_incidents_form .= '
'; $integria_incidents_form .= '
'; @@ -181,43 +228,6 @@ $integria_incidents_form .= ''; // ui_toggle($integria_incidents_form, __('Add Custom filter')); echo $integria_incidents_form; -// ---- LIST OF INCIDENTS ---- -$result_api_call_list = integria_api_call( - $config['integria_hostname'], - $config['integria_user'], - $config['integria_pass'], - $config['integria_api_pass'], - 'get_incidents', - [ - $incident_text, - $incident_status, - $incident_group, - $incident_priority, - '0', - $incident_owner, - $incident_creator, - ] -); -// 'get_incidents', ['', '0', '1', '-1', '0', 'admin', 'admin']); -// http://192.168.70.124/integria/include/api.php?user=admin&user_pass=integria&pass=1234&op=get_incidents¶ms=,0,1,-1 -$array_get_incidents = []; - -// Return array of api call 'get_incidents'. -get_array_from_csv_data_all($result_api_call_list, $array_get_incidents); - -// Modify $array_get_incidents if filter for resolution exists. -$filter_resolution = []; -foreach ($array_get_incidents as $key => $value) { - if ($incident_resolution !== '' && ($array_get_incidents[$key][12] == $incident_resolution)) { - $filter_resolution[$key] = $array_get_incidents[$key]; - continue; - } -} - -if ($incident_resolution !== '') { - $array_get_incidents = $filter_resolution; -} - /* * Order api call 'get_incidents'. * @@ -232,6 +242,10 @@ if ($incident_resolution !== '') { * */ +// ---- LIST OF INCIDENTS ---- +// Get list of incidents. +$array_get_incidents = get_tickets_integriaims($tickets_filters); + // Prepare pagination. $incidents_limit = $config['block_size']; $incidents_paginated = array_slice($array_get_incidents, $offset, $incidents_limit, true); @@ -273,7 +287,7 @@ foreach ($incidents_paginated as $key => $value) { $table->data[$i][4] = ui_print_integria_incident_priority($array_get_incidents[$key][7], $priority_incident[$array_get_incidents[$key][7]]); $table->data[$i][5] = $array_get_incidents[$key][9]; $table->data[$i][6] = $array_get_incidents[$key][10]; - $table->data[$i][7] = $array_get_incidents[$key][0]; + $table->data[$i][7] = $array_get_incidents[$key][5]; $table->data[$i][8] = ''; $table->cellclass[$i][8] = 'action_buttons'; if (check_acl($config['id_user'], 0, 'IW')) { @@ -301,7 +315,7 @@ ui_pagination(count($array_get_incidents), $url, $offset, 0, false, 'offset', tr if (check_acl($config['id_user'], 0, 'IR')) { echo '
'; echo '
'; - html_print_submit_button(__('Create'), 'create_new_incident', false, 'class="sub wand"'); + html_print_submit_button(__('Create'), 'create_new_incident', false, 'class="sub next"'); echo '
'; echo '
'; } From 8acdde9f3ab71e45fdef8712788a2f78f3ff1655 Mon Sep 17 00:00:00 2001 From: Tatiana Llorente Date: Wed, 18 Sep 2019 18:19:29 +0200 Subject: [PATCH 2/2] Added date filter - #4642 --- pandora_console/include/functions.php | 44 ++++++++++++++++++- .../incidents/list_integriaims_incidents.php | 31 +++++++++---- 2 files changed, 66 insertions(+), 9 deletions(-) diff --git a/pandora_console/include/functions.php b/pandora_console/include/functions.php index c2d2714d46..d4cfc46505 100644 --- a/pandora_console/include/functions.php +++ b/pandora_console/include/functions.php @@ -5618,7 +5618,8 @@ function get_tickets_integriaims($tickets_filters) $incident_creator = $tickets_filters['incident_creator']; $incident_priority = $tickets_filters['incident_priority']; $incident_resolution = $tickets_filters['incident_resolution']; - $incident_date = $tickets_filters['incident_date']; + $created_from = $tickets_filters['created_from']; + $created_to = $tickets_filters['created_to']; // API call. $result_api_call_list = integria_api_call( @@ -5655,5 +5656,46 @@ function get_tickets_integriaims($tickets_filters) $array_get_incidents = $filter_resolution; } + // Modify $array_get_incidents if filter for date is selected. + if ($created_from !== '' && $created_to !== '') { + $date = []; + $date_utimestamp = []; + foreach ($array_get_incidents as $key => $value) { + // Change format date / to -. + $date[$key] = date('Y-m-d', strtotime($array_get_incidents[$key][9])); + // Covert date to utimestamp. + $date_utimestamp[$key] = strtotime($date[$key]); + } + + // Change format date / to -. + $created_from_date = date('Y-m-d', strtotime($created_from)); + $created_to_date = date('Y-m-d', strtotime($created_to)); + + // Covert date to utimestamp. + $created_from_timestamp = strtotime($created_from_date); + $created_to_timestamp = strtotime($created_to_date); + + // Dates within the selected period. + $selected_period = array_filter( + $date_utimestamp, + function ($value) use ($created_from_timestamp, $created_to_timestamp) { + return ($value >= $created_from_timestamp && $value <= $created_to_timestamp); + } + ); + + // Return incidents with the correct dates. + $filter_date = []; + foreach ($array_get_incidents as $key => $value) { + foreach ($selected_period as $index => $value) { + if ($array_get_incidents[$key][0] == $index) { + $filter_date[$key] = $array_get_incidents[$key]; + continue; + } + } + } + + $array_get_incidents = $filter_date; + } + return $array_get_incidents; } diff --git a/pandora_console/operation/incidents/list_integriaims_incidents.php b/pandora_console/operation/incidents/list_integriaims_incidents.php index 41323ae91e..428693e39f 100644 --- a/pandora_console/operation/incidents/list_integriaims_incidents.php +++ b/pandora_console/operation/incidents/list_integriaims_incidents.php @@ -47,7 +47,8 @@ $incident_owner = (string) get_parameter('incident_owner', ''); $incident_creator = (string) get_parameter('incident_creator', ''); $incident_priority = (int) get_parameter('incident_priority', -1); $incident_resolution = (string) get_parameter('incident_resolution', ''); -$incident_date = (string) get_parameter('incident_date', ''); +$created_from = (string) get_parameter('created_from', ''); +$created_to = (string) get_parameter('created_to', ''); $offset = (int) get_parameter('offset'); @@ -74,9 +75,9 @@ if ($delete_incident) { // Full url with all filters. $url = ui_get_full_url( - 'index.php?sec=incident&sec2=operation/incidents/list_integriaims_incidents&incident_text='.$incident_text.'&incident_status='.$incident_status.'&incident_group='.$incident_group.'&incident_owner='.$incident_owner.'&incident_creator='.$incident_creator.'&incident_priority='.$incident_priority.'&incident_resolution='.$incident_resolution.'&incident_date='.$incident_date.'&offset='.$offset + 'index.php?sec=incident&sec2=operation/incidents/list_integriaims_incidents&incident_text='.$incident_text.'&incident_status='.$incident_status.'&incident_group='.$incident_group.'&incident_owner='.$incident_owner.'&incident_creator='.$incident_creator.'&incident_priority='.$incident_priority.'&incident_resolution='.$incident_resolution.'&created_from='.$created_from.'&created_to='.$created_to.'&offset='.$offset ); -hd($url); + // ---- FILTERS ---- // API calls to fill the filters. @@ -165,7 +166,7 @@ $table->data[2][1] = html_print_select( $table->data[2][2] = __('Date'); $table->data[2][3] = html_print_input_text_extended( 'created_from', - '', + $created_from, 'created_from', '', 12, @@ -177,7 +178,7 @@ $table->data[2][3] = html_print_input_text_extended( ); $table->data[2][3] .= html_print_input_text_extended( 'created_to', - '', + $created_to, 'created_to', '', 12, @@ -189,8 +190,8 @@ $table->data[2][3] .= html_print_input_text_extended( ); // TODO: image of Integria IMS. -$table->data[2][4] = 'Imagen:'; -$table->data[2][5] = 'IMAGEN'; +$table->data[2][4] = ''; +$table->data[2][5] = ''; // Send filters to get_tickets_integriaims(). @@ -202,7 +203,8 @@ $tickets_filters = [ 'incident_creator' => $incident_creator, 'incident_priority' => $incident_priority, 'incident_resolution' => $incident_resolution, - 'incident_date' => $incident_date, + 'created_from' => $created_from, + 'created_to' => $created_to, ]; // Data to export to csv file. @@ -319,3 +321,16 @@ if (check_acl($config['id_user'], 0, 'IR')) { echo ''; echo ''; } + +// Datapicker library for show calendar. +ui_require_jquery_file('ui.datepicker-'.get_user_language(), 'include/javascript/i18n/'); +?> + + + \ No newline at end of file