diff --git a/.gitignore b/.gitignore
index 0ba1652..3df09ac 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,3 +1,4 @@
-lib/*
-node_modules/*
-coverage/*
\ No newline at end of file
+**/lib
+**/node_modules
+coverage/*
+**/dist
diff --git a/.vscode/settings.json b/.vscode/settings.json
index eb45bbb..5f24f18 100644
--- a/.vscode/settings.json
+++ b/.vscode/settings.json
@@ -9,6 +9,7 @@
"**/coverage": true,
"**/lib": true,
"**/.vscode": true,
- "yarn.lock": true
+ "**/yarn.lock": true,
+ "**/dist": true
}
}
diff --git a/README.md b/README.md
index 3d22316..9be41a6 100644
--- a/README.md
+++ b/README.md
@@ -4,8 +4,8 @@ Originally forked from [here](https://github.com/ingoncalves/escpos-xml)
Cross platform JavaScript library that implements the thermal printer ESC / POS protocol and provides an XML interface for preparing templates for printing.
+## Features
-**Features:**
- [x] Text
- [x] Text line
- [x] Feed line
@@ -20,162 +20,104 @@ Cross platform JavaScript library that implements the thermal printer ESC / POS
- [x] Paper cut node
- [x] Image (base64) (png only)
- [x] XML with mustache
-- [ ] Font family
-## Tested On (manual)
+
+## Tested manually on following environments or platforms
- [x] React Native (Android)
-- [ ] React Native (iOS)
-- [ ] React Native Web
-- [x] Server side
+- [x] React Native (iOS)
+- [x] React Native Web
+- [x] Server side (NodeJs)
+- [x] Desktop applications (nwjs & electron)
- [x] Other node environment (terminal)
## Installation
-Using yarn:
-
-```
-yarn add @tillpos/xml-escpos-helper
+```bash
+ yarn add @tillpos/xml-escpos-helper
```
-## Usage
+## Examples
+
+### With an XML template + plain object input (regular text).
-### From plain XML
-```js
+```ts
import { EscPos } from '@tillpos/xml-escpos-helper';
-const xml = `
+// store this template somewhere `s3` or as `static asset` based on your preference
+const template = `
- hello world
-
-`;
-
-const buffer = EscPos.getBufferXML(xml);
-// send this buffer to a stream (eg.: bluetooth or socket)
-
-```
+
+
+ {{title}}
+
+
-### From XML + mustache
-```js
+ {{#thankyouNote}}
+
+ {{{thankyouNote}}}
+
-import { EscPos } from '@tillpos/xml-escpos-helper';
+
-const xml = `
-
-
- {{foo}}
+
`;
-const data = {
- foo: 'hello word'
+const input = {
+ title: 'Sample',
+ thankyouNote: 'Welcome...!'
};
-const buffer = EscPos.getBufferFromTemplate(xml, data);
-// send this buffer to a stream (eg.: bluetooth)
+const buffer = EscPos.getBufferFromTemplate(template, input);
+// send this buffer to a stream (eg.: bluetooth or wifi)
```
-### From Builder
-```js
-
-import { EscPos } from '@tillpos/xml-escpos-helper';
-
-
-const buffer = EscPos.getBufferBuilder()
- .printTextLine('hello world')
- .build();
-// send this buffer to a stream (eg.: bluetooth)
+### With an XML template + png image (base64)
-```
-
-## Example
-
-```js
-import { EscPos } from '@tillpos/xml-escpos-helper';
-
-const xml = `
-
+```ts
+ const template = `
-
-
-
- {{title}}
-
-
-
- {{subtitle}}
-
-
-
- {{paddedString}}
-
-
-
- {{underline}}
-
-
-
-
- {{description}}
-
-
-
- {{# condictionA}}
- True A
- {{#condictionB}}
- True B
- {{/condictionB}}
- False
- {{/condictionA}}
-
-
-
-
- {{barcode}}
-
-
-
- {{qrcode}}
-
-
-
-`;
-
-const data = {
- title: 'Tile',
- subtitle: 'Subtitle',
- description: 'This is a description',
- price: 1.99,
- paddedString: ' Line padded with 4 spaces',
- condictionA: false,
- condictionB: true,
- barcode: '12345678',
- qrcode: 'hello qrcode',
- underline: 'underline decorated text'
-}
-
-const buffer = EscPos.getBufferFromTemplate(xml, data);
-// send this buffer to a stream (eg.: bluetooth)
-
+
+
+ {{title}}
+
+
+
+ {{base64PngImage}}
+
+
+ `;
+
+ const input = {
+ title: 'PNG - base64',
+ base64PngImage: ``
+ };
+
+ const buffer = EscPos.getBufferFromTemplate(template, input);
```
+---
-# TODO
+## TODO
-- [ ] remove build files from source code
- [ ] Font styles (font family)
- [ ] Image bitmap conversion improvements
- [ ] jpeg support
+- [ ] Add example apps to repo
- [ ] Removed uglify for some reason, need to bring it back
+- [ ] Improve image rendering
+## Common issues
+- If there is any delay you observe while printing with this library it is mostly due to image manipulations (try without image :mask: )
-# Useful links / resources
+## Useful links / resources
- [ESC / POS Commands manual](./resources/ESCPOS_Command_Manual.pdf)
- A [blog post](https://www.visuality.pl/posts/thermal-printer-protocols-for-image-and-text#:~:text=How%20can%20we%20print%20an,command%20language%20of%20thermal%20printers) explaiing about printing images with ESCPOS
@@ -187,4 +129,8 @@ const buffer = EscPos.getBufferFromTemplate(xml, data);
- Most of popular image manupulation libraries does not have support for react-native. eg : [jimp](https://www.npmjs.com/package/jimp), [jpeg-js](https://www.npmjs.com/package/jpeg-js) and [sharp](https://www.npmjs.com/package/sharp). We can use these libraries with some native node lib implemented in react native (some sort of polyfill).
- For png this [library](https://github.com/photopea/UPNG.js) seems to be faster, but when tested this library with it, it is not retaining pixels at some places)
- Use this [node-libs-react-native](https://www.npmjs.com/package/node-libs-react-native) if we need to use this library in react native (adds some mock or js implementation for fs, stream etc)
-- If there is any delay you observe while printing with this library it is mostly due to image manipulations (try without image :mask: )
+
+---
+
+Contributions of any kind welcome! :heart:
+
diff --git a/examples/package.json b/examples/package.json
new file mode 100644
index 0000000..e93c3b9
--- /dev/null
+++ b/examples/package.json
@@ -0,0 +1,24 @@
+{
+ "name": "examples",
+ "version": "1.0.0",
+ "description": "Using in Nodejs env",
+ "main": "index.js",
+ "repository": "http://github.com/hitz-group/xml-escpos-helper.git",
+ "license": "MIT",
+ "private": false,
+ "scripts": {
+ "clean": "rm -rf ./dist && rm -rf ./tsconfig.build.tsbuildinfo",
+ "compile": "yarn clean && tsc -p ./tsconfig.json",
+ "print:basic": "yarn compile && yarn node ./dist/basic.js",
+ "print:image": "yarn compile && yarn node ./dist/printImage.js",
+ "print:table": "yarn compile && yarn node ./dist/printTable.js",
+ "print:barcode": "yarn compile && yarn node ./dist/printBarcode.js"
+ },
+ "dependencies": {
+ "@tillpos/xml-escpos-helper": "^0.1.8",
+ "table": "^6.6.0"
+ },
+ "devDependencies": {
+ "typescript": "^4.2.4"
+ }
+}
diff --git a/examples/src/basic.ts b/examples/src/basic.ts
new file mode 100644
index 0000000..aacc61a
--- /dev/null
+++ b/examples/src/basic.ts
@@ -0,0 +1,13 @@
+import { sendDataToPrinter } from './network';
+import { TEMPLATES } from './templates';
+
+const printBasic = async () => {
+ const input = {
+ title: 'Sample',
+ thankyouNote: 'Welcome...!'
+ };
+
+ await sendDataToPrinter(input, TEMPLATES.BASIC);
+};
+
+printBasic();
diff --git a/examples/src/network.ts b/examples/src/network.ts
new file mode 100644
index 0000000..0e018c4
--- /dev/null
+++ b/examples/src/network.ts
@@ -0,0 +1,39 @@
+import net from 'net';
+import { EscPos } from '@tillpos/xml-escpos-helper';
+const PRINTERS = [{ device_name: 'Epson', host: '192.168.0.8', port: 9100 }];
+
+const connectToPrinter = (
+ host: string,
+ port: number,
+ buffer: Buffer,
+): Promise => {
+ return new Promise((res: (value: unknown) => void, rej) => {
+ let device = new net.Socket();
+
+ device.on('close', () => {
+ if (device) {
+ device.destroy();
+ device = null;
+ }
+ res(true);
+ return;
+ });
+
+ device.on('error', rej);
+
+ device.connect(port, host, () => {
+ device.write(buffer);
+ device.emit('close');
+ });
+ });
+};
+
+export const sendDataToPrinter = async (input: any, template: string) => {
+ const { host, port } = PRINTERS[0];
+ const buffer = EscPos.getBufferFromTemplate(template, input);
+ try {
+ await connectToPrinter(host, port, (buffer as unknown) as Buffer);
+ } catch (err) {
+ console.log('some error', err);
+ }
+};
diff --git a/examples/src/printBarCode.ts b/examples/src/printBarCode.ts
new file mode 100644
index 0000000..789c585
--- /dev/null
+++ b/examples/src/printBarCode.ts
@@ -0,0 +1,12 @@
+import { sendDataToPrinter } from './network';
+import { TEMPLATES } from './templates';
+
+const printBarCode = async () => {
+ const input = {
+ barcode: '12345678',
+ };
+
+ await sendDataToPrinter(input, TEMPLATES.BAR_CODE);
+};
+
+printBarCode();
diff --git a/examples/src/printImage.ts b/examples/src/printImage.ts
new file mode 100644
index 0000000..3e26dea
--- /dev/null
+++ b/examples/src/printImage.ts
@@ -0,0 +1,15 @@
+import { sendDataToPrinter } from './network';
+import { TEMPLATES } from './templates';
+
+const BASE64_PNG_IMAGE = ``;
+
+const printImage = async () => {
+ const input = {
+ title: 'Github',
+ logo: BASE64_PNG_IMAGE
+ };
+
+ await sendDataToPrinter(input, TEMPLATES.PNG_IMAGE);
+};
+
+printImage();
diff --git a/examples/src/printTable.ts b/examples/src/printTable.ts
new file mode 100644
index 0000000..f9c418f
--- /dev/null
+++ b/examples/src/printTable.ts
@@ -0,0 +1,22 @@
+import { sendDataToPrinter } from './network';
+import { TEMPLATES } from './templates';
+import { getBorderCharacters, table } from 'table';
+
+const printTable = async () => {
+ const versions = [
+ ['React', '16.8'],
+ ['Angular', '9'],
+ ['Ember', '3.16'],
+ ];
+
+ const tableData = table(versions, {
+ border: getBorderCharacters(`void`),
+ drawHorizontalLine: () => {
+ return false;
+ },
+ });
+
+ await sendDataToPrinter({ tableData }, TEMPLATES.TABLE);
+};
+
+printTable();
diff --git a/examples/src/templates.ts b/examples/src/templates.ts
new file mode 100644
index 0000000..03604b3
--- /dev/null
+++ b/examples/src/templates.ts
@@ -0,0 +1,67 @@
+export enum Templates {
+ PNG_IMAGE = 'PNG_IMAGE',
+ BASIC = 'BASIC',
+ QR_CODE = 'QR_CODE',
+ BAR_CODE = 'BAR_CODE',
+ TABLE = 'TABLE',
+}
+
+export const TEMPLATES = {
+ [Templates.BASIC]: `
+
+
+
+ {{title}}
+
+
+
+ {{#thankyouNote}}
+
+ {{{thankyouNote}}}
+
+ {{/thankyouNote}}
+
+
+
+
+ `,
+ [Templates.PNG_IMAGE]: `
+
+
+
+
+ {{title}}
+
+
+
+ {{logo}}
+
+
+ `,
+ [Templates.QR_CODE]: `
+
+
+
+ {{qrcode}}
+
+
+
+
+ `,
+ [Templates.BAR_CODE]: `
+
+
+
+
+ {{barcode}}
+
+
+
+ `,
+ [Templates.TABLE]: `
+
+
+ {{tableData}}
+
+ `,
+}
diff --git a/examples/tsconfig.json b/examples/tsconfig.json
new file mode 100644
index 0000000..b67d3bc
--- /dev/null
+++ b/examples/tsconfig.json
@@ -0,0 +1,22 @@
+{
+ "compilerOptions": {
+ "module": "commonjs",
+ "esModuleInterop": true,
+ "allowSyntheticDefaultImports": true,
+ "target": "es6",
+ "noImplicitAny": true,
+ "moduleResolution": "node",
+ "sourceMap": true,
+ "outDir": "dist",
+ "baseUrl": ".",
+ "paths": {
+ "*": [
+ "node_modules/*",
+ "src/types/*"
+ ]
+ }
+ },
+ "include": [
+ "src/**/*"
+ ]
+}
diff --git a/examples/yarn.lock b/examples/yarn.lock
new file mode 100644
index 0000000..ba54036
--- /dev/null
+++ b/examples/yarn.lock
@@ -0,0 +1,219 @@
+# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
+# yarn lockfile v1
+
+
+"@tillpos/xml-escpos-helper@^0.1.8":
+ version "0.1.8"
+ resolved "https://registry.yarnpkg.com/@tillpos/xml-escpos-helper/-/xml-escpos-helper-0.1.8.tgz#d3a664d776fa022516f7c85b0280706892e7fa5b"
+ integrity sha512-2VdutlzFUcCMYxoJ7LmdK4l6/lWXA3TInwoWOdZ2cQKB0V0T3qogrHQGxKgRrlhFds2co0kksaa4ePj5QlFLCw==
+ dependencies:
+ buffer "^6.0.3"
+ mustache "^4.1.0"
+ mutable-buffer "2.0.3"
+ ndarray "^1.0.19"
+ pngjs "^6.0.0"
+ xml-parser "^1.2.1"
+
+ajv@^8.0.1:
+ version "8.2.0"
+ resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.2.0.tgz#c89d3380a784ce81b2085f48811c4c101df4c602"
+ integrity sha512-WSNGFuyWd//XO8n/m/EaOlNLtO0yL8EXT/74LqT4khdhpZjP7lkj/kT5uwRmGitKEVp/Oj7ZUHeGfPtgHhQ5CA==
+ dependencies:
+ fast-deep-equal "^3.1.1"
+ json-schema-traverse "^1.0.0"
+ require-from-string "^2.0.2"
+ uri-js "^4.2.2"
+
+ansi-regex@^5.0.0:
+ version "5.0.0"
+ resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75"
+ integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==
+
+ansi-styles@^4.0.0:
+ version "4.3.0"
+ resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937"
+ integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==
+ dependencies:
+ color-convert "^2.0.1"
+
+astral-regex@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31"
+ integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==
+
+base64-js@^1.3.1:
+ version "1.5.1"
+ resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a"
+ integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==
+
+buffer@^6.0.3:
+ version "6.0.3"
+ resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6"
+ integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==
+ dependencies:
+ base64-js "^1.3.1"
+ ieee754 "^1.2.1"
+
+color-convert@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3"
+ integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==
+ dependencies:
+ color-name "~1.1.4"
+
+color-name@~1.1.4:
+ version "1.1.4"
+ resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
+ integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
+
+debug@^2.2.0:
+ version "2.6.9"
+ resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f"
+ integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==
+ dependencies:
+ ms "2.0.0"
+
+emoji-regex@^8.0.0:
+ version "8.0.0"
+ resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37"
+ integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==
+
+fast-deep-equal@^3.1.1:
+ version "3.1.3"
+ resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525"
+ integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==
+
+ieee754@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352"
+ integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==
+
+iota-array@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/iota-array/-/iota-array-1.0.0.tgz#81ef57fe5d05814cd58c2483632a99c30a0e8087"
+ integrity sha1-ge9X/l0FgUzVjCSDYyqZwwoOgIc=
+
+is-buffer@^1.0.2:
+ version "1.1.6"
+ resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be"
+ integrity sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==
+
+is-fullwidth-code-point@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d"
+ integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==
+
+json-schema-traverse@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2"
+ integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==
+
+lodash.clonedeep@^4.5.0:
+ version "4.5.0"
+ resolved "https://registry.yarnpkg.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef"
+ integrity sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=
+
+lodash.flatten@^4.4.0:
+ version "4.4.0"
+ resolved "https://registry.yarnpkg.com/lodash.flatten/-/lodash.flatten-4.4.0.tgz#f31c22225a9632d2bbf8e4addbef240aa765a61f"
+ integrity sha1-8xwiIlqWMtK7+OSt2+8kCqdlph8=
+
+lodash.truncate@^4.4.2:
+ version "4.4.2"
+ resolved "https://registry.yarnpkg.com/lodash.truncate/-/lodash.truncate-4.4.2.tgz#5a350da0b1113b837ecfffd5812cbe58d6eae193"
+ integrity sha1-WjUNoLERO4N+z//VgSy+WNbq4ZM=
+
+ms@2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8"
+ integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=
+
+mustache@^4.1.0:
+ version "4.2.0"
+ resolved "https://registry.yarnpkg.com/mustache/-/mustache-4.2.0.tgz#e5892324d60a12ec9c2a73359edca52972bf6f64"
+ integrity sha512-71ippSywq5Yb7/tVYyGbkBggbU8H3u5Rz56fH60jGFgr8uHwxs+aSKeqmluIVzM0m0kB7xQjKS6qPfd0b2ZoqQ==
+
+mutable-buffer@2.0.3:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/mutable-buffer/-/mutable-buffer-2.0.3.tgz#67bca5568bf15d3f6035fb716e3899dc44901c8c"
+ integrity sha1-Z7ylVovxXT9gNftxbjiZ3ESQHIw=
+
+ndarray@^1.0.19:
+ version "1.0.19"
+ resolved "https://registry.yarnpkg.com/ndarray/-/ndarray-1.0.19.tgz#6785b5f5dfa58b83e31ae5b2a058cfd1ab3f694e"
+ integrity sha512-B4JHA4vdyZU30ELBw3g7/p9bZupyew5a7tX1Y/gGeF2hafrPaQZhgrGQfsvgfYbgdFZjYwuEcnaobeM/WMW+HQ==
+ dependencies:
+ iota-array "^1.0.0"
+ is-buffer "^1.0.2"
+
+pngjs@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.yarnpkg.com/pngjs/-/pngjs-6.0.0.tgz#ca9e5d2aa48db0228a52c419c3308e87720da821"
+ integrity sha512-TRzzuFRRmEoSW/p1KVAmiOgPco2Irlah+bGFCeNfJXxxYGwSw7YwAOAcd7X28K/m5bjBWKsC29KyoMfHbypayg==
+
+punycode@^2.1.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec"
+ integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==
+
+require-from-string@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909"
+ integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==
+
+slice-ansi@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-4.0.0.tgz#500e8dd0fd55b05815086255b3195adf2a45fe6b"
+ integrity sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==
+ dependencies:
+ ansi-styles "^4.0.0"
+ astral-regex "^2.0.0"
+ is-fullwidth-code-point "^3.0.0"
+
+string-width@^4.2.0:
+ version "4.2.2"
+ resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.2.tgz#dafd4f9559a7585cfba529c6a0a4f73488ebd4c5"
+ integrity sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==
+ dependencies:
+ emoji-regex "^8.0.0"
+ is-fullwidth-code-point "^3.0.0"
+ strip-ansi "^6.0.0"
+
+strip-ansi@^6.0.0:
+ version "6.0.0"
+ resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532"
+ integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==
+ dependencies:
+ ansi-regex "^5.0.0"
+
+table@^6.6.0:
+ version "6.6.0"
+ resolved "https://registry.yarnpkg.com/table/-/table-6.6.0.tgz#905654b79df98d9e9a973de1dd58682532c40e8e"
+ integrity sha512-iZMtp5tUvcnAdtHpZTWLPF0M7AgiQsURR2DwmxnJwSy8I3+cY+ozzVvYha3BOLG2TB+L0CqjIz+91htuj6yCXg==
+ dependencies:
+ ajv "^8.0.1"
+ lodash.clonedeep "^4.5.0"
+ lodash.flatten "^4.4.0"
+ lodash.truncate "^4.4.2"
+ slice-ansi "^4.0.0"
+ string-width "^4.2.0"
+ strip-ansi "^6.0.0"
+
+typescript@^4.2.4:
+ version "4.2.4"
+ resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.2.4.tgz#8610b59747de028fda898a8aef0e103f156d0961"
+ integrity sha512-V+evlYHZnQkaz8TRBuxTA92yZBPotr5H+WhQ7bD3hZUndx5tGOa1fuCgeSjxAzM1RiN5IzvadIXTVefuuwZCRg==
+
+uri-js@^4.2.2:
+ version "4.4.1"
+ resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e"
+ integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==
+ dependencies:
+ punycode "^2.1.0"
+
+xml-parser@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/xml-parser/-/xml-parser-1.2.1.tgz#c31f4c34f2975db82ad013222120592736156fcd"
+ integrity sha1-wx9MNPKXXbgq0BMiISBZJzYVb80=
+ dependencies:
+ debug "^2.2.0"