kopia lustrzana https://github.com/magicbug/Cloudlog
430 wiersze
14 KiB
PHP
430 wiersze
14 KiB
PHP
<?php
|
|
|
|
require_once './src/Label/vendor/autoload.php';
|
|
use Cloudlog\Label\PDF_Label;
|
|
use Cloudlog\Label\tfpdf;
|
|
use Cloudlog\Label\font\unifont\ttfonts;
|
|
|
|
if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
class Labels extends CI_Controller {
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Controller: Labels
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| This Controller handles all things Labels, creating, editing and printing
|
|
|
|
|
|
|
|
*/
|
|
|
|
function __construct() {
|
|
parent::__construct();
|
|
$this->load->helper(array('form', 'url', 'psr4_autoloader'));
|
|
|
|
$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'); }
|
|
}
|
|
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Function: index
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Nothing fancy just shows the main display of how many labels are waiting
|
|
| to be printed per station profile.
|
|
|
|
|
*/
|
|
public function index() {
|
|
$data['page_title'] = "QSL Card Labels";
|
|
|
|
$this->load->model('labels_model');
|
|
|
|
$data['labels'] = $this->labels_model->fetchLabels($this->session->userdata('user_id'));
|
|
|
|
$data['papertypes'] = $this->labels_model->fetchPapertypes($this->session->userdata('user_id'));
|
|
|
|
$data['qsos'] = $this->labels_model->fetchQsos($this->session->userdata('user_id'));
|
|
|
|
$footerData = [];
|
|
$footerData['scripts'] = [
|
|
'assets/js/sections/labels.js',
|
|
];
|
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
$this->load->view('labels/index');
|
|
$this->load->view('interface_assets/footer', $footerData);
|
|
|
|
}
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Function: create
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Shows the form used to create a label type.
|
|
|
|
|
*/
|
|
public function create() {
|
|
|
|
$data['page_title'] = "Create Label Type";
|
|
|
|
$this->load->library('form_validation');
|
|
$this->load->model('labels_model');
|
|
|
|
$data['papertypes'] = $this->labels_model->fetchPapertypes($this->session->userdata('user_id'));
|
|
|
|
$this->form_validation->set_rules('label_name', 'Label Name', 'required');
|
|
|
|
if ($this->form_validation->run() == FALSE)
|
|
{
|
|
$this->load->view('interface_assets/header', $data);
|
|
$this->load->view('labels/create');
|
|
$this->load->view('interface_assets/footer');
|
|
}
|
|
else
|
|
{
|
|
$this->load->model('labels_model');
|
|
$this->labels_model->addLabel();
|
|
|
|
redirect('labels');
|
|
}
|
|
|
|
}
|
|
|
|
/*
|
|
|--------------------------------------------------------------------------
|
|
| Function: createpaper
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Shows the form used to create a paper type.
|
|
|
|
|
*/
|
|
public function createpaper() {
|
|
|
|
$data['page_title'] = "Create Paper Type";
|
|
|
|
$this->load->library('form_validation');
|
|
|
|
$this->form_validation->set_rules('paper_name', 'Paper Name', 'required');
|
|
|
|
if ($this->form_validation->run() == FALSE)
|
|
{
|
|
$this->load->view('interface_assets/header', $data);
|
|
$this->load->view('labels/createpaper');
|
|
$this->load->view('interface_assets/footer');
|
|
}
|
|
else
|
|
{
|
|
$this->load->model('labels_model');
|
|
try {
|
|
$this->labels_model->addPaper();
|
|
} catch (\Throwable $th) {
|
|
$this->session->set_flashdata('error', 'Your paper could not be saved. Remember that it can\'t have the same name as existing paper types.');
|
|
redirect('labels/createpaper');
|
|
}
|
|
redirect('labels');
|
|
}
|
|
|
|
}
|
|
|
|
|
|
public function printids() {
|
|
$ids = xss_clean(json_decode($this->input->post('id')));
|
|
$offset = xss_clean($this->input->post('startat'));
|
|
$grid = $this->input->post('grid') === "true" ? 1 : 0;
|
|
$this->load->model('labels_model');
|
|
$result = $this->labels_model->export_printrequestedids($ids);
|
|
|
|
$this->prepareLabel($result, true, $offset, $grid);
|
|
}
|
|
|
|
public function print($station_id) {
|
|
$clean_id = xss_clean($station_id);
|
|
$offset = xss_clean($this->input->post('startat'));
|
|
$grid = xss_clean($this->input->post('grid') ?? 0);
|
|
$this->load->model('stations');
|
|
if ($this->stations->check_station_is_accessible($station_id)) {
|
|
$this->load->model('labels_model');
|
|
$result = $this->labels_model->export_printrequested($clean_id);
|
|
|
|
$this->prepareLabel($result, false, $offset, $grid);
|
|
} else {
|
|
redirect('labels');
|
|
}
|
|
}
|
|
|
|
function prepareLabel($qsos, $jscall = false, $offset = 1, $grid = false) {
|
|
$this->load->model('labels_model');
|
|
$label = $this->labels_model->getDefaultLabel();
|
|
|
|
|
|
try {
|
|
if ($label) {
|
|
$label->font='DejaVuSans'; // Fix font to DejaVuSans
|
|
$ptype=$this->labels_model->getPaperType($label->paper_type_id); // fetch papersize out of paper-table
|
|
if (($ptype->paper_id ?? '') != '') {
|
|
if ($ptype->metric == 'in') { // convert papersize to mm if given in inch
|
|
$paper_width=$ptype->width*25.4;
|
|
$paper_height=$ptype->height*25.4;
|
|
} else {
|
|
$paper_width=$ptype->width;
|
|
$paper_height=$ptype->height;
|
|
}
|
|
$pdf = new PDF_Label(array(
|
|
'paper-size' => 'custom', // $label->paper_type, // The only Type left is "custom" because A4 and so on are also defined at paper_types
|
|
'metric' => $label->metric,
|
|
'marginLeft' => $label->marginleft,
|
|
'marginTop' => $label->margintop,
|
|
'NX' => $label->nx,
|
|
'NY' => $label->ny,
|
|
'SpaceX' => $label->spacex,
|
|
'SpaceY' => $label->spacey,
|
|
'width' => $label->width,
|
|
'height' => $label->height,
|
|
'font-size' => $label->font_size,
|
|
'pgX' => $paper_width,
|
|
'pgY' => $paper_height
|
|
));
|
|
} else {
|
|
if ($jscall) {
|
|
header('Content-Type: application/json');
|
|
echo json_encode(array('message' => 'You need to assign a paperType to the label before printing'));
|
|
return;
|
|
} else {
|
|
$this->session->set_flashdata('error', 'You need to assign a paperType to the label before printing');
|
|
redirect('labels');
|
|
}
|
|
}
|
|
} else {
|
|
if ($jscall) {
|
|
header('Content-Type: application/json');
|
|
echo json_encode(array('message' => 'You need to create a label and set it to be used for print.'));
|
|
return;
|
|
} else {
|
|
$this->session->set_flashdata('error', 'You need to create a label and set it to be used for print.');
|
|
redirect('labels');
|
|
}
|
|
}
|
|
} catch (\Throwable $th) {
|
|
if ($jscall) {
|
|
header('Content-Type: application/json');
|
|
echo json_encode(array('message' => 'Something went wrong! The label could not be generated. Check label size and font size.'));
|
|
return;
|
|
} else {
|
|
$this->session->set_flashdata('error', 'Something went wrong! The label could not be generated. Check label size and font size.');
|
|
redirect('labels');
|
|
}
|
|
}
|
|
define('FPDF_FONTPATH', './src/Label/font/');
|
|
|
|
$pdf->AddPage($ptype->orientation);
|
|
|
|
if ($label->font == 'DejaVuSans') { // leave this here, for future Use
|
|
$pdf->AddFont($label->font,'','DejaVuSansMono.ttf',true);
|
|
$pdf->SetFont($label->font,'');
|
|
} else {
|
|
$pdf->AddFont($label->font);
|
|
$pdf->SetFont($label->font);
|
|
}
|
|
|
|
if ($qsos->num_rows() > 0) {
|
|
if ($label->qsos == 1) {
|
|
$this->makeMultiQsoLabel($qsos->result(), $pdf, 1, $offset, $ptype->orientation, $grid);
|
|
} else {
|
|
$this->makeMultiQsoLabel($qsos->result(), $pdf, $label->qsos, $offset, $ptype->orientation, $grid);
|
|
}
|
|
} else {
|
|
$this->session->set_flashdata('message', '0 QSOs found for print!');
|
|
redirect('labels');
|
|
}
|
|
$pdf->Output();
|
|
}
|
|
|
|
function makeMultiQsoLabel($qsos, $pdf, $numberofqsos, $offset, $orientation, $grid) {
|
|
$text = '';
|
|
$current_callsign = '';
|
|
$current_sat = '';
|
|
$current_sat_mode = '';
|
|
$current_sat_bandrx = '';
|
|
$qso_data = [];
|
|
if ($offset !== 1) {
|
|
for ($i = 1; $i < $offset; $i++) {
|
|
$pdf->Add_Label('',$orientation);
|
|
}
|
|
}
|
|
foreach($qsos as $qso) {
|
|
if (($this->pretty_sat_mode($qso->COL_SAT_MODE) !== $current_sat_mode) || ($qso->COL_SAT_NAME !== $current_sat) || ($qso->COL_CALL !== $current_callsign) || // Call, SAT or SAT-Mode differs?
|
|
( ($qso->COL_BAND_RX !== $current_sat_bandrx) && ($this->pretty_sat_mode($qso->COL_SAT_MODE) !== '')) ) {
|
|
// ((($qso->COL_SAT_NAME ?? '' !== $current_sat) || ($qso->COL_CALL !== $current_callsign)) && ($qso->COL_SAT_NAME ?? '' !== '') && ($col->COL_BAND_RX ?? '' !== $current_sat_bandrx))) {
|
|
if (!empty($qso_data)) {
|
|
$this->finalizeData($pdf, $current_callsign, $qso_data, $numberofqsos, $orientation, $grid);
|
|
$qso_data = [];
|
|
}
|
|
$current_callsign = $qso->COL_CALL;
|
|
$current_sat = $qso->COL_SAT_NAME;
|
|
$current_sat_mode = $this->pretty_sat_mode($qso->COL_SAT_MODE);
|
|
$current_sat_bandrx = $qso->COL_BAND_RX ?? '';
|
|
}
|
|
|
|
$qso_data[] = [
|
|
'time' => $qso->COL_TIME_ON,
|
|
'band' => $qso->COL_BAND,
|
|
'mode' => $qso->COL_MODE,
|
|
'rst' => $qso->COL_RST_SENT,
|
|
'mygrid' => $qso->station_gridsquare,
|
|
'sat' => $qso->COL_SAT_NAME,
|
|
'sat_mode' => $this->pretty_sat_mode($qso->COL_SAT_MODE ?? ''),
|
|
'sat_band_rx' => ($qso->COL_BAND_RX ?? ''),
|
|
'qsl_recvd' => $qso->COL_QSL_RCVD,
|
|
'mycall' => $qso->COL_STATION_CALLSIGN
|
|
];
|
|
}
|
|
if (!empty($qso_data)) {
|
|
$this->finalizeData($pdf, $current_callsign, $qso_data, $numberofqsos, $orientation, $grid);
|
|
}
|
|
}
|
|
// New begin
|
|
function pretty_sat_mode($sat_mode) {
|
|
return(strlen($sat_mode ?? '') == 2 ? (strtoupper($sat_mode[0]).'/'.strtoupper($sat_mode[1])) : strtoupper($sat_mode ?? ''));
|
|
}
|
|
|
|
function finalizeData($pdf, $current_callsign, &$preliminaryData, $qso_per_label,$orientation, $grid) {
|
|
|
|
$tableData = [];
|
|
$count_qso = 0;
|
|
$qso=[];
|
|
foreach ($preliminaryData as $key => $row) {
|
|
$qso=$row;
|
|
$time = strtotime($qso['time']);
|
|
$myFormatForView = date("d.m.y H:i", $time);
|
|
$rowData = [
|
|
'DD.MM.YY UTC' => $myFormatForView,
|
|
'Band' => $row['band'],
|
|
'Mode' => $row['mode'],
|
|
'RST' => $row['rst'],
|
|
];
|
|
$tableData[] = $rowData;
|
|
$count_qso++;
|
|
|
|
|
|
if($count_qso == $qso_per_label){
|
|
$this->generateLabel($pdf, $current_callsign, $tableData,$count_qso,$qso,$orientation, $grid);
|
|
$tableData = []; // reset the data
|
|
$count_qso = 0; // reset the counter
|
|
}
|
|
unset($preliminaryData[$key]);
|
|
}
|
|
// generate label for remaining QSOs
|
|
if($count_qso > 0){
|
|
$this->generateLabel($pdf, $current_callsign, $tableData,$count_qso,$qso,$orientation, $grid);
|
|
$preliminaryData = []; // reset the data
|
|
}
|
|
}
|
|
|
|
function generateLabel($pdf, $current_callsign, $tableData,$numofqsos,$qso,$orientation,$grid=true){
|
|
$builder = new \AsciiTable\Builder();
|
|
$builder->addRows($tableData);
|
|
$text = "Confirming QSO".($numofqsos>1 ? 's' : '')." with ";
|
|
$text .= $current_callsign."\n";
|
|
$text .= $builder->renderTable();
|
|
if($qso['sat'] != "") {
|
|
if (($qso['sat_mode'] == '') && ($qso['sat_band_rx'] !== '')) {
|
|
$text .= "\n".'Satellite: '.$qso['sat'].' Band RX: '.$qso['sat_band_rx'];
|
|
} elseif (($qso['sat_mode'] == '') && ($qso['sat_band_rx'] == '')) {
|
|
$text .= "\n".'Satellite: '.$qso['sat'];
|
|
} else {
|
|
$text .= "\n".'Satellite: '.$qso['sat'].' Mode: '.$qso['sat_mode'];
|
|
}
|
|
}
|
|
$text.="\n";
|
|
if ($grid) { $text .= "My call: ".$qso['mycall']." Grid: ".$qso['mygrid']."\n"; }
|
|
$text .= "Thanks for the QSO".($numofqsos>1 ? 's' : '');
|
|
$text .= " | ".($qso['qsl_recvd'] == 'Y' ? 'TNX' : 'PSE')." QSL";
|
|
$pdf->Add_Label($text,$orientation);
|
|
}
|
|
|
|
// New End
|
|
|
|
public function edit($id) {
|
|
$this->load->model('labels_model');
|
|
|
|
$cleanid = $this->security->xss_clean($id);
|
|
|
|
$data['label'] = $this->labels_model->getLabel($cleanid,$this->session->userdata('user_id'));
|
|
|
|
$data['papertypes'] = $this->labels_model->fetchPapertypes($this->session->userdata('user_id'));
|
|
|
|
$data['page_title'] = "Edit Label";
|
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
$this->load->view('labels/edit');
|
|
$this->load->view('interface_assets/footer');
|
|
}
|
|
|
|
public function updateLabel($id) {
|
|
$this->load->model('labels_model');
|
|
$this->labels_model->updateLabel($id);
|
|
$this->session->set_flashdata('message', 'Label was saved.');
|
|
redirect('labels');
|
|
}
|
|
|
|
public function delete($id) {
|
|
$this->load->model('labels_model');
|
|
$this->labels_model->deleteLabel($id);
|
|
$this->session->set_flashdata('warning', 'Label was deleted.');
|
|
redirect('labels');
|
|
}
|
|
|
|
public function saveDefaultLabel() {
|
|
$id = $this->input->post('id');
|
|
$this->load->model('labels_model');
|
|
$this->labels_model->saveDefaultLabel($id);
|
|
}
|
|
|
|
public function startAtLabel() {
|
|
$data['stationid'] = xss_clean($this->input->post('stationid'));
|
|
$this->load->view('labels/startatform', $data);
|
|
}
|
|
|
|
public function editPaper($id) {
|
|
$this->load->model('labels_model');
|
|
|
|
$cleanid = $this->security->xss_clean($id);
|
|
|
|
$data['paper'] = $this->labels_model->getPaper($cleanid);
|
|
|
|
$data['page_title'] = "Edit Paper";
|
|
|
|
$this->load->view('interface_assets/header', $data);
|
|
$this->load->view('labels/editpaper');
|
|
$this->load->view('interface_assets/footer');
|
|
}
|
|
|
|
public function updatePaper($id) {
|
|
$this->load->model('labels_model');
|
|
try {
|
|
$this->labels_model->updatePaper($id);
|
|
} catch (\Throwable $th) {
|
|
$this->session->set_flashdata('error', 'Your paper could not be saved. Remember that it can\'t have the same name as existing paper types.');
|
|
$cleanid = $this->security->xss_clean($id);
|
|
redirect('labels/editpaper/'.$cleanid);
|
|
}
|
|
$this->session->set_flashdata('message', 'Paper was saved.');
|
|
redirect('labels');
|
|
}
|
|
|
|
function label_cnt_with_paper($paper_id) {
|
|
$this->load->model('labels_model');
|
|
return $this->labels_model->label_cnt_with_paper($paper_id);
|
|
}
|
|
|
|
public function deletePaper($id) {
|
|
$this->load->model('labels_model');
|
|
$this->labels_model->deletePaper($id);
|
|
$this->session->set_flashdata('warning', 'Paper was deleted.');
|
|
redirect('labels');
|
|
}
|
|
}
|