kopia lustrzana https://github.com/magicbug/Cloudlog
[Dashboard] Reload the Logbook Table every 5 seconds
This reloads the logbook table on the dashboard every 5 seconds as mentioned in #3105pull/3109/head
rodzic
24f59af0d1
commit
9691a8bc3a
|
@ -188,6 +188,24 @@ class Dashboard extends CI_Controller
|
|||
}
|
||||
}
|
||||
|
||||
public function logbook_display_component() {
|
||||
$this->load->model('user_model');
|
||||
|
||||
if ($this->user_model->validate_session() == 0) {
|
||||
// User is not logged in
|
||||
} else {
|
||||
$this->load->model('logbook_model');
|
||||
$this->load->model('logbooks_model');
|
||||
}
|
||||
|
||||
// Get Logbook Locations
|
||||
$logbooks_locations_array = $this->logbooks_model->list_logbook_relationships($this->session->userdata('active_station_logbook'));
|
||||
|
||||
// Get the last 20 QSOs
|
||||
$data['last_five_qsos'] = $this->logbook_model->get_last_qsos('20', $logbooks_locations_array);
|
||||
$this->load->view('components/dashboard_logbook_table', $data);
|
||||
}
|
||||
|
||||
function radio_display_component()
|
||||
{
|
||||
$this->load->model('cat');
|
||||
|
|
|
@ -0,0 +1,211 @@
|
|||
<?php
|
||||
function echo_table_header_col($ctx, $name)
|
||||
{
|
||||
switch ($name) {
|
||||
case 'Mode':
|
||||
echo '<th>' . $ctx->lang->line('gen_hamradio_mode') . '</th>';
|
||||
break;
|
||||
case 'RSTS':
|
||||
echo '<th class="d-none d-sm-table-cell">' . $ctx->lang->line('gen_hamradio_rsts') . '</th>';
|
||||
break;
|
||||
case 'RSTR':
|
||||
echo '<th class="d-none d-sm-table-cell">' . $ctx->lang->line('gen_hamradio_rstr') . '</th>';
|
||||
break;
|
||||
case 'Country':
|
||||
echo '<th>' . $ctx->lang->line('general_word_country') . '</th>';
|
||||
break;
|
||||
case 'IOTA':
|
||||
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)
|
||||
{
|
||||
$ci = &get_instance();
|
||||
switch ($name) {
|
||||
case 'Mode':
|
||||
echo '<td>';
|
||||
echo $row->COL_SUBMODE == null ? $row->COL_MODE : $row->COL_SUBMODE . '</td>';
|
||||
break;
|
||||
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 '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)
|
||||
{
|
||||
if (!empty($grid)) {
|
||||
echo $grid . ' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $grid . '\')"><i class="fas fa-globe"></i></a>';
|
||||
} else if (!empty($vucc)) {
|
||||
echo $vucc . ' <a href="javascript:spawnQrbCalculator(\'' . $mygrid . '\',\'' . $vucc . '\')"><i class="fas fa-globe"></i></a>';
|
||||
}
|
||||
}
|
||||
?>
|
||||
<div class="table-responsive">
|
||||
<table class="table table-striped table-hover border-top">
|
||||
|
||||
<thead>
|
||||
<tr class="titles">
|
||||
<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'))) { ?>
|
||||
<th><?php echo lang('general_word_time'); ?></th>
|
||||
<?php } ?>
|
||||
<th><?php echo lang('gen_hamradio_call'); ?></th>
|
||||
<?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_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_column4') == "" ? 'Band' : $this->session->userdata('user_column4'));
|
||||
?>
|
||||
</tr>
|
||||
</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
|
||||
|
||||
// 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');
|
||||
}
|
||||
|
||||
?>
|
||||
|
||||
<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>
|
|
@ -222,68 +222,7 @@ function echoQrbCalcLink($mygrid, $grid, $vucc)
|
|||
<!-- Log Data -->
|
||||
<div class="row logdata">
|
||||
<div class="col-sm-8">
|
||||
|
||||
<div class="table-responsive">
|
||||
<table class="table table-striped table-hover border-top">
|
||||
|
||||
<thead>
|
||||
<tr class="titles">
|
||||
<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'))) { ?>
|
||||
<th><?php echo lang('general_word_time'); ?></th>
|
||||
<?php } ?>
|
||||
<th><?php echo lang('gen_hamradio_call'); ?></th>
|
||||
<?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_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_column4') == "" ? 'Band' : $this->session->userdata('user_column4'));
|
||||
?>
|
||||
</tr>
|
||||
</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
|
||||
|
||||
// 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');
|
||||
}
|
||||
|
||||
?>
|
||||
|
||||
<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 id="logbook_display_component" hx-get="<?php echo site_url('dashboard/logbook_display_component'); ?>" hx-trigger="load, every 5s"></div>
|
||||
</div>
|
||||
|
||||
<div class="col-sm-4">
|
||||
|
|
Ładowanie…
Reference in New Issue