-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathscript.js
76 lines (66 loc) · 2.48 KB
/
script.js
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
let qrContainer = document.getElementById("qr-container");
let downloadBtn = document.getElementById("download-btn");
let copyBtn = document.getElementById("copy-btn");
let loader = document.getElementById("loader");
function generateQRCode() {
let text = document.getElementById("text-input").value;
qrContainer.innerHTML = "";
loader.style.display = "block";
if (text.trim() !== "") {
setTimeout(() => {
let qr = new QRCode(qrContainer, {
text: text,
width: 160,
height: 160,
correctLevel: QRCode.CorrectLevel.H
});
loader.style.display = "none";
downloadBtn.style.display = "block";
copyBtn.style.display = "block";
}, 500);
} else {
loader.style.display = "none";
alert("Please enter a valid text or URL!");
}
}
function downloadQRCode() {
let qrCanvas = qrContainer.querySelector("canvas");
if (qrCanvas) {
let newCanvas = document.createElement("canvas");
let ctx = newCanvas.getContext("2d");
let padding = 16;
newCanvas.width = qrCanvas.width + padding * 2;
newCanvas.height = qrCanvas.height + padding * 2;
ctx.fillStyle = "white";
ctx.fillRect(0, 0, newCanvas.width, newCanvas.height);
ctx.drawImage(qrCanvas, padding, padding);
let qrImage = newCanvas.toDataURL("image/png");
let a = document.createElement("a");
a.href = qrImage;
a.download = "qr_code.png";
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
}
function copyQRCode() {
let qrCanvas = qrContainer.querySelector("canvas");
if (qrCanvas) {
let newCanvas = document.createElement("canvas");
let ctx = newCanvas.getContext("2d");
let padding = 16;
newCanvas.width = qrCanvas.width + padding * 2;
newCanvas.height = qrCanvas.height + padding * 2;
ctx.fillStyle = "white";
ctx.fillRect(0, 0, newCanvas.width, newCanvas.height);
ctx.drawImage(qrCanvas, padding, padding);
newCanvas.toBlob(blob => {
let item = new ClipboardItem({ "image/png": blob });
navigator.clipboard.write([item]).then(() => {
alert("QR Code copied to clipboard!");
}).catch(err => {
console.error("Copy failed: ", err);
});
});
}
}