Adds DXpeditions this week to dashboard
这个提交包含在:
		
							父节点
							
								
									f16a2716d8
								
							
						
					
					
						当前提交
						0db9b37f73
					
				
					共有  4 个文件被更改,包括 614 次插入 和 317 次删除
				
			
		|  | @ -127,6 +127,15 @@ class Dashboard extends CI_Controller | ||||||
| 
 | 
 | ||||||
| 			$data['total_countries_needed'] = count($dxcc->result()) - $current; | 			$data['total_countries_needed'] = count($dxcc->result()) - $current; | ||||||
| 
 | 
 | ||||||
|  | 			$this->load->model('Workabledxcc_model'); | ||||||
|  | 			$data['thisWeekRecords'] = $this->Workabledxcc_model->GetThisWeek(); | ||||||
|  | 
 | ||||||
|  | 			usort($data['thisWeekRecords'], function($a, $b) { | ||||||
|  | 				$dateA = new DateTime($a['1']); | ||||||
|  | 				$dateB = new DateTime($b['1']); | ||||||
|  | 				return $dateA <=> $dateB; | ||||||
|  | 			}); | ||||||
|  | 
 | ||||||
| 			$this->load->view('interface_assets/header', $data); | 			$this->load->view('interface_assets/header', $data); | ||||||
| 			$this->load->view('dashboard/index'); | 			$this->load->view('dashboard/index'); | ||||||
| 			$this->load->view('interface_assets/footer'); | 			$this->load->view('interface_assets/footer'); | ||||||
|  |  | ||||||
|  | @ -166,4 +166,5 @@ class Workabledxcc extends CI_Controller | ||||||
| 			return $return;; | 			return $return;; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -0,0 +1,163 @@ | ||||||
|  | <?php | ||||||
|  | 
 | ||||||
