285 行
		
	
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			285 行
		
	
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
 | |
| 
 | |
| 
 | |
| class Map extends CI_Controller {
 | |
| 
 | |
| 	function index()
 | |
| 	{
 | |
| 
 | |
|         // Calculate Lat/Lng from Locator to use on Maps
 | |
|         if($this->session->userdata('user_locator')) {
 | |
|             $this->load->library('qra');
 | |
| 
 | |
|             $qra_position = $this->qra->qra2latlong($this->session->userdata('user_locator'));
 | |
|             $data['qra'] = "set";
 | |
|             $data['qra_lat'] = $qra_position[0];
 | |
|             $data['qra_lng'] = $qra_position[1];
 | |
|         } else {
 | |
|             $data['qra'] = "none";
 | |
|         }
 | |
| 
 | |
|         $this->load->model('Stations');
 | |
|         $station_id = $this->Stations->find_active();
 | |
|         $station_data = $this->Stations->profile_clean($station_id);
 | |
| 
 | |
|         // load the view
 | |
|         $data['station_profile'] = $station_data;
 | |
| 		$data['page_title'] = "Map QSOs";
 | |
| 
 | |
| 		$this->load->view('interface_assets/header', $data);
 | |
| 		$this->load->view('map/qsos');
 | |
| 		$this->load->view('interface_assets/footer');
 | |
|     }
 | |
| 
 | |
|     function custom()
 | |
| 	{
 | |
| 		$this->load->model('bands');
 | |
|         $this->load->model('modes');
 | |
| 
 | |
|         $data['worked_bands'] = $this->bands->get_worked_bands(); // Used in the view for band select
 | |
| 		$data['modes'] = $this->modes->active(); 					// Used in the view for mode select
 | |
| 
 | |
|         if ($this->input->post('band') != NULL) {   			// Band is not set when page first loads.
 | |
|             if ($this->input->post('band') == 'All') {          // Did the user specify a band? If not, use all bands
 | |
|                 $bands = $data['worked_bands'];
 | |
|             }
 | |
|             else {
 | |
|                 $bands[] = $this->input->post('band');
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             $bands = $data['worked_bands'];
 | |
|         }
 | |
| 
 | |
|         $data['bands'] = $bands; // Used for displaying selected band(s) in the table in the view
 | |
| 
 | |
|         // Calculate Lat/Lng from Locator to use on Maps
 | |
|         if($this->session->userdata('user_locator')) {
 | |
|             $this->load->library('qra');
 | |
| 
 | |
|             $qra_position = $this->qra->qra2latlong($this->session->userdata('user_locator'));
 | |
|             $data['qra'] = "set";
 | |
|             $data['qra_lat'] = $qra_position[0];
 | |
|             $data['qra_lng'] = $qra_position[1];
 | |
|         } else {
 | |
|             $data['qra'] = "none";
 | |
|         }
 | |
| 
 | |
| 		$CI =& get_instance();
 | |
| 		$CI->load->model('logbooks_model');
 | |
| 		$result = $CI->logbooks_model->logbook($this->session->userdata('active_station_logbook'))->result();
 | |
| 		
 | |
| 		if ($result) {
 | |
| 			$logbook_name = $result[0]->logbook_name;
 | |
| 		} else {
 | |
| 			$logbook_name = '';
 | |
| 		}
 | |
| 
 | |
|         // load the view
 | |
|         $data['logbook_name'] = $logbook_name;
 | |
| 		$data['page_title'] = "Map QSOs";
 | |
| 
 | |
|         if ($this->input->post('from')) {
 | |
|             $from = $this->input->post('from');
 | |
|             $from = DateTime::createFromFormat('m/d/Y g:i A', $from);
 | |
|             $from = $from->format('Y-m-d H:i');
 | |
| 
 | |
|             $footer_data['date_from'] = $from;
 | |
|         } else {
 | |
|             $footer_data['date_from'] = date('Y-m-d H:i:00');
 | |
|         }
 | |
|         if ($this->input->post('to')) {
 | |
|             $to = DateTime::createFromFormat('m/d/Y g:i A', $this->input->post('to'));
 | |
|             $to = $to->modify('+1 day')->format('Y-m-d H:i:00');
 | |
|             $footer_data['date_to'] = $to;
 | |
|         } else {
 | |
|             $temp_to = new DateTime('tomorrow');
 | |
|             $footer_data['date_to'] = $temp_to->format('Y-m-d H:i:00');
 | |
|         }
 | |
| 
 | |
| 		$this->load->view('interface_assets/header', $data);
 | |
| 		$this->load->view('map/custom_date');
 | |
| 		$this->load->view('interface_assets/footer',$footer_data);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     function map_data_custom() {
 | |
|         $start_date = $this->uri->segment(3);
 | |
|         $end_date = $this->uri->segment(4);
 | |
| 		$band = $this->uri->segment(5);
 | |
| 		$mode = $this->uri->segment(6);
 | |
| 		$propagation = $this->uri->segment(7);
 | |
| 		$this->load->model('logbook_model');
 | |
| 
 | |
| 		$this->load->library('qra');
 | |
| 
 | |
| 		$qsos = $this->logbook_model->map_custom_qsos(rawurldecode($start_date), rawurldecode($end_date), $band, rawurldecode($mode), rawurldecode($propagation));
 | |
| 		header('Content-Type: application/json; charset=utf-8');
 | |
| 		echo "{\"markers\": [";
 | |
| 		$count = 1;
 | |
| 		if ($qsos) {
 | |
| 			foreach ($qsos->result() as $row) {
 | |
| 				//print_r($row);
 | |
| 				if($row->COL_GRIDSQUARE != null) {
 | |
| 					$stn_loc = $this->qra->qra2latlong($row->COL_GRIDSQUARE);
 | |
| 					if($count != 1) {
 | |
| 						echo ",";
 | |
| 					}
 | |
| 	
 | |
| 					if($row->COL_SAT_NAME != null) {
 | |
| 							echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />SAT: ".$row->COL_SAT_NAME."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					} else {
 | |
| 							echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					}
 | |
| 	
 | |
| 					$count++;
 | |
| 				}elseif($row->COL_VUCC_GRIDS != null) {
 | |
| 
 | |
| 					$grids = explode(",", $row->COL_VUCC_GRIDS);
 | |
| 					if (count($grids) == 2) {
 | |
| 						$grid1 = $this->qra->qra2latlong(trim($grids[0]));
 | |
| 						$grid2 = $this->qra->qra2latlong(trim($grids[1]));
 | |
| 			
 | |
| 						$coords[]=array('lat' => $grid1[0],'lng'=> $grid1[1]);
 | |
| 						$coords[]=array('lat' => $grid2[0],'lng'=> $grid2[1]);    
 | |
| 			
 | |
| 						$stn_loc = $this->qra->get_midpoint($coords);
 | |
| 					}
 | |
| 					if (count($grids) == 4) {
 | |
| 						$grid1 = $this->qra->qra2latlong(trim($grids[0]));
 | |
| 						$grid2 = $this->qra->qra2latlong(trim($grids[1]));
 | |
| 						$grid3 = $this->qra->qra2latlong(trim($grids[2]));
 | |
| 						$grid4 = $this->qra->qra2latlong(trim($grids[3]));
 | |
| 			
 | |
| 						$coords[]=array('lat' => $grid1[0],'lng'=> $grid1[1]);
 | |
| 						$coords[]=array('lat' => $grid2[0],'lng'=> $grid2[1]);    
 | |
| 						$coords[]=array('lat' => $grid3[0],'lng'=> $grid3[1]);    
 | |
| 						$coords[]=array('lat' => $grid4[0],'lng'=> $grid4[1]);    
 | |
| 
 | |
| 						$stn_loc = $this->qra->get_midpoint($coords);
 | |
| 					}
 | |
| 	
 | |
| 					if($count != 1) {
 | |
| 						echo ",";
 | |
| 					}
 | |
| 		
 | |
| 					if($row->COL_SAT_NAME != null) { 
 | |
| 						echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />SAT: ".$row->COL_SAT_NAME."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					} else {
 | |
| 					echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					}
 | |
| 		
 | |
| 					$count++;
 | |
| 				} else {
 | |
| 					if($count != 1) {
 | |
| 						echo ",";
 | |
| 					}
 | |
| 	
 | |
| 					if(isset($row->lat) && isset($row->long)) {
 | |
| 						$lat = $row->lat;
 | |
| 						$lng = $row->long;
 | |
| 					}
 | |
| 					
 | |
| 					echo "{\"lat\":\"".$lat."\",\"lng\":\"".$lng."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					$count++;
 | |
| 				}
 | |
| 		}
 | |
| 
 | |
| 		}
 | |
| 		echo "]";
 | |
| 		echo "}";
 | |
| 
 | |
| 	}
 | |
| 
 | |
|     function map_data() {
 | |
| 		$this->load->model('logbook_model');
 | |
| 
 | |
| 		$this->load->library('qra');
 | |
| 
 | |
| 		//echo date('Y-m-d')
 | |
| 		$raw = strtotime('Monday last week');
 | |
| 
 | |
| 		$mon = date('Y-m-d', $raw);
 | |
| 		$sun = date('Y-m-d', strtotime('Monday next week'));
 | |
| 
 | |
| 		$qsos = $this->logbook_model->map_all_qsos_for_active_station_profile();
 | |
| 
 | |
| 		echo "{\"markers\": [";
 | |
| 		$count = 1;
 | |
| 		foreach ($qsos->result() as $row) {
 | |
| 			//print_r($row);
 | |
| 			if($row->COL_GRIDSQUARE != null) {
 | |
| 				$stn_loc = $this->qra->qra2latlong($row->COL_GRIDSQUARE);
 | |
| 				if($count != 1) {
 | |
| 					echo ",";
 | |
| 				} 
 | |
| 
 | |
| 				if($row->COL_SAT_NAME != null) {
 | |
| 						echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />SAT: ".$row->COL_SAT_NAME."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 				} else {
 | |
| 						echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 				}
 | |
| 
 | |
| 				$count++;
 | |
| 			} elseif($row->COL_VUCC_GRIDS != null) {
 | |
| 
 | |
| 				$grids = explode(",", $row->COL_VUCC_GRIDS);
 | |
| 				if (count($grids) == 2) {
 | |
| 					$grid1 = $this->qra->qra2latlong(trim($grids[0]));
 | |
| 					$grid2 = $this->qra->qra2latlong(trim($grids[1]));
 | |
| 		
 | |
| 					$coords[]=array('lat' => $grid1[0],'lng'=> $grid1[1]);
 | |
| 					$coords[]=array('lat' => $grid2[0],'lng'=> $grid2[1]);    
 | |
| 		
 | |
| 					$stn_loc = $this->qra->get_midpoint($coords);
 | |
| 				}
 | |
| 				if (count($grids) == 4) {
 | |
| 					$grid1 = $this->qra->qra2latlong(trim($grids[0]));
 | |
| 					$grid2 = $this->qra->qra2latlong(trim($grids[1]));
 | |
| 					$grid3 = $this->qra->qra2latlong(trim($grids[2]));
 | |
| 					$grid4 = $this->qra->qra2latlong(trim($grids[3]));
 | |
| 		
 | |
| 					$coords[]=array('lat' => $grid1[0],'lng'=> $grid1[1]);
 | |
| 					$coords[]=array('lat' => $grid2[0],'lng'=> $grid2[1]);    
 | |
| 					$coords[]=array('lat' => $grid3[0],'lng'=> $grid3[1]);    
 | |
| 					$coords[]=array('lat' => $grid4[0],'lng'=> $grid4[1]);    
 | |
| 		
 | |
| 					$stn_loc = $this->qra->get_midpoint($coords);
 | |
| 
 | |
| 				}
 | |
| 
 | |
| 				if($count != 1) {
 | |
| 					echo ",";
 | |
| 				}
 | |
| 	
 | |
| 				if($row->COL_SAT_NAME != null) { 
 | |
| 					echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />SAT: ".$row->COL_SAT_NAME."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 				} else {
 | |
| 					echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 				}
 | |
| 	
 | |
| 				$count++;
 | |
| 			} else {
 | |
| 				$query = $this->db->query('
 | |
| 					SELECT *
 | |
| 					FROM dxcc_entities
 | |
| 					WHERE prefix = SUBSTRING( \''.$row->COL_CALL.'\', 1, LENGTH( prefix ) )
 | |
| 					ORDER BY LENGTH( prefix ) DESC
 | |
| 					LIMIT 1
 | |
| 				');
 | |
| 
 | |
| 				foreach ($query->result() as $dxcc) {
 | |
| 					if($count != 1) {
 | |
| 					echo ",";
 | |
| 						}
 | |
| 					echo "{\"lat\":\"".$dxcc->lat."\",\"lng\":\"".$dxcc->long."\", \"html\":\"Callsign: ".$row->COL_CALL."<br />Date/Time: ".$row->COL_TIME_ON."<br />Band: ".$row->COL_BAND."<br />Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
 | |
| 					$count++;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 		}
 | |
| 		echo "]";
 | |
| 		echo "}";
 | |
| 
 | |
| 	}
 | |
| }
 |