zetikettes/frontend/zetikettes.js

92 lines
3.0 KiB
JavaScript
Raw Normal View History

2022-07-13 07:11:15 +00:00
const params = {
'dluo': 'DLUO',
'lot': 'Nº de lot',
'qty': 'Poids net (g)',
'vol': 'Volume net (cL)',
'teneur': 'Teneur en fruits (%)',
'fruit': 'Quantité de fruits pour 100g (g)',
}
function loadAll(zetikettes) {
2022-07-12 10:04:38 +00:00
const appbody = $("#appbody");
for (let zett of zetikettes) {
const block = $('<div class="section">');
for (let sub in zett.subs) {
2022-07-13 07:11:15 +00:00
block.append($(`<div class="input-field"><label class="active">${params[sub]}</label><input type="text" name="${sub}" value="${zett.subs[sub]}">`));
2022-07-12 10:04:38 +00:00
}
const loader = $('<div class="progress"><div class="indeterminate"></div></div>')
.hide();
const action = $('<div class="section">')
.append($('<a class="btn">generate<a>')
.click(() => {
const subs = block.find(':text')
.toArray()
.reduce((obj, el) => ({...obj, [el.name]: el.value}), {});
const req = {
sticker: zett.sticker,
subs,
landscape: zett.landscape,
};
loader.show();
$('.btn').addClass("disabled");
$.post(backend_api, JSON.stringify(req))
.then(data => {
console.log(data);
const pdfbtn = $(`<a class="btn" href="${backend_api}data/${data.file}" target="_blank">open pdf</a>`);
2022-07-12 10:04:38 +00:00
action.append(pdfbtn);
})
.catch(err => {
console.log(err);
})
.always(() => {
loader.hide();
$('.btn').removeClass('disabled');
});
})
.append(loader));
appbody
.append($('<li>')
.append($(`<div class="collapsible-header"><h6 class="blue-text">${zett.title}</h6></div>`))
.append($('<div class="collapsible-body">')
.append(block)
.append(action)));
}
$('.collapsible').collapsible();
2023-06-28 21:42:46 +00:00
konami();
}
function konami() {
var k = [38, 38, 40, 40, 37, 39, 37, 39, 66, 65],
n = 0;
$(document).keydown(function (e) {
if (e.keyCode === k[n++]) {
if (n === k.length) {
document.location.href = backend_api + 'admin';
2023-06-28 21:42:46 +00:00
}
}
else {
n = 0;
}
});
}
$(document).ready(async () => {
try {
const resp = await $.ajax({
url: backend_api + 'list',
timeout: 1000,
});
2023-08-03 18:18:43 +00:00
loadAll(resp.tikettes.sort((a, b) => (a.title < b.title) ? -1 : 1));
} catch(e) {
const appbody = $("#appbody");
appbody.append(`<li>Could not reach backend server`);
throw e;
}
2023-06-28 21:42:46 +00:00
});