2023-06-18 20:01:59 +00:00
|
|
|
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
|
|
|
|
class Gridmap extends CI_Controller {
|
|
|
|
|
|
|
|
function __construct() {
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function index() {
|
2023-06-20 19:09:13 +00:00
|
|
|
$data['page_title'] = lang('gridsquares_gridsquare_map');
|
2023-06-18 20:01:59 +00:00
|
|
|
|
|
|
|
$this->load->model('bands');
|
|
|
|
$this->load->model('gridmap_model');
|
2023-07-02 14:50:06 +00:00
|
|
|
$this->load->model('stations');
|
|
|
|
|
|
|
|
$data['homegrid'] = explode(',', $this->stations->find_gridsquare());
|
2023-06-18 20:01:59 +00:00
|
|
|
|
|
|
|
$data['modes'] = $this->gridmap_model->get_worked_modes();
|
2023-06-19 09:29:46 +00:00
|
|
|
$data['bands'] = $this->bands->get_worked_bands();
|
|
|
|
$data['sats_available'] = $this->bands->get_worked_sats();
|
2023-06-20 16:39:37 +00:00
|
|
|
|
2023-10-16 20:39:33 +00:00
|
|
|
$data['user_default_band'] = $this->session->userdata('user_default_band');
|
|
|
|
$data['user_default_confirmation'] = $this->session->userdata('user_default_confirmation');
|
2023-07-07 14:04:19 +00:00
|
|
|
|
2023-06-20 16:39:37 +00:00
|
|
|
$data['layer'] = $this->optionslib->get_option('option_map_tile_server');
|
|
|
|
|
|
|
|
$data['attribution'] = $this->optionslib->get_option('option_map_tile_server_copyright');
|
|
|
|
|
2023-06-20 19:09:13 +00:00
|
|
|
$data['gridsquares_gridsquares'] = lang('gridsquares_gridsquares');
|
|
|
|
$data['gridsquares_gridsquares_confirmed'] = lang('gridsquares_gridsquares_confirmed');
|
|
|
|
$data['gridsquares_gridsquares_not_confirmed'] = lang('gridsquares_gridsquares_not_confirmed');
|
|
|
|
$data['gridsquares_gridsquares_total_worked'] = lang('gridsquares_gridsquares_total_worked');
|
|
|
|
|
2023-06-18 20:01:59 +00:00
|
|
|
$footerData = [];
|
|
|
|
$footerData['scripts'] = [
|
2023-07-02 14:50:06 +00:00
|
|
|
'assets/js/leaflet/geocoding.js',
|
2023-06-19 07:38:47 +00:00
|
|
|
'assets/js/leaflet/L.MaidenheadColouredGridMap.js',
|
2023-06-18 20:01:59 +00:00
|
|
|
'assets/js/sections/gridmap.js?'
|
|
|
|
];
|
2023-06-19 07:38:47 +00:00
|
|
|
|
2023-06-18 20:01:59 +00:00
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
|
|
$this->load->view('gridmap/index');
|
|
|
|
$this->load->view('interface_assets/footer', $footerData);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getGridsjs() {
|
|
|
|
$band = $this->security->xss_clean($this->input->post('band'));
|
|
|
|
$mode = $this->security->xss_clean($this->input->post('mode'));
|
|
|
|
$qsl = $this->security->xss_clean($this->input->post('qsl'));
|
|
|
|
$lotw = $this->security->xss_clean($this->input->post('lotw'));
|
|
|
|
$eqsl = $this->security->xss_clean($this->input->post('eqsl'));
|
2023-06-19 09:29:46 +00:00
|
|
|
$sat = $this->security->xss_clean($this->input->post('sat'));
|
2023-06-18 20:01:59 +00:00
|
|
|
$this->load->model('gridmap_model');
|
|
|
|
|
|
|
|
$array_grid_2char = array();
|
|
|
|
$array_grid_4char = array();
|
|
|
|
$array_grid_6char = array();
|
|
|
|
|
|
|
|
$array_grid_2char_confirmed = array();
|
|
|
|
$array_grid_4char_confirmed = array();
|
|
|
|
$array_grid_6char_confirmed = array();
|
|
|
|
|
|
|
|
$grid_2char = "";
|
|
|
|
$grid_4char = "";
|
|
|
|
$grid_6char = "";
|
|
|
|
|
|
|
|
$grid_2char_confirmed = "";
|
|
|
|
$grid_4char_confirmed = "";
|
|
|
|
$grid_6char_confirmed = "";
|
|
|
|
|
2023-06-19 09:29:46 +00:00
|
|
|
$query = $this->gridmap_model->get_band_confirmed($band, $mode, $qsl, $lotw, $eqsl, $sat);
|
2023-06-18 20:01:59 +00:00
|
|
|
|
|
|
|
if ($query && $query->num_rows() > 0) {
|
|
|
|
foreach ($query->result() as $row) {
|
|
|
|
$grid_2char_confirmed = strtoupper(substr($row->GRID_SQUARES,0,2));
|
|
|
|
$grid_4char_confirmed = strtoupper(substr($row->GRID_SQUARES,0,4));
|
|
|
|
if ($this->config->item('map_6digit_grids')) {
|
|
|
|
$grid_6char_confirmed = strtoupper(substr($row->GRID_SQUARES,0,6));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if 2 Char is in array
|
|
|
|
if(!in_array($grid_2char_confirmed, $array_grid_2char_confirmed)){
|
|
|
|
array_push($array_grid_2char_confirmed, $grid_2char_confirmed);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!in_array($grid_4char_confirmed, $array_grid_4char_confirmed)){
|
|
|
|
array_push($array_grid_4char_confirmed, $grid_4char_confirmed);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->config->item('map_6digit_grids')) {
|
|
|
|
if(!in_array($grid_6char_confirmed, $array_grid_6char_confirmed)){
|
|
|
|
array_push($array_grid_6char_confirmed, $grid_6char_confirmed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-19 09:29:46 +00:00
|
|
|
$query = $this->gridmap_model->get_band($band, $mode, $qsl, $lotw, $eqsl, $sat);
|
2023-06-18 20:01:59 +00:00
|
|
|
|
|
|
|
if ($query && $query->num_rows() > 0) {
|
|
|
|
foreach ($query->result() as $row) {
|
|
|
|
|
|
|
|
$grid_two = strtoupper(substr($row->GRID_SQUARES,0,2));
|
|
|
|
$grid_four = strtoupper(substr($row->GRID_SQUARES,0,4));
|
|
|
|
if ($this->config->item('map_6digit_grids')) {
|
|
|
|
$grid_six = strtoupper(substr($row->GRID_SQUARES,0,6));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if 2 Char is in array
|
|
|
|
if(!in_array($grid_two, $array_grid_2char)){
|
|
|
|
array_push($array_grid_2char, $grid_two);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!in_array($grid_four, $array_grid_4char)){
|
|
|
|
array_push($array_grid_4char, $grid_four);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->config->item('map_6digit_grids')) {
|
|
|
|
if(!in_array($grid_six, $array_grid_6char)){
|
|
|
|
array_push($array_grid_6char, $grid_six);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-06-19 09:29:46 +00:00
|
|
|
$query_vucc = $this->gridmap_model->get_band_worked_vucc_squares($band, $mode, $qsl, $lotw, $eqsl, $sat);
|
2023-06-18 20:01:59 +00:00
|
|
|
|
2023-06-19 07:38:47 +00:00
|
|
|
if ($query_vucc && $query_vucc->num_rows() > 0) {
|
2023-06-18 20:01:59 +00:00
|
|
|
foreach ($query_vucc->result() as $row) {
|
|
|
|
|
|
|
|
$grids = explode(",", $row->COL_VUCC_GRIDS);
|
|
|
|
|
|
|
|
foreach($grids as $key) {
|
|
|
|
$grid_two = strtoupper(substr($key,0,2));
|
|
|
|
$grid_four = strtoupper(substr($key,0,4));
|
|
|
|
|
|
|
|
// Check if 2 Char is in array
|
|
|
|
if(!in_array($grid_two, $array_grid_2char)){
|
|
|
|
array_push($array_grid_2char, $grid_two);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(!in_array($grid_four, $array_grid_4char)){
|
|
|
|
array_push($array_grid_4char, $grid_four);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-06-19 07:38:47 +00:00
|
|
|
// // Confirmed Squares
|
2023-06-19 09:29:46 +00:00
|
|
|
$query_vucc = $this->gridmap_model->get_band_confirmed_vucc_squares($band, $mode, $qsl, $lotw, $eqsl, $sat);
|
2023-06-18 20:01:59 +00:00
|
|
|
|
2023-06-19 07:38:47 +00:00
|
|
|
if ($query_vucc && $query_vucc->num_rows() > 0) {
|
2023-06-18 20:01:59 +00:00
|
|
|
foreach ($query_vucc->result() as $row) {
|
|
|
|
|
|
|
|
$grids = explode(",", $row->COL_VUCC_GRIDS);
|
|
|
|
|
|
|
|
foreach($grids as $key) {
|
|
|
|
$grid_2char_confirmed = strtoupper(substr($key,0,2));
|
|
|
|
$grid_4char_confirmed = strtoupper(substr($key,0,4));
|
|
|
|
|
|
|
|
// Check if 2 Char is in array
|
|
|
|
if(!in_array($grid_2char_confirmed, $array_grid_2char_confirmed)){
|
|
|
|
array_push($array_grid_2char_confirmed, $grid_2char_confirmed);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if(!in_array($grid_4char_confirmed, $array_grid_4char_confirmed)){
|
|
|
|
array_push($array_grid_4char_confirmed, $grid_4char_confirmed);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['grid_2char_confirmed'] = ($array_grid_2char_confirmed);
|
|
|
|
$data['grid_4char_confirmed'] = ($array_grid_4char_confirmed);
|
|
|
|
$data['grid_6char_confirmed'] = ($array_grid_6char_confirmed);
|
|
|
|
|
|
|
|
$data['grid_2char'] = ($array_grid_2char);
|
|
|
|
$data['grid_4char'] = ($array_grid_4char);
|
|
|
|
$data['grid_6char'] = ($array_grid_6char);
|
|
|
|
|
|
|
|
header('Content-Type: application/json');
|
|
|
|
echo json_encode($data);
|
|
|
|
}
|
2023-07-07 14:04:19 +00:00
|
|
|
}
|