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');
            $footer_data['date_from'] = $from;
        } else {
            $footer_data['date_from'] = date('Y-m-d H:i:00');
        }
        if ($this->input->post('to')) {
			$to = $this->input->post('to');
			$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."
Date/Time: ".$row->COL_TIME_ON."
SAT: ".$row->COL_SAT_NAME."
Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
					} else {
							echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
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."
Date/Time: ".$row->COL_TIME_ON."
SAT: ".$row->COL_SAT_NAME."
Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
					} else {
					echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
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."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
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."
Date/Time: ".$row->COL_TIME_ON."
SAT: ".$row->COL_SAT_NAME."
Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
				} else {
						echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
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."
Date/Time: ".$row->COL_TIME_ON."
SAT: ".$row->COL_SAT_NAME."
Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
				} else {
					echo "{\"lat\":\"".$stn_loc[0]."\",\"lng\":\"".$stn_loc[1]."\", \"html\":\"Callsign: ".$row->COL_CALL."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
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."
Date/Time: ".$row->COL_TIME_ON."
Band: ".$row->COL_BAND."
Mode: ".$row->COL_MODE."\",\"label\":\"".$row->COL_CALL."\"}";
					$count++;
				}
			}
		}
		echo "]";
		echo "}";
	}
}