Cloudlog/application/controllers/Qslprint.php
2023-12-07 01:18:04 +01:00

202 lines
5.1 KiB
PHP

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class QSLPrint extends CI_Controller {
function __construct()
{
parent::__construct();
$this->load->helper(array('form', 'url'));
$this->load->model('user_model');
// Check if users logged in
if($this->user_model->validate_session() == 0) {
// user is not logged in
redirect('user/login');
}
}
public function index($station_id = 'All')
{
$this->load->model('user_model');
// Check if users logged in
if($this->user_model->validate_session() == 0) {
// user is not logged in
redirect('user/login');
}
$this->load->model('stations');
$data['station_id'] = $this->security->xss_clean($station_id);
$data['station_profile'] = $this->stations->all_of_user();
$this->load->model('qslprint_model');
if ( ($station_id != 'All') && ($this->stations->check_station_is_accessible($station_id)) ) {
$data['qsos'] = $this->qslprint_model->get_qsos_for_print($station_id);
} else {
$data['qsos'] = $this->qslprint_model->get_qsos_for_print();
}
$footerData = [];
$footerData['scripts'] = [
'assets/js/sections/qslprint.js',
];
$data['page_title'] = $this->lang->line('menu_print_requested_qsls');
$this->load->view('interface_assets/header', $data);
$this->load->view('qslprint/index');
$this->load->view('interface_assets/footer', $footerData);
}
public function exportadif()
{
// Set memory limit to unlimited to allow heavy usage
ini_set('memory_limit', '-1');
if ($this->uri->segment(3) == 'all') {
$station_id = 'All';
} else {
$station_id = $this->security->xss_clean($this->uri->segment(3));
}
$this->load->model('adif_data');
$data['qsos'] = $this->adif_data->export_printrequested($station_id);
$this->load->view('adif/data/exportall', $data);
}
public function exportcsv()
{
// Set memory limit to unlimited to allow heavy usage
ini_set('memory_limit', '-1');
if ($this->uri->segment(3) == 'all') {
$station_id = 'All';
} else {
$station_id = $this->security->xss_clean($this->uri->segment(3));
}
$this->load->model('logbook_model');
$myData = $this->logbook_model->get_qsos_for_printing($station_id);
// file name
$filename = 'qsl_export.csv';
header("Content-Description: File Transfer");
header("Content-Disposition: attachment; filename=$filename");
header("Content-Type: application/csv;charset=iso-8859-1");
// file creation
$file = fopen('php://output', 'w');
$header = array("STATION_CALLSIGN",
"COL_CALL",
"COL_QSL_VIA",
"COL_TIME_ON",
"COL_MODE",
"COL_FREQ",
"COL_BAND",
"COL_RST_SENT",
"COL_SAT_NAME",
"COL_SAT_MODE",
"COL_QSL_RCVD",
"COL_COMMENT",
"COL_ROUTING",
"ADIF",
"ENTITY");
fputcsv($file, $header);
foreach ($myData->result() as $qso) {
fputcsv($file,
array($qso->STATION_CALLSIGN,
$qso->COL_CALL,
$qso->COL_QSL_VIA!=""?"via ".$qso->COL_QSL_VIA:"",
$qso->COL_TIME_ON,
$qso->COL_MODE,
$qso->COL_FREQ,
$qso->COL_BAND,
$qso->COL_RST_SENT,
$qso->COL_SAT_NAME,
$qso->COL_SAT_MODE,
$qso->COL_QSL_RCVD =='Y'?'TNX QSL':'PSE QSL',
$qso->COL_COMMENT,
$qso->COL_ROUTING,
$qso->ADIF,
$qso->ENTITY));
}
fclose($file);
exit;
}
function qsl_printed() {
if ($this->uri->segment(3) == 'all') {
$station_id = 'All';
} else {
$station_id = $this->security->xss_clean($this->uri->segment(3));
}
$this->load->model('qslprint_model');
$this->load->model('user_model');
if(!$this->user_model->authorize(2)) { $this->session->set_flashdata('notice', 'You\'re not allowed to do that!'); redirect('dashboard'); }
// Update Logbook to Mark Paper Card Sent
$this->qslprint_model->mark_qsos_printed($station_id);
$this->session->set_flashdata('notice', 'QSOs are marked as sent');
redirect('logbook');
}
public function delete_from_qsl_queue() {
$id = $this->input->post('id');
$this->load->model('qslprint_model');
$this->qslprint_model->delete_from_qsl_queue($this->security->xss_clean($id));
}
public function get_qsos_for_print_ajax() {
$station_id = $this->input->post('station_id');
$this->load->model('qslprint_model');
$data['qsos'] = $this->qslprint_model->get_qsos_for_print_ajax($this->security->xss_clean($station_id));
$data['station_id'] = $station_id;
$this->load->view('qslprint/qslprint', $data);
}
public function open_qso_list() {
$callsign = $this->input->post('callsign');
$this->load->model('qslprint_model');
$data['qsos'] = $this->qslprint_model->open_qso_list($this->security->xss_clean($callsign));
$this->load->view('qslprint/qsolist', $data);
}
public function add_qso_to_print_queue() {
$id = $this->input->post('id');
$this->load->model('qslprint_model');
$this->qslprint_model->add_qso_to_print_queue($this->security->xss_clean($id));
}
public function show_oqrs() {
$id = $this->security->xss_clean($this->input->post('id'));
$this->load->model('qslprint_model');
$data['result'] = $this->qslprint_model->show_oqrs($id);
$this->load->view('oqrs/showoqrs', $data);
}
}
/* End of file Qslprint.php */
/* Location: ./application/controllers/Qslprint.php */