2022-09-20 20:10:34 +08:00
|
|
|
/* eslint-disable no-param-reassign */
|
|
|
|
/* eslint-disable no-undef */
|
|
|
|
/* global I18n */
|
|
|
|
/* eslint-disable no-unused-vars, no-use-before-define */
|
|
|
|
|
|
|
|
/* config = {
|
|
|
|
clearSelectorOnFirstDevice: boolean, // clear selector options
|
|
|
|
noDevices: function(), // what to do if we do not find any device
|
|
|
|
appendDevice: function(device), // use device which we find during search
|
|
|
|
beforeRefresh: function(), // Action happen before every new device search
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
var zebraPrint = (function() {
|
|
|
|
var devices = [];
|
|
|
|
var CONFIG = {};
|
|
|
|
var SELECTOR = '';
|
|
|
|
const PRINTER_STATUS_READY = 'ready';
|
|
|
|
const PRINTER_STATUS_ERROR = 'error';
|
|
|
|
const PRINTER_STATUS_PRINTING = 'printing';
|
|
|
|
const PRINTER_STATUS_DONE = 'done';
|
2022-11-21 23:55:03 +08:00
|
|
|
const PRINTER_STATUS_SEARCH = 'search';
|
2022-09-20 20:10:34 +08:00
|
|
|
|
|
|
|
var getPrinterStatus = function(device) {
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
try {
|
|
|
|
new Zebra.Printer(device).getStatus(function(status) {
|
|
|
|
device.status = status.getMessage() === I18n.t('label_printers.modal_printing_status.printer_status.ready')
|
|
|
|
? I18n.t('label_printers.modal_printing_status.printer_status.ready')
|
|
|
|
: I18n.t('label_printers.modal_printing_status.printer_status.offline');
|
|
|
|
resolve(device);
|
|
|
|
}, function() {
|
|
|
|
device.status = I18n.t('label_printers.modal_printing_status.printer_status.offline');
|
|
|
|
resolve(device);
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
if (device) {
|
|
|
|
device.status = I18n.t('label_printers.modal_printing_status.printer_status.offline');
|
|
|
|
} else {
|
|
|
|
device = { status: I18n.t('label_printers.modal_printing_status.printer_status.offline') };
|
|
|
|
}
|
|
|
|
resolve(device);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
function stripPrinterNameHtml(html) {
|
|
|
|
let tmp = document.createElement('DIV');
|
|
|
|
tmp.innerHTML = html;
|
|
|
|
return tmp.textContent || tmp.innerText || '';
|
|
|
|
}
|
|
|
|
|
|
|
|
function noDevices() {
|
|
|
|
if (CONFIG && 'noDevices' in CONFIG) {
|
|
|
|
CONFIG.noDevices();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function appendDevice(device) {
|
|
|
|
if (CONFIG && 'appendDevice' in CONFIG) {
|
|
|
|
CONFIG.appendDevice(device);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function beforeRefresh() {
|
|
|
|
if (CONFIG && 'beforeRefresh' in CONFIG) {
|
|
|
|
CONFIG.beforeRefresh();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function clearSelector(clearSelectorOnFirstDevice) {
|
|
|
|
if (clearSelectorOnFirstDevice && devices.length === 0) {
|
|
|
|
SELECTOR.empty();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function addNewDevice(device, clearSelectorOnFirstDevice) {
|
|
|
|
clearSelector(clearSelectorOnFirstDevice);
|
|
|
|
if (!devices.some(function(el) {
|
|
|
|
return el.name === device.name;
|
|
|
|
})) {
|
|
|
|
devices.push(device);
|
|
|
|
appendDevice(device);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-12 22:56:58 +08:00
|
|
|
function searchZebraPrinters(getStatus) {
|
2022-09-20 20:10:34 +08:00
|
|
|
var clearSelectorOnFirstDevice = CONFIG.clearSelectorOnFirstDevice;
|
|
|
|
devices = [];
|
|
|
|
try {
|
|
|
|
beforeRefresh();
|
|
|
|
BrowserPrint.getLocalDevices(function(deviceList) {
|
2022-10-06 19:52:49 +08:00
|
|
|
if (deviceList && deviceList.printer && deviceList.printer.length !== 0) {
|
2022-09-20 20:10:34 +08:00
|
|
|
for (i = 0; i < deviceList.printer.length; i += 1) {
|
2022-10-12 22:56:58 +08:00
|
|
|
if (getStatus) {
|
|
|
|
getPrinterStatus(deviceList.printer[i]).then((device) => {
|
|
|
|
addNewDevice(device, clearSelectorOnFirstDevice);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
addNewDevice(deviceList.printer[i], clearSelectorOnFirstDevice);
|
|
|
|
}
|
2022-09-20 20:10:34 +08:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
noDevices();
|
|
|
|
}
|
|
|
|
}, () => {
|
|
|
|
noDevices();
|
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
noDevices();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function findDevice(deviceName) {
|
|
|
|
var selectedDevice = devices.filter(function(device) { return device.name === deviceName; });
|
|
|
|
return selectedDevice && selectedDevice.length ? selectedDevice[0] : null;
|
|
|
|
}
|
|
|
|
|
2022-11-21 23:55:03 +08:00
|
|
|
function updateProgressModalData(progressModal, printerName, printerStatus, printingStatus) {
|
2022-09-20 20:10:34 +08:00
|
|
|
$(progressModal + ' .title').html(stripPrinterNameHtml(printerName));
|
|
|
|
$(progressModal + ' .printer-status').attr('data-status', printerStatus);
|
2022-11-21 23:55:03 +08:00
|
|
|
if (printerStatus !== PRINTER_STATUS_SEARCH) {
|
|
|
|
$(progressModal + ' .printer-status').html(I18n.t('label_printers.modal_printing_status.printer_status.'
|
|
|
|
+ printerStatus));
|
|
|
|
}
|
2022-09-20 20:10:34 +08:00
|
|
|
$(progressModal + ' .printing-status').attr('data-status', printingStatus);
|
|
|
|
$(progressModal + ' .printing-status').html(I18n.t('label_printers.modal_printing_status.printing_status.'
|
|
|
|
+ printingStatus));
|
|
|
|
}
|
|
|
|
|
2023-11-03 17:11:19 +08:00
|
|
|
function print(device, progressModal, numberOfCopies, printerName, labels, labelIndex) {
|
|
|
|
if (labels.length <= labelIndex) {
|
|
|
|
updateProgressModalData(progressModal, printerName, PRINTER_STATUS_READY, PRINTER_STATUS_DONE);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
const label = labels[labelIndex];
|
|
|
|
|
|
|
|
function printNextLabel() {
|
|
|
|
print(device, progressModal, numberOfCopies, printerName, labels, labelIndex + 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function unsuccessfulPrint() {
|
|
|
|
updateProgressModalData(progressModal, printerName, PRINTER_STATUS_ERROR, PRINTER_STATUS_ERROR);
|
|
|
|
}
|
|
|
|
|
2022-09-20 20:10:34 +08:00
|
|
|
try {
|
|
|
|
updateProgressModalData(progressModal, printerName, PRINTER_STATUS_READY, PRINTER_STATUS_PRINTING);
|
2023-11-03 17:11:19 +08:00
|
|
|
for (let counter = 0; counter < numberOfCopies; counter += 1) {
|
|
|
|
if (counter + 1 === parseInt(numberOfCopies, 10)) {
|
|
|
|
device.sendThenRead(label, printNextLabel, unsuccessfulPrint);
|
|
|
|
} else {
|
|
|
|
device.send(label, () => {}, unsuccessfulPrint);
|
2022-09-20 20:10:34 +08:00
|
|
|
}
|
2023-11-03 17:11:19 +08:00
|
|
|
}
|
2022-09-20 20:10:34 +08:00
|
|
|
} catch (error) {
|
2023-11-03 17:11:19 +08:00
|
|
|
unsuccessfulPrint();
|
2022-09-20 20:10:34 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-12 22:56:58 +08:00
|
|
|
function initializeZebraPrinters(selector, config, getStatus) {
|
2022-09-20 20:10:34 +08:00
|
|
|
CONFIG = config;
|
|
|
|
SELECTOR = selector;
|
2022-10-12 22:56:58 +08:00
|
|
|
searchZebraPrinters(getStatus);
|
2022-09-20 20:10:34 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2022-10-12 22:56:58 +08:00
|
|
|
init: function(selector, config, getStatus) {
|
|
|
|
initializeZebraPrinters(selector, config, getStatus);
|
2022-09-20 20:10:34 +08:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
refreshList: function() {
|
2022-10-12 22:56:58 +08:00
|
|
|
searchZebraPrinters(true);
|
2022-09-20 20:10:34 +08:00
|
|
|
},
|
2022-09-22 21:06:36 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
printData: {
|
|
|
|
printer_name: string,
|
|
|
|
number_of_copies: int,
|
|
|
|
label_template_id: int,
|
2024-01-09 16:37:50 +08:00
|
|
|
repository_row_ids: array[],
|
|
|
|
repository_id: int
|
2022-09-22 21:06:36 +08:00
|
|
|
}
|
|
|
|
*/
|
|
|
|
print: function(modalUrl, progressModal, printModal, printData) {
|
2022-09-20 20:10:34 +08:00
|
|
|
var modal = $(progressModal);
|
2022-10-18 16:42:50 +08:00
|
|
|
$.ajax({
|
|
|
|
method: 'GET',
|
|
|
|
url: modalUrl,
|
|
|
|
data: printData,
|
|
|
|
dataType: 'json'
|
|
|
|
}).done(function(xhr, settings, dataZebra) {
|
|
|
|
$(printModal).modal('hide');
|
|
|
|
|
|
|
|
if (modal.length) {
|
|
|
|
modal.replaceWith(dataZebra.responseJSON.html);
|
|
|
|
} else {
|
|
|
|
$('body').append($(dataZebra.responseJSON.html));
|
2022-09-20 20:10:34 +08:00
|
|
|
$(document).on('click', progressModal, function() {
|
|
|
|
$(this).closest(progressModal).remove();
|
|
|
|
});
|
2022-11-21 23:55:03 +08:00
|
|
|
}
|
2022-09-20 20:10:34 +08:00
|
|
|
|
2022-11-21 23:55:03 +08:00
|
|
|
updateProgressModalData(progressModal, printData.printer_name, PRINTER_STATUS_SEARCH, PRINTER_STATUS_SEARCH);
|
|
|
|
device = findDevice(printData.printer_name);
|
|
|
|
|
|
|
|
getPrinterStatus(device).then((device) => {
|
|
|
|
if (device.status === I18n.t('label_printers.modal_printing_status.printer_status.ready')) {
|
|
|
|
print(
|
2023-11-03 17:11:19 +08:00
|
|
|
device,
|
|
|
|
progressModal,
|
|
|
|
printData.number_of_copies,
|
|
|
|
printData.printer_name,
|
|
|
|
dataZebra.responseJSON.labels,
|
|
|
|
0,
|
2022-11-21 23:55:03 +08:00
|
|
|
);
|
|
|
|
} else {
|
|
|
|
updateProgressModalData(progressModal, printData.printer_name, PRINTER_STATUS_ERROR, PRINTER_STATUS_ERROR);
|
|
|
|
}
|
2022-09-20 20:10:34 +08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}());
|