|
@@ -6,7 +6,7 @@
|
|
|
|
|
|
import Operation from "../Operation";
|
|
|
import OperationError from "../errors/OperationError";
|
|
|
-import qr from "qr-image";
|
|
|
+import { generateQrCode } from "../lib/QRCode";
|
|
|
import { toBase64 } from "../lib/Base64";
|
|
|
import { isImage } from "../lib/FileType";
|
|
|
import Utils from "../Utils";
|
|
@@ -27,7 +27,7 @@ class GenerateQRCode extends Operation {
|
|
|
this.description = "Generates a Quick Response (QR) code from the input text.<br><br>A QR code is a type of matrix barcode (or two-dimensional barcode) first designed in 1994 for the automotive industry in Japan. A barcode is a machine-readable optical label that contains information about the item to which it is attached.";
|
|
|
this.infoURL = "https://wikipedia.org/wiki/QR_code";
|
|
|
this.inputType = "string";
|
|
|
- this.outputType = "byteArray";
|
|
|
+ this.outputType = "ArrayBuffer";
|
|
|
this.presentType = "html";
|
|
|
this.args = [
|
|
|
{
|
|
@@ -38,12 +38,14 @@ class GenerateQRCode extends Operation {
|
|
|
{
|
|
|
"name": "Module size (px)",
|
|
|
"type": "number",
|
|
|
- "value": 5
|
|
|
+ "value": 5,
|
|
|
+ "min": 1
|
|
|
},
|
|
|
{
|
|
|
"name": "Margin (num modules)",
|
|
|
"type": "number",
|
|
|
- "value": 2
|
|
|
+ "value": 2,
|
|
|
+ "min": 0
|
|
|
},
|
|
|
{
|
|
|
"name": "Error correction",
|
|
@@ -57,61 +59,34 @@ class GenerateQRCode extends Operation {
|
|
|
/**
|
|
|
* @param {string} input
|
|
|
* @param {Object[]} args
|
|
|
- * @returns {byteArray}
|
|
|
+ * @returns {ArrayBuffer}
|
|
|
*/
|
|
|
run(input, args) {
|
|
|
const [format, size, margin, errorCorrection] = args;
|
|
|
|
|
|
- // Create new QR image from the input data, and convert it to a buffer
|
|
|
- const qrImage = qr.imageSync(input, {
|
|
|
- type: format,
|
|
|
- size: size,
|
|
|
- margin: margin,
|
|
|
- "ec_level": errorCorrection.charAt(0).toUpperCase()
|
|
|
- });
|
|
|
-
|
|
|
- if (qrImage == null) {
|
|
|
- throw new OperationError("Error generating QR code.");
|
|
|
- }
|
|
|
-
|
|
|
- switch (format) {
|
|
|
- case "SVG":
|
|
|
- case "EPS":
|
|
|
- case "PDF":
|
|
|
- return [...Buffer.from(qrImage)];
|
|
|
- case "PNG":
|
|
|
- // Return the QR image buffer as a byte array
|
|
|
- return [...qrImage];
|
|
|
- default:
|
|
|
- throw new OperationError("Unsupported QR code format.");
|
|
|
- }
|
|
|
+ return generateQrCode(input, format, size, margin, errorCorrection);
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* Displays the QR image using HTML for web apps
|
|
|
*
|
|
|
- * @param {byteArray} data
|
|
|
+ * @param {ArrayBuffer} data
|
|
|
* @returns {html}
|
|
|
*/
|
|
|
present(data, args) {
|
|
|
- if (!data.length) return "";
|
|
|
-
|
|
|
- const [format] = args;
|
|
|
-
|
|
|
+ if (!data.byteLength && !data.length) return "";
|
|
|
+ const dataArray = new Uint8Array(data),
|
|
|
+ [format] = args;
|
|
|
if (format === "PNG") {
|
|
|
- let dataURI = "data:";
|
|
|
- const mime = isImage(data);
|
|
|
- if (mime){
|
|
|
- dataURI += mime + ";";
|
|
|
- } else {
|
|
|
- throw new OperationError("Invalid PNG file generated by QR image");
|
|
|
+ const type = isImage(dataArray);
|
|
|
+ if (!type) {
|
|
|
+ throw new OperationError("Invalid file type.");
|
|
|
}
|
|
|
- dataURI += "base64," + toBase64(data);
|
|
|
|
|
|
- return `<img src="${dataURI}">`;
|
|
|
+ return `<img src="data:${type};base64,${toBase64(dataArray)}">`;
|
|
|
}
|
|
|
|
|
|
- return Utils.byteArrayToChars(data);
|
|
|
+ return Utils.arrayBufferToStr(data);
|
|
|
}
|
|
|
|
|
|
}
|