$value) { $url .= '&' . safe_url_extraclean($key) . '=' . safe_url_extraclean($value); } echo "
"; /* Map with the current position */ echo "
"; if (!gis_get_agent_map($id_agente, "500px", "98%", true, true, $period)) { ui_print_error_message(__("There is no default map. Please go to the setup for to set a default map.")); echo ""; } switch ($config["dbtype"]) { case "mysql": $timestampLastOperation = db_get_value_sql( "SELECT UNIX_TIMESTAMP()"); break; case "postgresql": $timestampLastOperation = db_get_value_sql( "SELECT ceil(date_part('epoch', CURRENT_TIMESTAMP))"); break; case "oracle": $timestampLastOperation = db_get_value_sql( "SELECT ceil((sysdate - to_date('19700101000000','YYYYMMDDHH24MISS')) * (86400)) from dual"); break; } gis_activate_ajax_refresh(null, $timestampLastOperation); gis_activate_select_control(); if ($agentData === false) { echo "

" . __("There is no GIS data for this agent, so it's positioned in default position of map.") . "

"; } echo "
"; $dataLastPosition = gis_get_data_last_position_agent($agentId); if ($dataLastPosition !== false) { echo "" . __("Last position in ") . $dataLastPosition['start_timestamp'] . ": " . $dataLastPosition['stored_longitude'] . ", " . $dataLastPosition['stored_latitude'] . ", " . $dataLastPosition['stored_altitude']; } echo "
"; echo "
"; echo __("Period to show data as path") . ": "; html_print_extended_select_for_time ('period', $period, '', '', '0', 10); html_print_submit_button(__('Refresh path'), 'refresh', false, 'class = "sub upd"'); echo "
"; echo "

" . __("Positional data from the last") . " " . human_time_description_raw ($period) ."

"; /* Get the total number of Elements for the pagination */ $sqlCount = sprintf ("SELECT COUNT(*) FROM tgis_data_history WHERE tagente_id_agente = %d AND end_timestamp > FROM_UNIXTIME(%d) ORDER BY end_timestamp DESC", $agentId, get_system_time () - $period); $countData = db_get_value_sql($sqlCount); /* Get the elements to present in this page */ $sql = sprintf (" SELECT longitude, latitude, altitude, start_timestamp, end_timestamp, description, number_of_packages, manual_placement FROM tgis_data_history WHERE tagente_id_agente = %d AND end_timestamp > FROM_UNIXTIME(%d) ORDER BY end_timestamp DESC LIMIT %d OFFSET %d", $agentId, get_system_time () - $period, $config['block_size'], (int)get_parameter ('offset')); $result = db_get_all_rows_sql ($sql, true); if ($result === false) { echo "
" . __('This agent doesn\'t have any GIS data.') . "
"; } else { ui_pagination ($countData, false) ; $table->data = array(); foreach ($result as $key => $row) { $distance = 0; if (isset($result[$key - 1])) { $distance = gis_calculate_distance($row['latitude'], $row['longitude'], $result[$key - 1]['latitude'], $result[$key - 1]['longitude']); } else { $dataLastPosition = gis_get_data_last_position_agent($agentId); if ($dataLastPosition !== false) { $distance = gis_calculate_distance($row['latitude'], $row['longitude'], $dataLastPosition['stored_latitude'], $dataLastPosition['stored_longitude']); } } $rowdata = array( $row['longitude'], $row['latitude'], $row['altitude'], $row['start_timestamp'], $row['end_timestamp'], $row['description'], sprintf(__('%s Km'), $distance), $row['number_of_packages'], $row['manual_placement']); array_push($table->data, $rowdata); } $table->head = array( __("Longitude"), __("Latitude"), __("Altitude"), __("From"), __("To"), __("Description"), __('Distance'), __("# of Packages"), __("Manual placement")); $table->class = 'position_data_table'; $table->id = $agent_name.'_position_data_table'; $table->title = $agent_name_original . " " . __("positional data"); $table->titlestyle = "background-color:#799E48;"; html_print_table($table); unset($table); ui_pagination ($countData, false) ; echo "

" . __('Total') . ' ' . $countData . ' ' . __('Data') . "

"; } ?>