|  | class Workabledxcc_model extends CI_Model | ||||||
|  | { | ||||||
|  | 
 | ||||||
|  |     public function GetThisWeek() | ||||||
|  |     { | ||||||
|  |         $json = file_get_contents('https://cdn.cloudlog.org/read_ng3k_dxped_list.php'); | ||||||
|  | 
 | ||||||
|  |         // Step 2: Convert the JSON data to an array.
 | ||||||
|  |         $data = json_decode($json, true); | ||||||
|  | 
 | ||||||
|  |         // Step 3: Create a new array to hold the records for this week.
 | ||||||
|  |         $thisWeekRecords = []; | ||||||
|  | 
 | ||||||
|  |         // Get the start and end of this week.
 | ||||||
|  |         $startOfWeek = (new DateTime())->setISODate((new DateTime())->format('o'), (new DateTime())->format('W'), 1); | ||||||
|  |         $endOfWeek = (clone $startOfWeek)->modify('+6 days'); | ||||||
|  | 
 | ||||||
|  |         // Step 4: Iterate over the array.
 | ||||||
|  |         foreach ($data as $record) { | ||||||
|  | 
 | ||||||
|  |             // Convert "0" and "1" to DateTime objects.
 | ||||||
|  |             $startDate = new DateTime($record['0']); | ||||||
|  |             $endDate = new DateTime($record['1']); | ||||||
|  | 
 | ||||||
|  |             // Step 5: Check if the start date or end date is within this week.
 | ||||||
|  |             if (($startDate >= $startOfWeek && $startDate <= $endOfWeek) || ($endDate >= $startOfWeek && $endDate <= $endOfWeek)) { | ||||||
|  |                 $endDate = new DateTime($record['1']); | ||||||
|  |                 $now = new DateTime(); | ||||||
|  |                 $interval = $now->diff($endDate); | ||||||
|  |                 $daysLeft = $interval->days; | ||||||
|  | 
 | ||||||
|  |                 // If daysLeft is 0, set it to "Last day"
 | ||||||
|  |                 if ($daysLeft == 0) { | ||||||
|  |                     $daysLeft = "Last day"; | ||||||
|  |                 } else { | ||||||
|  |                     $daysLeft = $daysLeft . " days left"; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Add daysLeft to record
 | ||||||
|  |                 $record['daysLeft'] = $daysLeft; | ||||||
|  |                 // Get Date format
 | ||||||
|  |                 if ($this->session->userdata('user_date_format')) { | ||||||
|  |                     // If Logged in and session exists
 | ||||||
|  |                     $custom_date_format = $this->session->userdata('user_date_format'); | ||||||
|  |                 } else { | ||||||
|  |                     // Get Default date format from /config/cloudlog.php
 | ||||||
|  |                     $custom_date_format = $this->config->item('qso_date_format'); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 // Create a new array with the required fields and add it to the main array
 | ||||||
|  |                 $oldStartDate = DateTime::createFromFormat('Y-m-d', $record['0']); | ||||||
|  | 
 | ||||||
|  |                 $StartDate = $oldStartDate->format($custom_date_format); | ||||||
|  |                 $record['startDate'] = $StartDate; | ||||||
|  | 
 | ||||||
|  |                 $oldEndDate = DateTime::createFromFormat('Y-m-d', $record['1']); | ||||||
|  |                 $EndDate = $oldEndDate->format($custom_date_format); | ||||||
|  |                 $record['endDate'] = $EndDate; | ||||||
|  | 
 | ||||||
|  |                 $record['confirmed'] = true; // or false, depending on your logic
 | ||||||
|  | 
 | ||||||
|  |                 $CI = &get_instance(); | ||||||
|  |                 $CI->load->model('logbook_model'); | ||||||
|  |                 $dxccInfo = $CI->logbook_model->dxcc_lookup($record['3'], $startDate->format('Y-m-d')); | ||||||
|  | 
 | ||||||
|  |                 // Call DXCC Worked function to check if the DXCC has been worked before
 | ||||||
|  |                 if (isset($dxccInfo['entity'])) { | ||||||
|  |                     $dxccWorkedData = $this->dxccWorked($dxccInfo['entity']); | ||||||
|  |                     $record = array_merge($record, $dxccWorkedData); | ||||||
|  |                 } else { | ||||||
|  |                     // Handle the case where 'entity' is not set in $dxccInfo
 | ||||||
|  |                     $itemsToAdd = array( | ||||||
|  |                         'workedBefore' => false, | ||||||
|  |                         'confirmed' => false, | ||||||
|  |                     ); | ||||||
|  |                     $record = array_merge($record, $itemsToAdd); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 $thisWeekRecords[] = $record; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return $thisWeekRecords; | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function dxccWorked($country) | ||||||
|  |     { | ||||||
|  | 
 | ||||||
|  |         $return = [ | ||||||
|  |             "workedBefore" => false, | ||||||
|  |             "confirmed" => false, | ||||||
|  |         ]; | ||||||
|  | 
 | ||||||
|  |         $user_default_confirmation = $this->session->userdata('user_default_confirmation'); | ||||||
|  |         $this->load->model('logbooks_model'); | ||||||
|  |         $logbooks_locations_array = $this->logbooks_model->list_logbook_relationships($this->session->userdata('active_station_logbook')); | ||||||
|  |         $this->load->model('logbook_model'); | ||||||
|  | 
 | ||||||
|  |         if (!empty($logbooks_locations_array)) { | ||||||
|  |             $this->db->where('COL_PROP_MODE !=', 'SAT'); | ||||||
|  | 
 | ||||||
|  |             $this->db->where_in('station_id', $logbooks_locations_array); | ||||||
|  |             $this->db->where('COL_COUNTRY', urldecode($country)); | ||||||
|  | 
 | ||||||
|  |             $query = $this->db->get($this->config->item('table_name'), 1, 0); | ||||||
|  |             foreach ($query->result() as $workedBeforeRow) { | ||||||
|  |                 $return['workedBefore'] = true; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             $extrawhere = ''; | ||||||
|  |             if (isset($user_default_confirmation) && strpos($user_default_confirmation, 'Q') !== false) { | ||||||
|  |                 $extrawhere = "COL_QSL_RCVD='Y'"; | ||||||
|  |             } | ||||||
|  |             if (isset($user_default_confirmation) && strpos($user_default_confirmation, 'L') !== false) { | ||||||
|  |                 if ($extrawhere != '') { | ||||||
|  |                     $extrawhere .= " OR"; | ||||||
|  |                 } | ||||||
|  |                 $extrawhere .= " COL_LOTW_QSL_RCVD='Y'"; | ||||||
|  |             } | ||||||
|  |             if (isset($user_default_confirmation) && strpos($user_default_confirmation, 'E') !== false) { | ||||||
|  |                 if ($extrawhere != '') { | ||||||
|  |                     $extrawhere .= " OR"; | ||||||
|  |                 } | ||||||
|  |                 $extrawhere .= " COL_EQSL_QSL_RCVD='Y'"; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (isset($user_default_confirmation) && strpos($user_default_confirmation, 'Z') !== false) { | ||||||
|  |                 if ($extrawhere != '') { | ||||||
|  |                     $extrawhere .= " OR"; | ||||||
|  |                 } | ||||||
|  |                 $extrawhere .= " COL_QRZCOM_QSO_DOWNLOAD_STATUS='Y'"; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             $this->load->model('logbook_model'); | ||||||
|  |             $this->db->where('COL_PROP_MODE !=', 'SAT'); | ||||||
|  |             if ($extrawhere != '') { | ||||||
|  |                 $this->db->where('(' . $extrawhere . ')'); | ||||||
|  |             } else { | ||||||
|  |                 $this->db->where("1=0"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             $this->db->where_in('station_id', $logbooks_locations_array); | ||||||
|  |             $this->db->where('COL_COUNTRY', urldecode($country)); | ||||||
|  | 
 | ||||||
|  |             $query = $this->db->get($this->config->item('table_name'), 1, 0); | ||||||
|  |             foreach ($query->result() as $workedBeforeRow) { | ||||||
|  |                 $return['confirmed'] = true; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return $return; | ||||||
|  |         } else { | ||||||
|  |             $return['workedBefore'] = false; | ||||||
|  |             $return['confirmed'] = false; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             return $return;; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -1,356 +1,480 @@ | ||||||
| <?php | <?php | ||||||
| function echo_table_header_col($ctx, $name) { | function echo_table_header_col($ctx, $name) | ||||||
| 	switch($name) { | { | ||||||
| 		case 'Mode': echo '<th>'.$ctx->lang->line('gen_hamradio_mode').'</th>'; break; | 	switch ($name) { | ||||||
| 		case 'RSTS': echo '<th class="d-none d-sm-table-cell">'.$ctx->lang->line('gen_hamradio_rsts').'</th>'; break; | 		case 'Mode': | ||||||
| 		case 'RSTR': echo '<th class="d-none d-sm-table-cell">'.$ctx->lang->line('gen_hamradio_rstr').'</th>'; break; | 			echo '<th>' . $ctx->lang->line('gen_hamradio_mode') . '</th>'; | ||||||
| 		case 'Country': echo '<th>'.$ctx->lang->line('general_word_country').'</th>'; break; | 			break; | ||||||
| 		case 'IOTA': echo '<th>'.$ctx->lang->line('gen_hamradio_iota').'</th>'; break; | 		case 'RSTS': | ||||||
| 		case 'SOTA': echo '<th>'.$ctx->lang->line('gen_hamradio_sota').'</th>'; break; | 			echo '<th class="d-none d-sm-table-cell">' . $ctx->lang->line('gen_hamradio_rsts') . '</th>'; | ||||||
| 		case 'WWFF': echo '<th>'.$ctx->lang->line('gen_hamradio_wwff').'</th>'; break; | 			break; | ||||||
| 		case 'POTA': echo '<th>'.$ctx->lang->line('gen_hamradio_pota').'</th>'; break; | 		case 'RSTR': | ||||||
| 		case 'State': echo '<th>'.$ctx->lang->line('gen_hamradio_state').'</th>'; break; | 			echo '<th class="d-none d-sm-table-cell">' . $ctx->lang->line('gen_hamradio_rstr') . '</th>'; | ||||||
| 		case 'Grid': echo '<th>'.$ctx->lang->line('gen_hamradio_gridsquare').'</th>'; break; | 			break; | ||||||
| 		case 'Distance': echo '<th>'.$ctx->lang->line('gen_hamradio_distance').'</th>'; break; | 		case 'Country': | ||||||
| 		case 'Band': echo '<th>'.$ctx->lang->line('gen_hamradio_band').'</th>'; break; | 			echo '<th>' . $ctx->lang->line('general_word_country') . '</th>'; | ||||||
| 		case 'Frequency': echo '<th>'.$ctx->lang->line('gen_hamradio_frequency').'</th>'; break; | 			break; | ||||||
| 		case 'Operator': echo '<th>'.$ctx->lang->line('gen_hamradio_operator').'</th>'; break; | 		case 'IOTA': | ||||||
| 		case 'Name': echo '<th>'.$ctx->lang->line('general_word_name').'</th>'; break; | 			echo '<th>' . $ctx->lang->line('gen_hamradio_iota') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'SOTA': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_sota') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'WWFF': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_wwff') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'POTA': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_pota') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'State': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_state') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Grid': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_gridsquare') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Distance': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_distance') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Band': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_band') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Frequency': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_frequency') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Operator': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('gen_hamradio_operator') . '</th>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Name': | ||||||
|  | 			echo '<th>' . $ctx->lang->line('general_word_name') . '</th>'; | ||||||
|  | 			break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function echo_table_col($row, $name) { | function echo_table_col($row, $name) | ||||||
| 	$ci =& get_instance(); | { | ||||||
| 	switch($name) { | 	$ci = &get_instance(); | ||||||
| 		case 'Mode':    echo '<td>'; echo $row->COL_SUBMODE==null?$row->COL_MODE:$row->COL_SUBMODE . '</td>'; break; | 	switch ($name) { | ||||||
|       case 'RSTS':    echo '<td class="d-none d-sm-table-cell">' . $row->COL_RST_SENT; if ($row->COL_STX) { echo ' <span data-bs-toggle="tooltip" title="'.($row->COL_CONTEST_ID!=""?$row->COL_CONTEST_ID:"n/a").'" class="badge text-bg-light">'; printf("%03d", $row->COL_STX); echo '</span>';} if ($row->COL_STX_STRING) { echo ' <span data-bs-toggle="tooltip" title="'.($row->COL_CONTEST_ID!=""?$row->COL_CONTEST_ID:"n/a").'" class="badge text-bg-light">' . $row->COL_STX_STRING . '</span>';} echo '</td>'; break; | 		case 'Mode': | ||||||
|       case 'RSTR':    echo '<td class="d-none d-sm-table-cell">' . $row->COL_RST_RCVD; if ($row->COL_SRX) { echo ' <span data-bs-toggle="tooltip" title="'.($row->COL_CONTEST_ID!=""?$row->COL_CONTEST_ID:"n/a").'" class="badge text-bg-light">'; printf("%03d", $row->COL_SRX); echo '</span>';} if ($row->COL_SRX_STRING) { echo ' <span data-bs-toggle="tooltip" title="'.($row->COL_CONTEST_ID!=""?$row->COL_CONTEST_ID:"n/a").'" class="badge text-bg-light">' . $row->COL_SRX_STRING . '</span>';} echo '</td>'; break; | 			echo '<td>'; | ||||||
| 		case 'Country': echo '<td>' . ucwords(strtolower(($row->COL_COUNTRY))); if ($row->end != NULL) echo ' <span class="badge text-bg-danger">'.$ci->lang->line('gen_hamradio_deleted_dxcc').'</span>'  . '</td>'; break; | 			echo $row->COL_SUBMODE == null ? $row->COL_MODE : $row->COL_SUBMODE . '</td>'; | ||||||
| 		case 'IOTA':    echo '<td>' . ($row->COL_IOTA) . '</td>'; break; | 			break; | ||||||
| 		case 'SOTA':    echo '<td>' . ($row->COL_SOTA_REF) . '</td>'; break; | 		case 'RSTS': | ||||||
| 		case 'WWFF':    echo '<td>' . ($row->COL_WWFF_REF) . '</td>'; break; | 			echo '<td class="d-none d-sm-table-cell">' . $row->COL_RST_SENT; | ||||||
| 		case 'POTA':    echo '<td>' . ($row->COL_POTA_REF) . '</td>'; break; | 			if ($row->COL_STX) { | ||||||
| 		case 'Grid':    echo '<td>'; echoQrbCalcLink($row->station_gridsquare, $row->COL_VUCC_GRIDS, $row->COL_GRIDSQUARE); echo '</td>'; break; | 				echo ' <span data-bs-toggle="tooltip" title="' . ($row->COL_CONTEST_ID != "" ? $row->COL_CONTEST_ID : "n/a") . '" class="badge text-bg-light">'; | ||||||
| 		case 'Distance':    echo '<td>' . ($row->COL_DISTANCE ? $row->COL_DISTANCE . ' km' : '') . '</td>'; break; | 				printf("%03d", $row->COL_STX); | ||||||
| 		case 'Band':    echo '<td>'; if($row->COL_SAT_NAME != null) { echo '<a href="https://db.satnogs.org/search/?q='.$row->COL_SAT_NAME.'" target="_blank">'.$row->COL_SAT_NAME.'</a></td>'; } else { echo strtolower($row->COL_BAND); } echo '</td>'; break; | 				echo '</span>'; | ||||||
| 		case 'Frequency':    echo '<td>'; if($row->COL_SAT_NAME != null) { echo '<a href="https://db.satnogs.org/search/?q='.$row->COL_SAT_NAME.'" target="_blank">'.$row->COL_SAT_NAME.'</a></td>'; } else { if($row->COL_FREQ != null) { echo $ci->frequency->hz_to_mhz($row->COL_FREQ); } else { echo strtolower($row->COL_BAND); } } echo '</td>'; break; | 			} | ||||||
| 		case 'State':   echo '<td>' . ($row->COL_STATE) . '</td>'; break; | 			if ($row->COL_STX_STRING) { | ||||||
| 		case 'Operator': echo '<td>' . ($row->COL_OPERATOR) . '</td>'; break; | 				echo ' <span data-bs-toggle="tooltip" title="' . ($row->COL_CONTEST_ID != "" ? $row->COL_CONTEST_ID : "n/a") . '" class="badge text-bg-light">' . $row->COL_STX_STRING . '</span>'; | ||||||
| 		case 'Name': echo '<td>' . ($row->COL_NAME) . '</td>'; break; | 			} | ||||||
|  | 			echo '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'RSTR': | ||||||
|  | 			echo '<td class="d-none d-sm-table-cell">' . $row->COL_RST_RCVD; | ||||||
|  | 			if ($row->COL_SRX) { | ||||||
|  | 				echo ' <span data-bs-toggle="tooltip" title="' . ($row->COL_CONTEST_ID != "" ? $row->COL_CONTEST_ID : "n/a") . '" class="badge text-bg-light">'; | ||||||
|  | 				printf("%03d", $row->COL_SRX); | ||||||
|  | 				echo '</span>'; | ||||||
|  | 			} | ||||||
|  | 			if ($row->COL_SRX_STRING) { | ||||||
|  | 				echo ' <span data-bs-toggle="tooltip" title="' . ($row->COL_CONTEST_ID != "" ? $row->COL_CONTEST_ID : "n/a") . '" class="badge text-bg-light">' . $row->COL_SRX_STRING . '</span>'; | ||||||
|  | 			} | ||||||
|  | 			echo '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Country': | ||||||
|  | 			echo '<td>' . ucwords(strtolower(($row->COL_COUNTRY))); | ||||||
|  | 			if ($row->end != NULL) echo ' <span class="badge text-bg-danger">' . $ci->lang->line('gen_hamradio_deleted_dxcc') . '</span>'  . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'IOTA': | ||||||
|  | 			echo '<td>' . ($row->COL_IOTA) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'SOTA': | ||||||
|  | 			echo '<td>' . ($row->COL_SOTA_REF) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'WWFF': | ||||||
|  | 			echo '<td>' . ($row->COL_WWFF_REF) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'POTA': | ||||||
|  | 			echo '<td>' . ($row->COL_POTA_REF) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Grid': | ||||||
|  | 			echo '<td>'; | ||||||
|  | 			echoQrbCalcLink($row->station_gridsquare, $row->COL_VUCC_GRIDS, $row->COL_GRIDSQUARE); | ||||||
|  | 			echo '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Distance': | ||||||
|  | 			echo '<td>' . ($row->COL_DISTANCE ? $row->COL_DISTANCE . ' km' : '') . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Band': | ||||||
|  | 			echo '<td>'; | ||||||
|  | 			if ($row->COL_SAT_NAME != null) { | ||||||
|  | 				echo '<a href="https://db.satnogs.org/search/?q=' . $row->COL_SAT_NAME . '" target="_blank">' . $row->COL_SAT_NAME . '</a></td>'; | ||||||
|  | 			} else { | ||||||
|  | 				echo strtolower($row->COL_BAND); | ||||||
|  | 			} | ||||||
|  | 			echo '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Frequency': | ||||||
|  | 			echo '<td>'; | ||||||
|  | 			if ($row->COL_SAT_NAME != null) { | ||||||
|  | 				echo '<a href="https://db.satnogs.org/search/?q=' . $row->COL_SAT_NAME . '" target="_blank">' . $row->COL_SAT_NAME . '</a></td>'; | ||||||
|  | 			} else { | ||||||
|  | 				if ($row->COL_FREQ != null) { | ||||||
|  | 					echo $ci->frequency->hz_to_mhz($row->COL_FREQ); | ||||||
|  | 				} else { | ||||||
|  | 					echo strtolower($row->COL_BAND); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			echo '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'State': | ||||||
|  | 			echo '<td>' . ($row->COL_STATE) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Operator': | ||||||
|  | 			echo '<td>' . ($row->COL_OPERATOR) . '</td>'; | ||||||
|  | 			break; | ||||||
|  | 		case 'Name': | ||||||
|  | 			echo '<td>' . ($row->COL_NAME) . '</td>'; | ||||||
|  | 			break; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function echoQrbCalcLink($mygrid, $grid, $vucc) { | function echoQrbCalcLink($mygrid, $grid, $vucc) | ||||||
|  | { | ||||||
| 	if (!empty($grid)) { | 	if (!empty($grid)) { | ||||||
| 		echo $grid . ' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $grid . '\')"><i class="fas fa-globe"></i></a>'; | 		echo $grid . ' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $grid . '\')"><i class="fas fa-globe"></i></a>'; | ||||||
| 	} else if (!empty($vucc)) { | 	} else if (!empty($vucc)) { | ||||||
| 		echo $vucc .' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $vucc . '\')"><i class="fas fa-globe"></i></a>'; | 		echo $vucc . ' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $vucc . '\')"><i class="fas fa-globe"></i></a>'; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| ?>
 | ?>
 | ||||||
| <div class="container dashboard"> | <div class="container dashboard"> | ||||||
| <?php if(($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) { ?>
 | 	<?php if (($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) { ?>
 | ||||||
| 
 | 
 | ||||||
| 	<?php if (version_compare(PHP_VERSION, '7.4.0') <= 0) { ?>
 | 		<?php if (version_compare(PHP_VERSION, '7.4.0') <= 0) { ?>
 | ||||||
| 		<div class="alert alert-danger" role="alert"> |  | ||||||
| 		<?php echo lang('dashboard_php_version_warning') . ' ' . PHP_VERSION . '.';?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if ($countryCount == 0) { ?>
 |  | ||||||
| 		<div class="alert alert-danger" role="alert"> |  | ||||||
| 		<?php echo lang('dashboard_country_files_warning'); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if ($locationCount == 0) { ?>
 |  | ||||||
| 		<div class="alert alert-danger" role="alert"> |  | ||||||
| 		<?php echo lang('dashboard_locations_warning'); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if ($logbookCount == 0) { ?>
 |  | ||||||
| 		<div class="alert alert-danger" role="alert"> |  | ||||||
| 		<?php echo lang('dashboard_logbooks_warning'); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if($this->optionslib->get_option('dashboard_banner') != "false") { ?>
 |  | ||||||
| 	<?php if($todays_qsos >= 1) { ?>
 |  | ||||||
| 		<div class="alert alert-success" role="alert"> |  | ||||||
| 			  <?php echo lang('dashboard_you_have_had'); ?> <strong><?php echo $todays_qsos; ?></strong> <?php echo $todays_qsos != 1 ? lang('dashboard_qsos_today') : str_replace('QSOs', 'QSO', lang('dashboard_qsos_today')); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } else { ?>
 |  | ||||||
| 		<div class="alert alert-warning" role="alert"> |  | ||||||
| 			  <span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-broadcast-tower"></i> <?php echo lang('notice_turn_the_radio_on'); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if($current_active == 0) { ?>
 |  | ||||||
| 		<div class="alert alert-danger" role="alert"> |  | ||||||
| 		  <?php echo lang('error_no_active_station_profile'); ?>
 |  | ||||||
| 		</div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 	<?php if ($this->session->userdata('user_id')) { ?>
 |  | ||||||
| 		<?php |  | ||||||
| 			$current_date = date('Y-m-d H:i:s'); |  | ||||||
| 			if($this->LotwCert->lotw_cert_expired($this->session->userdata('user_id'), $current_date) == true) { ?>
 |  | ||||||
| 			<div class="alert alert-danger" role="alert"> | 			<div class="alert alert-danger" role="alert"> | ||||||
| 				<span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-hourglass-end"></i> <?php echo lang('lotw_cert_expired'); ?>
 | 				<?php echo lang('dashboard_php_version_warning') . ' ' . PHP_VERSION . '.'; ?>
 | ||||||
| 			</div> | 			</div> | ||||||
| 		<?php } ?>
 | 		<?php } ?>
 | ||||||
| 
 | 
 | ||||||
| 		<?php if($this->LotwCert->lotw_cert_expiring($this->session->userdata('user_id'), $current_date) == true) { ?>
 | 		<?php if ($countryCount == 0) { ?>
 | ||||||
| 			<div class="alert alert-warning" role="alert"> | 			<div class="alert alert-danger" role="alert"> | ||||||
| 				<span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-hourglass-half"></i> <?php echo lang('lotw_cert_expiring'); ?>
 | 				<?php echo lang('dashboard_country_files_warning'); ?>
 | ||||||
| 			</div> | 			</div> | ||||||
| 		<?php } ?>
 | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 		<?php if ($locationCount == 0) { ?>
 | ||||||
|  | 			<div class="alert alert-danger" role="alert"> | ||||||
|  | 				<?php echo lang('dashboard_locations_warning'); ?>
 | ||||||
|  | 			</div> | ||||||
|  | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 		<?php if ($logbookCount == 0) { ?>
 | ||||||
|  | 			<div class="alert alert-danger" role="alert"> | ||||||
|  | 				<?php echo lang('dashboard_logbooks_warning'); ?>
 | ||||||
|  | 			</div> | ||||||
|  | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 		<?php if ($this->optionslib->get_option('dashboard_banner') != "false") { ?>
 | ||||||
|  | 			<?php if ($todays_qsos >= 1) { ?>
 | ||||||
|  | 				<div class="alert alert-success" role="alert"> | ||||||
|  | 					<?php echo lang('dashboard_you_have_had'); ?> <strong><?php echo $todays_qsos; ?></strong> <?php echo $todays_qsos != 1 ? lang('dashboard_qsos_today') : str_replace('QSOs', 'QSO', lang('dashboard_qsos_today')); ?>
 | ||||||
|  | 				</div> | ||||||
|  | 			<?php } else { ?>
 | ||||||
|  | 				<div class="alert alert-warning" role="alert"> | ||||||
|  | 					<span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-broadcast-tower"></i> <?php echo lang('notice_turn_the_radio_on'); ?>
 | ||||||
|  | 				</div> | ||||||
|  | 			<?php } ?>
 | ||||||
|  | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 		<?php if ($current_active == 0) { ?>
 | ||||||
|  | 			<div class="alert alert-danger" role="alert"> | ||||||
|  | 				<?php echo lang('error_no_active_station_profile'); ?>
 | ||||||
|  | 			</div> | ||||||
|  | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 		<?php if ($this->session->userdata('user_id')) { ?>
 | ||||||
|  | 			<?php | ||||||
|  | 			$current_date = date('Y-m-d H:i:s'); | ||||||
|  | 			if ($this->LotwCert->lotw_cert_expired($this->session->userdata('user_id'), $current_date) == true) { ?>
 | ||||||
|  | 				<div class="alert alert-danger" role="alert"> | ||||||
|  | 					<span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-hourglass-end"></i> <?php echo lang('lotw_cert_expired'); ?>
 | ||||||
|  | 				</div> | ||||||
|  | 			<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 			<?php if ($this->LotwCert->lotw_cert_expiring($this->session->userdata('user_id'), $current_date) == true) { ?>
 | ||||||
|  | 				<div class="alert alert-warning" role="alert"> | ||||||
|  | 					<span class="badge text-bg-info"><?php echo lang('general_word_important'); ?></span> <i class="fas fa-hourglass-half"></i> <?php echo lang('lotw_cert_expiring'); ?>
 | ||||||
|  | 				</div> | ||||||
|  | 			<?php } ?>
 | ||||||
|  | 		<?php } ?>
 | ||||||
|  | 
 | ||||||
| 	<?php } ?>
 | 	<?php } ?>
 | ||||||
| 
 |  | ||||||
| <?php } ?>
 |  | ||||||
| </div> | </div> | ||||||
| 
 | 
 | ||||||
| <?php if($this->config->item('option_dashboard_map ') != "false" && $this->config->item('option_dashboard_map ') != "map_at_right") { ?>
 | <?php if ($this->config->item('option_dashboard_map ') != "false" && $this->config->item('option_dashboard_map ') != "map_at_right") { ?>
 | ||||||
| <!-- Map --> | 	<!-- Map --> | ||||||
| <div id="map" class="map-leaflet" style="width: 100%; height: 350px"></div> | 	<div id="map" class="map-leaflet" style="width: 100%; height: 350px"></div> | ||||||
| <?php } ?>
 | <?php } ?>
 | ||||||
| <div style="padding-top: 0px; margin-top: 5px;" class="container dashboard"> | <div style="padding-top: 0px; margin-top: 5px;" class="container dashboard"> | ||||||
| 
 | 
 | ||||||
| <!-- Log Data --> | 	<!-- Log Data --> | ||||||
| <div class="row logdata"> | 	<div class="row logdata"> | ||||||
|   <div class="col-sm-8"> | 		<div class="col-sm-8"> | ||||||
| 
 | 
 | ||||||
|   	<div class="table-responsive"> | 			<div class="table-responsive"> | ||||||
|     	<table class="table table-striped table-hover border-top"> | 				<table class="table table-striped table-hover border-top"> | ||||||
| 
 | 
 | ||||||
|     		<thead> | 					<thead> | ||||||
| 				<tr class="titles"> | 						<tr class="titles"> | ||||||
| 					<th><?php echo lang('general_word_date'); ?></th>
 | 							<th><?php echo lang('general_word_date'); ?></th>
 | ||||||
| 
 | 
 | ||||||
| 					<?php if(($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE || ($this->config->item('show_time'))) { ?>
 | 							<?php if (($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE || ($this->config->item('show_time'))) { ?>
 | ||||||
| 					<th><?php echo lang('general_word_time'); ?></th>
 | 								<th><?php echo lang('general_word_time'); ?></th>
 | ||||||
| 					<?php } ?>
 | 							<?php } ?>
 | ||||||
| 					<th><?php echo lang('gen_hamradio_call'); ?></th>
 | 							<th><?php echo lang('gen_hamradio_call'); ?></th>
 | ||||||
| 					<?php | 							<?php | ||||||
| 					echo_table_header_col($this, $this->session->userdata('user_column1')==""?'Mode':$this->session->userdata('user_column1')); | 							echo_table_header_col($this, $this->session->userdata('user_column1') == "" ? 'Mode' : $this->session->userdata('user_column1')); | ||||||
| 					echo_table_header_col($this, $this->session->userdata('user_column2')==""?'RSTS':$this->session->userdata('user_column2')); | 							echo_table_header_col($this, $this->session->userdata('user_column2') == "" ? 'RSTS' : $this->session->userdata('user_column2')); | ||||||
| 					echo_table_header_col($this, $this->session->userdata('user_column3')==""?'RSTR':$this->session->userdata('user_column3')); | 							echo_table_header_col($this, $this->session->userdata('user_column3') == "" ? 'RSTR' : $this->session->userdata('user_column3')); | ||||||
| 					echo_table_header_col($this, $this->session->userdata('user_column4')==""?'Band':$this->session->userdata('user_column4')); | 							echo_table_header_col($this, $this->session->userdata('user_column4') == "" ? 'Band' : $this->session->userdata('user_column4')); | ||||||
| 				?>
 | 							?>
 | ||||||
| 				</tr> | 						</tr> | ||||||
| 			</thead> | 					</thead> | ||||||
| 
 |  | ||||||
| 			<?php |  | ||||||
| 			$i = 0; |  | ||||||
| 			if(!empty($last_five_qsos) > 0) { |  | ||||||
| 			foreach ($last_five_qsos->result() as $row) { ?>
 |  | ||||||
| 				<?php  echo '<tr id="qso_'.$row->COL_PRIMARY_KEY.'" class="tr'.($i & 1).'">'; ?>
 |  | ||||||
| 
 | 
 | ||||||
| 					<?php | 					<?php | ||||||
|  | 					$i = 0; | ||||||
|  | 					if (!empty($last_five_qsos) > 0) { | ||||||
|  | 						foreach ($last_five_qsos->result() as $row) { ?>
 | ||||||
|  | 							<?php echo '<tr id="qso_' . $row->COL_PRIMARY_KEY . '" class="tr' . ($i & 1) . '">'; ?>
 | ||||||
| 
 | 
 | ||||||
| 					// Get Date format
 | 							<?php | ||||||
| 					if($this->session->userdata('user_date_format')) { | 
 | ||||||
| 						// If Logged in and session exists
 | 							// Get Date format
 | ||||||
| 						$custom_date_format = $this->session->userdata('user_date_format'); | 							if ($this->session->userdata('user_date_format')) { | ||||||
| 					} else { | 								// If Logged in and session exists
 | ||||||
| 						// Get Default date format from /config/cloudlog.php
 | 								$custom_date_format = $this->session->userdata('user_date_format'); | ||||||
| 						$custom_date_format = $this->config->item('qso_date_format'); | 							} else { | ||||||
|  | 								// Get Default date format from /config/cloudlog.php
 | ||||||
|  | 								$custom_date_format = $this->config->item('qso_date_format'); | ||||||
|  | 							} | ||||||
|  | 
 | ||||||
|  | 							?>
 | ||||||
|  | 
 | ||||||
|  | 							<td><?php $timestamp = strtotime($row->COL_TIME_ON); | ||||||
|  | 								echo date($custom_date_format, $timestamp); ?></td>
 | ||||||
|  | 							<?php if (($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE || ($this->config->item('show_time'))) { ?>
 | ||||||
|  | 								<td><?php $timestamp = strtotime($row->COL_TIME_ON); | ||||||
|  | 									echo date('H:i', $timestamp); ?></td>
 | ||||||
|  | 
 | ||||||
|  | 							<?php } ?>
 | ||||||
|  | 							<td> | ||||||
|  | 								<a id="edit_qso" href="javascript:displayQso(<?php echo $row->COL_PRIMARY_KEY; ?>)"><?php echo str_replace("0", "Ø", strtoupper($row->COL_CALL)); ?></a>
 | ||||||
|  | 							</td> | ||||||
|  | 							<?php | ||||||
|  | 							echo_table_col($row, $this->session->userdata('user_column1') == "" ? 'Mode' : $this->session->userdata('user_column1')); | ||||||
|  | 							echo_table_col($row, $this->session->userdata('user_column2') == "" ? 'RSTS' : $this->session->userdata('user_column2')); | ||||||
|  | 							echo_table_col($row, $this->session->userdata('user_column3') == "" ? 'RSTR' : $this->session->userdata('user_column3')); | ||||||
|  | 							echo_table_col($row, $this->session->userdata('user_column4') == "" ? 'Band' : $this->session->userdata('user_column4')); | ||||||
|  | 							?>
 | ||||||
|  | 							</tr> | ||||||
|  | 					<?php $i++; | ||||||
|  | 						} | ||||||
|  | 					} ?>
 | ||||||
|  | 				</table> | ||||||
|  | 			</div> | ||||||
|  | 		</div> | ||||||
|  | 
 | ||||||
|  | 		<div class="col-sm-4"> | ||||||
|  | 			<?php if ($this->config->item('dashboard_map') == "map_at_right") { ?>
 | ||||||
|  | 				<!-- Map --> | ||||||
|  | 				<div id="map" class="map-leaflet" style="width: 100%; height: 350px;  margin-bottom: 15px;"></div> | ||||||
|  | 			<?php } ?>
 | ||||||
|  | 			<div class="table-responsive"> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 				<div id="radio_display" hx-get="<?php echo site_url('visitor/radio_display_component'); ?>" hx-trigger="load, every 5s"></div> | ||||||
|  | 
 | ||||||
|  | 				<table class="table table-striped border-top"> | ||||||
|  | 					<tr class="titles"> | ||||||
|  | 						<td colspan="3"><i class="fas fa-chart-bar"></i> DXPeditions (This Week)</td> | ||||||
|  | 					</tr> | ||||||
|  | 
 | ||||||
|  | 					<?php | ||||||
|  | 					foreach ($thisWeekRecords as $record) { | ||||||
|  | 						$color = $record['workedBefore'] == 1 ? '#ddffdd' : '#ffdddd'; | ||||||
|  | 						echo '<tr>'; | ||||||
|  | 						echo '<td style="background-color: ' . $color . ';" width="33%">' . $record['daysLeft'] . '</td>'; // Date
 | ||||||
|  | 						echo '<td style="background-color: ' . $color . ';" width="33%">' . $record['callsign'] . '</td>'; // Callsign
 | ||||||
|  | 						echo '<td style="background-color: ' . $color . ';" width="33%">' . $record['2'] . '</td>'; // Country
 | ||||||
|  | 						echo '</tr>'; | ||||||
| 					} | 					} | ||||||
| 
 |  | ||||||
| 					?>
 | 					?>
 | ||||||
| 
 | 
 | ||||||
| 					<td><?php $timestamp = strtotime($row->COL_TIME_ON); echo date($custom_date_format, $timestamp); ?></td>
 | 				</table> | ||||||
| 					<?php if(($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE || ($this->config->item('show_time'))) { ?>
 |  | ||||||
| 					<td><?php $timestamp = strtotime($row->COL_TIME_ON); echo date('H:i', $timestamp); ?></td>
 |  | ||||||
| 
 | 
 | ||||||
| 					<?php } ?>
 | 
 | ||||||
| 					<td> | 				<table class="table table-striped border-top"> | ||||||
|                         <a id="edit_qso" href="javascript:displayQso(<?php echo $row->COL_PRIMARY_KEY; ?>)"><?php echo str_replace("0","Ø",strtoupper($row->COL_CALL)); ?></a>
 | 					<tr class="titles"> | ||||||
| 					</td> | 						<td colspan="2"><i class="fas fa-chart-bar"></i> <?php echo lang('dashboard_qso_breakdown'); ?></td>
 | ||||||
| 					<?php | 					</tr> | ||||||
| 						echo_table_col($row, $this->session->userdata('user_column1')==""?'Mode':$this->session->userdata('user_column1')); | 
 | ||||||
| 						echo_table_col($row, $this->session->userdata('user_column2')==""?'RSTS':$this->session->userdata('user_column2')); | 					<tr> | ||||||
| 						echo_table_col($row, $this->session->userdata('user_column3')==""?'RSTR':$this->session->userdata('user_column3')); | 						<td width="50%"><?php echo lang('general_word_total'); ?></td>
 | ||||||
| 						echo_table_col($row, $this->session->userdata('user_column4')==""?'Band':$this->session->userdata('user_column4')); | 						<td width="50%"><?php echo $total_qsos; ?></td>
 | ||||||
| 					?>
 | 					</tr> | ||||||
| 				</tr> | 
 | ||||||
| 			<?php $i++; } } ?>
 | 					<tr> | ||||||
| 		</table> | 						<td width="50%"><?php echo lang('general_word_year'); ?></td>
 | ||||||
|  | 						<td width="50%"><?php echo $year_qsos; ?></td>
 | ||||||
|  | 					</tr> | ||||||
|  | 
 | ||||||
|  | 					<tr> | ||||||
|  | 						<td width="50%"><?php echo lang('general_word_month'); ?></td>
 | ||||||
|  | 						<td width="50%"><?php echo $month_qsos; ?></td>
 | ||||||
|  | 					</tr> | ||||||
|  | 				</table> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 				<table class="table table-striped border-top"> | ||||||
|  | 					<tr class="titles"> | ||||||
|  | 						<td colspan="2"><i class="fas fa-globe-europe"></i> <?php echo lang('dashboard_countries_breakdown'); ?></td>
 | ||||||
|  | 					</tr> | ||||||
|  | 
 | ||||||
|  | 					<tr> | ||||||
|  | 						<td width="50%"><?php echo lang('general_word_worked'); ?></td>
 | ||||||
|  | 						<td width="50%"><?php echo $total_countries; ?></td>
 | ||||||
|  | 					</tr> | ||||||
|  | 					<tr> | ||||||
|  | 						<td width="50%"><a href="#" onclick="return false" title="QSL Cards / eQSL / LoTW" data-bs-toggle="tooltip"><?php echo lang('general_word_confirmed'); ?></a></td>
 | ||||||
|  | 						<td width="50%"> | ||||||
|  | 							<?php echo $total_countries_confirmed_paper; ?> /
 | ||||||
|  | 							<?php echo $total_countries_confirmed_eqsl; ?> /
 | ||||||
|  | 							<?php echo $total_countries_confirmed_lotw; ?>
 | ||||||
|  | 						</td> | ||||||
|  | 					</tr> | ||||||
|  | 
 | ||||||
|  | 					<tr> | ||||||
|  | 						<td width="50%"><?php echo lang('general_word_needed'); ?></td>
 | ||||||
|  | 						<td width="50%"><?php echo $total_countries_needed; ?></td>
 | ||||||
|  | 					</tr> | ||||||
|  | 				</table> | ||||||
|  | 
 | ||||||
|  | 				<?php if ((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) && ($total_qsl_sent != 0 || $total_qsl_rcvd != 0 || $total_qsl_requested != 0)) { ?>
 | ||||||
|  | 					<table class="table table-striped border-top"> | ||||||
|  | 						<tr class="titles"> | ||||||
|  | 							<td colspan="2"><i class="fas fa-envelope"></i> <?php echo lang('general_word_qslcards'); ?></td>
 | ||||||
|  | 							<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_qsl_sent; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','All','All','QSLSDATE','');"><?php echo $qsl_sent_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_received'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_qsl_rcvd; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','All','All','QSLRDATE','');"><?php echo $qsl_rcvd_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_requested'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_qsl_requested; ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $qsl_requested_today; ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 					</table> | ||||||
|  | 				<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 				<?php if ((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) && ($total_eqsl_sent != 0 || $total_eqsl_rcvd != 0)) { ?>
 | ||||||
|  | 					<table class="table table-striped border-top"> | ||||||
|  | 						<tr class="titles"> | ||||||
|  | 							<td colspan="2"><i class="fas fa-address-card"></i> <?php echo lang('general_word_eqslcards'); ?></td>
 | ||||||
|  | 							<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_eqsl_sent; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','All','All','EQSLSDATE','');"><?php echo $eqsl_sent_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_received'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_eqsl_rcvd; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','All','All','EQSLRDATE','');"><?php echo $eqsl_rcvd_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 					</table> | ||||||
|  | 				<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 				<?php if ((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === false) && ($total_lotw_sent != 0 || $total_lotw_rcvd != 0)) { ?>
 | ||||||
|  | 					<table class="table table-striped border-top"> | ||||||
|  | 						<tr class="titles"> | ||||||
|  | 							<td colspan="2"><i class="fas fa-list"></i> <?php echo lang('general_word_lotw'); ?></td>
 | ||||||
|  | 							<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_lotw_sent; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','all','all','LOTWSDATE','');"><?php echo $lotw_sent_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_received'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_lotw_rcvd; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','all','all','LOTWRDATE','');"><?php echo $lotw_rcvd_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 					</table> | ||||||
|  | 				<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 				<?php if ((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === false) && ($total_qrz_sent != 0 || $total_qrz_rcvd != 0)) { ?>
 | ||||||
|  | 					<table class="table table-striped border-top"> | ||||||
|  | 						<tr class="titles"> | ||||||
|  | 							<td colspan="2"><i class="fas fa-list"></i> QRZ.com</td> | ||||||
|  | 							<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_qrz_sent; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','all','all','QRZSDATE','');"><?php echo $qrz_sent_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_received'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $total_qrz_rcvd; ?></td>
 | ||||||
|  | 							<td width="25%"><a href="javascript:displayContacts('','all','all','QRZRDATE','');"><?php echo $qrz_rcvd_today; ?></a></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 					</table> | ||||||
|  | 				<?php } ?>
 | ||||||
|  | 
 | ||||||
|  | 				<?php if ((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE)) { ?>
 | ||||||
|  | 					<table class="table table-striped border-top"> | ||||||
|  | 						<tr class="titles"> | ||||||
|  | 							<td colspan="2"><i class="fas fa-globe-europe"></i> VUCC-Grids</td> | ||||||
|  | 							<td colspan="1">SAT</td> | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_worked'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $vucc['All']['worked']; ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $vuccSAT['SAT']['worked'] ?? '0'; ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 						<tr> | ||||||
|  | 							<td width="50%"><?php echo lang('general_word_confirmed'); ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $vucc['All']['confirmed']; ?></td>
 | ||||||
|  | 							<td width="25%"><?php echo $vuccSAT['SAT']['confirmed'] ?? '0'; ?></td>
 | ||||||
|  | 						</tr> | ||||||
|  | 
 | ||||||
|  | 					</table> | ||||||
|  | 				<?php } ?>
 | ||||||
|  | 			</div> | ||||||
|  | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
|   </div> |  | ||||||
| 
 |  | ||||||
|   <div class="col-sm-4"> |  | ||||||
|   	<?php if($this->config->item('dashboard_map') == "map_at_right") { ?>
 |  | ||||||
| 	<!-- Map --> |  | ||||||
| 	<div id="map" class="map-leaflet" style="width: 100%; height: 350px;  margin-bottom: 15px;"></div> |  | ||||||
| 	<?php } ?>
 |  | ||||||
|   	<div class="table-responsive"> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 		<div id="radio_display" hx-get="<?php echo site_url('visitor/radio_display_component'); ?>" hx-trigger="load, every 5s"></div> |  | ||||||
| 		 |  | ||||||
|     	<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-chart-bar"></i> <?php echo lang('dashboard_qso_breakdown'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_total'); ?></td>
 |  | ||||||
| 				<td width="50%"><?php echo $total_qsos; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_year'); ?></td>
 |  | ||||||
| 				<td width="50%"><?php echo $year_qsos; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_month'); ?></td>
 |  | ||||||
| 				<td width="50%"><?php echo $month_qsos; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 		<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-globe-europe"></i> <?php echo lang('dashboard_countries_breakdown'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_worked'); ?></td>
 |  | ||||||
| 				<td width="50%"><?php echo $total_countries; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><a href="#" onclick="return false" title="QSL Cards / eQSL / LoTW" data-bs-toggle="tooltip"><?php echo lang('general_word_confirmed'); ?></a></td>
 |  | ||||||
| 				<td width="50%"> |  | ||||||
| 					<?php echo $total_countries_confirmed_paper; ?> /
 |  | ||||||
| 					<?php echo $total_countries_confirmed_eqsl; ?> /
 |  | ||||||
| 					<?php echo $total_countries_confirmed_lotw; ?>
 |  | ||||||
| 				</td> |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_needed'); ?></td>
 |  | ||||||
| 				<td width="50%"><?php echo $total_countries_needed; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 
 |  | ||||||
| 		<?php if((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) && ($total_qsl_sent != 0 || $total_qsl_rcvd != 0 || $total_qsl_requested != 0)) { ?>
 |  | ||||||
| 		<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-envelope"></i> <?php echo lang('general_word_qslcards'); ?></td>
 |  | ||||||
| 				<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_qsl_sent; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','All','All','QSLSDATE','');"><?php echo $qsl_sent_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_received'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_qsl_rcvd; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','All','All','QSLRDATE','');"><?php echo $qsl_rcvd_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_requested'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_qsl_requested; ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $qsl_requested_today; ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 		<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 		<?php if((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE) && ($total_eqsl_sent != 0 || $total_eqsl_rcvd != 0)) { ?>
 |  | ||||||
| 		<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-address-card"></i> <?php echo lang('general_word_eqslcards'); ?></td>
 |  | ||||||
| 				<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_eqsl_sent; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','All','All','EQSLSDATE','');"><?php echo $eqsl_sent_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_received'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_eqsl_rcvd; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','All','All','EQSLRDATE','');"><?php echo $eqsl_rcvd_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 		<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 		<?php if((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === false) && ($total_lotw_sent != 0 || $total_lotw_rcvd != 0)) { ?>
 |  | ||||||
| 		<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-list"></i> <?php echo lang('general_word_lotw'); ?></td>
 |  | ||||||
| 				<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_lotw_sent; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','all','all','LOTWSDATE','');"><?php echo $lotw_sent_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_received'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_lotw_rcvd; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','all','all','LOTWRDATE','');"><?php echo $lotw_rcvd_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 		<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 		<?php if((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === false) && ($total_qrz_sent != 0 || $total_qrz_rcvd != 0)) { ?>
 |  | ||||||
| 		<table class="table table-striped border-top"> |  | ||||||
| 			<tr class="titles"> |  | ||||||
| 				<td colspan="2"><i class="fas fa-list"></i> QRZ.com</td> |  | ||||||
| 				<td colspan="1"><?php echo lang('general_word_today'); ?></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_sent'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_qrz_sent; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','all','all','QRZSDATE','');"><?php echo $qrz_sent_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 
 |  | ||||||
| 			<tr> |  | ||||||
| 				<td width="50%"><?php echo lang('general_word_received'); ?></td>
 |  | ||||||
| 				<td width="25%"><?php echo $total_qrz_rcvd; ?></td>
 |  | ||||||
| 				<td width="25%"><a href="javascript:displayContacts('','all','all','QRZRDATE','');"><?php echo $qrz_rcvd_today; ?></a></td>
 |  | ||||||
| 			</tr> |  | ||||||
| 		</table> |  | ||||||
| 		<?php } ?>
 |  | ||||||
| 
 |  | ||||||
| 		<?php if((($this->config->item('use_auth') && ($this->session->userdata('user_type') >= 2)) || $this->config->item('use_auth') === FALSE)) { ?>
 |  | ||||||
|     	 <table class="table table-striped border-top"> |  | ||||||
|         <tr class="titles"> |  | ||||||
|             <td colspan="2"><i class="fas fa-globe-europe"></i> VUCC-Grids</td> |  | ||||||
|             <td colspan="1">SAT</td> |  | ||||||
|         </tr> |  | ||||||
| 
 |  | ||||||
|         <tr> |  | ||||||
|             <td width="50%"><?php echo lang('general_word_worked'); ?></td>
 |  | ||||||
|             <td width="25%"><?php echo $vucc['All']['worked']; ?></td>
 |  | ||||||
|             <td width="25%"><?php echo $vuccSAT['SAT']['worked'] ?? '0'; ?></td>
 |  | ||||||
|         </tr> |  | ||||||
| 
 |  | ||||||
|         <tr> |  | ||||||
|             <td width="50%"><?php echo lang('general_word_confirmed'); ?></td>
 |  | ||||||
|             <td width="25%"><?php echo $vucc['All']['confirmed']; ?></td>
 |  | ||||||
|             <td width="25%"><?php echo $vuccSAT['SAT']['confirmed'] ?? '0'; ?></td>
 |  | ||||||
|         </tr> |  | ||||||
| 
 |  | ||||||
|     </table> |  | ||||||
|     <?php } ?>
 |  | ||||||
| 	</div> |  | ||||||
|   </div> |  | ||||||
| </div> |  | ||||||
| 
 | 
 | ||||||
| </div> | </div> | ||||||
		正在加载…
	
		在新工单中引用