2023-06-18 20:01:59 +00:00
< ? php
class Gridmap_model extends CI_Model {
2023-11-27 23:20:47 +00:00
function get_band_confirmed ( $band , $mode , $qsl , $lotw , $eqsl , $sat , $logbooks_locations_array = NULL ) {
if ( $logbooks_locations_array == NULL ) {
$CI =& get_instance ();
$CI -> load -> model ( 'logbooks_model' );
$logbooks_locations_array = $CI -> logbooks_model -> list_logbook_relationships ( $this -> session -> userdata ( 'active_station_logbook' ));
}
2023-06-18 20:01:59 +00:00
if ( ! $logbooks_locations_array ) {
return null ;
}
$location_list = " ' " . implode ( " ',' " , $logbooks_locations_array ) . " ' " ;
$sql = 'SELECT distinct substring(COL_GRIDSQUARE,1,6) as GRID_SQUARES, COL_BAND FROM '
. $this -> config -> item ( 'table_name' )
. ' WHERE station_id in ('
. $location_list . ') AND COL_GRIDSQUARE != ""' ;
if ( $band != 'All' ) {
if ( $band == 'SAT' ) {
$sql .= " and col_prop_mode =' " . $band . " ' " ;
2023-06-19 09:29:46 +00:00
if ( $sat != 'All' ) {
$sql .= " and col_sat_name =' " . $sat . " ' " ;
}
2023-06-18 20:01:59 +00:00
}
else {
$sql .= " and col_prop_mode !='SAT' " ;
$sql .= " and col_band =' " . $band . " ' " ;
}
}
if ( $mode != 'All' ) {
$sql .= " and (col_mode =' " . $mode . " ' or col_submode =' " . $mode . " ') " ;
}
$sql .= $this -> addQslToQuery ( $qsl , $lotw , $eqsl );
return $this -> db -> query ( $sql );
}
2023-11-27 23:20:47 +00:00
function get_band ( $band , $mode , $qsl , $lotw , $eqsl , $sat , $logbooks_locations_array = NULL ) {
if ( $logbooks_locations_array == NULL ) {
$CI =& get_instance ();
$CI -> load -> model ( 'logbooks_model' );
$logbooks_locations_array = $CI -> logbooks_model -> list_logbook_relationships ( $this -> session -> userdata ( 'active_station_logbook' ));
}
2023-06-18 20:01:59 +00:00
if ( ! $logbooks_locations_array ) {
return null ;
}
$location_list = " ' " . implode ( " ',' " , $logbooks_locations_array ) . " ' " ;
$sql = 'SELECT distinct substring(COL_GRIDSQUARE,1,6) as GRID_SQUARES, COL_BAND FROM '
. $this -> config -> item ( 'table_name' )
. ' WHERE station_id in ('
. $location_list . ') AND COL_GRIDSQUARE != ""' ;
if ( $band != 'All' ) {
if ( $band == 'SAT' ) {
$sql .= " and col_prop_mode =' " . $band . " ' " ;
2023-06-19 09:29:46 +00:00
if ( $sat != 'All' ) {
$sql .= " and col_sat_name =' " . $sat . " ' " ;
}
2023-06-18 20:01:59 +00:00
}
else {
$sql .= " and col_prop_mode !='SAT' " ;
$sql .= " and col_band =' " . $band . " ' " ;
}
}
if ( $mode != 'All' ) {
$sql .= " and (col_mode =' " . $mode . " ' or col_submode =' " . $mode . " ') " ;
}
return $this -> db -> query ( $sql );
}
2023-11-27 23:20:47 +00:00
function get_band_worked_vucc_squares ( $band , $mode , $qsl , $lotw , $eqsl , $sat , $logbooks_locations_array = NULL ) {
if ( $logbooks_locations_array == NULL ) {
$CI =& get_instance ();
$CI -> load -> model ( 'logbooks_model' );
$logbooks_locations_array = $CI -> logbooks_model -> list_logbook_relationships ( $this -> session -> userdata ( 'active_station_logbook' ));
}
2023-06-18 20:01:59 +00:00
if ( ! $logbooks_locations_array ) {
return null ;
}
$location_list = " ' " . implode ( " ',' " , $logbooks_locations_array ) . " ' " ;
$sql = 'SELECT distinct COL_VUCC_GRIDS, COL_BAND FROM '
. $this -> config -> item ( 'table_name' )
. ' WHERE station_id in ('
. $location_list . ') AND COL_VUCC_GRIDS != ""' ;
if ( $band != 'All' ) {
if ( $band == 'SAT' ) {
$sql .= " and col_prop_mode =' " . $band . " ' " ;
2023-06-19 09:29:46 +00:00
if ( $sat != 'All' ) {
$sql .= " and col_sat_name =' " . $sat . " ' " ;
}
2023-06-18 20:01:59 +00:00
}
else {
$sql .= " and col_prop_mode !='SAT' " ;
$sql .= " and col_band =' " . $band . " ' " ;
}
}
if ( $mode != 'All' ) {
$sql .= " and (col_mode =' " . $mode . " ' or col_submode =' " . $mode . " ') " ;
}
2023-06-19 07:38:47 +00:00
return $this -> db -> query ( $sql );
2023-06-18 20:01:59 +00:00
}
2023-11-27 23:20:47 +00:00
function get_band_confirmed_vucc_squares ( $band , $mode , $qsl , $lotw , $eqsl , $sat , $logbooks_locations_array = NULL ) {
if ( $logbooks_locations_array == NULL ) {
$CI =& get_instance ();
$CI -> load -> model ( 'logbooks_model' );
$logbooks_locations_array = $CI -> logbooks_model -> list_logbook_relationships ( $this -> session -> userdata ( 'active_station_logbook' ));
}
2023-06-18 20:01:59 +00:00
if ( ! $logbooks_locations_array ) {
return null ;
}
$location_list = " ' " . implode ( " ',' " , $logbooks_locations_array ) . " ' " ;
$sql = 'SELECT distinct COL_VUCC_GRIDS, COL_BAND FROM '
. $this -> config -> item ( 'table_name' )
. ' WHERE station_id in ('
. $location_list . ') AND COL_VUCC_GRIDS != ""' ;
2023-06-19 09:29:46 +00:00
if ( $band != 'All' ) {
2023-06-18 20:01:59 +00:00
if ( $band == 'SAT' ) {
$sql .= " and col_prop_mode =' " . $band . " ' " ;
2023-06-19 09:29:46 +00:00
if ( $sat != 'All' ) {
$sql .= " and col_sat_name =' " . $sat . " ' " ;
}
2023-06-18 20:01:59 +00:00
}
else {
$sql .= " and col_prop_mode !='SAT' " ;
$sql .= " and col_band =' " . $band . " ' " ;
}
}
if ( $mode != 'All' ) {
$sql .= " and (col_mode =' " . $mode . " ' or col_submode =' " . $mode . " ') " ;
}
$sql .= $this -> addQslToQuery ( $qsl , $lotw , $eqsl );
return $this -> db -> query ( $sql );
}
// Adds confirmation to query
function addQslToQuery ( $qsl , $lotw , $eqsl ) {
$sql = '' ;
if ( $lotw == " true " && $qsl == " false " && $eqsl == " false " ) {
$sql .= " and col_lotw_qsl_rcvd = 'Y' " ;
}
if ( $qsl == " true " && $lotw == " false " && $eqsl == " false " ) {
$sql .= " and col_qsl_rcvd = 'Y' " ;
}
if ( $eqsl == " true " && $lotw == " false " && $qsl == " false " ) {
$sql .= " and col_eqsl_qsl_rcvd = 'Y' " ;
}
if ( $lotw == " true " && $qsl == " true " && $eqsl == " false " ) {
$sql .= " and (col_lotw_qsl_rcvd = 'Y' or col_qsl_rcvd = 'Y') " ;
}
if ( $qsl == " true " && $lotw == " false " && $eqsl == " true " ) {
$sql .= " and (col_qsl_rcvd = 'Y' or col_eqsl_qsl_rcvd = 'Y') " ;
}
if ( $eqsl == " true " && $lotw == " true " && $qsl == " false " ) {
$sql .= " and (col_eqsl_qsl_rcvd = 'Y' or col_lotw_qsl_rcvd = 'Y') " ;
}
if ( $qsl == " true " && $lotw == " true " && $eqsl == " true " ) {
$sql .= " and (col_qsl_rcvd = 'Y' or col_lotw_qsl_rcvd = 'Y' or col_eqsl_qsl_rcvd = 'Y') " ;
}
if ( $qsl == " false " && $lotw == " false " && $eqsl == " false " ) {
$sql .= " and (col_qsl_rcvd != 'Y' and col_lotw_qsl_rcvd != 'Y' and col_eqsl_qsl_rcvd != 'Y') " ;
}
return $sql ;
}
/*
* Get ' s the worked modes from the log
*/
function get_worked_modes () {
$CI =& get_instance ();
$CI -> load -> model ( 'logbooks_model' );
$logbooks_locations_array = $CI -> logbooks_model -> list_logbook_relationships ( $this -> session -> userdata ( 'active_station_logbook' ));
if ( ! $logbooks_locations_array ) {
return null ;
}
$location_list = " ' " . implode ( " ',' " , $logbooks_locations_array ) . " ' " ;
// get all worked modes from database
$data = $this -> db -> query (
" SELECT distinct LOWER(`COL_MODE`) as `COL_MODE` FROM ` " . $this -> config -> item ( 'table_name' ) . " ` WHERE station_id in ( " . $location_list . " ) order by COL_MODE ASC "
);
$results = array ();
foreach ( $data -> result () as $row ) {
array_push ( $results , $row -> COL_MODE );
}
$data = $this -> db -> query (
" SELECT distinct LOWER(`COL_SUBMODE`) as `COL_SUBMODE` FROM ` " . $this -> config -> item ( 'table_name' ) . " ` WHERE station_id in ( " . $location_list . " ) and coalesce(COL_SUBMODE, '') <> '' order by COL_SUBMODE ASC "
);
foreach ( $data -> result () as $row ) {
if ( ! in_array ( $row , $results )) {
array_push ( $results , $row -> COL_SUBMODE );
}
}
asort ( $results );
return $results ;
}
2023-11-27 23:20:47 +00:00
}