├── .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 | ![demo animation](demo.gif) 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 |
14 |
15 |
16 |
17 |
18 |
19 |
${msg} 20 | 23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
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 | } --------------------------------------------------------------------------------