From 76f2d38b544b403240bbff2d32de09aba7351181 Mon Sep 17 00:00:00 2001 From: Alexey Lunin <alexey.lunin@vereign.com> Date: Fri, 10 May 2024 10:11:02 +0300 Subject: [PATCH] remove not used packages in native --- dist/index.d.ts | 1 - dist/index.js | 4 +- dist/utils/getMerkleTreeRootHash.d.ts | 2 +- dist/utils/qrCodeTemplateUtils.d.ts | 21 -- dist/utils/qrCodeTemplateUtils.js | 299 --------------- package.json | 4 - src/index.ts | 1 - src/utils/qrCodeTemplateUtils.ts | 467 ----------------------- yarn.lock | 521 +------------------------- 9 files changed, 9 insertions(+), 1311 deletions(-) delete mode 100644 dist/utils/qrCodeTemplateUtils.d.ts delete mode 100644 dist/utils/qrCodeTemplateUtils.js delete mode 100644 src/utils/qrCodeTemplateUtils.ts diff --git a/dist/index.d.ts b/dist/index.d.ts index ec88b41..b7234bd 100644 --- a/dist/index.d.ts +++ b/dist/index.d.ts @@ -9,4 +9,3 @@ export { default as QrCodeDataService } from "./services/QrCodeDataService"; export { default as IPFSService } from "./services/IPFSService"; export { default as CryptoService } from "./services/CryptoService"; export { default as VerificationError } from "./services/VerificationService/VerificationError"; -export { default as QrCodeTemplate } from "./utils/qrCodeTemplateUtils"; diff --git a/dist/index.js b/dist/index.js index b6c5f47..0d9cde3 100644 --- a/dist/index.js +++ b/dist/index.js @@ -13,7 +13,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); -exports.QrCodeTemplate = exports.VerificationError = exports.CryptoService = exports.IPFSService = exports.QrCodeDataService = exports.CommonUtils = exports.StatusesService = exports.VerificationService = exports.CloudflareService = exports.getMerkleTreeRootHash = void 0; +exports.VerificationError = exports.CryptoService = exports.IPFSService = exports.QrCodeDataService = exports.CommonUtils = exports.StatusesService = exports.VerificationService = exports.CloudflareService = exports.getMerkleTreeRootHash = void 0; __exportStar(require("./types"), exports); __exportStar(require("./utils/common"), exports); var getMerkleTreeRootHash_1 = require("./utils/getMerkleTreeRootHash"); @@ -34,5 +34,3 @@ var CryptoService_1 = require("./services/CryptoService"); Object.defineProperty(exports, "CryptoService", { enumerable: true, get: function () { return __importDefault(CryptoService_1).default; } }); var VerificationError_1 = require("./services/VerificationService/VerificationError"); Object.defineProperty(exports, "VerificationError", { enumerable: true, get: function () { return __importDefault(VerificationError_1).default; } }); -var qrCodeTemplateUtils_1 = require("./utils/qrCodeTemplateUtils"); -Object.defineProperty(exports, "QrCodeTemplate", { enumerable: true, get: function () { return __importDefault(qrCodeTemplateUtils_1).default; } }); diff --git a/dist/utils/getMerkleTreeRootHash.d.ts b/dist/utils/getMerkleTreeRootHash.d.ts index 09d4db3..998cb76 100644 --- a/dist/utils/getMerkleTreeRootHash.d.ts +++ b/dist/utils/getMerkleTreeRootHash.d.ts @@ -1,3 +1,3 @@ -import { Buffer } from 'buffer'; +import { Buffer } from "buffer"; declare const getMerkleTreeRootHash: (leaves: Buffer[]) => Promise<Buffer>; export default getMerkleTreeRootHash; diff --git a/dist/utils/qrCodeTemplateUtils.d.ts b/dist/utils/qrCodeTemplateUtils.d.ts deleted file mode 100644 index e3e8c4f..0000000 --- a/dist/utils/qrCodeTemplateUtils.d.ts +++ /dev/null @@ -1,21 +0,0 @@ -interface TemplateOptions { - src: string; - placeholderSize: number; -} -/** - * https://www.qrcode.com/en/about/error_correction.html#:~:text=QR%20Code%20has%20error%20correction,of%20data%20QR%20Code%20size. - */ -declare type CorrectionLevels = "L" | "M" | "Q" | "H"; -interface QrCodeOptions { - width?: number; - height?: number; - logoSrc?: string; - logoWidth?: number; - logoHeight?: number; - correctionLevel?: CorrectionLevels; -} -declare const _default: { - putQrCodeOnChromakeyTemplate: (qrCodeImageBase64: string, templateImageBase64: string, placeholderWidth: number, placeholderHeight: number, scale?: number) => Promise<string>; - generateQrCode: (text: string, qrCodeOptions?: QrCodeOptions, templateOptions?: TemplateOptions) => Promise<string>; -}; -export default _default; diff --git a/dist/utils/qrCodeTemplateUtils.js b/dist/utils/qrCodeTemplateUtils.js deleted file mode 100644 index 3b29f8f..0000000 --- a/dist/utils/qrCodeTemplateUtils.js +++ /dev/null @@ -1,299 +0,0 @@ -"use strict"; -var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); -}) : (function(o, m, k, k2) { - if (k2 === undefined) k2 = k; - o[k2] = m[k]; -})); -var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { - Object.defineProperty(o, "default", { enumerable: true, value: v }); -}) : function(o, v) { - o["default"] = v; -}); -var __importStar = (this && this.__importStar) || function (mod) { - if (mod && mod.__esModule) return mod; - var result = {}; - if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); - __setModuleDefault(result, mod); - return result; -}; -var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); -}; -var __importDefault = (this && this.__importDefault) || function (mod) { - return (mod && mod.__esModule) ? mod : { "default": mod }; -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const easyqrcodejs_1 = __importDefault(require("easyqrcodejs")); -const common_1 = require("./common"); -const DEFAULT_TEMPLATE = "data:image/png;base64,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"; -const DEFAULT_LOGO = "data:image/png;base64,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"; -const findChromakeyBoundaries = (width, height, imageData, chromakeyWidth, chromakeyHeight) => { - const maskSizeX = chromakeyWidth; - const maskSizeY = chromakeyHeight; - const totalSum = maskSizeX * maskSizeY * 255; - const matrixR = []; - const matrixG = []; - const matrixB = []; - for (let i = 0; i < width; i++) { - matrixR[i] = []; - matrixG[i] = []; - matrixB[i] = []; - for (let j = 0; j < height; j++) { - matrixR[i][j] = 0; - matrixG[i][j] = 0; - matrixB[i][j] = 0; - } - } - const maxDistance = Math.sqrt(3 * totalSum * totalSum); - const suitableSimilarity = 0.6; - let bestSimilarity = 0; - let bestX = -1; - let bestY = -1; - for (let x = 0; x < width; x++) { - for (let y = 0; y < height; y++) { - const index = (y * width + x) * 4; - const r = imageData.data[index]; - const g = imageData.data[index + 1]; - const b = imageData.data[index + 2]; - matrixR[x][y] += r; - matrixG[x][y] += g; - matrixB[x][y] += b; - if (x - 1 >= 0) { - matrixR[x][y] += matrixR[x - 1][y]; - matrixG[x][y] += matrixG[x - 1][y]; - matrixB[x][y] += matrixB[x - 1][y]; - } - if (y - 1 >= 0) { - matrixR[x][y] += matrixR[x][y - 1]; - matrixG[x][y] += matrixG[x][y - 1]; - matrixB[x][y] += matrixB[x][y - 1]; - } - if (x - 1 >= 0 && y - 1 >= 0) { - matrixR[x][y] -= matrixR[x - 1][y - 1]; - matrixG[x][y] -= matrixG[x - 1][y - 1]; - matrixB[x][y] -= matrixB[x - 1][y - 1]; - } - if (x >= maskSizeX && y >= maskSizeY) { - const tempSumR = matrixR[x][y] + - matrixR[x - maskSizeX][y - maskSizeY] - - (matrixR[x - maskSizeX][y] + matrixR[x][y - maskSizeY]); - const tempSumG = matrixG[x][y] + - matrixG[x - maskSizeX][y - maskSizeY] - - (matrixG[x - maskSizeX][y] + matrixG[x][y - maskSizeY]); - const tempSumB = matrixB[x][y] + - matrixB[x - maskSizeX][y - maskSizeY] - - (matrixB[x - maskSizeX][y] + matrixB[x][y - maskSizeY]); - const distance = Math.sqrt(Math.pow(0 - tempSumR, 2) + - Math.pow(totalSum - tempSumG, 2) + - Math.pow(0 - tempSumB, 2)); - const similarity = 1 - distance / maxDistance; - if (similarity > bestSimilarity) { - bestX = x; - bestY = y; - bestSimilarity = similarity; - } - } - } - } - if (bestX >= 0 && bestY >= 0 && bestSimilarity > suitableSimilarity) { - return { - fromL: bestX - maskSizeX, - fromT: bestY - maskSizeY, - toL: bestX - maskSizeX + chromakeyWidth, - toT: bestY - maskSizeY + chromakeyHeight, - }; - } - return { fromL: -1, fromT: -1, toL: -1, toT: -1 }; -}; -const defaultOptions = { - width: 256, - height: 256, - logoSrc: DEFAULT_LOGO, - logoWidth: 75, - logoHeight: 66, - // Use "L" level as we don't need a redundancy - correctionLevel: "L", -}; -const defaultTemplateOptions = { - placeholderSize: 260, - src: DEFAULT_TEMPLATE, -}; -/** - * Generates QR Code based of the context - Browser or NodeJs. - * IMPORTANT: In case of NodeJS it uses the JSDON and Canvas libraries to mimic the DOM behaviour - * - * @param text - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateQrCode = (text, qrCodeOptions, templateOptions) => { - qrCodeOptions = qrCodeOptions - ? Object.assign(defaultOptions, qrCodeOptions) - : defaultOptions; - templateOptions = templateOptions - ? Object.assign(defaultTemplateOptions, templateOptions) - : defaultTemplateOptions; - const options = { - text, - width: qrCodeOptions.width, - height: qrCodeOptions.height, - colorDark: "#000000", - colorLight: "#ffffff", - dotScale: 1, - }; - if (qrCodeOptions.logoSrc) { - Object.assign(options, { - logo: qrCodeOptions.logoSrc, - logoBackgroundTransparent: true, - logoWidth: qrCodeOptions.logoWidth, - logoHeight: qrCodeOptions.logoHeight, - }); - } - if (common_1.isNode) { - return generateNodeJSQrCode(options, qrCodeOptions, templateOptions); - } - options["correctLevel"] = easyqrcodejs_1.default.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - return generateBrowserQrCode(options, templateOptions); -}; -/** - * Nodejs impl for generation of qr code. Uses JSDOM and Canvas libs to mimic the DOM. - * - * @param defaultOptions - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateNodeJSQrCode = (defaultOptions, qrCodeOptions, templateOptions) => __awaiter(void 0, void 0, void 0, function* () { - const QRCodeNodeJS = yield Promise.resolve().then(() => __importStar(require("easyqrcodejs-nodejs"))); - defaultOptions["correctLevel"] = - QRCodeNodeJS.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - const qrcode = new QRCodeNodeJS.default(defaultOptions); - const dataUrl = yield qrcode.toDataURL(); - yield new Promise((resolve) => setTimeout(resolve, 10)); - return yield putQrCodeOnChromakeyTemplateNodeJS(dataUrl, templateOptions.src, templateOptions.placeholderSize, templateOptions.placeholderSize); -}); -const generateBrowserQrCode = (qrCodeOptions, templateOptions) => __awaiter(void 0, void 0, void 0, function* () { - const container = document.createElement("div"); - new easyqrcodejs_1.default(container, qrCodeOptions); - const canvas = container.getElementsByTagName("canvas")[0]; - // Add short async action because of the bug with logo not appearing in the resulting image. - yield new Promise((resolve) => setTimeout(resolve, 10)); - return yield putQrCodeOnChromakeyTemplate(canvas.toDataURL(), templateOptions.src, templateOptions.placeholderSize, templateOptions.placeholderSize); -}); -/** - * Nodejs impl for template generation - * - * @param qrCodeImageBase64 - * @param templateImageBase64 - * @param placeholderWidth - * @param placeholderHeight - * @param scale - * @returns - */ -const putQrCodeOnChromakeyTemplateNodeJS = (qrCodeImageBase64, templateImageBase64, placeholderWidth, placeholderHeight, scale = 1) => __awaiter(void 0, void 0, void 0, function* () { - const jsdom = yield Promise.resolve().then(() => __importStar(require("jsdom"))); - const { JSDOM } = jsdom; - const dom = new JSDOM("", { resources: "usable" }); - const document = dom.window.document; - let qrCodeImage; - try { - qrCodeImage = yield loadImageNode(qrCodeImageBase64, document); - } - catch (e) { - throw new Error("NodeJS cannot load qr code image"); - } - const templateImage = yield loadImageNode(templateImageBase64, document); - if (templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight) { - throw new Error("Placeholder is bigger than image"); - } - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height); - const templateImgData = templateCtx.getImageData(0, 0, templateCanvas.width, templateCanvas.height); - const placeholderCoordinates = findChromakeyBoundaries(templateImage.width, templateImage.height, templateImgData, placeholderWidth, placeholderHeight); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - bannerCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height, 0, 0, scaledTemplateW, scaledTemplateH); - // +1 hides green border - bannerCtx.drawImage(qrCodeImage, placeholderCoordinates.fromL * scaleX, placeholderCoordinates.fromT * scaleY, qrCodeImage.width, qrCodeImage.height); - return bannerCanvas.toDataURL(); -}); -const putQrCodeOnChromakeyTemplate = (qrCodeImageBase64, templateImageBase64, placeholderWidth, placeholderHeight, scale = 1) => __awaiter(void 0, void 0, void 0, function* () { - const qrCodeImage = yield loadImage(qrCodeImageBase64); - const templateImage = yield loadImage(templateImageBase64); - if (templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight) { - throw new Error("Placeholder is bigger than image"); - } - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height); - const templateImgData = templateCtx.getImageData(0, 0, templateCanvas.width, templateCanvas.height); - const placeholderCoordinates = findChromakeyBoundaries(templateImage.width, templateImage.height, templateImgData, placeholderWidth, placeholderHeight); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - bannerCtx.drawImage(templateImage, 0, 0, templateImage.width, templateImage.height, 0, 0, scaledTemplateW, scaledTemplateH); - // +1 hides green border - bannerCtx.drawImage(qrCodeImage, placeholderCoordinates.fromL * scaleX, placeholderCoordinates.fromT * scaleY, qrCodeImage.width, qrCodeImage.height); - return bannerCanvas.toDataURL(); -}); -const loadImage = (imageSrc) => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; -/** - * Duplicates the load img for browser - * - * @param imageSrc - * @returns - */ -const loadImageNode = (imageSrc, document) => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; -exports.default = { - putQrCodeOnChromakeyTemplate, - generateQrCode, -}; diff --git a/package.json b/package.json index 119f0aa..17ffdfb 100644 --- a/package.json +++ b/package.json @@ -38,14 +38,10 @@ "dependencies": { "axios": "^0.20.0", "buffer": "^6.0.3", - "canvas": "^2.8.0", - "easyqrcodejs": "^4.3.1", - "easyqrcodejs-nodejs": "^4.4.2", "eventemitter2": "^6.4.3", "fflate": "^0.7.3", "google-protobuf": "^3.13.0", "js-md5": "^0.7.3", - "penpal": "^5.3.0", "protobufjs": "^6.10.1", "url-parse": "^1.4.7" }, diff --git a/src/index.ts b/src/index.ts index ec88b41..b7234bd 100644 --- a/src/index.ts +++ b/src/index.ts @@ -9,4 +9,3 @@ export { default as QrCodeDataService } from "./services/QrCodeDataService"; export { default as IPFSService } from "./services/IPFSService"; export { default as CryptoService } from "./services/CryptoService"; export { default as VerificationError } from "./services/VerificationService/VerificationError"; -export { default as QrCodeTemplate } from "./utils/qrCodeTemplateUtils"; diff --git a/src/utils/qrCodeTemplateUtils.ts b/src/utils/qrCodeTemplateUtils.ts deleted file mode 100644 index 7cfc925..0000000 --- a/src/utils/qrCodeTemplateUtils.ts +++ /dev/null @@ -1,467 +0,0 @@ -import QRCode from "easyqrcodejs"; -import { isNode } from "./common"; - -const DEFAULT_TEMPLATE = - "data:image/png;base64,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"; -const DEFAULT_LOGO = - "data:image/png;base64,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"; - -interface ChromakeyBoundaries { - fromL: number; - fromT: number; - toL: number; - toT: number; -} - -const findChromakeyBoundaries = ( - width: number, - height: number, - imageData: ImageData, - chromakeyWidth: number, - chromakeyHeight: number -): ChromakeyBoundaries => { - const maskSizeX = chromakeyWidth; - const maskSizeY = chromakeyHeight; - - const totalSum = maskSizeX * maskSizeY * 255; - - const matrixR = []; - const matrixG = []; - const matrixB = []; - - for (let i = 0; i < width; i++) { - matrixR[i] = []; - matrixG[i] = []; - matrixB[i] = []; - for (let j = 0; j < height; j++) { - matrixR[i][j] = 0; - matrixG[i][j] = 0; - matrixB[i][j] = 0; - } - } - - const maxDistance = Math.sqrt(3 * totalSum * totalSum); - const suitableSimilarity = 0.6; - - let bestSimilarity = 0; - let bestX = -1; - let bestY = -1; - for (let x = 0; x < width; x++) { - for (let y = 0; y < height; y++) { - const index = (y * width + x) * 4; - const r = imageData.data[index]; - const g = imageData.data[index + 1]; - const b = imageData.data[index + 2]; - - matrixR[x][y] += r; - matrixG[x][y] += g; - matrixB[x][y] += b; - - if (x - 1 >= 0) { - matrixR[x][y] += matrixR[x - 1][y]; - matrixG[x][y] += matrixG[x - 1][y]; - matrixB[x][y] += matrixB[x - 1][y]; - } - - if (y - 1 >= 0) { - matrixR[x][y] += matrixR[x][y - 1]; - matrixG[x][y] += matrixG[x][y - 1]; - matrixB[x][y] += matrixB[x][y - 1]; - } - - if (x - 1 >= 0 && y - 1 >= 0) { - matrixR[x][y] -= matrixR[x - 1][y - 1]; - matrixG[x][y] -= matrixG[x - 1][y - 1]; - matrixB[x][y] -= matrixB[x - 1][y - 1]; - } - if (x >= maskSizeX && y >= maskSizeY) { - const tempSumR = - matrixR[x][y] + - matrixR[x - maskSizeX][y - maskSizeY] - - (matrixR[x - maskSizeX][y] + matrixR[x][y - maskSizeY]); - const tempSumG = - matrixG[x][y] + - matrixG[x - maskSizeX][y - maskSizeY] - - (matrixG[x - maskSizeX][y] + matrixG[x][y - maskSizeY]); - const tempSumB = - matrixB[x][y] + - matrixB[x - maskSizeX][y - maskSizeY] - - (matrixB[x - maskSizeX][y] + matrixB[x][y - maskSizeY]); - - const distance = Math.sqrt( - Math.pow(0 - tempSumR, 2) + - Math.pow(totalSum - tempSumG, 2) + - Math.pow(0 - tempSumB, 2) - ); - const similarity = 1 - distance / maxDistance; - - if (similarity > bestSimilarity) { - bestX = x; - bestY = y; - bestSimilarity = similarity; - } - } - } - } - - if (bestX >= 0 && bestY >= 0 && bestSimilarity > suitableSimilarity) { - return { - fromL: bestX - maskSizeX, - fromT: bestY - maskSizeY, - toL: bestX - maskSizeX + chromakeyWidth, - toT: bestY - maskSizeY + chromakeyHeight, - }; - } - - return { fromL: -1, fromT: -1, toL: -1, toT: -1 }; -}; - -interface TemplateOptions { - src: string; - placeholderSize: number; -} - -/** - * https://www.qrcode.com/en/about/error_correction.html#:~:text=QR%20Code%20has%20error%20correction,of%20data%20QR%20Code%20size. - */ -type CorrectionLevels = "L" | "M" | "Q" | "H"; - -interface QrCodeOptions { - width?: number; - height?: number; - logoSrc?: string; - logoWidth?: number; - logoHeight?: number; - correctionLevel?: CorrectionLevels; -} - -const defaultOptions: QrCodeOptions = { - width: 256, - height: 256, - logoSrc: DEFAULT_LOGO, - logoWidth: 75, - logoHeight: 66, - // Use "L" level as we don't need a redundancy - correctionLevel: "L", -}; - -const defaultTemplateOptions: TemplateOptions = { - placeholderSize: 260, - src: DEFAULT_TEMPLATE, -}; - -/** - * Generates QR Code based of the context - Browser or NodeJs. - * IMPORTANT: In case of NodeJS it uses the JSDON and Canvas libraries to mimic the DOM behaviour - * - * @param text - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateQrCode = ( - text: string, - qrCodeOptions?: QrCodeOptions, - templateOptions?: TemplateOptions -): Promise<string> => { - qrCodeOptions = qrCodeOptions - ? Object.assign(defaultOptions, qrCodeOptions) - : defaultOptions; - - templateOptions = templateOptions - ? Object.assign(defaultTemplateOptions, templateOptions) - : defaultTemplateOptions; - - const options = { - text, - width: qrCodeOptions.width, - height: qrCodeOptions.height, - colorDark: "#000000", - colorLight: "#ffffff", - dotScale: 1, - }; - - if (qrCodeOptions.logoSrc) { - Object.assign(options, { - logo: qrCodeOptions.logoSrc, - logoBackgroundTransparent: true, - logoWidth: qrCodeOptions.logoWidth, - logoHeight: qrCodeOptions.logoHeight, - }); - } - - if (isNode) { - return generateNodeJSQrCode(options, qrCodeOptions, templateOptions); - } - options["correctLevel"] = QRCode.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - return generateBrowserQrCode(options, templateOptions); -}; - -/** - * Nodejs impl for generation of qr code. Uses JSDOM and Canvas libs to mimic the DOM. - * - * @param defaultOptions - * @param qrCodeOptions - * @param templateOptions - * @returns - */ -const generateNodeJSQrCode = async ( - defaultOptions: QrCodeOptions, - qrCodeOptions: QrCodeOptions, - templateOptions: TemplateOptions -): Promise<string> => { - const QRCodeNodeJS = await import("easyqrcodejs-nodejs"); - - defaultOptions["correctLevel"] = - QRCodeNodeJS.CorrectLevel[qrCodeOptions.correctionLevel]; // L, M, Q, H - - const qrcode = new QRCodeNodeJS.default(defaultOptions); - const dataUrl = await qrcode.toDataURL(); - - await new Promise((resolve) => setTimeout(resolve, 10)); - - return await putQrCodeOnChromakeyTemplateNodeJS( - dataUrl, - templateOptions.src, - templateOptions.placeholderSize, - templateOptions.placeholderSize - ); -}; - -const generateBrowserQrCode = async ( - qrCodeOptions: QrCodeOptions, - templateOptions: TemplateOptions -): Promise<string> => { - const container = document.createElement("div"); - new QRCode(container, qrCodeOptions); - const canvas = container.getElementsByTagName("canvas")[0]; - - // Add short async action because of the bug with logo not appearing in the resulting image. - await new Promise((resolve) => setTimeout(resolve, 10)); - - return await putQrCodeOnChromakeyTemplate( - canvas.toDataURL(), - templateOptions.src, - templateOptions.placeholderSize, - templateOptions.placeholderSize - ); -}; - -/** - * Nodejs impl for template generation - * - * @param qrCodeImageBase64 - * @param templateImageBase64 - * @param placeholderWidth - * @param placeholderHeight - * @param scale - * @returns - */ -const putQrCodeOnChromakeyTemplateNodeJS = async ( - qrCodeImageBase64: string, - templateImageBase64: string, - placeholderWidth: number, - placeholderHeight: number, - scale = 1 -): Promise<string> => { - const jsdom = await import("jsdom"); - - const { JSDOM } = jsdom; - const dom = new JSDOM("", { resources: "usable" }); - const document = dom.window.document; - let qrCodeImage; - - try { - qrCodeImage = await loadImageNode(qrCodeImageBase64, document); - } catch (e) { - throw new Error("NodeJS cannot load qr code image"); - } - const templateImage = await loadImageNode(templateImageBase64, document); - - if ( - templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight - ) { - throw new Error("Placeholder is bigger than image"); - } - - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height - ); - - const templateImgData = templateCtx.getImageData( - 0, - 0, - templateCanvas.width, - templateCanvas.height - ); - - const placeholderCoordinates = findChromakeyBoundaries( - templateImage.width, - templateImage.height, - templateImgData, - placeholderWidth, - placeholderHeight - ); - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - - bannerCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height, - 0, - 0, - scaledTemplateW, - scaledTemplateH - ); - // +1 hides green border - bannerCtx.drawImage( - qrCodeImage, - placeholderCoordinates.fromL * scaleX, - placeholderCoordinates.fromT * scaleY, - qrCodeImage.width, - qrCodeImage.height - ); - return bannerCanvas.toDataURL(); -}; - -const putQrCodeOnChromakeyTemplate = async ( - qrCodeImageBase64: string, - templateImageBase64: string, - placeholderWidth: number, - placeholderHeight: number, - scale = 1 -): Promise<string> => { - const qrCodeImage = await loadImage(qrCodeImageBase64); - const templateImage = await loadImage(templateImageBase64); - - if ( - templateImage.width < placeholderWidth || - templateImage.height < placeholderHeight - ) { - throw new Error("Placeholder is bigger than image"); - } - - const templateCanvas = document.createElement("canvas"); - templateCanvas.width = templateImage.width; - templateCanvas.height = templateImage.height; - - const templateCtx = templateCanvas.getContext("2d"); - templateCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height - ); - - const templateImgData = templateCtx.getImageData( - 0, - 0, - templateCanvas.width, - templateCanvas.height - ); - - const placeholderCoordinates = findChromakeyBoundaries( - templateImage.width, - templateImage.height, - templateImgData, - placeholderWidth, - placeholderHeight - ); - - // -2 is for QR to slightly cover borders. To avoid green mask bulging out - const scaleX = ((qrCodeImage.width - 2) / placeholderWidth) * scale; - const scaleY = ((qrCodeImage.height - 2) / placeholderHeight) * scale; - qrCodeImage.width *= scale; - qrCodeImage.height *= scale; - - const bannerCanvas = document.createElement("canvas"); - const scaledTemplateW = Math.floor(templateImage.width * scaleX); - const scaledTemplateH = Math.floor(templateImage.height * scaleY); - - bannerCanvas.width = scaledTemplateW; - bannerCanvas.height = scaledTemplateH; - - const bannerCtx = bannerCanvas.getContext("2d"); - // bannerCtx - - bannerCtx.drawImage( - templateImage, - 0, - 0, - templateImage.width, - templateImage.height, - 0, - 0, - scaledTemplateW, - scaledTemplateH - ); - - // +1 hides green border - bannerCtx.drawImage( - qrCodeImage, - placeholderCoordinates.fromL * scaleX, - placeholderCoordinates.fromT * scaleY, - qrCodeImage.width, - qrCodeImage.height - ); - return bannerCanvas.toDataURL(); -}; - -const loadImage = (imageSrc: string): Promise<HTMLImageElement> => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; - -/** - * Duplicates the load img for browser - * - * @param imageSrc - * @returns - */ -const loadImageNode = ( - imageSrc: string, - document -): Promise<HTMLImageElement> => { - return new Promise((resolve, reject) => { - const templateImg = document.createElement("img"); - templateImg.src = imageSrc; - templateImg.onload = () => resolve(templateImg); - templateImg.onerror = (error) => reject(error); - }); -}; - -export default { - putQrCodeOnChromakeyTemplate, - generateQrCode, -}; diff --git a/yarn.lock b/yarn.lock index ec1738e..b988d6a 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1163,21 +1163,6 @@ "@types/yargs" "^15.0.0" chalk "^4.0.0" -"@mapbox/node-pre-gyp@^1.0.0": - version "1.0.8" - resolved "https://registry.yarnpkg.com/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.8.tgz#32abc8a5c624bc4e46c43d84dfb8b26d33a96f58" - integrity sha512-CMGKi28CF+qlbXh26hDe6NxCd7amqeAzEqnS6IHeO6LoaKyM/n+Xw3HT1COdq8cuioOdlKdqn/hCmqPUOMOywg== - dependencies: - detect-libc "^1.0.3" - https-proxy-agent "^5.0.0" - make-dir "^3.1.0" - node-fetch "^2.6.5" - nopt "^5.0.0" - npmlog "^5.0.1" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.11" - "@protobufjs/aspromise@^1.1.1", "@protobufjs/aspromise@^1.1.2": version "1.1.2" resolved "https://registry.yarnpkg.com/@protobufjs/aspromise/-/aspromise-1.1.2.tgz#9b8b0cc663d669a7d8f6f5d0893a14d348f30fbf" @@ -1250,16 +1235,6 @@ resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82" integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== -"@tootallnate/once@2": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" - integrity sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A== - -"@trysound/sax@0.2.0": - version "0.2.0" - resolved "https://registry.yarnpkg.com/@trysound/sax/-/sax-0.2.0.tgz#cccaab758af56761eb7bf37af6f03f326dd798ad" - integrity sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA== - "@types/babel__core@^7.0.0", "@types/babel__core@^7.1.7": version "7.1.18" resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.18.tgz#1a29abcc411a9c05e2094c98f9a1b7da6cdf49f8" @@ -1455,11 +1430,6 @@ abab@^2.0.3, abab@^2.0.5: resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q== -abbrev@1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" - integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== - acorn-globals@^6.0.0: version "6.0.0" resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-6.0.0.tgz#46cdd39f0f8ff08a876619b55f5ac8a6dc770b45" @@ -1483,7 +1453,7 @@ acorn@^7.1.1, acorn@^7.4.0: resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== -acorn@^8.2.4, acorn@^8.5.0: +acorn@^8.2.4: version "8.7.0" resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf" integrity sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ== @@ -1570,19 +1540,6 @@ anymatch@^3.0.3: normalize-path "^3.0.0" picomatch "^2.0.4" -"aproba@^1.0.3 || ^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" - integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== - -are-we-there-yet@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz#372e0e7bd279d8e94c653aaa1f67200884bf3e1c" - integrity sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw== - dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" - argparse@^1.0.7: version "1.0.10" resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" @@ -1764,11 +1721,6 @@ base@^0.11.1: mixin-deep "^1.2.0" pascalcase "^0.1.1" -boolbase@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" - integrity sha1-aN/1++YMUes3cl6p4+0xDcwed24= - brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" @@ -1884,15 +1836,6 @@ caniuse-lite@^1.0.30001286: resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001296.tgz#d99f0f3bee66544800b93d261c4be55a35f1cec8" integrity sha512-WfrtPEoNSoeATDlf4y3QvkwiELl9GyPLISV5GejTbbQRtQx4LhsXmc9IQ6XCL2d7UxCyEzToEZNMeqR79OUw8Q== -canvas@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/canvas/-/canvas-2.8.0.tgz#f99ca7f25e6e26686661ffa4fec1239bbef74461" - integrity sha512-gLTi17X8WY9Cf5GZ2Yns8T5lfBOcGgFehDFb+JQwDqdOoBOcECS9ZWMEAqMSVcMYwXD659J8NyzjRY/2aE+C2Q== - dependencies: - "@mapbox/node-pre-gyp" "^1.0.0" - nan "^2.14.0" - simple-get "^3.0.3" - capture-exit@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/capture-exit/-/capture-exit-2.0.0.tgz#fb953bfaebeb781f62898239dabb426d08a509a4" @@ -1922,11 +1865,6 @@ char-regex@^1.0.2: resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== -chownr@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" - integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== - ci-info@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" @@ -2018,11 +1956,6 @@ color-name@~1.1.4: resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== -color-support@^1.1.2: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" - integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== - colorette@^2.0.16: version "2.0.16" resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.16.tgz#713b9af84fdb000139f04546bd4a93f62a5085da" @@ -2045,11 +1978,6 @@ commander@^6.2.0: resolved "https://registry.yarnpkg.com/commander/-/commander-6.2.1.tgz#0792eb682dfbc325999bb2b84fddddba110ac73c" integrity sha512-U7VdrJFnJgo4xjrHpTzu0yrHPGImdsmD95ZlgYSEajAn2JKzDhDTPG9kBTefmObL2w/ngeZnilk+OV9CG3d7UA== -commander@^7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" - integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== - compare-versions@^3.6.0: version "3.6.0" resolved "https://registry.yarnpkg.com/compare-versions/-/compare-versions-3.6.0.tgz#1a5689913685e5a87637b8d3ffca75514ec41d62" @@ -2065,11 +1993,6 @@ concat-map@0.0.1: resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= -console-control-strings@^1.0.0, console-control-strings@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" - integrity sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4= - convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: version "1.8.0" resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" @@ -2121,47 +2044,11 @@ cross-spawn@^7.0.0, cross-spawn@^7.0.2: shebang-command "^2.0.0" which "^2.0.1" -css-select@^4.1.3: - version "4.2.1" - resolved "https://registry.yarnpkg.com/css-select/-/css-select-4.2.1.tgz#9e665d6ae4c7f9d65dbe69d0316e3221fb274cdd" - integrity sha512-/aUslKhzkTNCQUB2qTX84lVmfia9NyjP3WpDGtj/WxhwBzWBYUV3DgUpurHTme8UTPcPlAD1DJ+b0nN/t50zDQ== - dependencies: - boolbase "^1.0.0" - css-what "^5.1.0" - domhandler "^4.3.0" - domutils "^2.8.0" - nth-check "^2.0.1" - -css-tree@^1.1.2, css-tree@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d" - integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q== - dependencies: - mdn-data "2.0.14" - source-map "^0.6.1" - -css-what@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/css-what/-/css-what-5.1.0.tgz#3f7b707aadf633baf62c2ceb8579b545bb40f7fe" - integrity sha512-arSMRWIIFY0hV8pIxZMEfmMI47Wj3R/aWpZDDxWYCPEiOMv6tfOrnpDtgxBYPEQD4V0Y/958+1TdC3iWTFcUPw== - -csso@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/csso/-/csso-4.2.0.tgz#ea3a561346e8dc9f546d6febedd50187cf389529" - integrity sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA== - dependencies: - css-tree "^1.1.2" - cssom@^0.4.4: version "0.4.4" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" integrity sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw== -cssom@^0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.5.0.tgz#d254fa92cd8b6fbd83811b9fbaed34663cc17c36" - integrity sha512-iKuQcq+NdHqlAcwUY0o/HL69XQrUaQdMjmStJ8JFmUaiiQErlhrmuigkg/CU4E2J0IyUKUrMAgl36TvN67MqTw== - cssom@~0.3.6: version "0.3.8" resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" @@ -2183,15 +2070,6 @@ data-urls@^2.0.0: whatwg-mimetype "^2.3.0" whatwg-url "^8.0.0" -data-urls@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-3.0.1.tgz#597fc2ae30f8bc4dbcf731fcd1b1954353afc6f8" - integrity sha512-Ds554NeT5Gennfoo9KN50Vh6tpgtvYEwraYjejXnyTpu1C7oXKxdFk75REooENHE8ndTVOJuv+BEs4/J/xcozw== - dependencies: - abab "^2.0.3" - whatwg-mimetype "^3.0.0" - whatwg-url "^10.0.0" - debug@4, debug@^4.0.1, debug@^4.1.0, debug@^4.1.1, debug@^4.2.0: version "4.3.3" resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" @@ -2211,7 +2089,7 @@ decamelize@^1.2.0: resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA= -decimal.js@^10.2.1, decimal.js@^10.3.1: +decimal.js@^10.2.1: version "10.3.1" resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783" integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== @@ -2221,13 +2099,6 @@ decode-uri-component@^0.2.0: resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545" integrity sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU= -decompress-response@^4.2.0: - version "4.2.1" - resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-4.2.1.tgz#414023cc7a302da25ce2ec82d0d5238ccafd8986" - integrity sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw== - dependencies: - mimic-response "^2.0.0" - dedent@^0.7.0: version "0.7.0" resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" @@ -2277,16 +2148,6 @@ delayed-stream@~1.0.0: resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk= -delegates@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" - integrity sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o= - -detect-libc@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" - integrity sha1-+hN8S9aY7fVc1c0CrFWfkaTEups= - detect-newline@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" @@ -2304,20 +2165,6 @@ doctrine@^3.0.0: dependencies: esutils "^2.0.2" -dom-serializer@^1.0.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-1.3.2.tgz#6206437d32ceefaec7161803230c7a20bc1b4d91" - integrity sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.2.0" - entities "^2.0.0" - -domelementtype@^2.0.1, domelementtype@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.2.0.tgz#9a0b6c2782ed6a1c7323d42267183df9bd8b1d57" - integrity sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A== - domexception@^2.0.1: version "2.0.1" resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" @@ -2325,43 +2172,6 @@ domexception@^2.0.1: dependencies: webidl-conversions "^5.0.0" -domexception@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/domexception/-/domexception-4.0.0.tgz#4ad1be56ccadc86fc76d033353999a8037d03673" - integrity sha512-A2is4PLG+eeSfoTMA95/s4pvAoSo2mKtiM5jlHkAVewmiO8ISFTFKZjH7UAM1Atli/OT/7JHOrJRJiMKUZKYBw== - dependencies: - webidl-conversions "^7.0.0" - -domhandler@^4.2.0, domhandler@^4.3.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.0.tgz#16c658c626cf966967e306f966b431f77d4a5626" - integrity sha512-fC0aXNQXqKSFTr2wDNZDhsEYjCiYsDWl3D01kwt25hm1YIPyDGHvvi3rw+PLqHAl/m71MaiF7d5zvBr0p5UB2g== - dependencies: - domelementtype "^2.2.0" - -domutils@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.8.0.tgz#4437def5db6e2d1f5d6ee859bd95ca7d02048135" - integrity sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A== - dependencies: - dom-serializer "^1.0.1" - domelementtype "^2.2.0" - domhandler "^4.2.0" - -easyqrcodejs-nodejs@^4.4.2: - version "4.4.3" - resolved "https://registry.yarnpkg.com/easyqrcodejs-nodejs/-/easyqrcodejs-nodejs-4.4.3.tgz#52bdbdfaf3449a0fddb0f56c99e365b30b244fdb" - integrity sha512-hKHG3v5UX1aADze2NSqyws9N+Xw8bfXNfTkFvbZxvmzbwCFGPvQ7rQF+95jM2BkJdWjHCJ7/BtRT5dhGWMmdaQ== - dependencies: - canvas "^2.8.0" - jsdom "^18.1.0" - svgo "^2.8.0" - -easyqrcodejs@^4.3.1: - version "4.4.10" - resolved "https://registry.yarnpkg.com/easyqrcodejs/-/easyqrcodejs-4.4.10.tgz#38e84f2002e94b30415fc1232861465e9ce1c5c6" - integrity sha512-DEr/Txdyfo0RsKuC0tX6t72GF5oqNFbnKVL9dTLatL5yiLJaId65BSfa5HKl4FaJt71yRX3DF1sf977FwynWtw== - electron-to-chromium@^1.4.17: version "1.4.34" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.34.tgz#7d87dc0e95c2c65cbd0687ae23146a662506d1ef" @@ -2391,11 +2201,6 @@ enquirer@^2.3.5, enquirer@^2.3.6: dependencies: ansi-colors "^4.1.1" -entities@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" - integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== - error-ex@^1.3.1: version "1.3.2" resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" @@ -2759,15 +2564,6 @@ form-data@^3.0.0: combined-stream "^1.0.8" mime-types "^2.1.12" -form-data@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" - integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== - dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.8" - mime-types "^2.1.12" - fragment-cache@^0.2.1: version "0.2.1" resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19" @@ -2775,13 +2571,6 @@ fragment-cache@^0.2.1: dependencies: map-cache "^0.2.2" -fs-minipass@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" - integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== - dependencies: - minipass "^3.0.0" - fs.realpath@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" @@ -2809,21 +2598,6 @@ functional-red-black-tree@^1.0.1: resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= -gauge@^3.0.0: - version "3.0.2" - resolved "https://registry.yarnpkg.com/gauge/-/gauge-3.0.2.tgz#03bf4441c044383908bcfa0656ad91803259b395" - integrity sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q== - dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.2" - console-control-strings "^1.0.0" - has-unicode "^2.0.1" - object-assign "^4.1.1" - signal-exit "^3.0.0" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.2" - gensync@^1.0.0-beta.2: version "1.0.0-beta.2" resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" @@ -2933,11 +2707,6 @@ has-symbols@^1.0.1: resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.2.tgz#165d3070c00309752a1236a479331e3ac56f1423" integrity sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw== -has-unicode@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" - integrity sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk= - has-value@^0.3.1: version "0.3.1" resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f" @@ -2988,13 +2757,6 @@ html-encoding-sniffer@^2.0.1: dependencies: whatwg-encoding "^1.0.5" -html-encoding-sniffer@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-3.0.0.tgz#2cb1a8cf0db52414776e5b2a7a04d5dd98158de9" - integrity sha512-oWv4T4yJ52iKrufjnyZPkrN0CH3QnrUqdB6In1g5Fe1mia8GmF36gnfNySxoZtxD5+NmYw1EElVXiBk93UeskA== - dependencies: - whatwg-encoding "^2.0.0" - html-escaper@^2.0.0: version "2.0.2" resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" @@ -3009,15 +2771,6 @@ http-proxy-agent@^4.0.1: agent-base "6" debug "4" -http-proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" - integrity sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w== - dependencies: - "@tootallnate/once" "2" - agent-base "6" - debug "4" - https-proxy-agent@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2" @@ -3054,13 +2807,6 @@ iconv-lite@0.4.24: dependencies: safer-buffer ">= 2.1.2 < 3" -iconv-lite@0.6.3: - version "0.6.3" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" - integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== - dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" - ieee754@^1.2.1: version "1.2.1" resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" @@ -3105,7 +2851,7 @@ inflight@^1.0.4: once "^1.3.0" wrappy "1" -inherits@2, inherits@^2.0.3: +inherits@2: version "2.0.4" resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== @@ -3783,39 +3529,6 @@ jsdom@^16.4.0, jsdom@^16.5.3: ws "^7.4.6" xml-name-validator "^3.0.0" -jsdom@^18.1.0: - version "18.1.1" - resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-18.1.1.tgz#15ec896f5ab7df9669a62375606f47c8c09551aa" - integrity sha512-NmJQbjQ/gpS/1at/ce3nCx89HbXL/f5OcenBe8wU1Eik0ROhyUc3LtmG3567dEHAGXkN8rmILW/qtCOPxPHQJw== - dependencies: - abab "^2.0.5" - acorn "^8.5.0" - acorn-globals "^6.0.0" - cssom "^0.5.0" - cssstyle "^2.3.0" - data-urls "^3.0.1" - decimal.js "^10.3.1" - domexception "^4.0.0" - escodegen "^2.0.0" - form-data "^4.0.0" - html-encoding-sniffer "^3.0.0" - http-proxy-agent "^5.0.0" - https-proxy-agent "^5.0.0" - is-potential-custom-element-name "^1.0.1" - nwsapi "^2.2.0" - parse5 "6.0.1" - saxes "^5.0.1" - symbol-tree "^3.2.4" - tough-cookie "^4.0.0" - w3c-hr-time "^1.0.2" - w3c-xmlserializer "^3.0.0" - webidl-conversions "^7.0.0" - whatwg-encoding "^2.0.0" - whatwg-mimetype "^3.0.0" - whatwg-url "^10.0.0" - ws "^8.2.3" - xml-name-validator "^4.0.0" - jsesc@^2.5.1: version "2.5.2" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" @@ -4007,7 +3720,7 @@ lru-cache@^6.0.0: dependencies: yallist "^4.0.0" -make-dir@^3.0.0, make-dir@^3.1.0: +make-dir@^3.0.0: version "3.1.0" resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== @@ -4033,11 +3746,6 @@ map-visit@^1.0.0: dependencies: object-visit "^1.0.0" -mdn-data@2.0.14: - version "2.0.14" - resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50" - integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow== - merge-stream@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" @@ -4087,11 +3795,6 @@ mimic-fn@^2.1.0: resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -mimic-response@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-2.1.0.tgz#d13763d35f613d09ec37ebb30bac0469c0ee8f43" - integrity sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA== - minimatch@^3.0.4: version "3.0.4" resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" @@ -4104,21 +3807,6 @@ minimist@^1.1.1, minimist@^1.2.0, minimist@^1.2.5: resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== -minipass@^3.0.0: - version "3.1.6" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.1.6.tgz#3b8150aa688a711a1521af5e8779c1d3bb4f45ee" - integrity sha512-rty5kpw9/z8SX9dmxblFA6edItUmwJgMeYDZRrwlIVN27i8gysGbznJwUggw2V/FVqFSDdWy040ZPS811DYAqQ== - dependencies: - yallist "^4.0.0" - -minizlib@^2.1.1: - version "2.1.2" - resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" - integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== - dependencies: - minipass "^3.0.0" - yallist "^4.0.0" - mixin-deep@^1.2.0: version "1.3.2" resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.2.tgz#1120b43dc359a785dce65b55b82e257ccf479566" @@ -4127,11 +3815,6 @@ mixin-deep@^1.2.0: for-in "^1.0.2" is-extendable "^1.0.1" -mkdirp@^1.0.3: - version "1.0.4" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" - integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== - ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -4142,11 +3825,6 @@ ms@2.1.2: resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== -nan@^2.14.0: - version "2.15.0" - resolved "https://registry.yarnpkg.com/nan/-/nan-2.15.0.tgz#3f34a473ff18e15c1b5626b62903b5ad6e665fee" - integrity sha512-8ZtvEnA2c5aYCZYd1cvgdnU6cqwixRoYg70xPLWUws5ORTa/lnw+u4amixRS/Ac5U5mQVgp9pnlSUnbNWFaWZQ== - nanomatch@^1.2.9: version "1.2.13" resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.13.tgz#b87a8aa4fc0de8fe6be88895b38983ff265bd119" @@ -4174,13 +3852,6 @@ nice-try@^1.0.4: resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== -node-fetch@^2.6.5: - version "2.6.6" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.6.tgz#1751a7c01834e8e1697758732e9efb6eeadfaf89" - integrity sha512-Z8/6vRlTUChSdIgMa51jxQ4lrw/Jy5SOW10ObaA47/RElsAN2c5Pn8bTgFGWn/ibwzXTE8qwr1Yzx28vsecXEA== - dependencies: - whatwg-url "^5.0.0" - node-int64@^0.4.0: version "0.4.0" resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" @@ -4203,13 +3874,6 @@ node-releases@^2.0.1: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.1.tgz#3d1d395f204f1f2f29a54358b9fb678765ad2fc5" integrity sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA== -nopt@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/nopt/-/nopt-5.0.0.tgz#530942bb58a512fccafe53fe210f13a25355dc88" - integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== - dependencies: - abbrev "1" - normalize-package-data@^2.5.0: version "2.5.0" resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" @@ -4246,33 +3910,11 @@ npm-run-path@^4.0.0: dependencies: path-key "^3.0.0" -npmlog@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-5.0.1.tgz#f06678e80e29419ad67ab964e0fa69959c1eb8b0" - integrity sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw== - dependencies: - are-we-there-yet "^2.0.0" - console-control-strings "^1.1.0" - gauge "^3.0.0" - set-blocking "^2.0.0" - -nth-check@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.0.1.tgz#2efe162f5c3da06a28959fbd3db75dbeea9f0fc2" - integrity sha512-it1vE95zF6dTT9lBsYbxvqh0Soy4SPowchj0UBGj/V6cTPnXXtQOPUbhZ6CmGzAD/rW22LQK6E96pcdJXk4A4w== - dependencies: - boolbase "^1.0.0" - nwsapi@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7" integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ== -object-assign@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" - integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= - object-copy@^0.1.0: version "0.1.0" resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c" @@ -4474,11 +4116,6 @@ pend@~1.2.0: resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" integrity sha1-elfrVQpng/kRUzH89GY9XI4AelA= -penpal@^5.3.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/penpal/-/penpal-5.3.0.tgz#1a6afc56d6f257189e3d99650f58651a913db3ce" - integrity sha512-ezGckenx66j3RShl4nZiswjgDxyoDaJJ9tLBp46UvVxlA9MlIPF6hWfuppw1AzaDKgUULU1i44QFOuI4SXY/mg== - picocolors@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" @@ -4629,15 +4266,6 @@ read-pkg@^5.2.0: parse-json "^5.0.0" type-fest "^0.6.0" -readable-stream@^3.6.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - regenerate-unicode-properties@^9.0.0: version "9.0.0" resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-9.0.0.tgz#54d09c7115e1f53dc2314a974b32c1c344efe326" @@ -4807,11 +4435,6 @@ safe-buffer@~5.1.1: resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== -safe-buffer@~5.2.0: - version "5.2.1" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" - integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== - safe-regex@^1.1.0: version "1.1.0" resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e" @@ -4819,7 +4442,7 @@ safe-regex@^1.1.0: dependencies: ret "~0.1.10" -"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0": +"safer-buffer@>= 2.1.2 < 3": version "2.1.2" resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== @@ -4871,7 +4494,7 @@ semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== -semver@^7.2.1, semver@^7.3.2, semver@^7.3.5: +semver@^7.2.1, semver@^7.3.2: version "7.3.5" resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7" integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ== @@ -4927,20 +4550,6 @@ signal-exit@^3.0.0, signal-exit@^3.0.2: resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.6.tgz#24e630c4b0f03fea446a2bd299e62b4a6ca8d0af" integrity sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ== -simple-concat@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" - integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== - -simple-get@^3.0.3: - version "3.1.0" - resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-3.1.0.tgz#b45be062435e50d159540b576202ceec40b9c6b3" - integrity sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA== - dependencies: - decompress-response "^4.2.0" - once "^1.3.1" - simple-concat "^1.0.0" - sisteransi@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" @@ -5076,11 +4685,6 @@ sprintf-js@~1.0.2: resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= -stable@^0.1.8: - version "0.1.8" - resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.8.tgz#836eb3c8382fe2936feaf544631017ce7d47a3cf" - integrity sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w== - stack-utils@^2.0.2: version "2.0.5" resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.5.tgz#d25265fca995154659dbbfba3b49254778d2fdd5" @@ -5109,7 +4713,7 @@ string-length@^4.0.1: char-regex "^1.0.2" strip-ansi "^6.0.0" -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: +string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== @@ -5118,13 +4722,6 @@ string-length@^4.0.1: is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== - dependencies: - safe-buffer "~5.2.0" - stringify-object@^3.3.0: version "3.3.0" resolved "https://registry.yarnpkg.com/stringify-object/-/stringify-object-3.3.0.tgz#703065aefca19300d3ce88af4f5b3956d7556629" @@ -5188,19 +4785,6 @@ supports-preserve-symlinks-flag@^1.0.0: resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== -svgo@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/svgo/-/svgo-2.8.0.tgz#4ff80cce6710dc2795f0c7c74101e6764cfccd24" - integrity sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg== - dependencies: - "@trysound/sax" "0.2.0" - commander "^7.2.0" - css-select "^4.1.3" - css-tree "^1.1.3" - csso "^4.2.0" - picocolors "^1.0.0" - stable "^0.1.8" - symbol-tree@^3.2.4: version "3.2.4" resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" @@ -5217,18 +4801,6 @@ table@^6.0.9: string-width "^4.2.3" strip-ansi "^6.0.1" -tar@^6.1.11: - version "6.1.11" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.11.tgz#6760a38f003afa1b2ffd0ffe9e9abbd0eab3d621" - integrity sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA== - dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^3.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" - terminal-link@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" @@ -5319,18 +4891,6 @@ tr46@^2.1.0: dependencies: punycode "^2.1.1" -tr46@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-3.0.0.tgz#555c4e297a950617e8eeddef633c87d4d9d6cbf9" - integrity sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA== - dependencies: - punycode "^2.1.1" - -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o= - tslib@^1.8.1: version "1.14.1" resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" @@ -5470,11 +5030,6 @@ use@^3.1.0: resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f" integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ== -util-deprecate@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" - integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= - uuid@^8.3.0: version "8.3.2" resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" @@ -5516,13 +5071,6 @@ w3c-xmlserializer@^2.0.0: dependencies: xml-name-validator "^3.0.0" -w3c-xmlserializer@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-3.0.0.tgz#06cdc3eefb7e4d0b20a560a5a3aeb0d2d9a65923" - integrity sha512-3WFqGEgSXIyGhOmAFtlicJNMjEps8b1MG31NCA0/vOF9+nKMUW1ckhi9cnNHmf88Rzw5V+dwIwsm2C7X8k9aQg== - dependencies: - xml-name-validator "^4.0.0" - walker@^1.0.7, walker@~1.0.5: version "1.0.8" resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.8.tgz#bd498db477afe573dc04185f011d3ab8a8d7653f" @@ -5530,11 +5078,6 @@ walker@^1.0.7, walker@~1.0.5: dependencies: makeerror "1.0.12" -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE= - webidl-conversions@^5.0.0: version "5.0.0" resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" @@ -5545,11 +5088,6 @@ webidl-conversions@^6.1.0: resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-6.1.0.tgz#9111b4d7ea80acd40f5270d666621afa78b69514" integrity sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w== -webidl-conversions@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-7.0.0.tgz#256b4e1882be7debbf01d05f0aa2039778ea080a" - integrity sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g== - whatwg-encoding@^1.0.5: version "1.0.5" resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz#5abacf777c32166a51d085d6b4f3e7d27113ddb0" @@ -5557,39 +5095,11 @@ whatwg-encoding@^1.0.5: dependencies: iconv-lite "0.4.24" -whatwg-encoding@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-2.0.0.tgz#e7635f597fd87020858626805a2729fa7698ac53" - integrity sha512-p41ogyeMUrw3jWclHWTQg1k05DSVXPLcVxRTYsXUk+ZooOCZLcoYgPZ/HL/D/N+uQPOtcp1me1WhBEaX02mhWg== - dependencies: - iconv-lite "0.6.3" - whatwg-mimetype@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf" integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g== -whatwg-mimetype@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz#5fa1a7623867ff1af6ca3dc72ad6b8a4208beba7" - integrity sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q== - -whatwg-url@^10.0.0: - version "10.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-10.0.0.tgz#37264f720b575b4a311bd4094ed8c760caaa05da" - integrity sha512-CLxxCmdUby142H5FZzn4D8ikO1cmypvXVQktsgosNy4a4BHrDHeciBBGZhb0bNoR5/MltoCatso+vFjjGx8t0w== - dependencies: - tr46 "^3.0.0" - webidl-conversions "^7.0.0" - -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha1-lmRU6HZUYuN2RNNib2dCzotwll0= - dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" - whatwg-url@^8.0.0, whatwg-url@^8.5.0: version "8.7.0" resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77" @@ -5623,13 +5133,6 @@ which@^2.0.1, which@^2.0.2: dependencies: isexe "^2.0.0" -wide-align@^1.1.2: - version "1.1.5" - resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" - integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== - dependencies: - string-width "^1.0.2 || 2 || 3 || 4" - word-wrap@^1.2.3, word-wrap@~1.2.3: version "1.2.3" resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" @@ -5673,21 +5176,11 @@ ws@^7.4.6: resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.6.tgz#e59fc509fb15ddfb65487ee9765c5a51dec5fe7b" integrity sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA== -ws@^8.2.3: - version "8.4.0" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.4.0.tgz#f05e982a0a88c604080e8581576e2a063802bed6" - integrity sha512-IHVsKe2pjajSUIl4KYMQOdlyliovpEPquKkqbwswulszzI7r0SfQrxnXdWAEqOlDCLrVSJzo+O1hAwdog2sKSQ== - xml-name-validator@^3.0.0: version "3.0.0" resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-3.0.0.tgz#6ae73e06de4d8c6e47f9fb181f78d648ad457c6a" integrity sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw== -xml-name-validator@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-4.0.0.tgz#79a006e2e63149a8600f15430f0a4725d1524835" - integrity sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw== - xmlchars@^2.2.0: version "2.2.0" resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" -- GitLab