-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathscript.js
More file actions
98 lines (80 loc) · 2.72 KB
/
script.js
File metadata and controls
98 lines (80 loc) · 2.72 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
// Elements
const qrDataElement = document.querySelector("#qr-data");
const qrCodeListElement = document.querySelector("#qr-code-list");
const validateUrlElement = document.querySelector("#validate-url");
const totalCountElement = document.querySelector("#total-count");
const validCountElement = document.querySelector("#valid-count");
const invalidCountElement = document.querySelector("#invalid-count");
const downloadZipButton = document.querySelector("#download-zip");
// Const variables
const QRCODE_SIZE = 1024;
// Variables
let validUrls = [];
let invalidUrls = [];
// Functions
function isValidUrl(url) {
try {
new URL(url);
return true;
} catch (e) {
return false;
}
}
function generateQrCodes() {
const urls = qrDataElement.value.split("\n").map(url => url.trim()).filter(Boolean);
validUrls = [];
invalidUrls = [];
qrCodeListElement.innerHTML = "";
urls.forEach(url => {
const isValid = !validateUrlElement.checked || isValidUrl(url);
if (isValid) {
validUrls.push(url);
const qrCodeContainer = document.createElement("div");
const qrCode = new QRCode(qrCodeContainer, {
text: url,
width: QRCODE_SIZE,
height: QRCODE_SIZE,
});
qrCodeContainer.setAttribute("data-url", url);
qrCodeListElement.appendChild(qrCodeContainer);
} else {
invalidUrls.push(url);
}
});
totalCountElement.textContent = urls.length;
validCountElement.textContent = validUrls.length;
invalidCountElement.textContent = invalidUrls.length;
updateCountElements();
}
function updateCountElements() {
if (validateUrlElement.checked) {
validCountElement.parentElement.style.display = "block";
invalidCountElement.parentElement.style.display = "block";
} else {
validCountElement.parentElement.style.display = "none";
invalidCountElement.parentElement.style.display = "none";
}
}
function padNumber(number, length) {
return String(number).padStart(length, '0');
}
async function downloadQrCodesAsZip() {
const zip = new JSZip();
let index = 1;
for (const url of validUrls) {
const qrCodeContainer = document.querySelector(`[data-url="${url}"] canvas`);
const dataUrl = qrCodeContainer.toDataURL("image/png");
const imgData = dataUrl.replace(/^data:image\/(png|jpg);base64,/, "");
const qrcodeName = `${padNumber(index++, 4)}.png`;
zip.file(qrcodeName, imgData, { base64: true });
}
const blob = await zip.generateAsync({ type: "blob" });
const downloadLink = document.createElement("a");
downloadLink.href = URL.createObjectURL(blob);
downloadLink.download = "max-qrcodes.zip";
downloadLink.click();
}
// Events
qrDataElement.addEventListener("input", generateQrCodes);
validateUrlElement.addEventListener("change", generateQrCodes);
downloadZipButton.addEventListener("click", downloadQrCodesAsZip);