├── .github
├── FUNDING.yml
└── workflows
│ └── publish.yml
├── .gitignore
├── LICENSE
├── README.md
├── demo.gif
├── icon.png
├── index.html
├── jsconfig.json
├── package-lock.json
├── package.json
└── src
├── index.ts
└── progress.ts
/.github/FUNDING.yml:
--------------------------------------------------------------------------------
1 | # These are supported funding model platforms
2 |
3 | github: isosphere # Replace with up to 4 GitHub Sponsors-enabled usernames e.g., [user1, user2]
4 | patreon: # Replace with a single Patreon username
5 | open_collective: # Replace with a single Open Collective username
6 | ko_fi: # Replace with a single Ko-fi username
7 | tidelift: # Replace with a single Tidelift platform-name/package-name e.g., npm/babel
8 | community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
9 | liberapay: mscheffel # Replace with a single Liberapay username
10 | issuehunt: # Replace with a single IssueHunt username
11 | otechie: # Replace with a single Otechie username
12 | lfx_crowdfunding: # Replace with a single LFX Crowdfunding project-name e.g., cloud-foundry
13 | custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2']
14 |
--------------------------------------------------------------------------------
/.github/workflows/publish.yml:
--------------------------------------------------------------------------------
1 | name: Build plugin
2 |
3 | on:
4 | workflow_dispatch:
5 | push:
6 | # Sequence of patterns matched against refs/tags
7 | tags:
8 | - "*" # Push events to matching any tag format, i.e. 1.0, 20.15.10
9 |
10 | env:
11 | PLUGIN_NAME: logseq-koreader-sync
12 |
13 | jobs:
14 | build:
15 | runs-on: ubuntu-latest
16 |
17 | steps:
18 | - uses: actions/checkout@v2
19 | - name: Use Node.js
20 | uses: actions/setup-node@v1
21 | with:
22 | node-version: "20.x" # You might need to adjust this value to your own version
23 | - name: Build
24 | id: build
25 | run: |
26 | npm ci
27 | npm run build
28 | mkdir ${{ env.PLUGIN_NAME }}
29 | cp README.md package.json icon.png demo.gif ${{ env.PLUGIN_NAME }}
30 | mv dist ${{ env.PLUGIN_NAME }}
31 | zip -r ${{ env.PLUGIN_NAME }}.zip ${{ env.PLUGIN_NAME }}
32 | ls
33 | echo "::set-output name=tag_name::$(git tag --sort version:refname | tail -n 1)"
34 |
35 | - name: Create Release
36 | uses: ncipollo/release-action@v1
37 | id: create_release
38 | env:
39 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
40 | VERSION: ${{ github.ref }}
41 | with:
42 | allowUpdates: true
43 | draft: false
44 | prerelease: false
45 |
46 | - name: Upload zip file
47 | id: upload_zip
48 | uses: actions/upload-release-asset@v1
49 | env:
50 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
51 | with:
52 | upload_url: ${{ steps.create_release.outputs.upload_url }}
53 | asset_path: ./${{ env.PLUGIN_NAME }}.zip
54 | asset_name: ${{ env.PLUGIN_NAME }}-${{ steps.build.outputs.tag_name }}.zip
55 | asset_content_type: application/zip
56 |
57 | - name: Upload package.json
58 | id: upload_metadata
59 | uses: actions/upload-release-asset@v1
60 | env:
61 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
62 | with:
63 | upload_url: ${{ steps.create_release.outputs.upload_url }}
64 | asset_path: ./package.json
65 | asset_name: package.json
66 | asset_content_type: application/json
67 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules
2 | .DS_Store
3 | dist
4 | dist-ssr
5 | *.local
6 | /.idea/
7 | /.lsp/
8 | /.clj-kondo/
9 | /.parcel-cache/
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2024 Matthew Scheffel
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Logseq Koreader Sync
2 | A [KOReader](https://koreader.rocks/) to [Logseq](https://logseq.com/) syncing plugin
3 |
4 | ⚠️ Known to work with KOReader 2024.03.1. KOReader metadata formats change and we are unable to detect this.
5 | Built with a separate sidecar directory (see https://github.com/koreader/koreader/pull/10074) in mind.
6 |
7 |
8 | This is a tool to import your annotations from KOReader in a read-only format - this is a one directional synchronization[^1]. It is not affiliated with the KOReader project.
9 |
10 | The `_logseq-koreader-sync` page generated by this plugin is intended to be read-only. However, the blocks created within it are intended to be freely referenced elsewhere in your graph. Their UUIDs **should** not change. If they do, please create an issue.
11 |
12 | [^1]: perhaps one day we can do bidirectional synchronization, but that sounds like a very difficult task right now.
13 |
14 | ## 🚀 Features
15 | - [x] Import annotations from a [KOReader](https://koreader.rocks/) metadata folder containing "*.sdr" folders with `metadata.*.lua` files.
16 | - [x] Blocks imported by the sync persist despite future syncs - references should remain stable
17 |
18 | ## 🛠️ Usage
19 |
20 | 1. Install the plugin from the Logseq marketplace, in-app
21 | 2. Pin the "koreader-sync" icon to your Logseq toolbar
22 | 3. Press the "koreader-sync" icon on your toolbar, and when prompted locate your KOReader metadata directory
23 | 4. Reference the created blocks, but don't alter them.
24 |
25 | I use [Syncthing](https://syncthing.net/) on Android to ensure that I have a local copy of my metadata.
26 |
27 | 
28 |
--------------------------------------------------------------------------------
/demo.gif:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/isosphere/logseq-koreader-sync/da00a5f5a7c0f0a35122900e4821e35dc23e6e4f/demo.gif
--------------------------------------------------------------------------------
/icon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/isosphere/logseq-koreader-sync/da00a5f5a7c0f0a35122900e4821e35dc23e6e4f/icon.png
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | Logseq Koreader Sync
7 |
8 |
9 |
10 |
11 |
12 |
13 |
--------------------------------------------------------------------------------
/jsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "module": "ESNext",
4 | "moduleResolution": "Node",
5 | "target": "ES2020",
6 | "jsx": "react",
7 | "allowImportingTsExtensions": true,
8 | "strictNullChecks": true,
9 | "strictFunctionTypes": true
10 | },
11 | "exclude": [
12 | "node_modules",
13 | "**/node_modules/*"
14 | ]
15 | }
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "logseq-koreader-sync",
3 | "version": "1.2.1",
4 | "lockfileVersion": 3,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "logseq-koreader-sync",
9 | "version": "1.2.1",
10 | "license": "MIT",
11 | "dependencies": {
12 | "@logseq/libs": "^0.0.17",
13 | "idb-keyval": "^6.2.1",
14 | "luaparse": "^0.3.1"
15 | },
16 | "devDependencies": {
17 | "buffer": "^6.0.3",
18 | "parcel": "^2.11",
19 | "path-browserify": "^1.0.0"
20 | },
21 | "optionalDependencies": {
22 | "@parcel/watcher-linux-x64-glibc": "^2.4.0"
23 | }
24 | },
25 | "node_modules/@babel/code-frame": {
26 | "version": "7.16.7",
27 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.7.tgz",
28 | "integrity": "sha512-iAXqUn8IIeBTNd72xsFlgaXHkMBMt6y4HJp1tIaK465CWLT/fG1aqB7ykr95gHHmlBdGbFeWWfyB4NJJ0nmeIg==",
29 | "dev": true,
30 | "license": "MIT",
31 | "dependencies": {
32 | "@babel/highlight": "^7.16.7"
33 | },
34 | "engines": {
35 | "node": ">=6.9.0"
36 | }
37 | },
38 | "node_modules/@babel/helper-validator-identifier": {
39 | "version": "7.16.7",
40 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.16.7.tgz",
41 | "integrity": "sha512-hsEnFemeiW4D08A5gUAZxLBTXpZ39P+a+DGDsHw1yxqyQ/jzFEnxf5uTEGp+3bzAbNOxU1paTgYS4ECU/IgfDw==",
42 | "dev": true,
43 | "license": "MIT",
44 | "engines": {
45 | "node": ">=6.9.0"
46 | }
47 | },
48 | "node_modules/@babel/highlight": {
49 | "version": "7.17.9",
50 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.17.9.tgz",
51 | "integrity": "sha512-J9PfEKCbFIv2X5bjTMiZu6Vf341N05QIY+d6FvVKynkG1S7G0j3I0QoRtWIrXhZ+/Nlb5Q0MzqL7TokEJ5BNHg==",
52 | "dev": true,
53 | "license": "MIT",
54 | "dependencies": {
55 | "@babel/helper-validator-identifier": "^7.16.7",
56 | "chalk": "^2.0.0",
57 | "js-tokens": "^4.0.0"
58 | },
59 | "engines": {
60 | "node": ">=6.9.0"
61 | }
62 | },
63 | "node_modules/@babel/highlight/node_modules/ansi-styles": {
64 | "version": "3.2.1",
65 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
66 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
67 | "dev": true,
68 | "license": "MIT",
69 | "dependencies": {
70 | "color-convert": "^1.9.0"
71 | },
72 | "engines": {
73 | "node": ">=4"
74 | }
75 | },
76 | "node_modules/@babel/highlight/node_modules/chalk": {
77 | "version": "2.4.2",
78 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
79 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
80 | "dev": true,
81 | "license": "MIT",
82 | "dependencies": {
83 | "ansi-styles": "^3.2.1",
84 | "escape-string-regexp": "^1.0.5",
85 | "supports-color": "^5.3.0"
86 | },
87 | "engines": {
88 | "node": ">=4"
89 | }
90 | },
91 | "node_modules/@babel/highlight/node_modules/color-convert": {
92 | "version": "1.9.3",
93 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
94 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
95 | "dev": true,
96 | "license": "MIT",
97 | "dependencies": {
98 | "color-name": "1.1.3"
99 | }
100 | },
101 | "node_modules/@babel/highlight/node_modules/color-name": {
102 | "version": "1.1.3",
103 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
104 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
105 | "dev": true,
106 | "license": "MIT"
107 | },
108 | "node_modules/@babel/highlight/node_modules/has-flag": {
109 | "version": "3.0.0",
110 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
111 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
112 | "dev": true,
113 | "license": "MIT",
114 | "engines": {
115 | "node": ">=4"
116 | }
117 | },
118 | "node_modules/@babel/highlight/node_modules/supports-color": {
119 | "version": "5.5.0",
120 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
121 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
122 | "dev": true,
123 | "license": "MIT",
124 | "dependencies": {
125 | "has-flag": "^3.0.0"
126 | },
127 | "engines": {
128 | "node": ">=4"
129 | }
130 | },
131 | "node_modules/@lezer/common": {
132 | "version": "0.15.12",
133 | "resolved": "https://registry.npmjs.org/@lezer/common/-/common-0.15.12.tgz",
134 | "integrity": "sha512-edfwCxNLnzq5pBA/yaIhwJ3U3Kz8VAUOTRg0hhxaizaI1N+qxV7EXDv/kLCkLeq2RzSFvxexlaj5Mzfn2kY0Ig==",
135 | "dev": true,
136 | "license": "MIT"
137 | },
138 | "node_modules/@lezer/lr": {
139 | "version": "0.15.8",
140 | "resolved": "https://registry.npmjs.org/@lezer/lr/-/lr-0.15.8.tgz",
141 | "integrity": "sha512-bM6oE6VQZ6hIFxDNKk8bKPa14hqFrV07J/vHGOeiAbJReIaQXmkVb6xQu4MR+JBTLa5arGRyAAjJe1qaQt3Uvg==",
142 | "dev": true,
143 | "license": "MIT",
144 | "dependencies": {
145 | "@lezer/common": "^0.15.0"
146 | }
147 | },
148 | "node_modules/@lmdb/lmdb-win32-x64": {
149 | "version": "2.8.5",
150 | "resolved": "https://registry.npmjs.org/@lmdb/lmdb-win32-x64/-/lmdb-win32-x64-2.8.5.tgz",
151 | "integrity": "sha512-4wvrf5BgnR8RpogHhtpCPJMKBmvyZPhhUtEwMJbXh0ni2BucpfF07jlmyM11zRqQ2XIq6PbC2j7W7UCCcm1rRQ==",
152 | "cpu": [
153 | "x64"
154 | ],
155 | "dev": true,
156 | "license": "MIT",
157 | "optional": true,
158 | "os": [
159 | "win32"
160 | ]
161 | },
162 | "node_modules/@logseq/libs": {
163 | "version": "0.0.17",
164 | "resolved": "https://registry.npmjs.org/@logseq/libs/-/libs-0.0.17.tgz",
165 | "integrity": "sha512-SkzzAaocmrgeHYrCOaRyEqzPOxw3d0qVEZSrt9qVvXE4tuEgbvEHR8tzI1N5RjgAv+PDWuGPiP7/mhcXHpINEw==",
166 | "dependencies": {
167 | "csstype": "3.1.0",
168 | "debug": "4.3.4",
169 | "deepmerge": "4.3.1",
170 | "dompurify": "2.3.8",
171 | "eventemitter3": "4.0.7",
172 | "fast-deep-equal": "3.1.3",
173 | "lodash-es": "4.17.21",
174 | "path": "0.12.7",
175 | "snake-case": "3.0.4"
176 | }
177 | },
178 | "node_modules/@mischnic/json-sourcemap": {
179 | "version": "0.1.0",
180 | "resolved": "https://registry.npmjs.org/@mischnic/json-sourcemap/-/json-sourcemap-0.1.0.tgz",
181 | "integrity": "sha512-dQb3QnfNqmQNYA4nFSN/uLaByIic58gOXq4Y4XqLOWmOrw73KmJPt/HLyG0wvn1bnR6mBKs/Uwvkh+Hns1T0XA==",
182 | "dev": true,
183 | "license": "MIT",
184 | "dependencies": {
185 | "@lezer/common": "^0.15.7",
186 | "@lezer/lr": "^0.15.4",
187 | "json5": "^2.2.1"
188 | },
189 | "engines": {
190 | "node": ">=12.0.0"
191 | }
192 | },
193 | "node_modules/@msgpackr-extract/msgpackr-extract-win32-x64": {
194 | "version": "3.0.2",
195 | "resolved": "https://registry.npmjs.org/@msgpackr-extract/msgpackr-extract-win32-x64/-/msgpackr-extract-win32-x64-3.0.2.tgz",
196 | "integrity": "sha512-O+6Gs8UeDbyFpbSh2CPEz/UOrrdWPTBYNblZK5CxxLisYt4kGX3Sc+czffFonyjiGSq3jWLwJS/CCJc7tBr4sQ==",
197 | "cpu": [
198 | "x64"
199 | ],
200 | "dev": true,
201 | "license": "MIT",
202 | "optional": true,
203 | "os": [
204 | "win32"
205 | ]
206 | },
207 | "node_modules/@parcel/bundler-default": {
208 | "version": "2.11.0",
209 | "resolved": "https://registry.npmjs.org/@parcel/bundler-default/-/bundler-default-2.11.0.tgz",
210 | "integrity": "sha512-ZIs0865Lp871ZK83k5I9L4DeeE26muNMrHa7j8bvls6fKBJKAn8djrhfU4XOLyziU4aAOobcPwXU0+npWqs52g==",
211 | "dev": true,
212 | "license": "MIT",
213 | "dependencies": {
214 | "@parcel/diagnostic": "2.11.0",
215 | "@parcel/graph": "3.1.0",
216 | "@parcel/plugin": "2.11.0",
217 | "@parcel/rust": "2.11.0",
218 | "@parcel/utils": "2.11.0",
219 | "nullthrows": "^1.1.1"
220 | },
221 | "engines": {
222 | "node": ">= 12.0.0",
223 | "parcel": "^2.11.0"
224 | },
225 | "funding": {
226 | "type": "opencollective",
227 | "url": "https://opencollective.com/parcel"
228 | }
229 | },
230 | "node_modules/@parcel/cache": {
231 | "version": "2.11.0",
232 | "resolved": "https://registry.npmjs.org/@parcel/cache/-/cache-2.11.0.tgz",
233 | "integrity": "sha512-RSSkGNjO00lJPyftzaC9eaNVs4jMjPSAm0VJNWQ9JSm2n4A9BzQtTFAt1vhJOzzW1UsQvvBge9DdfkB7a2gIOw==",
234 | "dev": true,
235 | "license": "MIT",
236 | "dependencies": {
237 | "@parcel/fs": "2.11.0",
238 | "@parcel/logger": "2.11.0",
239 | "@parcel/utils": "2.11.0",
240 | "lmdb": "2.8.5"
241 | },
242 | "engines": {
243 | "node": ">= 12.0.0"
244 | },
245 | "funding": {
246 | "type": "opencollective",
247 | "url": "https://opencollective.com/parcel"
248 | },
249 | "peerDependencies": {
250 | "@parcel/core": "^2.11.0"
251 | }
252 | },
253 | "node_modules/@parcel/codeframe": {
254 | "version": "2.11.0",
255 | "resolved": "https://registry.npmjs.org/@parcel/codeframe/-/codeframe-2.11.0.tgz",
256 | "integrity": "sha512-YHs9g/i5af/sd/JrWAojU9YFbKffcJ3Tx2EJaK0ME8OJsye91UaI/3lxSUYLmJG9e4WLNJtqci8V5FBMz//ZPg==",
257 | "dev": true,
258 | "license": "MIT",
259 | "dependencies": {
260 | "chalk": "^4.1.0"
261 | },
262 | "engines": {
263 | "node": ">= 12.0.0"
264 | },
265 | "funding": {
266 | "type": "opencollective",
267 | "url": "https://opencollective.com/parcel"
268 | }
269 | },
270 | "node_modules/@parcel/compressor-raw": {
271 | "version": "2.11.0",
272 | "resolved": "https://registry.npmjs.org/@parcel/compressor-raw/-/compressor-raw-2.11.0.tgz",
273 | "integrity": "sha512-RArhBPRTCfz77soX2IECH09NUd76UBWujXiPRcXGPIHK+C3L1cRuzsNcA39QeSb3thz3b99JcozMJ1nkC2Bsgw==",
274 | "dev": true,
275 | "license": "MIT",
276 | "dependencies": {
277 | "@parcel/plugin": "2.11.0"
278 | },
279 | "engines": {
280 | "node": ">= 12.0.0",
281 | "parcel": "^2.11.0"
282 | },
283 | "funding": {
284 | "type": "opencollective",
285 | "url": "https://opencollective.com/parcel"
286 | }
287 | },
288 | "node_modules/@parcel/config-default": {
289 | "version": "2.11.0",
290 | "resolved": "https://registry.npmjs.org/@parcel/config-default/-/config-default-2.11.0.tgz",
291 | "integrity": "sha512-1e2+qcZkm5/0f4eI20p/DemcYiSxq9d/eyjpTXA7PulJaHbL1wonwUAuy3mvnAvDnLOJmAk/obDVgX1ZfxMGtg==",
292 | "dev": true,
293 | "license": "MIT",
294 | "dependencies": {
295 | "@parcel/bundler-default": "2.11.0",
296 | "@parcel/compressor-raw": "2.11.0",
297 | "@parcel/namer-default": "2.11.0",
298 | "@parcel/optimizer-css": "2.11.0",
299 | "@parcel/optimizer-htmlnano": "2.11.0",
300 | "@parcel/optimizer-image": "2.11.0",
301 | "@parcel/optimizer-svgo": "2.11.0",
302 | "@parcel/optimizer-swc": "2.11.0",
303 | "@parcel/packager-css": "2.11.0",
304 | "@parcel/packager-html": "2.11.0",
305 | "@parcel/packager-js": "2.11.0",
306 | "@parcel/packager-raw": "2.11.0",
307 | "@parcel/packager-svg": "2.11.0",
308 | "@parcel/packager-wasm": "2.11.0",
309 | "@parcel/reporter-dev-server": "2.11.0",
310 | "@parcel/resolver-default": "2.11.0",
311 | "@parcel/runtime-browser-hmr": "2.11.0",
312 | "@parcel/runtime-js": "2.11.0",
313 | "@parcel/runtime-react-refresh": "2.11.0",
314 | "@parcel/runtime-service-worker": "2.11.0",
315 | "@parcel/transformer-babel": "2.11.0",
316 | "@parcel/transformer-css": "2.11.0",
317 | "@parcel/transformer-html": "2.11.0",
318 | "@parcel/transformer-image": "2.11.0",
319 | "@parcel/transformer-js": "2.11.0",
320 | "@parcel/transformer-json": "2.11.0",
321 | "@parcel/transformer-postcss": "2.11.0",
322 | "@parcel/transformer-posthtml": "2.11.0",
323 | "@parcel/transformer-raw": "2.11.0",
324 | "@parcel/transformer-react-refresh-wrap": "2.11.0",
325 | "@parcel/transformer-svg": "2.11.0"
326 | },
327 | "funding": {
328 | "type": "opencollective",
329 | "url": "https://opencollective.com/parcel"
330 | },
331 | "peerDependencies": {
332 | "@parcel/core": "^2.11.0"
333 | }
334 | },
335 | "node_modules/@parcel/core": {
336 | "version": "2.11.0",
337 | "resolved": "https://registry.npmjs.org/@parcel/core/-/core-2.11.0.tgz",
338 | "integrity": "sha512-Npe0S6hVaqWEwRL+HI7gtOYOaoE5bJQZTgUDhsDoppWbau51jOlRYOZTXuvRK/jxXnze4/S1sdM24xBYAQ5qkw==",
339 | "dev": true,
340 | "license": "MIT",
341 | "dependencies": {
342 | "@mischnic/json-sourcemap": "^0.1.0",
343 | "@parcel/cache": "2.11.0",
344 | "@parcel/diagnostic": "2.11.0",
345 | "@parcel/events": "2.11.0",
346 | "@parcel/fs": "2.11.0",
347 | "@parcel/graph": "3.1.0",
348 | "@parcel/logger": "2.11.0",
349 | "@parcel/package-manager": "2.11.0",
350 | "@parcel/plugin": "2.11.0",
351 | "@parcel/profiler": "2.11.0",
352 | "@parcel/rust": "2.11.0",
353 | "@parcel/source-map": "^2.1.1",
354 | "@parcel/types": "2.11.0",
355 | "@parcel/utils": "2.11.0",
356 | "@parcel/workers": "2.11.0",
357 | "abortcontroller-polyfill": "^1.1.9",
358 | "base-x": "^3.0.8",
359 | "browserslist": "^4.6.6",
360 | "clone": "^2.1.1",
361 | "dotenv": "^7.0.0",
362 | "dotenv-expand": "^5.1.0",
363 | "json5": "^2.2.0",
364 | "msgpackr": "^1.9.9",
365 | "nullthrows": "^1.1.1",
366 | "semver": "^7.5.2"
367 | },
368 | "engines": {
369 | "node": ">= 12.0.0"
370 | },
371 | "funding": {
372 | "type": "opencollective",
373 | "url": "https://opencollective.com/parcel"
374 | }
375 | },
376 | "node_modules/@parcel/diagnostic": {
377 | "version": "2.11.0",
378 | "resolved": "https://registry.npmjs.org/@parcel/diagnostic/-/diagnostic-2.11.0.tgz",
379 | "integrity": "sha512-4dJmOXVL5YGGQRRsQosQbSRONBcboB71mSwaeaEgz3pPdq9QXVPLACkGe/jTXSqa3OnAHu3g5vQLpE1g5xqBqw==",
380 | "dev": true,
381 | "license": "MIT",
382 | "dependencies": {
383 | "@mischnic/json-sourcemap": "^0.1.0",
384 | "nullthrows": "^1.1.1"
385 | },
386 | "engines": {
387 | "node": ">= 12.0.0"
388 | },
389 | "funding": {
390 | "type": "opencollective",
391 | "url": "https://opencollective.com/parcel"
392 | }
393 | },
394 | "node_modules/@parcel/events": {
395 | "version": "2.11.0",
396 | "resolved": "https://registry.npmjs.org/@parcel/events/-/events-2.11.0.tgz",
397 | "integrity": "sha512-K6SOjOrQsz1GdNl2qKBktq7KJ3Q3yxK8WXdmQYo10wG39dr051xtMb38aqieTp4eVhL8Yaq2iJgGkdr11fuBnA==",
398 | "dev": true,
399 | "license": "MIT",
400 | "engines": {
401 | "node": ">= 12.0.0"
402 | },
403 | "funding": {
404 | "type": "opencollective",
405 | "url": "https://opencollective.com/parcel"
406 | }
407 | },
408 | "node_modules/@parcel/fs": {
409 | "version": "2.11.0",
410 | "resolved": "https://registry.npmjs.org/@parcel/fs/-/fs-2.11.0.tgz",
411 | "integrity": "sha512-zWckdnnovdrgdFX4QYuQV4bbKCsh6IYCkmwaB4yp47rhw1MP0lkBINLt4yFPHBxWXOpElCfxjL+z69c9xJQRBQ==",
412 | "dev": true,
413 | "license": "MIT",
414 | "dependencies": {
415 | "@parcel/rust": "2.11.0",
416 | "@parcel/types": "2.11.0",
417 | "@parcel/utils": "2.11.0",
418 | "@parcel/watcher": "^2.0.7",
419 | "@parcel/workers": "2.11.0"
420 | },
421 | "engines": {
422 | "node": ">= 12.0.0"
423 | },
424 | "funding": {
425 | "type": "opencollective",
426 | "url": "https://opencollective.com/parcel"
427 | },
428 | "peerDependencies": {
429 | "@parcel/core": "^2.11.0"
430 | }
431 | },
432 | "node_modules/@parcel/graph": {
433 | "version": "3.1.0",
434 | "resolved": "https://registry.npmjs.org/@parcel/graph/-/graph-3.1.0.tgz",
435 | "integrity": "sha512-d1dTW5C7A52HgDtoXlyvlET1ypSlmIxSIZOJ1xp3R9L9hgo3h1u3jHNyaoTe/WPkGVe2QnFxh0h+UibVJhu9vg==",
436 | "dev": true,
437 | "license": "MIT",
438 | "dependencies": {
439 | "nullthrows": "^1.1.1"
440 | },
441 | "engines": {
442 | "node": ">= 12.0.0"
443 | },
444 | "funding": {
445 | "type": "opencollective",
446 | "url": "https://opencollective.com/parcel"
447 | }
448 | },
449 | "node_modules/@parcel/logger": {
450 | "version": "2.11.0",
451 | "resolved": "https://registry.npmjs.org/@parcel/logger/-/logger-2.11.0.tgz",
452 | "integrity": "sha512-HtMEdCq3LKnvv4T2CIskcqlf2gpBvHMm3pkeUFB/hc/7hW/hE1k6/HA2VOQvc0tBsaMpmEx7PCrfrH56usQSyA==",
453 | "dev": true,
454 | "license": "MIT",
455 | "dependencies": {
456 | "@parcel/diagnostic": "2.11.0",
457 | "@parcel/events": "2.11.0"
458 | },
459 | "engines": {
460 | "node": ">= 12.0.0"
461 | },
462 | "funding": {
463 | "type": "opencollective",
464 | "url": "https://opencollective.com/parcel"
465 | }
466 | },
467 | "node_modules/@parcel/markdown-ansi": {
468 | "version": "2.11.0",
469 | "resolved": "https://registry.npmjs.org/@parcel/markdown-ansi/-/markdown-ansi-2.11.0.tgz",
470 | "integrity": "sha512-YA60EWbXi6cLOIzcwRC2wijotPauOGQbUi0vSbu0O6/mjQ68kWCMGz0hwZjDRQcPypQVJEIvTgMymLbvumxwhg==",
471 | "dev": true,
472 | "license": "MIT",
473 | "dependencies": {
474 | "chalk": "^4.1.0"
475 | },
476 | "engines": {
477 | "node": ">= 12.0.0"
478 | },
479 | "funding": {
480 | "type": "opencollective",
481 | "url": "https://opencollective.com/parcel"
482 | }
483 | },
484 | "node_modules/@parcel/namer-default": {
485 | "version": "2.11.0",
486 | "resolved": "https://registry.npmjs.org/@parcel/namer-default/-/namer-default-2.11.0.tgz",
487 | "integrity": "sha512-DEwBSKSClg4DA2xAWimYkw9bFi7MFb9TdT7/TYZStMTsfYHPWOyyjGR7aVr3Ra4wNb+XX6g4rR41yp3HD6KO7A==",
488 | "dev": true,
489 | "license": "MIT",
490 | "dependencies": {
491 | "@parcel/diagnostic": "2.11.0",
492 | "@parcel/plugin": "2.11.0",
493 | "nullthrows": "^1.1.1"
494 | },
495 | "engines": {
496 | "node": ">= 12.0.0",
497 | "parcel": "^2.11.0"
498 | },
499 | "funding": {
500 | "type": "opencollective",
501 | "url": "https://opencollective.com/parcel"
502 | }
503 | },
504 | "node_modules/@parcel/node-resolver-core": {
505 | "version": "3.2.0",
506 | "resolved": "https://registry.npmjs.org/@parcel/node-resolver-core/-/node-resolver-core-3.2.0.tgz",
507 | "integrity": "sha512-XJRSxCkNbGFWjfmwFdcQZ/qlzWZd35qLtvLz2va8euGL7M5OMEQOv7dsvEhl0R+CC2zcnfFzZwxk78q6ezs8AQ==",
508 | "dev": true,
509 | "license": "MIT",
510 | "dependencies": {
511 | "@mischnic/json-sourcemap": "^0.1.0",
512 | "@parcel/diagnostic": "2.11.0",
513 | "@parcel/fs": "2.11.0",
514 | "@parcel/rust": "2.11.0",
515 | "@parcel/utils": "2.11.0",
516 | "nullthrows": "^1.1.1",
517 | "semver": "^7.5.2"
518 | },
519 | "engines": {
520 | "node": ">= 12.0.0"
521 | },
522 | "funding": {
523 | "type": "opencollective",
524 | "url": "https://opencollective.com/parcel"
525 | }
526 | },
527 | "node_modules/@parcel/optimizer-css": {
528 | "version": "2.11.0",
529 | "resolved": "https://registry.npmjs.org/@parcel/optimizer-css/-/optimizer-css-2.11.0.tgz",
530 | "integrity": "sha512-bV97PRxshHV3dMwOpLRgcP1QNhrVWh6VVDfm2gmWULpvsjoykcPS6vrCFksY5CpQsSvNHqJBzQjWS8FubUI76w==",
531 | "dev": true,
532 | "license": "MIT",
533 | "dependencies": {
534 | "@parcel/diagnostic": "2.11.0",
535 | "@parcel/plugin": "2.11.0",
536 | "@parcel/source-map": "^2.1.1",
537 | "@parcel/utils": "2.11.0",
538 | "browserslist": "^4.6.6",
539 | "lightningcss": "^1.22.1",
540 | "nullthrows": "^1.1.1"
541 | },
542 | "engines": {
543 | "node": ">= 12.0.0",
544 | "parcel": "^2.11.0"
545 | },
546 | "funding": {
547 | "type": "opencollective",
548 | "url": "https://opencollective.com/parcel"
549 | }
550 | },
551 | "node_modules/@parcel/optimizer-htmlnano": {
552 | "version": "2.11.0",
553 | "resolved": "https://registry.npmjs.org/@parcel/optimizer-htmlnano/-/optimizer-htmlnano-2.11.0.tgz",
554 | "integrity": "sha512-c20pz4EFF5DNFmqYgptlIj49eT6xjGLkDTdHH3RRzxKovuSXWfYSPs3GED3ZsjVuQyjNQif+/MAk9547F7hrdQ==",
555 | "dev": true,
556 | "license": "MIT",
557 | "dependencies": {
558 | "@parcel/plugin": "2.11.0",
559 | "htmlnano": "^2.0.0",
560 | "nullthrows": "^1.1.1",
561 | "posthtml": "^0.16.5",
562 | "svgo": "^2.4.0"
563 | },
564 | "engines": {
565 | "node": ">= 12.0.0",
566 | "parcel": "^2.11.0"
567 | },
568 | "funding": {
569 | "type": "opencollective",
570 | "url": "https://opencollective.com/parcel"
571 | }
572 | },
573 | "node_modules/@parcel/optimizer-image": {
574 | "version": "2.11.0",
575 | "resolved": "https://registry.npmjs.org/@parcel/optimizer-image/-/optimizer-image-2.11.0.tgz",
576 | "integrity": "sha512-jCaJww5QFG2GuNzYW8nlSW+Ea+Cv47TRnOPJNquFIajgfTLJ5ddsWbaNal0GQsL8yNiCBKWd1AV4W0RH9tG0Jg==",
577 | "dev": true,
578 | "license": "MIT",
579 | "dependencies": {
580 | "@parcel/diagnostic": "2.11.0",
581 | "@parcel/plugin": "2.11.0",
582 | "@parcel/rust": "2.11.0",
583 | "@parcel/utils": "2.11.0",
584 | "@parcel/workers": "2.11.0"
585 | },
586 | "engines": {
587 | "node": ">= 12.0.0",
588 | "parcel": "^2.11.0"
589 | },
590 | "funding": {
591 | "type": "opencollective",
592 | "url": "https://opencollective.com/parcel"
593 | },
594 | "peerDependencies": {
595 | "@parcel/core": "^2.11.0"
596 | }
597 | },
598 | "node_modules/@parcel/optimizer-svgo": {
599 | "version": "2.11.0",
600 | "resolved": "https://registry.npmjs.org/@parcel/optimizer-svgo/-/optimizer-svgo-2.11.0.tgz",
601 | "integrity": "sha512-TQpvfBhjV2IsuFHXUolbDS6XWB3DDR2rYTlqlA8LMmuOY7jQd9Bnkl4JnapzWm/bRuzRlzdGjjVCPGL8iShFvA==",
602 | "dev": true,
603 | "license": "MIT",
604 | "dependencies": {
605 | "@parcel/diagnostic": "2.11.0",
606 | "@parcel/plugin": "2.11.0",
607 | "@parcel/utils": "2.11.0",
608 | "svgo": "^2.4.0"
609 | },
610 | "engines": {
611 | "node": ">= 12.0.0",
612 | "parcel": "^2.11.0"
613 | },
614 | "funding": {
615 | "type": "opencollective",
616 | "url": "https://opencollective.com/parcel"
617 | }
618 | },
619 | "node_modules/@parcel/optimizer-swc": {
620 | "version": "2.11.0",
621 | "resolved": "https://registry.npmjs.org/@parcel/optimizer-swc/-/optimizer-swc-2.11.0.tgz",
622 | "integrity": "sha512-ftf42F3JyZxJb6nnLlgNGyNQ273YOla4dFGH/tWC8iTwObHUpWe7cMbCGcrSJBvAlsLkZfLpFNAXFxUgxdKyHQ==",
623 | "dev": true,
624 | "license": "MIT",
625 | "dependencies": {
626 | "@parcel/diagnostic": "2.11.0",
627 | "@parcel/plugin": "2.11.0",
628 | "@parcel/source-map": "^2.1.1",
629 | "@parcel/utils": "2.11.0",
630 | "@swc/core": "^1.3.36",
631 | "nullthrows": "^1.1.1"
632 | },
633 | "engines": {
634 | "node": ">= 12.0.0",
635 | "parcel": "^2.11.0"
636 | },
637 | "funding": {
638 | "type": "opencollective",
639 | "url": "https://opencollective.com/parcel"
640 | }
641 | },
642 | "node_modules/@parcel/package-manager": {
643 | "version": "2.11.0",
644 | "resolved": "https://registry.npmjs.org/@parcel/package-manager/-/package-manager-2.11.0.tgz",
645 | "integrity": "sha512-QzdsrUYlAwIzb8by7WJjqYnbR1MoMKWbtE1MXUeYsZbFusV8B6pOH+lwqNJKS/BFtddZMRPYFueZS2N2fwzjig==",
646 | "dev": true,
647 | "license": "MIT",
648 | "dependencies": {
649 | "@parcel/diagnostic": "2.11.0",
650 | "@parcel/fs": "2.11.0",
651 | "@parcel/logger": "2.11.0",
652 | "@parcel/node-resolver-core": "3.2.0",
653 | "@parcel/types": "2.11.0",
654 | "@parcel/utils": "2.11.0",
655 | "@parcel/workers": "2.11.0",
656 | "semver": "^7.5.2"
657 | },
658 | "engines": {
659 | "node": ">= 12.0.0"
660 | },
661 | "funding": {
662 | "type": "opencollective",
663 | "url": "https://opencollective.com/parcel"
664 | },
665 | "peerDependencies": {
666 | "@parcel/core": "^2.11.0"
667 | }
668 | },
669 | "node_modules/@parcel/packager-css": {
670 | "version": "2.11.0",
671 | "resolved": "https://registry.npmjs.org/@parcel/packager-css/-/packager-css-2.11.0.tgz",
672 | "integrity": "sha512-AyIxsp4eL8c22vp2oO2hSRnr3hSVNkARNZc9DG6uXxCc2Is5tUEX0I4PwxWnAx0EI44l+3zX/o414zT8yV9wwQ==",
673 | "dev": true,
674 | "license": "MIT",
675 | "dependencies": {
676 | "@parcel/diagnostic": "2.11.0",
677 | "@parcel/plugin": "2.11.0",
678 | "@parcel/source-map": "^2.1.1",
679 | "@parcel/utils": "2.11.0",
680 | "nullthrows": "^1.1.1"
681 | },
682 | "engines": {
683 | "node": ">= 12.0.0",
684 | "parcel": "^2.11.0"
685 | },
686 | "funding": {
687 | "type": "opencollective",
688 | "url": "https://opencollective.com/parcel"
689 | }
690 | },
691 | "node_modules/@parcel/packager-html": {
692 | "version": "2.11.0",
693 | "resolved": "https://registry.npmjs.org/@parcel/packager-html/-/packager-html-2.11.0.tgz",
694 | "integrity": "sha512-ho5AQ70naTV8IqkKIbKtK+jsXQ5TJfFgtBvmJlyB3YydRMbIc+3g4G0xgIvf15V4uCMw9Md0Sv1W65nQXHPQoA==",
695 | "dev": true,
696 | "license": "MIT",
697 | "dependencies": {
698 | "@parcel/plugin": "2.11.0",
699 | "@parcel/types": "2.11.0",
700 | "@parcel/utils": "2.11.0",
701 | "nullthrows": "^1.1.1",
702 | "posthtml": "^0.16.5"
703 | },
704 | "engines": {
705 | "node": ">= 12.0.0",
706 | "parcel": "^2.11.0"
707 | },
708 | "funding": {
709 | "type": "opencollective",
710 | "url": "https://opencollective.com/parcel"
711 | }
712 | },
713 | "node_modules/@parcel/packager-js": {
714 | "version": "2.11.0",
715 | "resolved": "https://registry.npmjs.org/@parcel/packager-js/-/packager-js-2.11.0.tgz",
716 | "integrity": "sha512-SxjCsd0xQfg5H73YtVJj9VOpr9s0rwMsSoeykjkatbkEla9NsZajsUkd/bfYf+/0WvEKOrB8oUBo15HkGOgKug==",
717 | "dev": true,
718 | "license": "MIT",
719 | "dependencies": {
720 | "@parcel/diagnostic": "2.11.0",
721 | "@parcel/plugin": "2.11.0",
722 | "@parcel/rust": "2.11.0",
723 | "@parcel/source-map": "^2.1.1",
724 | "@parcel/types": "2.11.0",
725 | "@parcel/utils": "2.11.0",
726 | "globals": "^13.2.0",
727 | "nullthrows": "^1.1.1"
728 | },
729 | "engines": {
730 | "node": ">= 12.0.0",
731 | "parcel": "^2.11.0"
732 | },
733 | "funding": {
734 | "type": "opencollective",
735 | "url": "https://opencollective.com/parcel"
736 | }
737 | },
738 | "node_modules/@parcel/packager-raw": {
739 | "version": "2.11.0",
740 | "resolved": "https://registry.npmjs.org/@parcel/packager-raw/-/packager-raw-2.11.0.tgz",
741 | "integrity": "sha512-2/0JQ8DZrz7cVNXwD6OYoUUtSSnlr4dsz8ZkpFDKsBJhvMHtC78Sq+1EDixDGOMiUcalSEjNsoHtkpq9uNh+Xw==",
742 | "dev": true,
743 | "license": "MIT",
744 | "dependencies": {
745 | "@parcel/plugin": "2.11.0"
746 | },
747 | "engines": {
748 | "node": ">= 12.0.0",
749 | "parcel": "^2.11.0"
750 | },
751 | "funding": {
752 | "type": "opencollective",
753 | "url": "https://opencollective.com/parcel"
754 | }
755 | },
756 | "node_modules/@parcel/packager-svg": {
757 | "version": "2.11.0",
758 | "resolved": "https://registry.npmjs.org/@parcel/packager-svg/-/packager-svg-2.11.0.tgz",
759 | "integrity": "sha512-2wQBkzLwcaWFGWz8TP+bgsXgiueWPzrjKsWugWdDfq0FbXh8XVeR/599qnus3RFHZy4cH6L6yq/7zxcljtxK8A==",
760 | "dev": true,
761 | "license": "MIT",
762 | "dependencies": {
763 | "@parcel/plugin": "2.11.0",
764 | "@parcel/types": "2.11.0",
765 | "@parcel/utils": "2.11.0",
766 | "posthtml": "^0.16.4"
767 | },
768 | "engines": {
769 | "node": ">= 12.0.0",
770 | "parcel": "^2.11.0"
771 | },
772 | "funding": {
773 | "type": "opencollective",
774 | "url": "https://opencollective.com/parcel"
775 | }
776 | },
777 | "node_modules/@parcel/packager-wasm": {
778 | "version": "2.11.0",
779 | "resolved": "https://registry.npmjs.org/@parcel/packager-wasm/-/packager-wasm-2.11.0.tgz",
780 | "integrity": "sha512-tTy4EbDXeeiZ0oB7L2FWaHSD1mbmYZP6R5HXqkvc5dECGUKPU5Jz6ek2C5AM+HfQdQLKXPQ/Xw3eJnI/AmctVg==",
781 | "dev": true,
782 | "license": "MIT",
783 | "dependencies": {
784 | "@parcel/plugin": "2.11.0"
785 | },
786 | "engines": {
787 | "node": ">=12.0.0",
788 | "parcel": "^2.11.0"
789 | },
790 | "funding": {
791 | "type": "opencollective",
792 | "url": "https://opencollective.com/parcel"
793 | }
794 | },
795 | "node_modules/@parcel/plugin": {
796 | "version": "2.11.0",
797 | "resolved": "https://registry.npmjs.org/@parcel/plugin/-/plugin-2.11.0.tgz",
798 | "integrity": "sha512-9npuKBlhnPn7oeUpLJGecceg16GkXbvzbr6MNSZiHhkx3IBeITHQXlZnp2zAjUOFreNsYOfifwEF2S4KsARfBQ==",
799 | "dev": true,
800 | "license": "MIT",
801 | "dependencies": {
802 | "@parcel/types": "2.11.0"
803 | },
804 | "engines": {
805 | "node": ">= 12.0.0"
806 | },
807 | "funding": {
808 | "type": "opencollective",
809 | "url": "https://opencollective.com/parcel"
810 | }
811 | },
812 | "node_modules/@parcel/profiler": {
813 | "version": "2.11.0",
814 | "resolved": "https://registry.npmjs.org/@parcel/profiler/-/profiler-2.11.0.tgz",
815 | "integrity": "sha512-s10SS09prOdwnaAcjK8M5zO8o+zPJJW5oOqXPNdf6KH4NGD/ue7iOk2xM8QLw6ulSwxE7NDt++lyfW3AXgCZwg==",
816 | "dev": true,
817 | "license": "MIT",
818 | "dependencies": {
819 | "@parcel/diagnostic": "2.11.0",
820 | "@parcel/events": "2.11.0",
821 | "chrome-trace-event": "^1.0.2"
822 | },
823 | "engines": {
824 | "node": ">= 12.0.0"
825 | },
826 | "funding": {
827 | "type": "opencollective",
828 | "url": "https://opencollective.com/parcel"
829 | }
830 | },
831 | "node_modules/@parcel/reporter-cli": {
832 | "version": "2.11.0",
833 | "resolved": "https://registry.npmjs.org/@parcel/reporter-cli/-/reporter-cli-2.11.0.tgz",
834 | "integrity": "sha512-hY0iO0f+LifgJHDUIjGQJnxLFSkk2jlbfy+kIaft5oI3/IM+UljecfGO+14XH8mYlqRXXPsT09TJe8ZKQzp4ZQ==",
835 | "dev": true,
836 | "license": "MIT",
837 | "dependencies": {
838 | "@parcel/plugin": "2.11.0",
839 | "@parcel/types": "2.11.0",
840 | "@parcel/utils": "2.11.0",
841 | "chalk": "^4.1.0",
842 | "cli-progress": "^3.12.0",
843 | "term-size": "^2.2.1"
844 | },
845 | "engines": {
846 | "node": ">= 12.0.0",
847 | "parcel": "^2.11.0"
848 | },
849 | "funding": {
850 | "type": "opencollective",
851 | "url": "https://opencollective.com/parcel"
852 | }
853 | },
854 | "node_modules/@parcel/reporter-dev-server": {
855 | "version": "2.11.0",
856 | "resolved": "https://registry.npmjs.org/@parcel/reporter-dev-server/-/reporter-dev-server-2.11.0.tgz",
857 | "integrity": "sha512-T4ue1+oLFNdcd9maw8QWQuxzOS2kX2jOrSvYKwYd9oGnqiAr1rpiHYYKJhHng+PF5ybwWkj8dUJfGh2NoQysJA==",
858 | "dev": true,
859 | "license": "MIT",
860 | "dependencies": {
861 | "@parcel/plugin": "2.11.0",
862 | "@parcel/utils": "2.11.0"
863 | },
864 | "engines": {
865 | "node": ">= 12.0.0",
866 | "parcel": "^2.11.0"
867 | },
868 | "funding": {
869 | "type": "opencollective",
870 | "url": "https://opencollective.com/parcel"
871 | }
872 | },
873 | "node_modules/@parcel/reporter-tracer": {
874 | "version": "2.11.0",
875 | "resolved": "https://registry.npmjs.org/@parcel/reporter-tracer/-/reporter-tracer-2.11.0.tgz",
876 | "integrity": "sha512-33q4ftO26OPWHkUpEm0bzzSjW2kHEh6q/JFePwf8W6APTQVruj4mV46+Fh6rxX42ixs92K/QoiE0gYgWZQVDHA==",
877 | "dev": true,
878 | "license": "MIT",
879 | "dependencies": {
880 | "@parcel/plugin": "2.11.0",
881 | "@parcel/utils": "2.11.0",
882 | "chrome-trace-event": "^1.0.3",
883 | "nullthrows": "^1.1.1"
884 | },
885 | "engines": {
886 | "node": ">= 12.0.0",
887 | "parcel": "^2.11.0"
888 | },
889 | "funding": {
890 | "type": "opencollective",
891 | "url": "https://opencollective.com/parcel"
892 | }
893 | },
894 | "node_modules/@parcel/resolver-default": {
895 | "version": "2.11.0",
896 | "resolved": "https://registry.npmjs.org/@parcel/resolver-default/-/resolver-default-2.11.0.tgz",
897 | "integrity": "sha512-suZNN2lE5W48LPTwAbG7gnj1IeubkCVEm0XspWXcXUtCzglimNJ8PVVBGx171o5CqDpdbGF3AqHjG9N3uOwXag==",
898 | "dev": true,
899 | "license": "MIT",
900 | "dependencies": {
901 | "@parcel/node-resolver-core": "3.2.0",
902 | "@parcel/plugin": "2.11.0"
903 | },
904 | "engines": {
905 | "node": ">= 12.0.0",
906 | "parcel": "^2.11.0"
907 | },
908 | "funding": {
909 | "type": "opencollective",
910 | "url": "https://opencollective.com/parcel"
911 | }
912 | },
913 | "node_modules/@parcel/runtime-browser-hmr": {
914 | "version": "2.11.0",
915 | "resolved": "https://registry.npmjs.org/@parcel/runtime-browser-hmr/-/runtime-browser-hmr-2.11.0.tgz",
916 | "integrity": "sha512-uVwNBtoLMrlPHLvRS05BVhLseduMOpZT36yiIjS0YSBJcC6/otI9AY7ZiDPYmrB5xTqM0R+D554JhPaJHCuocw==",
917 | "dev": true,
918 | "license": "MIT",
919 | "dependencies": {
920 | "@parcel/plugin": "2.11.0",
921 | "@parcel/utils": "2.11.0"
922 | },
923 | "engines": {
924 | "node": ">= 12.0.0",
925 | "parcel": "^2.11.0"
926 | },
927 | "funding": {
928 | "type": "opencollective",
929 | "url": "https://opencollective.com/parcel"
930 | }
931 | },
932 | "node_modules/@parcel/runtime-js": {
933 | "version": "2.11.0",
934 | "resolved": "https://registry.npmjs.org/@parcel/runtime-js/-/runtime-js-2.11.0.tgz",
935 | "integrity": "sha512-fH3nJoexINz7s4cDzp0Vjsx0k1pMYSa5ch38LbbNqCKTermy0pS0zZuvgfLfHFFP+AMRpFQenrF7h7N3bgDmHw==",
936 | "dev": true,
937 | "license": "MIT",
938 | "dependencies": {
939 | "@parcel/diagnostic": "2.11.0",
940 | "@parcel/plugin": "2.11.0",
941 | "@parcel/utils": "2.11.0",
942 | "nullthrows": "^1.1.1"
943 | },
944 | "engines": {
945 | "node": ">= 12.0.0",
946 | "parcel": "^2.11.0"
947 | },
948 | "funding": {
949 | "type": "opencollective",
950 | "url": "https://opencollective.com/parcel"
951 | }
952 | },
953 | "node_modules/@parcel/runtime-react-refresh": {
954 | "version": "2.11.0",
955 | "resolved": "https://registry.npmjs.org/@parcel/runtime-react-refresh/-/runtime-react-refresh-2.11.0.tgz",
956 | "integrity": "sha512-Kfnc7gLjhoephLMnjABrkIkzVfzPrpJlxiJFIleY2Fm57YhmCfKsEYxm3lHOutNaYl1VArW0LKClPH/VHG9vfQ==",
957 | "dev": true,
958 | "license": "MIT",
959 | "dependencies": {
960 | "@parcel/plugin": "2.11.0",
961 | "@parcel/utils": "2.11.0",
962 | "react-error-overlay": "6.0.9",
963 | "react-refresh": "^0.9.0"
964 | },
965 | "engines": {
966 | "node": ">= 12.0.0",
967 | "parcel": "^2.11.0"
968 | },
969 | "funding": {
970 | "type": "opencollective",
971 | "url": "https://opencollective.com/parcel"
972 | }
973 | },
974 | "node_modules/@parcel/runtime-service-worker": {
975 | "version": "2.11.0",
976 | "resolved": "https://registry.npmjs.org/@parcel/runtime-service-worker/-/runtime-service-worker-2.11.0.tgz",
977 | "integrity": "sha512-c8MaSpSbXIKuN5sA/g4UsrsH1BtBZ6Em+eSxt9AYbdPtWrW+qwCioNVZj9lugBRUzDMjVfJz0yK59nS42hABvw==",
978 | "dev": true,
979 | "license": "MIT",
980 | "dependencies": {
981 | "@parcel/plugin": "2.11.0",
982 | "@parcel/utils": "2.11.0",
983 | "nullthrows": "^1.1.1"
984 | },
985 | "engines": {
986 | "node": ">= 12.0.0",
987 | "parcel": "^2.11.0"
988 | },
989 | "funding": {
990 | "type": "opencollective",
991 | "url": "https://opencollective.com/parcel"
992 | }
993 | },
994 | "node_modules/@parcel/rust": {
995 | "version": "2.11.0",
996 | "resolved": "https://registry.npmjs.org/@parcel/rust/-/rust-2.11.0.tgz",
997 | "integrity": "sha512-UkLWdHOD8Md2YmJDPsqd3yIs9chhdl/ATfV/B/xdPKGmqtNouYpDCRlq+WxMt3mLoYgHEg9UwrWLTebo2rr2iQ==",
998 | "dev": true,
999 | "license": "MIT",
1000 | "engines": {
1001 | "node": ">= 12.0.0"
1002 | },
1003 | "funding": {
1004 | "type": "opencollective",
1005 | "url": "https://opencollective.com/parcel"
1006 | }
1007 | },
1008 | "node_modules/@parcel/source-map": {
1009 | "version": "2.1.1",
1010 | "resolved": "https://registry.npmjs.org/@parcel/source-map/-/source-map-2.1.1.tgz",
1011 | "integrity": "sha512-Ejx1P/mj+kMjQb8/y5XxDUn4reGdr+WyKYloBljpppUy8gs42T+BNoEOuRYqDVdgPc6NxduzIDoJS9pOFfV5Ew==",
1012 | "dev": true,
1013 | "license": "MIT",
1014 | "dependencies": {
1015 | "detect-libc": "^1.0.3"
1016 | },
1017 | "engines": {
1018 | "node": "^12.18.3 || >=14"
1019 | }
1020 | },
1021 | "node_modules/@parcel/transformer-babel": {
1022 | "version": "2.11.0",
1023 | "resolved": "https://registry.npmjs.org/@parcel/transformer-babel/-/transformer-babel-2.11.0.tgz",
1024 | "integrity": "sha512-WKGblnp7r426VG+cpeQzc6dj/30EoUaYwyl4OEaigQSJizyuPWTBWTz6FUw+ih1/sg37h+D1BIh9C2FsVzpzbw==",
1025 | "dev": true,
1026 | "license": "MIT",
1027 | "dependencies": {
1028 | "@parcel/diagnostic": "2.11.0",
1029 | "@parcel/plugin": "2.11.0",
1030 | "@parcel/source-map": "^2.1.1",
1031 | "@parcel/utils": "2.11.0",
1032 | "browserslist": "^4.6.6",
1033 | "json5": "^2.2.0",
1034 | "nullthrows": "^1.1.1",
1035 | "semver": "^7.5.2"
1036 | },
1037 | "engines": {
1038 | "node": ">= 12.0.0",
1039 | "parcel": "^2.11.0"
1040 | },
1041 | "funding": {
1042 | "type": "opencollective",
1043 | "url": "https://opencollective.com/parcel"
1044 | }
1045 | },
1046 | "node_modules/@parcel/transformer-css": {
1047 | "version": "2.11.0",
1048 | "resolved": "https://registry.npmjs.org/@parcel/transformer-css/-/transformer-css-2.11.0.tgz",
1049 | "integrity": "sha512-nFmBulF/ErNoafO87JbVrBavjBMNwE/kahbCRVxc2Mvlphz4F4lBW4eDRS5l4xBqFJaNkHr9R55ehLBBilF4Jw==",
1050 | "dev": true,
1051 | "license": "MIT",
1052 | "dependencies": {
1053 | "@parcel/diagnostic": "2.11.0",
1054 | "@parcel/plugin": "2.11.0",
1055 | "@parcel/source-map": "^2.1.1",
1056 | "@parcel/utils": "2.11.0",
1057 | "browserslist": "^4.6.6",
1058 | "lightningcss": "^1.22.1",
1059 | "nullthrows": "^1.1.1"
1060 | },
1061 | "engines": {
1062 | "node": ">= 12.0.0",
1063 | "parcel": "^2.11.0"
1064 | },
1065 | "funding": {
1066 | "type": "opencollective",
1067 | "url": "https://opencollective.com/parcel"
1068 | }
1069 | },
1070 | "node_modules/@parcel/transformer-html": {
1071 | "version": "2.11.0",
1072 | "resolved": "https://registry.npmjs.org/@parcel/transformer-html/-/transformer-html-2.11.0.tgz",
1073 | "integrity": "sha512-90vp7mbvvfqPr9XIINpMcELtywj56f1bxfOkLQgWU1bm22H0FT3i5dqdac++2My0IGDvMwhAEjQfbn4pA579NQ==",
1074 | "dev": true,
1075 | "license": "MIT",
1076 | "dependencies": {
1077 | "@parcel/diagnostic": "2.11.0",
1078 | "@parcel/plugin": "2.11.0",
1079 | "@parcel/rust": "2.11.0",
1080 | "nullthrows": "^1.1.1",
1081 | "posthtml": "^0.16.5",
1082 | "posthtml-parser": "^0.10.1",
1083 | "posthtml-render": "^3.0.0",
1084 | "semver": "^7.5.2",
1085 | "srcset": "4"
1086 | },
1087 | "engines": {
1088 | "node": ">= 12.0.0",
1089 | "parcel": "^2.11.0"
1090 | },
1091 | "funding": {
1092 | "type": "opencollective",
1093 | "url": "https://opencollective.com/parcel"
1094 | }
1095 | },
1096 | "node_modules/@parcel/transformer-html/node_modules/srcset": {
1097 | "version": "4.0.0",
1098 | "resolved": "https://registry.npmjs.org/srcset/-/srcset-4.0.0.tgz",
1099 | "integrity": "sha512-wvLeHgcVHKO8Sc/H/5lkGreJQVeYMm9rlmt8PuR1xE31rIuXhuzznUUqAt8MqLhB3MqJdFzlNAfpcWnxiFUcPw==",
1100 | "dev": true,
1101 | "engines": {
1102 | "node": ">=12"
1103 | },
1104 | "funding": {
1105 | "url": "https://github.com/sponsors/sindresorhus"
1106 | }
1107 | },
1108 | "node_modules/@parcel/transformer-image": {
1109 | "version": "2.11.0",
1110 | "resolved": "https://registry.npmjs.org/@parcel/transformer-image/-/transformer-image-2.11.0.tgz",
1111 | "integrity": "sha512-QiZj18UHf3lVFsi65Vz8YbS3ydx9Pe9x8ktMxE1oh9qpznN8lD7gE/Z9DxuTZB84EZ9pKytKwcv5WGXP25xIFg==",
1112 | "dev": true,
1113 | "license": "MIT",
1114 | "dependencies": {
1115 | "@parcel/plugin": "2.11.0",
1116 | "@parcel/utils": "2.11.0",
1117 | "@parcel/workers": "2.11.0",
1118 | "nullthrows": "^1.1.1"
1119 | },
1120 | "engines": {
1121 | "node": ">= 12.0.0",
1122 | "parcel": "^2.11.0"
1123 | },
1124 | "peerDependencies": {
1125 | "@parcel/core": "^2.11.0"
1126 | }
1127 | },
1128 | "node_modules/@parcel/transformer-js": {
1129 | "version": "2.11.0",
1130 | "resolved": "https://registry.npmjs.org/@parcel/transformer-js/-/transformer-js-2.11.0.tgz",
1131 | "integrity": "sha512-G1sv0n8/fJqHqwUs0iVnVdmRY0Kh8kWaDkuWcU/GJBHMGhUnLXKdNwxX2Av9UdBL14bU1nTINfr9qOfnQotXWg==",
1132 | "dev": true,
1133 | "license": "MIT",
1134 | "dependencies": {
1135 | "@parcel/diagnostic": "2.11.0",
1136 | "@parcel/plugin": "2.11.0",
1137 | "@parcel/rust": "2.11.0",
1138 | "@parcel/source-map": "^2.1.1",
1139 | "@parcel/utils": "2.11.0",
1140 | "@parcel/workers": "2.11.0",
1141 | "@swc/helpers": "^0.5.0",
1142 | "browserslist": "^4.6.6",
1143 | "nullthrows": "^1.1.1",
1144 | "regenerator-runtime": "^0.13.7",
1145 | "semver": "^7.5.2"
1146 | },
1147 | "engines": {
1148 | "node": ">= 12.0.0",
1149 | "parcel": "^2.11.0"
1150 | },
1151 | "funding": {
1152 | "type": "opencollective",
1153 | "url": "https://opencollective.com/parcel"
1154 | },
1155 | "peerDependencies": {
1156 | "@parcel/core": "^2.11.0"
1157 | }
1158 | },
1159 | "node_modules/@parcel/transformer-json": {
1160 | "version": "2.11.0",
1161 | "resolved": "https://registry.npmjs.org/@parcel/transformer-json/-/transformer-json-2.11.0.tgz",
1162 | "integrity": "sha512-Wt/wgSBaRWmPL4gpvjkV0bCBRxFOtsuLNzsm8vYA5poxTFhuLY+AoyQ8S2+xXU4VxwBfdppfIr2Ny3SwGs8xbQ==",
1163 | "dev": true,
1164 | "license": "MIT",
1165 | "dependencies": {
1166 | "@parcel/plugin": "2.11.0",
1167 | "json5": "^2.2.0"
1168 | },
1169 | "engines": {
1170 | "node": ">= 12.0.0",
1171 | "parcel": "^2.11.0"
1172 | },
1173 | "funding": {
1174 | "type": "opencollective",
1175 | "url": "https://opencollective.com/parcel"
1176 | }
1177 | },
1178 | "node_modules/@parcel/transformer-postcss": {
1179 | "version": "2.11.0",
1180 | "resolved": "https://registry.npmjs.org/@parcel/transformer-postcss/-/transformer-postcss-2.11.0.tgz",
1181 | "integrity": "sha512-Ugy8XHBaUptGotsvwzq7gPCvkCopTIqqZ0JZ40Jmy9slGms8wnx06pNHA1Be/RcJwkJ2TbSu+7ncZdgmP5x5GQ==",
1182 | "dev": true,
1183 | "license": "MIT",
1184 | "dependencies": {
1185 | "@parcel/diagnostic": "2.11.0",
1186 | "@parcel/plugin": "2.11.0",
1187 | "@parcel/rust": "2.11.0",
1188 | "@parcel/utils": "2.11.0",
1189 | "clone": "^2.1.1",
1190 | "nullthrows": "^1.1.1",
1191 | "postcss-value-parser": "^4.2.0",
1192 | "semver": "^7.5.2"
1193 | },
1194 | "engines": {
1195 | "node": ">= 12.0.0",
1196 | "parcel": "^2.11.0"
1197 | },
1198 | "funding": {
1199 | "type": "opencollective",
1200 | "url": "https://opencollective.com/parcel"
1201 | }
1202 | },
1203 | "node_modules/@parcel/transformer-posthtml": {
1204 | "version": "2.11.0",
1205 | "resolved": "https://registry.npmjs.org/@parcel/transformer-posthtml/-/transformer-posthtml-2.11.0.tgz",
1206 | "integrity": "sha512-dMK4p1RRAoIJEjK/Wz9GOLqwHqdD/VQDhMPk+6sUKp5zf2MhSohUstpp5gKsSZivCM3PS2f8k9rgroacJ/ReuA==",
1207 | "dev": true,
1208 | "license": "MIT",
1209 | "dependencies": {
1210 | "@parcel/plugin": "2.11.0",
1211 | "@parcel/utils": "2.11.0",
1212 | "nullthrows": "^1.1.1",
1213 | "posthtml": "^0.16.5",
1214 | "posthtml-parser": "^0.10.1",
1215 | "posthtml-render": "^3.0.0",
1216 | "semver": "^7.5.2"
1217 | },
1218 | "engines": {
1219 | "node": ">= 12.0.0",
1220 | "parcel": "^2.11.0"
1221 | },
1222 | "funding": {
1223 | "type": "opencollective",
1224 | "url": "https://opencollective.com/parcel"
1225 | }
1226 | },
1227 | "node_modules/@parcel/transformer-raw": {
1228 | "version": "2.11.0",
1229 | "resolved": "https://registry.npmjs.org/@parcel/transformer-raw/-/transformer-raw-2.11.0.tgz",
1230 | "integrity": "sha512-2ltp3TgS+cxEqSM1vk5gDtJrYx4KMuRRtbSgSvkdldyOgPhflnLU3/HRz72hXSNGqYOV0/JN0+ocsfPnqR00ug==",
1231 | "dev": true,
1232 | "license": "MIT",
1233 | "dependencies": {
1234 | "@parcel/plugin": "2.11.0"
1235 | },
1236 | "engines": {
1237 | "node": ">= 12.0.0",
1238 | "parcel": "^2.11.0"
1239 | },
1240 | "funding": {
1241 | "type": "opencollective",
1242 | "url": "https://opencollective.com/parcel"
1243 | }
1244 | },
1245 | "node_modules/@parcel/transformer-react-refresh-wrap": {
1246 | "version": "2.11.0",
1247 | "resolved": "https://registry.npmjs.org/@parcel/transformer-react-refresh-wrap/-/transformer-react-refresh-wrap-2.11.0.tgz",
1248 | "integrity": "sha512-6pY0CdIgIpXC6XpsDWizf+zLgiuEsJ106HjWLwF7/R72BrvDhLPZ6jRu4UTrnd6bM89KahPw9fZZzjKoA5Efcw==",
1249 | "dev": true,
1250 | "license": "MIT",
1251 | "dependencies": {
1252 | "@parcel/plugin": "2.11.0",
1253 | "@parcel/utils": "2.11.0",
1254 | "react-refresh": "^0.9.0"
1255 | },
1256 | "engines": {
1257 | "node": ">= 12.0.0",
1258 | "parcel": "^2.11.0"
1259 | },
1260 | "funding": {
1261 | "type": "opencollective",
1262 | "url": "https://opencollective.com/parcel"
1263 | }
1264 | },
1265 | "node_modules/@parcel/transformer-svg": {
1266 | "version": "2.11.0",
1267 | "resolved": "https://registry.npmjs.org/@parcel/transformer-svg/-/transformer-svg-2.11.0.tgz",
1268 | "integrity": "sha512-GrTNi04OoQSXsyrB7FqQPeYREscEXFhIBPkyQ0q7WDG/yYynWljiA0kwITCtMjPfv2EDVks292dvM3EcnERRIA==",
1269 | "dev": true,
1270 | "license": "MIT",
1271 | "dependencies": {
1272 | "@parcel/diagnostic": "2.11.0",
1273 | "@parcel/plugin": "2.11.0",
1274 | "@parcel/rust": "2.11.0",
1275 | "nullthrows": "^1.1.1",
1276 | "posthtml": "^0.16.5",
1277 | "posthtml-parser": "^0.10.1",
1278 | "posthtml-render": "^3.0.0",
1279 | "semver": "^7.5.2"
1280 | },
1281 | "engines": {
1282 | "node": ">= 12.0.0",
1283 | "parcel": "^2.11.0"
1284 | },
1285 | "funding": {
1286 | "type": "opencollective",
1287 | "url": "https://opencollective.com/parcel"
1288 | }
1289 | },
1290 | "node_modules/@parcel/types": {
1291 | "version": "2.11.0",
1292 | "resolved": "https://registry.npmjs.org/@parcel/types/-/types-2.11.0.tgz",
1293 | "integrity": "sha512-lN5XlfV9b1s2rli8q1LqsLtu+D4ZwNI3sKmNcL/3tohSfQcF2EgF+MaiANGo9VzXOzoWFHt4dqWjO4OcdyC5tg==",
1294 | "dev": true,
1295 | "license": "MIT",
1296 | "dependencies": {
1297 | "@parcel/cache": "2.11.0",
1298 | "@parcel/diagnostic": "2.11.0",
1299 | "@parcel/fs": "2.11.0",
1300 | "@parcel/package-manager": "2.11.0",
1301 | "@parcel/source-map": "^2.1.1",
1302 | "@parcel/workers": "2.11.0",
1303 | "utility-types": "^3.10.0"
1304 | }
1305 | },
1306 | "node_modules/@parcel/utils": {
1307 | "version": "2.11.0",
1308 | "resolved": "https://registry.npmjs.org/@parcel/utils/-/utils-2.11.0.tgz",
1309 | "integrity": "sha512-AcL70cXlIyE7eQdvjQbYxegN5l+skqvlJllxTWg4YkIZe9p8Gmv74jLAeLWh5F+IGl5WRn0TSy9JhNJjIMQGwQ==",
1310 | "dev": true,
1311 | "license": "MIT",
1312 | "dependencies": {
1313 | "@parcel/codeframe": "2.11.0",
1314 | "@parcel/diagnostic": "2.11.0",
1315 | "@parcel/logger": "2.11.0",
1316 | "@parcel/markdown-ansi": "2.11.0",
1317 | "@parcel/rust": "2.11.0",
1318 | "@parcel/source-map": "^2.1.1",
1319 | "chalk": "^4.1.0",
1320 | "nullthrows": "^1.1.1"
1321 | },
1322 | "engines": {
1323 | "node": ">= 12.0.0"
1324 | },
1325 | "funding": {
1326 | "type": "opencollective",
1327 | "url": "https://opencollective.com/parcel"
1328 | }
1329 | },
1330 | "node_modules/@parcel/watcher": {
1331 | "version": "2.4.0",
1332 | "resolved": "https://registry.npmjs.org/@parcel/watcher/-/watcher-2.4.0.tgz",
1333 | "integrity": "sha512-XJLGVL0DEclX5pcWa2N9SX1jCGTDd8l972biNooLFtjneuGqodupPQh6XseXIBBeVIMaaJ7bTcs3qGvXwsp4vg==",
1334 | "dev": true,
1335 | "license": "MIT",
1336 | "dependencies": {
1337 | "detect-libc": "^1.0.3",
1338 | "is-glob": "^4.0.3",
1339 | "micromatch": "^4.0.5",
1340 | "node-addon-api": "^7.0.0"
1341 | },
1342 | "engines": {
1343 | "node": ">= 10.0.0"
1344 | },
1345 | "funding": {
1346 | "type": "opencollective",
1347 | "url": "https://opencollective.com/parcel"
1348 | },
1349 | "optionalDependencies": {
1350 | "@parcel/watcher-android-arm64": "2.4.0",
1351 | "@parcel/watcher-darwin-arm64": "2.4.0",
1352 | "@parcel/watcher-darwin-x64": "2.4.0",
1353 | "@parcel/watcher-freebsd-x64": "2.4.0",
1354 | "@parcel/watcher-linux-arm-glibc": "2.4.0",
1355 | "@parcel/watcher-linux-arm64-glibc": "2.4.0",
1356 | "@parcel/watcher-linux-arm64-musl": "2.4.0",
1357 | "@parcel/watcher-linux-x64-glibc": "2.4.0",
1358 | "@parcel/watcher-linux-x64-musl": "2.4.0",
1359 | "@parcel/watcher-win32-arm64": "2.4.0",
1360 | "@parcel/watcher-win32-ia32": "2.4.0",
1361 | "@parcel/watcher-win32-x64": "2.4.0"
1362 | }
1363 | },
1364 | "node_modules/@parcel/watcher-linux-x64-glibc": {
1365 | "version": "2.4.0",
1366 | "resolved": "https://registry.npmjs.org/@parcel/watcher-linux-x64-glibc/-/watcher-linux-x64-glibc-2.4.0.tgz",
1367 | "integrity": "sha512-KphV8awJmxU3q52JQvJot0QMu07CIyEjV+2Tb2ZtbucEgqyRcxOBDMsqp1JNq5nuDXtcCC0uHQICeiEz38dPBQ==",
1368 | "cpu": [
1369 | "x64"
1370 | ],
1371 | "optional": true,
1372 | "os": [
1373 | "linux"
1374 | ],
1375 | "engines": {
1376 | "node": ">= 10.0.0"
1377 | },
1378 | "funding": {
1379 | "type": "opencollective",
1380 | "url": "https://opencollective.com/parcel"
1381 | }
1382 | },
1383 | "node_modules/@parcel/watcher-win32-x64": {
1384 | "version": "2.4.0",
1385 | "resolved": "https://registry.npmjs.org/@parcel/watcher-win32-x64/-/watcher-win32-x64-2.4.0.tgz",
1386 | "integrity": "sha512-pAUyUVjfFjWaf/pShmJpJmNxZhbMvJASUpdes9jL6bTEJ+gDxPRSpXTIemNyNsb9AtbiGXs9XduP1reThmd+dA==",
1387 | "cpu": [
1388 | "x64"
1389 | ],
1390 | "dev": true,
1391 | "license": "MIT",
1392 | "optional": true,
1393 | "os": [
1394 | "win32"
1395 | ],
1396 | "engines": {
1397 | "node": ">= 10.0.0"
1398 | },
1399 | "funding": {
1400 | "type": "opencollective",
1401 | "url": "https://opencollective.com/parcel"
1402 | }
1403 | },
1404 | "node_modules/@parcel/workers": {
1405 | "version": "2.11.0",
1406 | "resolved": "https://registry.npmjs.org/@parcel/workers/-/workers-2.11.0.tgz",
1407 | "integrity": "sha512-wjybqdSy6Nk0N9iBGsFcp7739W2zvx0WGfVxPVShqhz46pIkPOiFF/iSn+kFu5EmMKTRWeUif42+a6rRZ7pCnQ==",
1408 | "dev": true,
1409 | "license": "MIT",
1410 | "dependencies": {
1411 | "@parcel/diagnostic": "2.11.0",
1412 | "@parcel/logger": "2.11.0",
1413 | "@parcel/profiler": "2.11.0",
1414 | "@parcel/types": "2.11.0",
1415 | "@parcel/utils": "2.11.0",
1416 | "nullthrows": "^1.1.1"
1417 | },
1418 | "engines": {
1419 | "node": ">= 12.0.0"
1420 | },
1421 | "funding": {
1422 | "type": "opencollective",
1423 | "url": "https://opencollective.com/parcel"
1424 | },
1425 | "peerDependencies": {
1426 | "@parcel/core": "^2.11.0"
1427 | }
1428 | },
1429 | "node_modules/@swc/core": {
1430 | "version": "1.3.104",
1431 | "resolved": "https://registry.npmjs.org/@swc/core/-/core-1.3.104.tgz",
1432 | "integrity": "sha512-9LWH/qzR/Pmyco+XwPiPfz59T1sryI7o5dmqb593MfCkaX5Fzl9KhwQTI47i21/bXYuCdfa9ySZuVkzXMirYxA==",
1433 | "dev": true,
1434 | "hasInstallScript": true,
1435 | "license": "Apache-2.0",
1436 | "dependencies": {
1437 | "@swc/counter": "^0.1.1",
1438 | "@swc/types": "^0.1.5"
1439 | },
1440 | "engines": {
1441 | "node": ">=10"
1442 | },
1443 | "funding": {
1444 | "type": "opencollective",
1445 | "url": "https://opencollective.com/swc"
1446 | },
1447 | "optionalDependencies": {
1448 | "@swc/core-darwin-arm64": "1.3.104",
1449 | "@swc/core-darwin-x64": "1.3.104",
1450 | "@swc/core-linux-arm-gnueabihf": "1.3.104",
1451 | "@swc/core-linux-arm64-gnu": "1.3.104",
1452 | "@swc/core-linux-arm64-musl": "1.3.104",
1453 | "@swc/core-linux-x64-gnu": "1.3.104",
1454 | "@swc/core-linux-x64-musl": "1.3.104",
1455 | "@swc/core-win32-arm64-msvc": "1.3.104",
1456 | "@swc/core-win32-ia32-msvc": "1.3.104",
1457 | "@swc/core-win32-x64-msvc": "1.3.104"
1458 | },
1459 | "peerDependencies": {
1460 | "@swc/helpers": "^0.5.0"
1461 | },
1462 | "peerDependenciesMeta": {
1463 | "@swc/helpers": {
1464 | "optional": true
1465 | }
1466 | }
1467 | },
1468 | "node_modules/@swc/core-win32-x64-msvc": {
1469 | "version": "1.3.104",
1470 | "resolved": "https://registry.npmjs.org/@swc/core-win32-x64-msvc/-/core-win32-x64-msvc-1.3.104.tgz",
1471 | "integrity": "sha512-fZJ1Ju62U4lMZVU+nHxLkFNcu0hG5Y0Yj/5zjrlbuX5N8J5eDndWAFsVnQhxRTZqKhZB53pvWRQs5FItSDqgXg==",
1472 | "cpu": [
1473 | "x64"
1474 | ],
1475 | "dev": true,
1476 | "license": "Apache-2.0 AND MIT",
1477 | "optional": true,
1478 | "os": [
1479 | "win32"
1480 | ],
1481 | "engines": {
1482 | "node": ">=10"
1483 | }
1484 | },
1485 | "node_modules/@swc/counter": {
1486 | "version": "0.1.2",
1487 | "resolved": "https://registry.npmjs.org/@swc/counter/-/counter-0.1.2.tgz",
1488 | "integrity": "sha512-9F4ys4C74eSTEUNndnER3VJ15oru2NumfQxS8geE+f3eB5xvfxpWyqE5XlVnxb/R14uoXi6SLbBwwiDSkv+XEw==",
1489 | "dev": true,
1490 | "license": "Apache-2.0"
1491 | },
1492 | "node_modules/@swc/helpers": {
1493 | "version": "0.5.3",
1494 | "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.3.tgz",
1495 | "integrity": "sha512-FaruWX6KdudYloq1AHD/4nU+UsMTdNE8CKyrseXWEcgjDAbvkwJg2QGPAnfIJLIWsjZOSPLOAykK6fuYp4vp4A==",
1496 | "dev": true,
1497 | "license": "Apache-2.0",
1498 | "dependencies": {
1499 | "tslib": "^2.4.0"
1500 | }
1501 | },
1502 | "node_modules/@swc/helpers/node_modules/tslib": {
1503 | "version": "2.6.2",
1504 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
1505 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==",
1506 | "dev": true,
1507 | "license": "0BSD"
1508 | },
1509 | "node_modules/@swc/types": {
1510 | "version": "0.1.5",
1511 | "resolved": "https://registry.npmjs.org/@swc/types/-/types-0.1.5.tgz",
1512 | "integrity": "sha512-myfUej5naTBWnqOCc/MdVOLVjXUXtIA+NpDrDBKJtLLg2shUjBu3cZmB/85RyitKc55+lUUyl7oRfLOvkr2hsw==",
1513 | "dev": true,
1514 | "license": "Apache-2.0"
1515 | },
1516 | "node_modules/@trysound/sax": {
1517 | "version": "0.2.0",
1518 | "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz",
1519 | "integrity": "sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA==",
1520 | "dev": true,
1521 | "license": "ISC",
1522 | "engines": {
1523 | "node": ">=10.13.0"
1524 | }
1525 | },
1526 | "node_modules/@types/parse-json": {
1527 | "version": "4.0.0",
1528 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz",
1529 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==",
1530 | "dev": true,
1531 | "license": "MIT"
1532 | },
1533 | "node_modules/abortcontroller-polyfill": {
1534 | "version": "1.7.3",
1535 | "resolved": "https://registry.npmjs.org/abortcontroller-polyfill/-/abortcontroller-polyfill-1.7.3.tgz",
1536 | "integrity": "sha512-zetDJxd89y3X99Kvo4qFx8GKlt6GsvN3UcRZHwU6iFA/0KiOmhkTVhe8oRoTBiTVPZu09x3vCra47+w8Yz1+2Q==",
1537 | "dev": true,
1538 | "license": "MIT"
1539 | },
1540 | "node_modules/ansi-regex": {
1541 | "version": "5.0.1",
1542 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
1543 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
1544 | "dev": true,
1545 | "license": "MIT",
1546 | "engines": {
1547 | "node": ">=8"
1548 | }
1549 | },
1550 | "node_modules/ansi-styles": {
1551 | "version": "4.3.0",
1552 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
1553 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
1554 | "dev": true,
1555 | "license": "MIT",
1556 | "dependencies": {
1557 | "color-convert": "^2.0.1"
1558 | },
1559 | "engines": {
1560 | "node": ">=8"
1561 | },
1562 | "funding": {
1563 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1564 | }
1565 | },
1566 | "node_modules/base-x": {
1567 | "version": "3.0.8",
1568 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.8.tgz",
1569 | "integrity": "sha512-Rl/1AWP4J/zRrk54hhlxH4drNxPJXYUaKffODVI53/dAsV4t9fBxyxYKAVPU1XBHxYwOWP9h9H0hM2MVw4YfJA==",
1570 | "dev": true,
1571 | "license": "MIT",
1572 | "dependencies": {
1573 | "safe-buffer": "^5.0.1"
1574 | }
1575 | },
1576 | "node_modules/base64-js": {
1577 | "version": "1.5.1",
1578 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz",
1579 | "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==",
1580 | "dev": true,
1581 | "funding": [
1582 | {
1583 | "type": "github",
1584 | "url": "https://github.com/sponsors/feross"
1585 | },
1586 | {
1587 | "type": "patreon",
1588 | "url": "https://www.patreon.com/feross"
1589 | },
1590 | {
1591 | "type": "consulting",
1592 | "url": "https://feross.org/support"
1593 | }
1594 | ]
1595 | },
1596 | "node_modules/boolbase": {
1597 | "version": "1.0.0",
1598 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
1599 | "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=",
1600 | "dev": true,
1601 | "license": "ISC"
1602 | },
1603 | "node_modules/braces": {
1604 | "version": "3.0.2",
1605 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
1606 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
1607 | "dev": true,
1608 | "license": "MIT",
1609 | "dependencies": {
1610 | "fill-range": "^7.0.1"
1611 | },
1612 | "engines": {
1613 | "node": ">=8"
1614 | }
1615 | },
1616 | "node_modules/browserslist": {
1617 | "version": "4.16.6",
1618 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.16.6.tgz",
1619 | "integrity": "sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ==",
1620 | "dev": true,
1621 | "license": "MIT",
1622 | "dependencies": {
1623 | "caniuse-lite": "^1.0.30001219",
1624 | "colorette": "^1.2.2",
1625 | "electron-to-chromium": "^1.3.723",
1626 | "escalade": "^3.1.1",
1627 | "node-releases": "^1.1.71"
1628 | },
1629 | "bin": {
1630 | "browserslist": "cli.js"
1631 | },
1632 | "engines": {
1633 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
1634 | },
1635 | "funding": {
1636 | "type": "opencollective",
1637 | "url": "https://opencollective.com/browserslist"
1638 | }
1639 | },
1640 | "node_modules/buffer": {
1641 | "version": "6.0.3",
1642 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz",
1643 | "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==",
1644 | "dev": true,
1645 | "funding": [
1646 | {
1647 | "type": "github",
1648 | "url": "https://github.com/sponsors/feross"
1649 | },
1650 | {
1651 | "type": "patreon",
1652 | "url": "https://www.patreon.com/feross"
1653 | },
1654 | {
1655 | "type": "consulting",
1656 | "url": "https://feross.org/support"
1657 | }
1658 | ],
1659 | "dependencies": {
1660 | "base64-js": "^1.3.1",
1661 | "ieee754": "^1.2.1"
1662 | }
1663 | },
1664 | "node_modules/callsites": {
1665 | "version": "3.1.0",
1666 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
1667 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
1668 | "dev": true,
1669 | "license": "MIT",
1670 | "engines": {
1671 | "node": ">=6"
1672 | }
1673 | },
1674 | "node_modules/caniuse-lite": {
1675 | "version": "1.0.30001237",
1676 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001237.tgz",
1677 | "integrity": "sha512-pDHgRndit6p1NR2GhzMbQ6CkRrp4VKuSsqbcLeOQppYPKOYkKT/6ZvZDvKJUqcmtyWIAHuZq3SVS2vc1egCZzw==",
1678 | "dev": true,
1679 | "license": "CC-BY-4.0",
1680 | "funding": {
1681 | "type": "opencollective",
1682 | "url": "https://opencollective.com/browserslist"
1683 | }
1684 | },
1685 | "node_modules/chalk": {
1686 | "version": "4.1.1",
1687 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.1.tgz",
1688 | "integrity": "sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==",
1689 | "dev": true,
1690 | "license": "MIT",
1691 | "dependencies": {
1692 | "ansi-styles": "^4.1.0",
1693 | "supports-color": "^7.1.0"
1694 | },
1695 | "engines": {
1696 | "node": ">=10"
1697 | },
1698 | "funding": {
1699 | "url": "https://github.com/chalk/chalk?sponsor=1"
1700 | }
1701 | },
1702 | "node_modules/chrome-trace-event": {
1703 | "version": "1.0.3",
1704 | "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz",
1705 | "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==",
1706 | "dev": true,
1707 | "license": "MIT",
1708 | "engines": {
1709 | "node": ">=6.0"
1710 | }
1711 | },
1712 | "node_modules/cli-progress": {
1713 | "version": "3.12.0",
1714 | "resolved": "https://registry.npmjs.org/cli-progress/-/cli-progress-3.12.0.tgz",
1715 | "integrity": "sha512-tRkV3HJ1ASwm19THiiLIXLO7Im7wlTuKnvkYaTkyoAPefqjNg7W7DHKUlGRxy9vxDvbyCYQkQozvptuMkGCg8A==",
1716 | "dev": true,
1717 | "license": "MIT",
1718 | "dependencies": {
1719 | "string-width": "^4.2.3"
1720 | },
1721 | "engines": {
1722 | "node": ">=4"
1723 | }
1724 | },
1725 | "node_modules/clone": {
1726 | "version": "2.1.2",
1727 | "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz",
1728 | "integrity": "sha1-G39Ln1kfHo+DZwQBYANFoCiHQ18=",
1729 | "dev": true,
1730 | "license": "MIT",
1731 | "engines": {
1732 | "node": ">=0.8"
1733 | }
1734 | },
1735 | "node_modules/color-convert": {
1736 | "version": "2.0.1",
1737 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
1738 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
1739 | "dev": true,
1740 | "license": "MIT",
1741 | "dependencies": {
1742 | "color-name": "~1.1.4"
1743 | },
1744 | "engines": {
1745 | "node": ">=7.0.0"
1746 | }
1747 | },
1748 | "node_modules/color-name": {
1749 | "version": "1.1.4",
1750 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
1751 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
1752 | "dev": true,
1753 | "license": "MIT"
1754 | },
1755 | "node_modules/colorette": {
1756 | "version": "1.2.2",
1757 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.2.2.tgz",
1758 | "integrity": "sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w==",
1759 | "dev": true,
1760 | "license": "MIT"
1761 | },
1762 | "node_modules/commander": {
1763 | "version": "7.2.0",
1764 | "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz",
1765 | "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==",
1766 | "dev": true,
1767 | "license": "MIT",
1768 | "engines": {
1769 | "node": ">= 10"
1770 | }
1771 | },
1772 | "node_modules/cosmiconfig": {
1773 | "version": "7.0.1",
1774 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.0.1.tgz",
1775 | "integrity": "sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ==",
1776 | "dev": true,
1777 | "license": "MIT",
1778 | "dependencies": {
1779 | "@types/parse-json": "^4.0.0",
1780 | "import-fresh": "^3.2.1",
1781 | "parse-json": "^5.0.0",
1782 | "path-type": "^4.0.0",
1783 | "yaml": "^1.10.0"
1784 | },
1785 | "engines": {
1786 | "node": ">=10"
1787 | }
1788 | },
1789 | "node_modules/css-select": {
1790 | "version": "4.3.0",
1791 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz",
1792 | "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==",
1793 | "dev": true,
1794 | "license": "BSD-2-Clause",
1795 | "dependencies": {
1796 | "boolbase": "^1.0.0",
1797 | "css-what": "^6.0.1",
1798 | "domhandler": "^4.3.1",
1799 | "domutils": "^2.8.0",
1800 | "nth-check": "^2.0.1"
1801 | },
1802 | "funding": {
1803 | "url": "https://github.com/sponsors/fb55"
1804 | }
1805 | },
1806 | "node_modules/css-select/node_modules/domhandler": {
1807 | "version": "4.3.1",
1808 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
1809 | "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
1810 | "dev": true,
1811 | "license": "BSD-2-Clause",
1812 | "dependencies": {
1813 | "domelementtype": "^2.2.0"
1814 | },
1815 | "engines": {
1816 | "node": ">= 4"
1817 | },
1818 | "funding": {
1819 | "url": "https://github.com/fb55/domhandler?sponsor=1"
1820 | }
1821 | },
1822 | "node_modules/css-tree": {
1823 | "version": "1.1.3",
1824 | "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz",
1825 | "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==",
1826 | "dev": true,
1827 | "license": "MIT",
1828 | "dependencies": {
1829 | "mdn-data": "2.0.14",
1830 | "source-map": "^0.6.1"
1831 | },
1832 | "engines": {
1833 | "node": ">=8.0.0"
1834 | }
1835 | },
1836 | "node_modules/css-what": {
1837 | "version": "6.1.0",
1838 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz",
1839 | "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==",
1840 | "dev": true,
1841 | "license": "BSD-2-Clause",
1842 | "engines": {
1843 | "node": ">= 6"
1844 | },
1845 | "funding": {
1846 | "url": "https://github.com/sponsors/fb55"
1847 | }
1848 | },
1849 | "node_modules/csso": {
1850 | "version": "4.2.0",
1851 | "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz",
1852 | "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==",
1853 | "dev": true,
1854 | "license": "MIT",
1855 | "dependencies": {
1856 | "css-tree": "^1.1.2"
1857 | },
1858 | "engines": {
1859 | "node": ">=8.0.0"
1860 | }
1861 | },
1862 | "node_modules/csstype": {
1863 | "version": "3.1.0",
1864 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.0.tgz",
1865 | "integrity": "sha512-uX1KG+x9h5hIJsaKR9xHUeUraxf8IODOwq9JLNPq6BwB04a/xgpq3rcx47l5BZu5zBPlgD342tdke3Hom/nJRA==",
1866 | "license": "MIT"
1867 | },
1868 | "node_modules/debug": {
1869 | "version": "4.3.4",
1870 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
1871 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==",
1872 | "license": "MIT",
1873 | "dependencies": {
1874 | "ms": "2.1.2"
1875 | },
1876 | "engines": {
1877 | "node": ">=6.0"
1878 | },
1879 | "peerDependenciesMeta": {
1880 | "supports-color": {
1881 | "optional": true
1882 | }
1883 | }
1884 | },
1885 | "node_modules/deepmerge": {
1886 | "version": "4.3.1",
1887 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz",
1888 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==",
1889 | "license": "MIT",
1890 | "engines": {
1891 | "node": ">=0.10.0"
1892 | }
1893 | },
1894 | "node_modules/detect-libc": {
1895 | "version": "1.0.3",
1896 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz",
1897 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=",
1898 | "dev": true,
1899 | "license": "Apache-2.0",
1900 | "bin": {
1901 | "detect-libc": "bin/detect-libc.js"
1902 | },
1903 | "engines": {
1904 | "node": ">=0.10"
1905 | }
1906 | },
1907 | "node_modules/dom-serializer": {
1908 | "version": "1.3.2",
1909 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.3.2.tgz",
1910 | "integrity": "sha512-5c54Bk5Dw4qAxNOI1pFEizPSjVsx5+bpJKmL2kPn8JhBUq2q09tTCa3mjijun2NfK78NMouDYNMBkOrPZiS+ig==",
1911 | "dev": true,
1912 | "license": "MIT",
1913 | "dependencies": {
1914 | "domelementtype": "^2.0.1",
1915 | "domhandler": "^4.2.0",
1916 | "entities": "^2.0.0"
1917 | },
1918 | "funding": {
1919 | "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1"
1920 | }
1921 | },
1922 | "node_modules/dom-serializer/node_modules/entities": {
1923 | "version": "2.2.0",
1924 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz",
1925 | "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==",
1926 | "dev": true,
1927 | "license": "BSD-2-Clause",
1928 | "funding": {
1929 | "url": "https://github.com/fb55/entities?sponsor=1"
1930 | }
1931 | },
1932 | "node_modules/domelementtype": {
1933 | "version": "2.2.0",
1934 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.2.0.tgz",
1935 | "integrity": "sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==",
1936 | "dev": true,
1937 | "funding": [
1938 | {
1939 | "type": "github",
1940 | "url": "https://github.com/sponsors/fb55"
1941 | }
1942 | ],
1943 | "license": "BSD-2-Clause"
1944 | },
1945 | "node_modules/domhandler": {
1946 | "version": "4.2.0",
1947 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.2.0.tgz",
1948 | "integrity": "sha512-zk7sgt970kzPks2Bf+dwT/PLzghLnsivb9CcxkvR8Mzr66Olr0Ofd8neSbglHJHaHa2MadfoSdNlKYAaafmWfA==",
1949 | "dev": true,
1950 | "license": "BSD-2-Clause",
1951 | "dependencies": {
1952 | "domelementtype": "^2.2.0"
1953 | },
1954 | "engines": {
1955 | "node": ">= 4"
1956 | },
1957 | "funding": {
1958 | "url": "https://github.com/fb55/domhandler?sponsor=1"
1959 | }
1960 | },
1961 | "node_modules/dompurify": {
1962 | "version": "2.3.8",
1963 | "resolved": "https://registry.npmjs.org/dompurify/-/dompurify-2.3.8.tgz",
1964 | "integrity": "sha512-eVhaWoVibIzqdGYjwsBWodIQIaXFSB+cKDf4cfxLMsK0xiud6SE+/WCVx/Xw/UwQsa4cS3T2eITcdtmTg2UKcw==",
1965 | "license": "(MPL-2.0 OR Apache-2.0)"
1966 | },
1967 | "node_modules/domutils": {
1968 | "version": "2.8.0",
1969 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz",
1970 | "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==",
1971 | "dev": true,
1972 | "license": "BSD-2-Clause",
1973 | "dependencies": {
1974 | "dom-serializer": "^1.0.1",
1975 | "domelementtype": "^2.2.0",
1976 | "domhandler": "^4.2.0"
1977 | },
1978 | "funding": {
1979 | "url": "https://github.com/fb55/domutils?sponsor=1"
1980 | }
1981 | },
1982 | "node_modules/dot-case": {
1983 | "version": "3.0.4",
1984 | "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz",
1985 | "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==",
1986 | "license": "MIT",
1987 | "dependencies": {
1988 | "no-case": "^3.0.4",
1989 | "tslib": "^2.0.3"
1990 | }
1991 | },
1992 | "node_modules/dotenv": {
1993 | "version": "7.0.0",
1994 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-7.0.0.tgz",
1995 | "integrity": "sha512-M3NhsLbV1i6HuGzBUH8vXrtxOk+tWmzWKDMbAVSUp3Zsjm7ywFeuwrUXhmhQyRK1q5B5GGy7hcXPbj3bnfZg2g==",
1996 | "dev": true,
1997 | "license": "BSD-2-Clause",
1998 | "engines": {
1999 | "node": ">=6"
2000 | }
2001 | },
2002 | "node_modules/dotenv-expand": {
2003 | "version": "5.1.0",
2004 | "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-5.1.0.tgz",
2005 | "integrity": "sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA==",
2006 | "dev": true,
2007 | "license": "BSD-2-Clause"
2008 | },
2009 | "node_modules/electron-to-chromium": {
2010 | "version": "1.3.752",
2011 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.752.tgz",
2012 | "integrity": "sha512-2Tg+7jSl3oPxgsBsWKh5H83QazTkmWG/cnNwJplmyZc7KcN61+I10oUgaXSVk/NwfvN3BdkKDR4FYuRBQQ2v0A==",
2013 | "dev": true,
2014 | "license": "ISC"
2015 | },
2016 | "node_modules/emoji-regex": {
2017 | "version": "8.0.0",
2018 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
2019 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
2020 | "dev": true,
2021 | "license": "MIT"
2022 | },
2023 | "node_modules/entities": {
2024 | "version": "3.0.1",
2025 | "resolved": "https://registry.npmjs.org/entities/-/entities-3.0.1.tgz",
2026 | "integrity": "sha512-WiyBqoomrwMdFG1e0kqvASYfnlb0lp8M5o5Fw2OFq1hNZxxcNk8Ik0Xm7LxzBhuidnZB/UtBqVCgUz3kBOP51Q==",
2027 | "dev": true,
2028 | "license": "BSD-2-Clause",
2029 | "engines": {
2030 | "node": ">=0.12"
2031 | },
2032 | "funding": {
2033 | "url": "https://github.com/fb55/entities?sponsor=1"
2034 | }
2035 | },
2036 | "node_modules/error-ex": {
2037 | "version": "1.3.2",
2038 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
2039 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
2040 | "dev": true,
2041 | "license": "MIT",
2042 | "dependencies": {
2043 | "is-arrayish": "^0.2.1"
2044 | }
2045 | },
2046 | "node_modules/escalade": {
2047 | "version": "3.1.1",
2048 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
2049 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==",
2050 | "dev": true,
2051 | "license": "MIT",
2052 | "engines": {
2053 | "node": ">=6"
2054 | }
2055 | },
2056 | "node_modules/escape-string-regexp": {
2057 | "version": "1.0.5",
2058 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
2059 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
2060 | "dev": true,
2061 | "license": "MIT",
2062 | "engines": {
2063 | "node": ">=0.8.0"
2064 | }
2065 | },
2066 | "node_modules/eventemitter3": {
2067 | "version": "4.0.7",
2068 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz",
2069 | "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==",
2070 | "license": "MIT"
2071 | },
2072 | "node_modules/fast-deep-equal": {
2073 | "version": "3.1.3",
2074 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
2075 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
2076 | "license": "MIT"
2077 | },
2078 | "node_modules/fill-range": {
2079 | "version": "7.0.1",
2080 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
2081 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
2082 | "dev": true,
2083 | "license": "MIT",
2084 | "dependencies": {
2085 | "to-regex-range": "^5.0.1"
2086 | },
2087 | "engines": {
2088 | "node": ">=8"
2089 | }
2090 | },
2091 | "node_modules/get-port": {
2092 | "version": "4.2.0",
2093 | "resolved": "https://registry.npmjs.org/get-port/-/get-port-4.2.0.tgz",
2094 | "integrity": "sha512-/b3jarXkH8KJoOMQc3uVGHASwGLPq3gSFJ7tgJm2diza+bydJPTGOibin2steecKeOylE8oY2JERlVWkAJO6yw==",
2095 | "dev": true,
2096 | "license": "MIT",
2097 | "engines": {
2098 | "node": ">=6"
2099 | }
2100 | },
2101 | "node_modules/globals": {
2102 | "version": "13.9.0",
2103 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.9.0.tgz",
2104 | "integrity": "sha512-74/FduwI/JaIrr1H8e71UbDE+5x7pIPs1C2rrwC52SszOo043CsWOZEMW7o2Y58xwm9b+0RBKDxY5n2sUpEFxA==",
2105 | "dev": true,
2106 | "license": "MIT",
2107 | "dependencies": {
2108 | "type-fest": "^0.20.2"
2109 | },
2110 | "engines": {
2111 | "node": ">=8"
2112 | },
2113 | "funding": {
2114 | "url": "https://github.com/sponsors/sindresorhus"
2115 | }
2116 | },
2117 | "node_modules/has-flag": {
2118 | "version": "4.0.0",
2119 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2120 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2121 | "dev": true,
2122 | "license": "MIT",
2123 | "engines": {
2124 | "node": ">=8"
2125 | }
2126 | },
2127 | "node_modules/htmlnano": {
2128 | "version": "2.0.2",
2129 | "resolved": "https://registry.npmjs.org/htmlnano/-/htmlnano-2.0.2.tgz",
2130 | "integrity": "sha512-+ZrQFS4Ub+zd+/fWwfvoYCEGNEa0/zrpys6CyXxvZDwtL7Pl+pOtRkiujyvBQ7Lmfp7/iEPxtOFgxWA16Gkj3w==",
2131 | "dev": true,
2132 | "license": "MIT",
2133 | "dependencies": {
2134 | "cosmiconfig": "^7.0.1",
2135 | "posthtml": "^0.16.5",
2136 | "timsort": "^0.3.0"
2137 | },
2138 | "peerDependencies": {
2139 | "cssnano": "^5.0.11",
2140 | "postcss": "^8.3.11",
2141 | "purgecss": "^4.0.3",
2142 | "relateurl": "^0.2.7",
2143 | "srcset": "^5.0.0",
2144 | "svgo": "^2.8.0",
2145 | "terser": "^5.10.0",
2146 | "uncss": "^0.17.3"
2147 | },
2148 | "peerDependenciesMeta": {
2149 | "cssnano": {
2150 | "optional": true
2151 | },
2152 | "postcss": {
2153 | "optional": true
2154 | },
2155 | "purgecss": {
2156 | "optional": true
2157 | },
2158 | "relateurl": {
2159 | "optional": true
2160 | },
2161 | "srcset": {
2162 | "optional": true
2163 | },
2164 | "svgo": {
2165 | "optional": true
2166 | },
2167 | "terser": {
2168 | "optional": true
2169 | },
2170 | "uncss": {
2171 | "optional": true
2172 | }
2173 | }
2174 | },
2175 | "node_modules/htmlparser2": {
2176 | "version": "7.2.0",
2177 | "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-7.2.0.tgz",
2178 | "integrity": "sha512-H7MImA4MS6cw7nbyURtLPO1Tms7C5H602LRETv95z1MxO/7CP7rDVROehUYeYBUYEON94NXXDEPmZuq+hX4sog==",
2179 | "dev": true,
2180 | "funding": [
2181 | "https://github.com/fb55/htmlparser2?sponsor=1",
2182 | {
2183 | "type": "github",
2184 | "url": "https://github.com/sponsors/fb55"
2185 | }
2186 | ],
2187 | "license": "MIT",
2188 | "dependencies": {
2189 | "domelementtype": "^2.0.1",
2190 | "domhandler": "^4.2.2",
2191 | "domutils": "^2.8.0",
2192 | "entities": "^3.0.1"
2193 | }
2194 | },
2195 | "node_modules/htmlparser2/node_modules/domhandler": {
2196 | "version": "4.3.1",
2197 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz",
2198 | "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==",
2199 | "dev": true,
2200 | "license": "BSD-2-Clause",
2201 | "dependencies": {
2202 | "domelementtype": "^2.2.0"
2203 | },
2204 | "engines": {
2205 | "node": ">= 4"
2206 | },
2207 | "funding": {
2208 | "url": "https://github.com/fb55/domhandler?sponsor=1"
2209 | }
2210 | },
2211 | "node_modules/idb-keyval": {
2212 | "version": "6.2.1",
2213 | "resolved": "https://registry.npmjs.org/idb-keyval/-/idb-keyval-6.2.1.tgz",
2214 | "integrity": "sha512-8Sb3veuYCyrZL+VBt9LJfZjLUPWVvqn8tG28VqYNFCo43KHcKuq+b4EiXGeuaLAQWL2YmyDgMp2aSpH9JHsEQg=="
2215 | },
2216 | "node_modules/ieee754": {
2217 | "version": "1.2.1",
2218 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz",
2219 | "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==",
2220 | "dev": true,
2221 | "funding": [
2222 | {
2223 | "type": "github",
2224 | "url": "https://github.com/sponsors/feross"
2225 | },
2226 | {
2227 | "type": "patreon",
2228 | "url": "https://www.patreon.com/feross"
2229 | },
2230 | {
2231 | "type": "consulting",
2232 | "url": "https://feross.org/support"
2233 | }
2234 | ]
2235 | },
2236 | "node_modules/import-fresh": {
2237 | "version": "3.3.0",
2238 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
2239 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
2240 | "dev": true,
2241 | "license": "MIT",
2242 | "dependencies": {
2243 | "parent-module": "^1.0.0",
2244 | "resolve-from": "^4.0.0"
2245 | },
2246 | "engines": {
2247 | "node": ">=6"
2248 | },
2249 | "funding": {
2250 | "url": "https://github.com/sponsors/sindresorhus"
2251 | }
2252 | },
2253 | "node_modules/inherits": {
2254 | "version": "2.0.3",
2255 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
2256 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=",
2257 | "license": "ISC"
2258 | },
2259 | "node_modules/is-arrayish": {
2260 | "version": "0.2.1",
2261 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
2262 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
2263 | "dev": true,
2264 | "license": "MIT"
2265 | },
2266 | "node_modules/is-extglob": {
2267 | "version": "2.1.1",
2268 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2269 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
2270 | "dev": true,
2271 | "license": "MIT",
2272 | "engines": {
2273 | "node": ">=0.10.0"
2274 | }
2275 | },
2276 | "node_modules/is-fullwidth-code-point": {
2277 | "version": "3.0.0",
2278 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
2279 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
2280 | "dev": true,
2281 | "license": "MIT",
2282 | "engines": {
2283 | "node": ">=8"
2284 | }
2285 | },
2286 | "node_modules/is-glob": {
2287 | "version": "4.0.3",
2288 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
2289 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
2290 | "dev": true,
2291 | "license": "MIT",
2292 | "dependencies": {
2293 | "is-extglob": "^2.1.1"
2294 | },
2295 | "engines": {
2296 | "node": ">=0.10.0"
2297 | }
2298 | },
2299 | "node_modules/is-json": {
2300 | "version": "2.0.1",
2301 | "resolved": "https://registry.npmjs.org/is-json/-/is-json-2.0.1.tgz",
2302 | "integrity": "sha1-a+Fm0USCihMdaGiRuYPfYsOUkf8=",
2303 | "dev": true,
2304 | "license": "ISC"
2305 | },
2306 | "node_modules/is-number": {
2307 | "version": "7.0.0",
2308 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
2309 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
2310 | "dev": true,
2311 | "license": "MIT",
2312 | "engines": {
2313 | "node": ">=0.12.0"
2314 | }
2315 | },
2316 | "node_modules/js-tokens": {
2317 | "version": "4.0.0",
2318 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
2319 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
2320 | "dev": true,
2321 | "license": "MIT"
2322 | },
2323 | "node_modules/json-parse-even-better-errors": {
2324 | "version": "2.3.1",
2325 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
2326 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
2327 | "dev": true,
2328 | "license": "MIT"
2329 | },
2330 | "node_modules/json5": {
2331 | "version": "2.2.3",
2332 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
2333 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
2334 | "dev": true,
2335 | "bin": {
2336 | "json5": "lib/cli.js"
2337 | },
2338 | "engines": {
2339 | "node": ">=6"
2340 | }
2341 | },
2342 | "node_modules/lightningcss": {
2343 | "version": "1.23.0",
2344 | "resolved": "https://registry.npmjs.org/lightningcss/-/lightningcss-1.23.0.tgz",
2345 | "integrity": "sha512-SEArWKMHhqn/0QzOtclIwH5pXIYQOUEkF8DgICd/105O+GCgd7jxjNod/QPnBCSWvpRHQBGVz5fQ9uScby03zA==",
2346 | "dev": true,
2347 | "license": "MPL-2.0",
2348 | "dependencies": {
2349 | "detect-libc": "^1.0.3"
2350 | },
2351 | "engines": {
2352 | "node": ">= 12.0.0"
2353 | },
2354 | "funding": {
2355 | "type": "opencollective",
2356 | "url": "https://opencollective.com/parcel"
2357 | },
2358 | "optionalDependencies": {
2359 | "lightningcss-darwin-arm64": "1.23.0",
2360 | "lightningcss-darwin-x64": "1.23.0",
2361 | "lightningcss-freebsd-x64": "1.23.0",
2362 | "lightningcss-linux-arm-gnueabihf": "1.23.0",
2363 | "lightningcss-linux-arm64-gnu": "1.23.0",
2364 | "lightningcss-linux-arm64-musl": "1.23.0",
2365 | "lightningcss-linux-x64-gnu": "1.23.0",
2366 | "lightningcss-linux-x64-musl": "1.23.0",
2367 | "lightningcss-win32-x64-msvc": "1.23.0"
2368 | }
2369 | },
2370 | "node_modules/lightningcss-win32-x64-msvc": {
2371 | "version": "1.23.0",
2372 | "resolved": "https://registry.npmjs.org/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.23.0.tgz",
2373 | "integrity": "sha512-1rcBDJLU+obPPJM6qR5fgBUiCdZwZLafZM5f9kwjFLkb/UBNIzmae39uCSmh71nzPCTXZqHbvwu23OWnWEz+eg==",
2374 | "cpu": [
2375 | "x64"
2376 | ],
2377 | "dev": true,
2378 | "license": "MPL-2.0",
2379 | "optional": true,
2380 | "os": [
2381 | "win32"
2382 | ],
2383 | "engines": {
2384 | "node": ">= 12.0.0"
2385 | },
2386 | "funding": {
2387 | "type": "opencollective",
2388 | "url": "https://opencollective.com/parcel"
2389 | }
2390 | },
2391 | "node_modules/lines-and-columns": {
2392 | "version": "1.2.4",
2393 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
2394 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
2395 | "dev": true,
2396 | "license": "MIT"
2397 | },
2398 | "node_modules/lmdb": {
2399 | "version": "2.8.5",
2400 | "resolved": "https://registry.npmjs.org/lmdb/-/lmdb-2.8.5.tgz",
2401 | "integrity": "sha512-9bMdFfc80S+vSldBmG3HOuLVHnxRdNTlpzR6QDnzqCQtCzGUEAGTzBKYMeIM+I/sU4oZfgbcbS7X7F65/z/oxQ==",
2402 | "dev": true,
2403 | "hasInstallScript": true,
2404 | "license": "MIT",
2405 | "dependencies": {
2406 | "msgpackr": "^1.9.5",
2407 | "node-addon-api": "^6.1.0",
2408 | "node-gyp-build-optional-packages": "5.1.1",
2409 | "ordered-binary": "^1.4.1",
2410 | "weak-lru-cache": "^1.2.2"
2411 | },
2412 | "bin": {
2413 | "download-lmdb-prebuilds": "bin/download-prebuilds.js"
2414 | },
2415 | "optionalDependencies": {
2416 | "@lmdb/lmdb-darwin-arm64": "2.8.5",
2417 | "@lmdb/lmdb-darwin-x64": "2.8.5",
2418 | "@lmdb/lmdb-linux-arm": "2.8.5",
2419 | "@lmdb/lmdb-linux-arm64": "2.8.5",
2420 | "@lmdb/lmdb-linux-x64": "2.8.5",
2421 | "@lmdb/lmdb-win32-x64": "2.8.5"
2422 | }
2423 | },
2424 | "node_modules/lmdb/node_modules/detect-libc": {
2425 | "version": "2.0.2",
2426 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.2.tgz",
2427 | "integrity": "sha512-UX6sGumvvqSaXgdKGUsgZWqcUyIXZ/vZTrlRT/iobiKhGL0zL4d3osHj3uqllWJK+i+sixDS/3COVEOFbupFyw==",
2428 | "dev": true,
2429 | "license": "Apache-2.0",
2430 | "engines": {
2431 | "node": ">=8"
2432 | }
2433 | },
2434 | "node_modules/lmdb/node_modules/node-addon-api": {
2435 | "version": "6.1.0",
2436 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-6.1.0.tgz",
2437 | "integrity": "sha512-+eawOlIgy680F0kBzPUNFhMZGtJ1YmqM6l4+Crf4IkImjYrO/mqPwRMh352g23uIaQKFItcQ64I7KMaJxHgAVA==",
2438 | "dev": true,
2439 | "license": "MIT"
2440 | },
2441 | "node_modules/lmdb/node_modules/node-gyp-build-optional-packages": {
2442 | "version": "5.1.1",
2443 | "resolved": "https://registry.npmjs.org/node-gyp-build-optional-packages/-/node-gyp-build-optional-packages-5.1.1.tgz",
2444 | "integrity": "sha512-+P72GAjVAbTxjjwUmwjVrqrdZROD4nf8KgpBoDxqXXTiYZZt/ud60dE5yvCSr9lRO8e8yv6kgJIC0K0PfZFVQw==",
2445 | "dev": true,
2446 | "license": "MIT",
2447 | "dependencies": {
2448 | "detect-libc": "^2.0.1"
2449 | },
2450 | "bin": {
2451 | "node-gyp-build-optional-packages": "bin.js",
2452 | "node-gyp-build-optional-packages-optional": "optional.js",
2453 | "node-gyp-build-optional-packages-test": "build-test.js"
2454 | }
2455 | },
2456 | "node_modules/lodash-es": {
2457 | "version": "4.17.21",
2458 | "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz",
2459 | "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==",
2460 | "license": "MIT"
2461 | },
2462 | "node_modules/lower-case": {
2463 | "version": "2.0.2",
2464 | "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz",
2465 | "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==",
2466 | "license": "MIT",
2467 | "dependencies": {
2468 | "tslib": "^2.0.3"
2469 | }
2470 | },
2471 | "node_modules/lru-cache": {
2472 | "version": "6.0.0",
2473 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz",
2474 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==",
2475 | "dev": true,
2476 | "license": "ISC",
2477 | "dependencies": {
2478 | "yallist": "^4.0.0"
2479 | },
2480 | "engines": {
2481 | "node": ">=10"
2482 | }
2483 | },
2484 | "node_modules/luaparse": {
2485 | "version": "0.3.1",
2486 | "resolved": "https://registry.npmjs.org/luaparse/-/luaparse-0.3.1.tgz",
2487 | "integrity": "sha512-b21h2bFEbtGXmVqguHogbyrMAA0wOHyp9u/rx+w6Yc9pW1t9YjhGUsp87lYcp7pFRqSWN/PhFkrdIqKEUzRjjQ==",
2488 | "license": "MIT",
2489 | "bin": {
2490 | "luaparse": "bin/luaparse"
2491 | }
2492 | },
2493 | "node_modules/mdn-data": {
2494 | "version": "2.0.14",
2495 | "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz",
2496 | "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==",
2497 | "dev": true,
2498 | "license": "CC0-1.0"
2499 | },
2500 | "node_modules/micromatch": {
2501 | "version": "4.0.5",
2502 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz",
2503 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==",
2504 | "dev": true,
2505 | "license": "MIT",
2506 | "dependencies": {
2507 | "braces": "^3.0.2",
2508 | "picomatch": "^2.3.1"
2509 | },
2510 | "engines": {
2511 | "node": ">=8.6"
2512 | }
2513 | },
2514 | "node_modules/ms": {
2515 | "version": "2.1.2",
2516 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
2517 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
2518 | "license": "MIT"
2519 | },
2520 | "node_modules/msgpackr": {
2521 | "version": "1.10.1",
2522 | "resolved": "https://registry.npmjs.org/msgpackr/-/msgpackr-1.10.1.tgz",
2523 | "integrity": "sha512-r5VRLv9qouXuLiIBrLpl2d5ZvPt8svdQTl5/vMvE4nzDMyEX4sgW5yWhuBBj5UmgwOTWj8CIdSXn5sAfsHAWIQ==",
2524 | "dev": true,
2525 | "license": "MIT",
2526 | "optionalDependencies": {
2527 | "msgpackr-extract": "^3.0.2"
2528 | }
2529 | },
2530 | "node_modules/msgpackr-extract": {
2531 | "version": "3.0.2",
2532 | "resolved": "https://registry.npmjs.org/msgpackr-extract/-/msgpackr-extract-3.0.2.tgz",
2533 | "integrity": "sha512-SdzXp4kD/Qf8agZ9+iTu6eql0m3kWm1A2y1hkpTeVNENutaB0BwHlSvAIaMxwntmRUAUjon2V4L8Z/njd0Ct8A==",
2534 | "dev": true,
2535 | "hasInstallScript": true,
2536 | "license": "MIT",
2537 | "optional": true,
2538 | "dependencies": {
2539 | "node-gyp-build-optional-packages": "5.0.7"
2540 | },
2541 | "bin": {
2542 | "download-msgpackr-prebuilds": "bin/download-prebuilds.js"
2543 | },
2544 | "optionalDependencies": {
2545 | "@msgpackr-extract/msgpackr-extract-darwin-arm64": "3.0.2",
2546 | "@msgpackr-extract/msgpackr-extract-darwin-x64": "3.0.2",
2547 | "@msgpackr-extract/msgpackr-extract-linux-arm": "3.0.2",
2548 | "@msgpackr-extract/msgpackr-extract-linux-arm64": "3.0.2",
2549 | "@msgpackr-extract/msgpackr-extract-linux-x64": "3.0.2",
2550 | "@msgpackr-extract/msgpackr-extract-win32-x64": "3.0.2"
2551 | }
2552 | },
2553 | "node_modules/no-case": {
2554 | "version": "3.0.4",
2555 | "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz",
2556 | "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==",
2557 | "license": "MIT",
2558 | "dependencies": {
2559 | "lower-case": "^2.0.2",
2560 | "tslib": "^2.0.3"
2561 | }
2562 | },
2563 | "node_modules/node-addon-api": {
2564 | "version": "7.1.0",
2565 | "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-7.1.0.tgz",
2566 | "integrity": "sha512-mNcltoe1R8o7STTegSOHdnJNN7s5EUvhoS7ShnTHDyOSd+8H+UdWODq6qSv67PjC8Zc5JRT8+oLAMCr0SIXw7g==",
2567 | "dev": true,
2568 | "license": "MIT",
2569 | "engines": {
2570 | "node": "^16 || ^18 || >= 20"
2571 | }
2572 | },
2573 | "node_modules/node-gyp-build-optional-packages": {
2574 | "version": "5.0.7",
2575 | "resolved": "https://registry.npmjs.org/node-gyp-build-optional-packages/-/node-gyp-build-optional-packages-5.0.7.tgz",
2576 | "integrity": "sha512-YlCCc6Wffkx0kHkmam79GKvDQ6x+QZkMjFGrIMxgFNILFvGSbCp2fCBC55pGTT9gVaz8Na5CLmxt/urtzRv36w==",
2577 | "dev": true,
2578 | "license": "MIT",
2579 | "optional": true,
2580 | "bin": {
2581 | "node-gyp-build-optional-packages": "bin.js",
2582 | "node-gyp-build-optional-packages-optional": "optional.js",
2583 | "node-gyp-build-optional-packages-test": "build-test.js"
2584 | }
2585 | },
2586 | "node_modules/node-releases": {
2587 | "version": "1.1.73",
2588 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.73.tgz",
2589 | "integrity": "sha512-uW7fodD6pyW2FZNZnp/Z3hvWKeEW1Y8R1+1CnErE8cXFXzl5blBOoVB41CvMer6P6Q0S5FXDwcHgFd1Wj0U9zg==",
2590 | "dev": true,
2591 | "license": "MIT"
2592 | },
2593 | "node_modules/nth-check": {
2594 | "version": "2.0.1",
2595 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.0.1.tgz",
2596 | "integrity": "sha512-it1vE95zF6dTT9lBsYbxvqh0Soy4SPowchj0UBGj/V6cTPnXXtQOPUbhZ6CmGzAD/rW22LQK6E96pcdJXk4A4w==",
2597 | "dev": true,
2598 | "license": "BSD-2-Clause",
2599 | "dependencies": {
2600 | "boolbase": "^1.0.0"
2601 | },
2602 | "funding": {
2603 | "url": "https://github.com/fb55/nth-check?sponsor=1"
2604 | }
2605 | },
2606 | "node_modules/nullthrows": {
2607 | "version": "1.1.1",
2608 | "resolved": "https://registry.npmjs.org/nullthrows/-/nullthrows-1.1.1.tgz",
2609 | "integrity": "sha512-2vPPEi+Z7WqML2jZYddDIfy5Dqb0r2fze2zTxNNknZaFpVHU3mFB3R+DWeJWGVx0ecvttSGlJTI+WG+8Z4cDWw==",
2610 | "dev": true,
2611 | "license": "MIT"
2612 | },
2613 | "node_modules/ordered-binary": {
2614 | "version": "1.5.1",
2615 | "resolved": "https://registry.npmjs.org/ordered-binary/-/ordered-binary-1.5.1.tgz",
2616 | "integrity": "sha512-5VyHfHY3cd0iza71JepYG50My+YUbrFtGoUz2ooEydPyPM7Aai/JW098juLr+RG6+rDJuzNNTsEQu2DZa1A41A==",
2617 | "dev": true,
2618 | "license": "MIT"
2619 | },
2620 | "node_modules/parcel": {
2621 | "version": "2.11.0",
2622 | "resolved": "https://registry.npmjs.org/parcel/-/parcel-2.11.0.tgz",
2623 | "integrity": "sha512-H/RI1/DmuOkL8RuG/EpNPvtzrbF+7jA/R56ydEEm+lqFbYktKB4COR7JXdHkZXRgbSJyimrFB8d0r9+SaRnj0Q==",
2624 | "dev": true,
2625 | "license": "MIT",
2626 | "dependencies": {
2627 | "@parcel/config-default": "2.11.0",
2628 | "@parcel/core": "2.11.0",
2629 | "@parcel/diagnostic": "2.11.0",
2630 | "@parcel/events": "2.11.0",
2631 | "@parcel/fs": "2.11.0",
2632 | "@parcel/logger": "2.11.0",
2633 | "@parcel/package-manager": "2.11.0",
2634 | "@parcel/reporter-cli": "2.11.0",
2635 | "@parcel/reporter-dev-server": "2.11.0",
2636 | "@parcel/reporter-tracer": "2.11.0",
2637 | "@parcel/utils": "2.11.0",
2638 | "chalk": "^4.1.0",
2639 | "commander": "^7.0.0",
2640 | "get-port": "^4.2.0"
2641 | },
2642 | "bin": {
2643 | "parcel": "lib/bin.js"
2644 | },
2645 | "engines": {
2646 | "node": ">= 12.0.0"
2647 | },
2648 | "funding": {
2649 | "type": "opencollective",
2650 | "url": "https://opencollective.com/parcel"
2651 | }
2652 | },
2653 | "node_modules/parent-module": {
2654 | "version": "1.0.1",
2655 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
2656 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
2657 | "dev": true,
2658 | "license": "MIT",
2659 | "dependencies": {
2660 | "callsites": "^3.0.0"
2661 | },
2662 | "engines": {
2663 | "node": ">=6"
2664 | }
2665 | },
2666 | "node_modules/parse-json": {
2667 | "version": "5.2.0",
2668 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
2669 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
2670 | "dev": true,
2671 | "license": "MIT",
2672 | "dependencies": {
2673 | "@babel/code-frame": "^7.0.0",
2674 | "error-ex": "^1.3.1",
2675 | "json-parse-even-better-errors": "^2.3.0",
2676 | "lines-and-columns": "^1.1.6"
2677 | },
2678 | "engines": {
2679 | "node": ">=8"
2680 | },
2681 | "funding": {
2682 | "url": "https://github.com/sponsors/sindresorhus"
2683 | }
2684 | },
2685 | "node_modules/path": {
2686 | "version": "0.12.7",
2687 | "resolved": "https://registry.npmjs.org/path/-/path-0.12.7.tgz",
2688 | "integrity": "sha512-aXXC6s+1w7otVF9UletFkFcDsJeO7lSZBPUQhtb5O0xJe8LtYhj/GxldoL09bBj9+ZmE2hNoHqQSFMN5fikh4Q==",
2689 | "license": "MIT",
2690 | "dependencies": {
2691 | "process": "^0.11.1",
2692 | "util": "^0.10.3"
2693 | }
2694 | },
2695 | "node_modules/path-browserify": {
2696 | "version": "1.0.1",
2697 | "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-1.0.1.tgz",
2698 | "integrity": "sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==",
2699 | "dev": true,
2700 | "license": "MIT"
2701 | },
2702 | "node_modules/path-type": {
2703 | "version": "4.0.0",
2704 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
2705 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
2706 | "dev": true,
2707 | "license": "MIT",
2708 | "engines": {
2709 | "node": ">=8"
2710 | }
2711 | },
2712 | "node_modules/picocolors": {
2713 | "version": "1.0.0",
2714 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz",
2715 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==",
2716 | "dev": true,
2717 | "license": "ISC"
2718 | },
2719 | "node_modules/picomatch": {
2720 | "version": "2.3.1",
2721 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
2722 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
2723 | "dev": true,
2724 | "license": "MIT",
2725 | "engines": {
2726 | "node": ">=8.6"
2727 | },
2728 | "funding": {
2729 | "url": "https://github.com/sponsors/jonschlinkert"
2730 | }
2731 | },
2732 | "node_modules/postcss-value-parser": {
2733 | "version": "4.2.0",
2734 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz",
2735 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==",
2736 | "dev": true,
2737 | "license": "MIT"
2738 | },
2739 | "node_modules/posthtml": {
2740 | "version": "0.16.6",
2741 | "resolved": "https://registry.npmjs.org/posthtml/-/posthtml-0.16.6.tgz",
2742 | "integrity": "sha512-JcEmHlyLK/o0uGAlj65vgg+7LIms0xKXe60lcDOTU7oVX/3LuEuLwrQpW3VJ7de5TaFKiW4kWkaIpJL42FEgxQ==",
2743 | "dev": true,
2744 | "license": "MIT",
2745 | "dependencies": {
2746 | "posthtml-parser": "^0.11.0",
2747 | "posthtml-render": "^3.0.0"
2748 | },
2749 | "engines": {
2750 | "node": ">=12.0.0"
2751 | }
2752 | },
2753 | "node_modules/posthtml-parser": {
2754 | "version": "0.10.2",
2755 | "resolved": "https://registry.npmjs.org/posthtml-parser/-/posthtml-parser-0.10.2.tgz",
2756 | "integrity": "sha512-PId6zZ/2lyJi9LiKfe+i2xv57oEjJgWbsHGGANwos5AvdQp98i6AtamAl8gzSVFGfQ43Glb5D614cvZf012VKg==",
2757 | "dev": true,
2758 | "license": "MIT",
2759 | "dependencies": {
2760 | "htmlparser2": "^7.1.1"
2761 | },
2762 | "engines": {
2763 | "node": ">=12"
2764 | }
2765 | },
2766 | "node_modules/posthtml-render": {
2767 | "version": "3.0.0",
2768 | "resolved": "https://registry.npmjs.org/posthtml-render/-/posthtml-render-3.0.0.tgz",
2769 | "integrity": "sha512-z+16RoxK3fUPgwaIgH9NGnK1HKY9XIDpydky5eQGgAFVXTCSezalv9U2jQuNV+Z9qV1fDWNzldcw4eK0SSbqKA==",
2770 | "dev": true,
2771 | "license": "MIT",
2772 | "dependencies": {
2773 | "is-json": "^2.0.1"
2774 | },
2775 | "engines": {
2776 | "node": ">=12"
2777 | }
2778 | },
2779 | "node_modules/posthtml/node_modules/posthtml-parser": {
2780 | "version": "0.11.0",
2781 | "resolved": "https://registry.npmjs.org/posthtml-parser/-/posthtml-parser-0.11.0.tgz",
2782 | "integrity": "sha512-QecJtfLekJbWVo/dMAA+OSwY79wpRmbqS5TeXvXSX+f0c6pW4/SE6inzZ2qkU7oAMCPqIDkZDvd/bQsSFUnKyw==",
2783 | "dev": true,
2784 | "license": "MIT",
2785 | "dependencies": {
2786 | "htmlparser2": "^7.1.1"
2787 | },
2788 | "engines": {
2789 | "node": ">=12"
2790 | }
2791 | },
2792 | "node_modules/process": {
2793 | "version": "0.11.10",
2794 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz",
2795 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=",
2796 | "license": "MIT",
2797 | "engines": {
2798 | "node": ">= 0.6.0"
2799 | }
2800 | },
2801 | "node_modules/react-error-overlay": {
2802 | "version": "6.0.9",
2803 | "resolved": "https://registry.npmjs.org/react-error-overlay/-/react-error-overlay-6.0.9.tgz",
2804 | "integrity": "sha512-nQTTcUu+ATDbrSD1BZHr5kgSD4oF8OFjxun8uAaL8RwPBacGBNPf/yAuVVdx17N8XNzRDMrZ9XcKZHCjPW+9ew==",
2805 | "dev": true,
2806 | "license": "MIT"
2807 | },
2808 | "node_modules/react-refresh": {
2809 | "version": "0.9.0",
2810 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.9.0.tgz",
2811 | "integrity": "sha512-Gvzk7OZpiqKSkxsQvO/mbTN1poglhmAV7gR/DdIrRrSMXraRQQlfikRJOr3Nb9GTMPC5kof948Zy6jJZIFtDvQ==",
2812 | "dev": true,
2813 | "license": "MIT",
2814 | "engines": {
2815 | "node": ">=0.10.0"
2816 | }
2817 | },
2818 | "node_modules/regenerator-runtime": {
2819 | "version": "0.13.9",
2820 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz",
2821 | "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==",
2822 | "dev": true,
2823 | "license": "MIT"
2824 | },
2825 | "node_modules/resolve-from": {
2826 | "version": "4.0.0",
2827 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
2828 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
2829 | "dev": true,
2830 | "license": "MIT",
2831 | "engines": {
2832 | "node": ">=4"
2833 | }
2834 | },
2835 | "node_modules/safe-buffer": {
2836 | "version": "5.2.1",
2837 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
2838 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
2839 | "dev": true,
2840 | "funding": [
2841 | {
2842 | "type": "github",
2843 | "url": "https://github.com/sponsors/feross"
2844 | },
2845 | {
2846 | "type": "patreon",
2847 | "url": "https://www.patreon.com/feross"
2848 | },
2849 | {
2850 | "type": "consulting",
2851 | "url": "https://feross.org/support"
2852 | }
2853 | ],
2854 | "license": "MIT"
2855 | },
2856 | "node_modules/semver": {
2857 | "version": "7.5.4",
2858 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz",
2859 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==",
2860 | "dev": true,
2861 | "license": "ISC",
2862 | "dependencies": {
2863 | "lru-cache": "^6.0.0"
2864 | },
2865 | "bin": {
2866 | "semver": "bin/semver.js"
2867 | },
2868 | "engines": {
2869 | "node": ">=10"
2870 | }
2871 | },
2872 | "node_modules/snake-case": {
2873 | "version": "3.0.4",
2874 | "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz",
2875 | "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==",
2876 | "license": "MIT",
2877 | "dependencies": {
2878 | "dot-case": "^3.0.4",
2879 | "tslib": "^2.0.3"
2880 | }
2881 | },
2882 | "node_modules/source-map": {
2883 | "version": "0.6.1",
2884 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
2885 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
2886 | "dev": true,
2887 | "license": "BSD-3-Clause",
2888 | "engines": {
2889 | "node": ">=0.10.0"
2890 | }
2891 | },
2892 | "node_modules/srcset": {
2893 | "version": "5.0.1",
2894 | "resolved": "https://registry.npmjs.org/srcset/-/srcset-5.0.1.tgz",
2895 | "integrity": "sha512-/P1UYbGfJVlxZag7aABNRrulEXAwCSDo7fklafOQrantuPTDmYgijJMks2zusPCVzgW9+4P69mq7w6pYuZpgxw==",
2896 | "dev": true,
2897 | "optional": true,
2898 | "peer": true,
2899 | "engines": {
2900 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0"
2901 | },
2902 | "funding": {
2903 | "url": "https://github.com/sponsors/sindresorhus"
2904 | }
2905 | },
2906 | "node_modules/stable": {
2907 | "version": "0.1.8",
2908 | "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz",
2909 | "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==",
2910 | "dev": true,
2911 | "license": "MIT"
2912 | },
2913 | "node_modules/string-width": {
2914 | "version": "4.2.3",
2915 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
2916 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
2917 | "dev": true,
2918 | "license": "MIT",
2919 | "dependencies": {
2920 | "emoji-regex": "^8.0.0",
2921 | "is-fullwidth-code-point": "^3.0.0",
2922 | "strip-ansi": "^6.0.1"
2923 | },
2924 | "engines": {
2925 | "node": ">=8"
2926 | }
2927 | },
2928 | "node_modules/strip-ansi": {
2929 | "version": "6.0.1",
2930 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
2931 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
2932 | "dev": true,
2933 | "license": "MIT",
2934 | "dependencies": {
2935 | "ansi-regex": "^5.0.1"
2936 | },
2937 | "engines": {
2938 | "node": ">=8"
2939 | }
2940 | },
2941 | "node_modules/supports-color": {
2942 | "version": "7.2.0",
2943 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
2944 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
2945 | "dev": true,
2946 | "license": "MIT",
2947 | "dependencies": {
2948 | "has-flag": "^4.0.0"
2949 | },
2950 | "engines": {
2951 | "node": ">=8"
2952 | }
2953 | },
2954 | "node_modules/svgo": {
2955 | "version": "2.8.0",
2956 | "resolved": "https://registry.npmjs.org/svgo/-/svgo-2.8.0.tgz",
2957 | "integrity": "sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg==",
2958 | "dev": true,
2959 | "license": "MIT",
2960 | "dependencies": {
2961 | "@trysound/sax": "0.2.0",
2962 | "commander": "^7.2.0",
2963 | "css-select": "^4.1.3",
2964 | "css-tree": "^1.1.3",
2965 | "csso": "^4.2.0",
2966 | "picocolors": "^1.0.0",
2967 | "stable": "^0.1.8"
2968 | },
2969 | "bin": {
2970 | "svgo": "bin/svgo"
2971 | },
2972 | "engines": {
2973 | "node": ">=10.13.0"
2974 | }
2975 | },
2976 | "node_modules/term-size": {
2977 | "version": "2.2.1",
2978 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz",
2979 | "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==",
2980 | "dev": true,
2981 | "license": "MIT",
2982 | "engines": {
2983 | "node": ">=8"
2984 | },
2985 | "funding": {
2986 | "url": "https://github.com/sponsors/sindresorhus"
2987 | }
2988 | },
2989 | "node_modules/timsort": {
2990 | "version": "0.3.0",
2991 | "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz",
2992 | "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=",
2993 | "dev": true,
2994 | "license": "MIT"
2995 | },
2996 | "node_modules/to-regex-range": {
2997 | "version": "5.0.1",
2998 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
2999 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
3000 | "dev": true,
3001 | "license": "MIT",
3002 | "dependencies": {
3003 | "is-number": "^7.0.0"
3004 | },
3005 | "engines": {
3006 | "node": ">=8.0"
3007 | }
3008 | },
3009 | "node_modules/tslib": {
3010 | "version": "2.3.0",
3011 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.0.tgz",
3012 | "integrity": "sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg==",
3013 | "license": "0BSD"
3014 | },
3015 | "node_modules/type-fest": {
3016 | "version": "0.20.2",
3017 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz",
3018 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==",
3019 | "dev": true,
3020 | "license": "(MIT OR CC0-1.0)",
3021 | "engines": {
3022 | "node": ">=10"
3023 | },
3024 | "funding": {
3025 | "url": "https://github.com/sponsors/sindresorhus"
3026 | }
3027 | },
3028 | "node_modules/util": {
3029 | "version": "0.10.4",
3030 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz",
3031 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==",
3032 | "license": "MIT",
3033 | "dependencies": {
3034 | "inherits": "2.0.3"
3035 | }
3036 | },
3037 | "node_modules/utility-types": {
3038 | "version": "3.10.0",
3039 | "resolved": "https://registry.npmjs.org/utility-types/-/utility-types-3.10.0.tgz",
3040 | "integrity": "sha512-O11mqxmi7wMKCo6HKFt5AhO4BwY3VV68YU07tgxfz8zJTIxr4BpsezN49Ffwy9j3ZpwwJp4fkRwjRzq3uWE6Rg==",
3041 | "dev": true,
3042 | "license": "MIT",
3043 | "engines": {
3044 | "node": ">= 4"
3045 | }
3046 | },
3047 | "node_modules/weak-lru-cache": {
3048 | "version": "1.2.2",
3049 | "resolved": "https://registry.npmjs.org/weak-lru-cache/-/weak-lru-cache-1.2.2.tgz",
3050 | "integrity": "sha512-DEAoo25RfSYMuTGc9vPJzZcZullwIqRDSI9LOy+fkCJPi6hykCnfKaXTuPBDuXAUcqHXyOgFtHNp/kB2FjYHbw==",
3051 | "dev": true,
3052 | "license": "MIT"
3053 | },
3054 | "node_modules/yallist": {
3055 | "version": "4.0.0",
3056 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz",
3057 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==",
3058 | "dev": true,
3059 | "license": "ISC"
3060 | },
3061 | "node_modules/yaml": {
3062 | "version": "1.10.2",
3063 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
3064 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
3065 | "dev": true,
3066 | "license": "ISC",
3067 | "engines": {
3068 | "node": ">= 6"
3069 | }
3070 | }
3071 | }
3072 | }
3073 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "logseq-koreader-sync",
3 | "version": "1.2.3",
4 | "title": "Logseq Koreader Sync",
5 | "description": "A koreader to logseq syncing plugin. Reference and read annotations in your notebook.",
6 | "main": "dist/index.html",
7 | "targets": {
8 | "main": false
9 | },
10 | "default": "dist/index.html",
11 | "repository": {
12 | "type": "git",
13 | "url": "https://github.com/isosphere/logseq-koreader-sync/tree/main/"
14 | },
15 | "author": "Matthew Scheffel",
16 | "scripts": {
17 | "dev": "parcel ./index.html --public-url ./",
18 | "build": "parcel build --public-url . --no-source-maps index.html"
19 | },
20 | "license": "MIT",
21 | "logseq": {
22 | "id": "_isosphere-koreader-sync",
23 | "title": "Logseq Koreader Sync",
24 | "icon": "./icon.png"
25 | },
26 | "dependencies": {
27 | "@logseq/libs": "^0.0.17",
28 | "idb-keyval": "^6.2.1",
29 | "luaparse": "^0.3.1"
30 | },
31 | "devDependencies": {
32 | "buffer": "^6.0.3",
33 | "parcel": "^2.11",
34 | "path-browserify": "^1.0.0"
35 | },
36 | "optionalDependencies": {
37 | "@parcel/watcher-linux-x64-glibc": "^2.4.0"
38 | }
39 | }
40 |
--------------------------------------------------------------------------------
/src/index.ts:
--------------------------------------------------------------------------------
1 | import '@logseq/libs'
2 | import { SettingSchemaDesc, BlockEntity, IBatchBlock, BlockUUID } from '@logseq/libs/dist/LSPlugin'
3 | import { parse as luaparse } from 'luaparse'
4 | import { ProgressNotification } from './progress'
5 | import { get as getStorage, set as setStorage } from 'idb-keyval';
6 |
7 | let settings: SettingSchemaDesc[] = []
8 |
9 | const delay = (t = 100) => new Promise(r => setTimeout(r, t))
10 |
11 | function truncateString(str, length) {
12 | if (!str) {
13 | return '';
14 | }
15 |
16 | if (str.length > length) {
17 | return str.slice(0, length);
18 | } else {
19 | return str;
20 | }
21 | }
22 |
23 | const MAXIMUM_DESCRIPTION_LENGTH = 250; // FIXME: this should be a setting
24 | const COLLAPSE_BLOCKS = true; // FIXME: this should be a setting
25 |
26 | /** This function is responsible for converting a KOReader metadata data structure into a Logseq block. */
27 | function metadata_to_block(metadata: any): IBatchBlock | null {
28 | let bookmarks: IBatchBlock[] = [];
29 |
30 | if (metadata.doc_props === 'object' && Object.keys(metadata.doc_props).length === 0) {
31 | return null;
32 | }
33 |
34 | if (typeof metadata.bookmarks === 'object' && Object.keys(metadata.bookmarks).length === 0) {
35 | return null;
36 | }
37 |
38 | let authors = metadata.doc_props.authors;
39 | if (authors) {
40 | authors = authors.replace(/\\\n/g, ', '); // this seems to be how KOReader stores multiple authors; at least from Calibre
41 | }
42 |
43 | if (!metadata.bookmarks) {
44 | return {
45 | content: `## ${metadata.doc_props.title}`,
46 | properties: {
47 | 'authors': authors,
48 | 'description': truncateString(metadata.doc_props.description, MAXIMUM_DESCRIPTION_LENGTH),
49 | 'language': metadata.doc_props.language,
50 | }
51 | }
52 | }
53 |
54 | for (const bookmark of metadata.bookmarks) {
55 | let personal_note: IBatchBlock[] = [];
56 | if (bookmark.text) {
57 | personal_note.push({
58 | content: bookmark.text,
59 | });
60 | }
61 |
62 | bookmarks.push(
63 | {
64 | content: `> ${bookmark.notes.replace('-', '\\-')}`, // escape dashes; they're used for lists in logseq
65 | properties: {
66 | 'datetime': bookmark.datetime,
67 | 'page': bookmark.page,
68 | 'chapter': bookmark.chapter,
69 | 'collapsed': COLLAPSE_BLOCKS && personal_note.length > 0,
70 | },
71 | children: personal_note
72 | }
73 | )
74 | }
75 |
76 | return {
77 | content: `## ${metadata.doc_props.title}`,
78 | properties: {
79 | 'authors': authors,
80 | 'description': truncateString(metadata.doc_props.description, MAXIMUM_DESCRIPTION_LENGTH),
81 | 'language': metadata.doc_props.language,
82 | 'collapsed': COLLAPSE_BLOCKS,
83 | },
84 | children: [
85 | {
86 | content: `### Bookmarks`,
87 | children: bookmarks
88 | }
89 | ]
90 | }
91 | }
92 |
93 | /** Uses luaparse to read a lua file and builds a metadata data structure to pass off to `metadata_to_block` */
94 | function lua_to_block(text: string): IBatchBlock | null {
95 | const ast = luaparse(text, {
96 | comments: false,
97 | locations: false,
98 | ranges: false,
99 | luaVersion: 'LuaJIT'
100 | });
101 |
102 | var metadata = {};
103 |
104 | for (const field in (ast.body[0] as any).arguments[0].fields) {
105 | const target = (ast.body[0] as any).arguments[0].fields[field]
106 | const key = target.key.raw.replace(/"/g, '');
107 |
108 | // it's easier to skip some fields
109 | if (key === "stats") {
110 | continue;
111 | }
112 |
113 | if (target.value.type === "TableConstructorExpression") {
114 | if (target.value.fields[0] && target.value.fields[0].value.type === "TableConstructorExpression") {
115 | metadata[key] = [];
116 | } else {
117 | metadata[key] = {};
118 | }
119 |
120 | for (const subfield in target.value.fields) {
121 | const subtarget = target.value.fields[subfield];
122 | if (subtarget.value.type === "TableConstructorExpression") {
123 | const sub_dictionary = {};
124 |
125 | for (const subsubfield in subtarget.value.fields) {
126 | const subsubtarget = subtarget.value.fields[subsubfield];
127 | const subkey = subsubtarget.key.raw.replace(/"/g, '');
128 | sub_dictionary[subkey] = subsubtarget.value.raw?.replace(/"/g, '');
129 | }
130 | metadata[key].push(sub_dictionary);
131 | } else {
132 | metadata[key][subtarget.key.raw.replace(/"/g, '')] = subtarget.value.raw?.replace(/"/g, '');
133 | }
134 | }
135 | } else {
136 | metadata[key] = target.value.raw?.replace(/"/g, '');
137 | }
138 | }
139 |
140 | return metadata_to_block(metadata);
141 | }
142 |
143 |
144 | /** Used to find all of the KOReader metadata files in a directory and its subdirectories */
145 | async function* walkDirectory(directoryHandle: any) { // DirectoryHandle
146 | if (directoryHandle.kind === "file") {
147 | const file = await directoryHandle.getFile();
148 | if (file !== null && file.name.toLowerCase().endsWith('.lua') && file.name.toLowerCase().includes('metadata')) {
149 | yield file;
150 | }
151 | } else if (directoryHandle.kind === "directory") {
152 | for await (const handle of directoryHandle.values()) {
153 | yield* walkDirectory(handle);
154 | }
155 | }
156 | }
157 |
158 | // https://developer.chrome.com/docs/capabilities/web-apis/file-system-access#stored_file_or_directory_handles_and_permissions
159 | async function verifyPermission(fileHandle) {
160 | // Check if permission was already granted. If so, return true.
161 | if ((await fileHandle.queryPermission({})) === 'granted') {
162 | return true;
163 | }
164 | // Request permission. If the user grants permission, return true.
165 | if ((await fileHandle.requestPermission({})) === 'granted') { // should work, won't work until Electron or logseq or something supports it
166 | return true;
167 | }
168 | // The user didn't grant permission, so return false.
169 | return false;
170 | }
171 |
172 | declare global {
173 | interface Window {
174 | showDirectoryPicker: any; // DirectoryHandle
175 | }
176 | }
177 |
178 | /**
179 | * main entry
180 | * @param baseInfo
181 | */
182 | function main () {
183 | let loading = false;
184 |
185 | logseq.useSettingsSchema(settings)
186 | logseq.provideModel({
187 | async syncKOReader () {
188 | const info = await logseq.App.getUserConfigs()
189 | if (loading) return
190 |
191 | const pageName = '_logseq-koreader-sync'
192 | const syncTimeLabel = (new Date()).toLocaleString() // date and time as of now
193 |
194 | logseq.App.pushState('page', { name: pageName })
195 |
196 | await delay(300) // wait for our UI elements to exist. FIXME: replace with check/sleep loop
197 |
198 | loading = true
199 |
200 | const currentPage = await logseq.Editor.getCurrentPage()
201 | if (currentPage?.originalName !== pageName) throw new Error('page error')
202 |
203 | const pageBlocksTree = await logseq.Editor.getCurrentPageBlocksTree()
204 |
205 | let targetBlock : BlockEntity | null = null;
206 | let warningBlockFound = false;
207 | for (const block of pageBlocksTree) {
208 | if (block?.content.includes("LKRS")) {
209 | targetBlock = block;
210 | continue;
211 | }
212 | else if (block?.content.includes("BEGIN_WARNING")) {
213 | warningBlockFound = true;
214 | }
215 | }
216 |
217 | if (!warningBlockFound) {
218 | await logseq.Editor.insertBatchBlock(currentPage.uuid, [{ content: "\n#+BEGIN_WARNING\nPlease do not edit this page; stick to block references made elsewhere.\n#+END_WARNING" }], { sibling: false})
219 | }
220 |
221 | const original_content = targetBlock?.content;
222 | if (targetBlock === null || targetBlock === undefined) {
223 | targetBlock = await logseq.Editor.insertBlock(currentPage.uuid, '🚀 LKRS: Please Select KOReader Metadata Directory ...',)
224 | } else {
225 | await logseq.Editor.updateBlock(targetBlock!.uuid, `🚀 LKRS: Please Select KOReader Metadata Directory ...`)
226 | }
227 |
228 | let directoryHandle : any = await getStorage('logseq_koreader_sync__directoryHandle');
229 |
230 | let permission;
231 | if (directoryHandle) {
232 | permission = await verifyPermission(directoryHandle);
233 | }
234 |
235 | if (!directoryHandle || !permission) {
236 | try {
237 | directoryHandle = await window.showDirectoryPicker() // get a DirectoryHandle that will allow us to read the contents of the directory
238 | } catch (e) {
239 | if (original_content) {
240 | await logseq.Editor.updateBlock(targetBlock!.uuid, original_content)
241 | } else {
242 | await logseq.Editor.updateBlock(targetBlock!.uuid, "# ❌ LKRS: Sync cancelled by user.")
243 | }
244 | console.error(e);
245 | return;
246 | }
247 | setStorage('logseq_koreader_sync__directoryHandle', directoryHandle);
248 | }
249 |
250 | if (!directoryHandle) {
251 | console.error('No directory selected / found.')
252 | return; // something went wrong
253 | }
254 |
255 | await logseq.Editor.updateBlock(targetBlock!.uuid, `# ⚙ LKRS: Processing KOReader Annotations ...`)
256 |
257 | // FIXME: change the max value to the number of files in the directory
258 | let fileCount = 0;
259 | for await (const _ of walkDirectory(directoryHandle)) { fileCount++; };
260 |
261 | // iterate over all blocks in this target page, and collect the titles, authors, and uuids and place them in a dictionary
262 | let ret;
263 | try {
264 | ret = await logseq.DB.datascriptQuery(`
265 | [
266 | :find (pull ?b [:block/content :block/uuid]) ?authors
267 | :where
268 | [?b :block/parent ?p]
269 | [?p :block/uuid #uuid "${targetBlock!.uuid}"]
270 | [?b :block/properties ?props]
271 | [(get ?props :authors) ?authors]
272 | ]
273 | `)
274 | } catch (e) {
275 | console.error("Error while iterating over blocks in the target page: ", e);
276 | return;
277 | }
278 |
279 | const titleMatch : RegExp = /##\s+(.*?)\n/;
280 |
281 | let existingBlocks = {}
282 | for (const block of ret) {
283 | const authors = block[1];
284 | const content = block[0]["content"];
285 | const match = content?.match(titleMatch);
286 | let title = match[1];
287 |
288 | const key = authors + "___" + title;
289 | if (!(key in existingBlocks)) {
290 | let block_uuid = block[0]["uuid"];
291 | if (block_uuid) {
292 | existingBlocks[key] = block_uuid;
293 | }
294 | }
295 | }
296 |
297 | const syncProgress = new ProgressNotification("Syncing Koreader Annotations to Logseq:", fileCount);
298 | for await (const fileHandle of walkDirectory(directoryHandle)) {
299 | var text = await fileHandle.text();
300 | var parsed_block = lua_to_block(text);
301 |
302 | if (parsed_block) {
303 | let key: string;
304 | if (parsed_block.properties!.authors === undefined) {
305 | key = "___" + parsed_block.content.substring(3);
306 | } else {
307 | key = parsed_block.properties!.authors + "___" + parsed_block.content.substring(3);
308 | }
309 |
310 | // Has this been synced before?
311 | if (key in existingBlocks) {
312 | const existing_block = await logseq.Editor.getBlock(existingBlocks[key]);
313 | if (existing_block === null) {
314 | console.error("Block not found, but we also just found it - which is pretty weird: ", existingBlocks[key]);
315 | continue;
316 | }
317 |
318 | // find the bookmarks block
319 | let existing_bookmark_blocks;
320 | let existing_bookmark_block_uuid;
321 |
322 | for (const child of existing_block!.children!) {
323 | let child_block = await logseq.Editor.getBlock(child[1] as BlockEntity);
324 |
325 | if (child_block!.content === "### Bookmarks") {
326 | existing_bookmark_blocks = child_block!.children;
327 | existing_bookmark_block_uuid = child[1];
328 |
329 | break;
330 | }
331 | }
332 |
333 | if (existing_bookmark_blocks === undefined) {
334 | console.error("Bookmarks not found for block ", existingBlocks[key]);
335 | continue;
336 | }
337 |
338 | // iterate over bookmarks and build a dictionary for easy lookup
339 | let existing_bookmarks = {};
340 | for (const bookmark of existing_bookmark_blocks) {
341 | let bookmark_block = await logseq.Editor.getBlock(bookmark[1] as BlockEntity);
342 |
343 | const content_start = bookmark_block!.content!.indexOf("\n> "); // not ideal
344 | const content = bookmark_block!.content!.substring(content_start+3).replace('-', '\-');
345 |
346 | existing_bookmarks[content] = bookmark[1];
347 | }
348 |
349 | // iterate over bookmarks in `block`, checking if they already exist
350 | // the first child of `parsed_block` is the "### Bookmarks" block
351 | for (const bookmark of parsed_block.children![0].children!) {
352 | let key = bookmark.content.substring(2);
353 |
354 | // does this parsed block have a personal note?
355 | let parsed_personal_note = false;
356 | if (bookmark.children && bookmark.children.length > 0) {
357 | parsed_personal_note = true;
358 | }
359 |
360 | // existing bookmark, check personal note
361 | if (key in existing_bookmarks) {
362 | let existing_bookmark = await logseq.Editor.getBlock(existing_bookmarks[key]);
363 |
364 | // personal note exists in graph
365 | if (existing_bookmark!.children && existing_bookmark!.children!.length > 0) {
366 | let existing_note = existing_bookmark!.children![0];
367 |
368 | if (!parsed_personal_note) {
369 | // delete it
370 | await logseq.Editor.removeBlock(existing_note[1] as BlockUUID);
371 | } else {
372 | let existing_note_block = await logseq.Editor.getBlock(existing_note[1] as BlockEntity);
373 |
374 | // if the existing note is different, update it
375 | if (existing_note_block!.content !== bookmark.children![0].content) {
376 | await logseq.Editor.updateBlock(existing_note[1] as string, bookmark.children![0].content);
377 | }
378 | }
379 | }
380 | // personal note does not exist in graph
381 | else {
382 | // add it
383 | if (parsed_personal_note) {
384 | await logseq.Editor.insertBatchBlock(existing_bookmark!.uuid, [bookmark.children![0]], {
385 | sibling: false
386 | })
387 | }
388 | }
389 | }
390 | // new bookmark, add it
391 | else {
392 | await logseq.Editor.insertBatchBlock(existing_bookmark_block_uuid, [bookmark], {
393 | sibling: false
394 | })
395 | }
396 | }
397 | } else {
398 | await logseq.Editor.insertBatchBlock(targetBlock!.uuid, [parsed_block], {
399 | sibling: false
400 | })
401 | }
402 | }
403 | syncProgress.increment(1);
404 | }
405 |
406 | await logseq.Editor.updateBlock(targetBlock!.uuid, `# 📚 LKRS: KOReader - Sync Initiated at ${syncTimeLabel}`)
407 |
408 | syncProgress.destruct();
409 | loading = false
410 | }
411 | })
412 |
413 | logseq.App.registerUIItem('toolbar', {
414 | key: 'koreader-sync',
415 | template: `
416 |
417 |
418 |
419 | `
420 | })
421 | }
422 |
423 | // bootstrap
424 | logseq.ready(main).catch(console.error)
--------------------------------------------------------------------------------
/src/progress.ts:
--------------------------------------------------------------------------------
1 | export class ProgressNotification {
2 | max: number;
3 | current: number;
4 | progressBar: HTMLElement | null;
5 |
6 | constructor(msg: string, max: number) {
7 | this.max = max;
8 | this.current = 0;
9 | logseq.provideUI({
10 | key: `logseq-koreader-sync-progress-notification-${logseq.baseInfo.id}`,
11 | path: "div.notifications",
12 | template: `
13 |
32 | `,
33 | });
34 | logseq.provideStyle(`
35 | #logseq-koreader-sync-progress-bar-${logseq.baseInfo.id}::-webkit-progress-bar {
36 | border-radius: 7px;
37 | }
38 | #logseq-koreader-sync-progress-bar-${logseq.baseInfo.id}::-webkit-progress-value {
39 | border-radius: 7px;
40 | background-color: var(--ls-link-text-color,#045591);
41 | }
42 | `);
43 | }
44 |
45 | increment(amount = 1) {
46 | this.current += amount;
47 | try {
48 | if (this.progressBar == null) {
49 | this.progressBar = window.parent.document.getElementById(
50 | `logseq-koreader-sync-progress-bar-${logseq.baseInfo.id}`,
51 | );
52 | }
53 | if (this.progressBar === null) {
54 | console.error("Progress bar not found");
55 | return;
56 | }
57 |
58 | this.progressBar.setAttribute("value", `${this.current}`);
59 | } catch (e) {}
60 | }
61 |
62 | destruct() {
63 | logseq.provideUI({
64 | key: `logseq-koreader-sync-progress-notification-${logseq.baseInfo.id}`,
65 | template: ``,
66 | });
67 | this.progressBar = null;
68 | }
69 | }
--------------------------------------------------------------------------------