[Gridmap] Added gridsquare map with band/mode/qsl
这个提交包含在:
父节点
fe27baabfb
当前提交
8deb34cee6
共有 5 个文件被更改,包括 906 次插入 和 0 次删除
307
application/controllers/Gridmap.php
普通文件
307
application/controllers/Gridmap.php
普通文件
|
|
@ -0,0 +1,307 @@
|
||||||
|
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
||||||
|
|
||||||
|
class Gridmap extends CI_Controller {
|
||||||
|
|
||||||
|
function __construct() {
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function index() {
|
||||||
|
$data['page_title'] = "Gridsquare Map";
|
||||||
|
|
||||||
|
$this->load->model('bands');
|
||||||
|
$this->load->model('gridmap_model');
|
||||||
|
|
||||||
|
$data['modes'] = $this->gridmap_model->get_worked_modes();
|
||||||
|
|
||||||
|
$data['bands'] = $this->bands->get_worked_bands();
|
||||||
|
|
||||||
|
$footerData = [];
|
||||||
|
$footerData['scripts'] = [
|
||||||
|
'assets/js/leaflet/L.MaidenheadColouredGridMap.js',
|
||||||
|
'assets/js/sections/gridmap.js?'
|
||||||
|
];
|
||||||
|
|
||||||
|
$this->load->view('interface_assets/header', $data);
|
||||||
|
$this->load->view('gridmap/index');
|
||||||
|
$this->load->view('interface_assets/footer', $footerData);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getGrids() {
|
||||||
|
$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'));
|
||||||
|
$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 = "";
|
||||||
|
|
||||||
|
$query = $this->gridmap_model->get_band_confirmed($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = $this->gridmap_model->get_band($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$query_vucc = $this->gridmap_model->get_band_worked_vucc_squares($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
if ($query && $query_vucc->num_rows() > 0) {
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Confirmed Squares
|
||||||
|
$query_vucc = $this->gridmap_model->get_band_confirmed_vucc_squares($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
if ($query && $query_vucc->num_rows() > 0) {
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
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'));
|
||||||
|
$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 = "";
|
||||||
|
|
||||||
|
$query = $this->gridmap_model->get_band_confirmed($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = $this->gridmap_model->get_band($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$query_vucc = $this->gridmap_model->get_band_worked_vucc_squares($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
if ($query && $query_vucc->num_rows() > 0) {
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Confirmed Squares
|
||||||
|
$query_vucc = $this->gridmap_model->get_band_confirmed_vucc_squares($band, $mode, $qsl, $lotw, $eqsl);
|
||||||
|
|
||||||
|
if ($query && $query_vucc->num_rows() > 0) {
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
214
application/models/Gridmap_model.php
普通文件
214
application/models/Gridmap_model.php
普通文件
|
|
@ -0,0 +1,214 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class Gridmap_model extends CI_Model {
|
||||||
|
|
||||||
|
function get_band_confirmed($band, $mode, $qsl, $lotw, $eqsl) {
|
||||||
|
$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)."'";
|
||||||
|
|
||||||
|
$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 . "'";
|
||||||
|
}
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_band($band, $mode, $qsl, $lotw, $eqsl) {
|
||||||
|
$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)."'";
|
||||||
|
|
||||||
|
$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 . "'";
|
||||||
|
}
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_band_worked_vucc_squares($band, $mode, $qsl, $lotw, $eqsl) {
|
||||||
|
$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)."'";
|
||||||
|
|
||||||
|
$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 . "'";
|
||||||
|
}
|
||||||
|
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->get($this->config->item('table_name'));
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_band_confirmed_vucc_squares($band, $mode, $qsl, $lotw, $eqsl) {
|
||||||
|
$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)."'";
|
||||||
|
|
||||||
|
$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 . "'";
|
||||||
|
}
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,56 @@
|
||||||
|
<div class="container">
|
||||||
|
|
||||||
|
<br>
|
||||||
|
|
||||||
|
<h2><?php echo $page_title; ?></h2>
|
||||||
|
|
||||||
|
<form class="form-inline">
|
||||||
|
<label class="my-1 mr-2" for="band"><?php echo lang('gen_band_selection'); ?></label>
|
||||||
|
<select class="custom-select my-1 mr-sm-2" id="band">
|
||||||
|
<option value="All">All</option>
|
||||||
|
<?php foreach($bands as $band) {
|
||||||
|
echo '<option value="' . $band . '"' . '>' . $band . '</option>'."\n";
|
||||||
|
} ?>
|
||||||
|
</select>
|
||||||
|
<label class="my-1 mr-2" for="mode">Mode selection</label>
|
||||||
|
<select class="custom-select my-1 mr-sm-2" id="mode">
|
||||||
|
<option value="All">All</option>
|
||||||
|
<?php
|
||||||
|
foreach($modes as $mode){
|
||||||
|
if ($mode->submode == null) {
|
||||||
|
echo '<option value="' . $mode . '">' . strtoupper($mode) . '</option>'."\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
</select>
|
||||||
|
<label class="my-1 mr-2">Confirmation</label>
|
||||||
|
<div>
|
||||||
|
<div class="form-check-inline">
|
||||||
|
<input class="form-check-input" type="checkbox" name="qsl" id="qsl" checked>
|
||||||
|
<label class="form-check-label" for="qsl">QSL</label>
|
||||||
|
</div>
|
||||||
|
<div class="form-check-inline">
|
||||||
|
<input class="form-check-input" type="checkbox" name="lotw" id="lotw" checked>
|
||||||
|
<label class="form-check-label" for="lotw">LoTW</label>
|
||||||
|
</div>
|
||||||
|
<div class="form-check-inline">
|
||||||
|
<input class="form-check-input" type="checkbox" name="eqsl" id="eqsl">
|
||||||
|
<label class="form-check-label" for="eqsl">eQSL</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<button id="plot" type="button" name="plot" class="btn btn-primary" onclick="gridPlot(this.form)">Plot</button>
|
||||||
|
</form>
|
||||||
|
|
||||||
|
<?php if($this->session->flashdata('message')) { ?>
|
||||||
|
<!-- Display Message -->
|
||||||
|
<div class="alert-message error">
|
||||||
|
<p><?php echo $this->session->flashdata('message'); ?></p>
|
||||||
|
</div>
|
||||||
|
<?php } ?>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="gridmapcontainer">
|
||||||
|
<div id="gridsquare_map" style="width: 100%; height: 800px"></div>
|
||||||
|
</div>
|
||||||
|
<script>var gridsquaremap = true;</script>
|
||||||
|
|
@ -0,0 +1,217 @@
|
||||||
|
/*
|
||||||
|
* L.Maidenhead displays a Maidenhead Locator of lines on the map.
|
||||||
|
*/
|
||||||
|
|
||||||
|
L.Maidenhead = L.LayerGroup.extend({
|
||||||
|
|
||||||
|
|
||||||
|
options: {
|
||||||
|
// Line and label color
|
||||||
|
color: 'rgba(255, 0, 0, 0.4)',
|
||||||
|
|
||||||
|
// Redraw on move or moveend
|
||||||
|
redraw: 'move'
|
||||||
|
},
|
||||||
|
|
||||||
|
initialize: function (options) {
|
||||||
|
L.LayerGroup.prototype.initialize.call(this);
|
||||||
|
L.Util.setOptions(this, options);
|
||||||
|
},
|
||||||
|
|
||||||
|
onAdd: function (map) {
|
||||||
|
this._map = map;
|
||||||
|
var grid = this.redraw();
|
||||||
|
this._map.on('viewreset '+ this.options.redraw, function () {
|
||||||
|
grid.redraw();
|
||||||
|
});
|
||||||
|
|
||||||
|
this.eachLayer(map.addLayer, map);
|
||||||
|
},
|
||||||
|
|
||||||
|
onRemove: function (map) {
|
||||||
|
// remove layer listeners and elements
|
||||||
|
map.off('viewreset '+ this.options.redraw, this.map);
|
||||||
|
this.eachLayer(this.removeLayer, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
redraw: function () {
|
||||||
|
var d3 = new Array(20, 10, 10, 1, 1, 1, 1, 1, 1, 1, 1 / 24, 1 / 24, 1 / 24, 1 / 24, 1 / 24, 1 / 240, 1 / 240, 1 / 240, 1 / 240, 1 / 240 / 24, 1 / 240 / 24);
|
||||||
|
var lat_cor = new Array(0, 8, 8, 8, 2.5, 2.2, 6, 8, 8, 8, 1.4, 2.5, 3, 3.5, 4, 4, 3.5, 3.5, 3, 1.8, 1.6); // Used for gridsquare text offset
|
||||||
|
var bounds = map.getBounds();
|
||||||
|
var zoom = map.getZoom();
|
||||||
|
console.log(zoom);
|
||||||
|
var unit = d3[zoom];
|
||||||
|
var lcor = lat_cor[zoom];
|
||||||
|
var w = bounds.getWest();
|
||||||
|
var e = bounds.getEast();
|
||||||
|
var n = bounds.getNorth();
|
||||||
|
var s = bounds.getSouth();
|
||||||
|
var field_lat_cor = new Array(0, 8, 8, 9, 8, 7, 6, 8, 8, 8, 1.4, 2.5, 3, 3.5, 4, 4, 3.5, 3.5, 3, 1.8, 1.6); // Used for field text offset
|
||||||
|
var field_cor = field_lat_cor[zoom];
|
||||||
|
if (zoom==1) {var c = 2;} else {var c = 0.2;} // Height offset
|
||||||
|
if (n > 85) n = 85;
|
||||||
|
if (s < -85) s = -85;
|
||||||
|
var left = Math.floor(w/(unit*2))*(unit*2);
|
||||||
|
var right = Math.ceil(e/(unit*2))*(unit*2);
|
||||||
|
var top = Math.ceil(n/unit)*unit;
|
||||||
|
var bottom = Math.floor(s/unit)*unit;
|
||||||
|
this.eachLayer(this.removeLayer, this);
|
||||||
|
|
||||||
|
for (var lon = left; lon < right; lon += (unit*2)) {
|
||||||
|
if (lon > -180 || lon < 180) {
|
||||||
|
for (var lat = bottom; lat < top; lat += unit) {
|
||||||
|
var bounds = [[lat,lon],[lat+unit,lon+(unit*2)]];
|
||||||
|
var locator = this._getLocator(lon,lat);
|
||||||
|
|
||||||
|
if(grid_two.includes(locator) || grid_four.includes(locator) || grid_six.includes(locator)) {
|
||||||
|
|
||||||
|
if(grid_two_confirmed.includes(locator) || grid_four_confirmed.includes(locator) || grid_six_confirmed.includes(locator)) {
|
||||||
|
var rectConfirmed = L.rectangle(bounds, {className: 'grid-rectangle grid-confirmed', color: 'rgba(144,238,144, 0.6)', weight: 1, fillOpacity: 1, fill:true, interactive: false});
|
||||||
|
this.addLayer(rectConfirmed);
|
||||||
|
} else {
|
||||||
|
var rectWorked = L.rectangle(bounds, {className: 'grid-rectangle grid-worked', color: this.options.color, weight: 1, fillOpacity: 1, fill:true, interactive: false})
|
||||||
|
this.addLayer(rectWorked);
|
||||||
|
}
|
||||||
|
// Controls text on grid on various zoom levels
|
||||||
|
if (zoom < 2 || zoom > 2) {
|
||||||
|
this.addLayer(this._getLabel(lon+unit-(unit/lcor),lat+(unit/2)+(unit/lcor*c)));
|
||||||
|
}
|
||||||
|
if (zoom < 3 ) {
|
||||||
|
this.addLayer(L.rectangle(bounds, {className: 'grid-rectangle', color: this.options.color, weight: 1, fill:false, interactive: false}));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (zoom < 3 || zoom > 5) {
|
||||||
|
this.addLayer(L.rectangle(bounds, {className: 'grid-rectangle', color: this.options.color, weight: 1, fill:false, interactive: false}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// This one shows all grids, not just the worked/confirmed
|
||||||
|
if (zoom < 3 || zoom > 5) {
|
||||||
|
this.addLayer(this._getLabel(lon+unit-(unit/lcor),lat+(unit/2)+(unit/lcor*c)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Added this to print fields and field name, while still showing worked/confirmed gridsquares
|
||||||
|
if (zoom < 6 && zoom > 2) {
|
||||||
|
unit = 10;
|
||||||
|
var left = Math.floor(w / (unit * 2)) * (unit * 2);
|
||||||
|
var right = Math.ceil(e / (unit * 2)) * (unit * 2);
|
||||||
|
var top = Math.ceil(n / unit) * unit;
|
||||||
|
var bottom = Math.floor(s / unit) * unit;
|
||||||
|
for (var lon = left; lon < right; lon += (unit * 2)) {
|
||||||
|
for (var lat = bottom; lat < top; lat += unit) {
|
||||||
|
var bounds = [[lat, lon], [lat + unit, lon + (unit * 2)]];
|
||||||
|
|
||||||
|
this.addLayer(L.rectangle(bounds, {
|
||||||
|
className: 'grid-rectangle',
|
||||||
|
color: this.options.color,
|
||||||
|
weight: 1,
|
||||||
|
fill: false,
|
||||||
|
interactive: false
|
||||||
|
}));
|
||||||
|
this.addLayer(this._getLabel2(lon + unit - (unit / field_cor), lat + (unit / 2) + (unit / lcor * c)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
_getLabel: function(lon,lat) {
|
||||||
|
var title_size = new Array(0, 10, 14, 16, 8.5, 13, 14, 16, 24, 36, 12, 14, 20, 36, 60, 12, 20, 36, 60, 12, 24); // Controls text size on labels
|
||||||
|
var zoom = map.getZoom();
|
||||||
|
var size = title_size[zoom]+'px';
|
||||||
|
var title = '';
|
||||||
|
var locator = this._getLocator(lon,lat);
|
||||||
|
if (zoom != 3) {
|
||||||
|
title = '<span class="grid-text" style="cursor: default;"><font style="color:'+this.options.color+'; font-size:'+size+'; font-weight: 900; ">' + locator + '</font></span>';
|
||||||
|
}
|
||||||
|
var myIcon = L.divIcon({className: 'my-div-icon', html: title});
|
||||||
|
var marker = L.marker([lat,lon], {icon: myIcon}, clickable=false);
|
||||||
|
if (zoom == 4 || zoom == 3) {
|
||||||
|
marker.bindTooltip(locator);
|
||||||
|
}
|
||||||
|
if (typeof gridsquaremap !== 'undefined' && gridsquaremap == true) {
|
||||||
|
marker.on('click', function(event) {
|
||||||
|
spawnGridsquareModal(locator);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return marker;
|
||||||
|
},
|
||||||
|
|
||||||
|
_getLocator: function(lon,lat) {
|
||||||
|
var ydiv_arr=new Array(10, 1, 1/24, 1/240, 1/240/24);
|
||||||
|
var d1 = "ABCDEFGHIJKLMNOPQR".split("");
|
||||||
|
var d2 = "ABCDEFGHIJKLMNOPQRSTUVWX".split("");
|
||||||
|
var d4 = new Array(0, 1, 1, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5);
|
||||||
|
var locator = "";
|
||||||
|
var x = lon;
|
||||||
|
var y = lat;
|
||||||
|
var precision = d4[map.getZoom()];
|
||||||
|
while (x < -180) {x += 360;}
|
||||||
|
while (x > 180) {x -=360;}
|
||||||
|
x = x + 180;
|
||||||
|
y = y + 90;
|
||||||
|
locator = locator + d1[Math.floor(x/20)] + d1[Math.floor(y/10)];
|
||||||
|
for (var i=0; i<4; i=i+1) {
|
||||||
|
if (precision > i+1) {
|
||||||
|
rlon = x%(ydiv_arr[i]*2);
|
||||||
|
rlat = y%(ydiv_arr[i]);
|
||||||
|
if ((i%2)==0) {
|
||||||
|
locator += Math.floor(rlon/(ydiv_arr[i+1]*2)) +""+ Math.floor(rlat/(ydiv_arr[i+1]));
|
||||||
|
} else {
|
||||||
|
locator += d2[Math.floor(rlon/(ydiv_arr[i+1]*2))] +""+ d2[Math.floor(rlat/(ydiv_arr[i+1]))];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return locator;
|
||||||
|
},
|
||||||
|
|
||||||
|
/*
|
||||||
|
Need this for the field printing, while showing worked/confirmed grids
|
||||||
|
*/
|
||||||
|
_getLabel2: function(lon,lat) {
|
||||||
|
var title_size = new Array(0, 10, 12, 16, 20, 26, 26, 16, 24, 36, 12, 14, 20, 36, 60, 12, 20, 36, 60, 12, 24);
|
||||||
|
var zoom = map.getZoom();
|
||||||
|
var size = title_size[zoom]+'px';
|
||||||
|
var title = '<span class="grid-text" style="cursor: default;"><font style="color:'+this.options.color+'; font-size:'+size+'; font-weight: 900; ">' + this._getLocator2(lon,lat) + '</font></span>';
|
||||||
|
var myIcon = L.divIcon({className: 'my-div-icon', html: title});
|
||||||
|
var marker = L.marker([lat,lon], {icon: myIcon}, clickable=false);
|
||||||
|
return marker;
|
||||||
|
},
|
||||||
|
|
||||||
|
/*
|
||||||
|
Need this for the field printing, while showing worked/confirmed grids
|
||||||
|
*/
|
||||||
|
_getLocator2: function(lon,lat) {
|
||||||
|
var ydiv_arr=new Array(10, 1, 1/24, 1/240, 1/240/24);
|
||||||
|
var d1 = "ABCDEFGHIJKLMNOPQR".split("");
|
||||||
|
var d2 = "ABCDEFGHIJKLMNOPQRSTUVWX".split("");
|
||||||
|
var d4 = new Array(0, 1, 1, 1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5);
|
||||||
|
var locator = "";
|
||||||
|
var x = lon;
|
||||||
|
var y = lat;
|
||||||
|
var precision = d4[map.getZoom()];
|
||||||
|
while (x < -180) {x += 360;}
|
||||||
|
while (x > 180) {x -=360;}
|
||||||
|
x = x + 180;
|
||||||
|
y = y + 90;
|
||||||
|
locator = locator + d1[Math.floor(x/20)] + d1[Math.floor(y/10)];
|
||||||
|
for (var i=0; i<4; i=i+1) {
|
||||||
|
if (precision > i+1) {
|
||||||
|
rlon = x%(ydiv_arr[i]*2);
|
||||||
|
rlat = y%(ydiv_arr[i]);
|
||||||
|
if ((i%2)==0) {
|
||||||
|
locator += Math.floor(rlon/(ydiv_arr[i+1]*2)) +""+ Math.floor(rlat/(ydiv_arr[i+1]));
|
||||||
|
} else {
|
||||||
|
locator += d2[Math.floor(rlon/(ydiv_arr[i+1]*2))] +""+ d2[Math.floor(rlat/(ydiv_arr[i+1]))];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return locator;
|
||||||
|
},
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
L.maidenhead = function (options) {
|
||||||
|
return new L.Maidenhead(options);
|
||||||
|
};
|
||||||
112
assets/js/sections/gridmap.js
普通文件
112
assets/js/sections/gridmap.js
普通文件
|
|
@ -0,0 +1,112 @@
|
||||||
|
var map;
|
||||||
|
var grid_two = '';
|
||||||
|
var grid_four = '';
|
||||||
|
var grid_six = '';
|
||||||
|
var grid_two_confirmed = '';
|
||||||
|
var grid_four_confirmed = '';
|
||||||
|
var grid_six_confirmed = '';
|
||||||
|
|
||||||
|
function gridPlot(form) {
|
||||||
|
$('#plot').prop("disabled", true);
|
||||||
|
// If map is already initialized
|
||||||
|
var container = L.DomUtil.get('gridsquare_map');
|
||||||
|
|
||||||
|
if(container != null){
|
||||||
|
container._leaflet_id = null;
|
||||||
|
container.remove();
|
||||||
|
$("#gridmapcontainer").append('<div id="gridsquare_map" style="width: 100%; height: 800px"></div>');
|
||||||
|
}
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
url: site_url + '/gridmap/getGridsjs',
|
||||||
|
type: 'post',
|
||||||
|
data: {
|
||||||
|
band: $("#band").val(),
|
||||||
|
mode: $("#mode").val(),
|
||||||
|
qsl: $("#qsl").is(":checked"),
|
||||||
|
lotw: $("#lotw").is(":checked"),
|
||||||
|
eqsl: $("#eqsl").is(":checked")
|
||||||
|
},
|
||||||
|
success: function (data) {
|
||||||
|
$('#plot').prop("disabled", false);
|
||||||
|
grid_two = data.grid_2char;
|
||||||
|
grid_four = data.grid_4char;
|
||||||
|
grid_six = data.grid_6char;
|
||||||
|
grid_two_confirmed = data.grid_2char_confirmed;
|
||||||
|
grid_four_confirmed = data.grid_4char_confirmed;
|
||||||
|
grid_six_confirmed = data.grid_6char_confirmed;
|
||||||
|
var layer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
|
||||||
|
maxZoom: 9,
|
||||||
|
attribution: 'Map data © <a href="https://www.openstreetmap.org/">OpenStreetMap</a>',
|
||||||
|
id: 'mapbox.streets'
|
||||||
|
});
|
||||||
|
|
||||||
|
map = L.map('gridsquare_map', {
|
||||||
|
layers: [layer],
|
||||||
|
center: [19, 0],
|
||||||
|
zoom: 3,
|
||||||
|
minZoom: 2,
|
||||||
|
fullscreenControl: true,
|
||||||
|
fullscreenControlOptions: {
|
||||||
|
position: 'topleft'
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
var printer = L.easyPrint({
|
||||||
|
tileLayer: layer,
|
||||||
|
sizeModes: ['Current'],
|
||||||
|
filename: 'myMap',
|
||||||
|
exportOnly: true,
|
||||||
|
hideControlContainer: true
|
||||||
|
}).addTo(map);
|
||||||
|
var maidenhead = L.maidenhead().addTo(map);
|
||||||
|
},
|
||||||
|
error: function (data) {
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function spawnGridsquareModal(loc_4char) {
|
||||||
|
$.ajax({
|
||||||
|
url: base_url + 'index.php/awards/qso_details_ajax',
|
||||||
|
type: 'post',
|
||||||
|
data: {
|
||||||
|
'Searchphrase': loc_4char,
|
||||||
|
'Band': $("#band").val(),
|
||||||
|
'Mode': $("#mode").val(),
|
||||||
|
'Type': 'VUCC'
|
||||||
|
},
|
||||||
|
success: function (html) {
|
||||||
|
BootstrapDialog.show({
|
||||||
|
title: 'QSO Data',
|
||||||
|
cssClass: 'qso-dialog',
|
||||||
|
size: BootstrapDialog.SIZE_WIDE,
|
||||||
|
nl2br: false,
|
||||||
|
message: html,
|
||||||
|
onshown: function(dialog) {
|
||||||
|
|
||||||
|
$('[data-toggle="tooltip"]').tooltip();
|
||||||
|
$('.contacttable').DataTable({
|
||||||
|
"pageLength": 25,
|
||||||
|
responsive: false,
|
||||||
|
ordering: false,
|
||||||
|
"scrollY": "550px",
|
||||||
|
"scrollCollapse": true,
|
||||||
|
"paging": false,
|
||||||
|
"scrollX": true,
|
||||||
|
dom: 'Bfrtip',
|
||||||
|
buttons: [
|
||||||
|
'csv'
|
||||||
|
]
|
||||||
|
});
|
||||||
|
},
|
||||||
|
buttons: [{
|
||||||
|
label: 'Close',
|
||||||
|
action: function(dialogItself) {
|
||||||
|
dialogItself.close();
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
正在加载…
在新工单中引用