├── .eslintignore ├── .eslintrc.json ├── .gitignore ├── .husky ├── commit-msg └── pre-commit ├── .prettierrc.json ├── LICENSE ├── README.MD ├── __mocks__ └── zustand.ts ├── commitlint.config.js ├── docs ├── badge-branches.svg ├── badge-functions.svg ├── badge-lines.svg ├── badge-statements.svg ├── tron1.png └── tron2.png ├── example ├── .eslintrc.cjs ├── .gitignore ├── README.md ├── index.html ├── package-lock.json ├── package.json ├── public │ └── vite.svg ├── src │ ├── App.tsx │ ├── Reactotron.ts │ ├── main.tsx │ ├── store │ │ ├── useCounter.ts │ │ └── useOtherCounter.ts │ └── vite-env.d.ts ├── tsconfig.json ├── tsconfig.node.json └── vite.config.ts ├── index.js ├── lint-staged.config.js ├── package-lock.json ├── package.json ├── src ├── index.ts ├── test │ ├── index.spec.ts │ └── utils.spec.ts ├── types.ts └── utils.ts ├── tsconfig.json ├── tsup.config.ts └── vitest.config.ts /.eslintignore: -------------------------------------------------------------------------------- 1 | example/ -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "env": { 3 | "es2021": true, 4 | "node": true 5 | }, 6 | "extends": ["standard-with-typescript", "prettier"], 7 | "overrides": [], 8 | "parserOptions": { 9 | "ecmaVersion": "latest", 10 | "sourceType": "module", 11 | "project": "./tsconfig.json" 12 | }, 13 | "root": true, 14 | "rules": { 15 | "@typescript-eslint/explicit-function-return-type": "off", 16 | "@typescript-eslint/consistent-type-assertions": "off", 17 | "@typescript-eslint/strict-boolean-expressions": "off", 18 | "no-prototype-builtins": "off" 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | coverage/ 3 | dist/ -------------------------------------------------------------------------------- /.husky/commit-msg: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env sh 2 | . "$(dirname -- "$0")/_/husky.sh" 3 | 4 | npx --no -- commitlint --edit "$1" 5 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env sh 2 | . "$(dirname -- "$0")/_/husky.sh" 3 | 4 | npx lint-staged && npm run check-types 5 | -------------------------------------------------------------------------------- /.prettierrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "semi": true, 3 | "singleQuote": true, 4 | "trailingComma": "none" 5 | } 6 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2023 Joalison Pereira (https://joalisonpereira.dev) 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 13 | all 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 21 | THE SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.MD: -------------------------------------------------------------------------------- 1 | # reactotron-plugin-zustand 2 | 3 | Plugin to monitor states from zustand. 4 | 5 | ![](./docs/badge-statements.svg) ![](./docs/badge-functions.svg) ![](./docs/badge-lines.svg) ![](./docs/badge-branches.svg) 6 | 7 | ## Install 8 | 9 | ```bash 10 | npm i -D reactotron-plugin-zustand 11 | ``` 12 | 13 | ## Setup 14 | 15 | Go to file "Reactotron.config.ts" or your config reactotron from project, is similar to this file: 16 | 17 | ```ts 18 | import Reactotron from 'reactotron-react-js'; 19 | import reactotronZustand from 'reactotron-plugin-zustand'; 20 | 21 | Reactotron.configure({ name: 'Project name' }) 22 | .use( 23 | //add this line 🙌 24 | reactotronZustand({ 25 | stores: [{ name: 'auth', store: useAuth }], 26 | omitFunctionKeys: true 27 | }) 28 | ) 29 | .connect(); 30 | ``` 31 | 32 | | Option | Description | Default | 33 | | ------------------ | ---------------------------------------------------------------- | ------- | 34 | | `stores` | List of stores to be monitored by the Reactotron Zustand plugin. | | 35 | | `stores[].name` | Name of the store to be monitored. | | 36 | | `stores[].store` | Reference to the store hook to be monitored. | | 37 | | `omitFunctionKeys` | Omit state functions | false | 38 | 39 | ## Usage 40 | 41 | Install [Reactotron Client](https://github.com/infinitered/reactotron/tree/master) and add your store observer, using the example `"auth"` or all states using: `"*"`. 42 | 43 | Captura de Tela 2023-06-23 às 00 09 08 44 | -------------------------------------------------------------------------------- /__mocks__/zustand.ts: -------------------------------------------------------------------------------- 1 | import type * as zustand from 'zustand'; 2 | import { afterEach, vi } from 'vitest'; 3 | 4 | const { create: actualCreate, createStore: actualCreateStore } = 5 | await vi.importActual('zustand'); 6 | 7 | // a variable to hold reset functions for all stores declared in the app 8 | export const storeResetFns = new Set<() => void>(); 9 | 10 | // when creating a store, we get its initial state, create a reset function and add it in the set 11 | export const create = (() => { 12 | return (stateCreator: zustand.StateCreator) => { 13 | const store = actualCreate(stateCreator); 14 | 15 | const initialState = store.getState(); 16 | 17 | storeResetFns.add(() => { 18 | store.setState(initialState, true); 19 | }); 20 | 21 | return store; 22 | }; 23 | }) as typeof zustand.create; 24 | 25 | // when creating a store, we get its initial state, create a reset function and add it in the set 26 | export const createStore = ((stateCreator: zustand.StateCreator) => { 27 | const store = actualCreateStore(stateCreator); 28 | 29 | const initialState = store.getState(); 30 | 31 | storeResetFns.add(() => { 32 | store.setState(initialState, true); 33 | }); 34 | 35 | return store; 36 | }) as typeof zustand.createStore; 37 | 38 | // reset all stores after each test run 39 | afterEach(() => { 40 | storeResetFns.forEach((resetFn) => { 41 | resetFn(); 42 | }); 43 | }); 44 | -------------------------------------------------------------------------------- /commitlint.config.js: -------------------------------------------------------------------------------- 1 | const config = require("@commitlint/config-conventional"); 2 | 3 | module.exports = { 4 | extends: ["@commitlint/config-conventional"], 5 | rules: { 6 | ...config.rules, 7 | "type-enum": [2, "always", [...config.rules["type-enum"][2], "wip"]], 8 | }, 9 | prompt: { 10 | ...config.prompt, 11 | questions: { 12 | ...config.prompt.questions, 13 | type: { 14 | ...config.prompt.questions.type, 15 | enum: { 16 | ...config.prompt.questions.type.enum, 17 | wip: { 18 | description: "Working in progress", 19 | title: "Wip", 20 | emoji: "🚧", 21 | }, 22 | }, 23 | }, 24 | }, 25 | }, 26 | }; 27 | -------------------------------------------------------------------------------- /docs/badge-branches.svg: -------------------------------------------------------------------------------- 1 | Coverage:branches: 97.14%Coverage:branches97.14% -------------------------------------------------------------------------------- /docs/badge-functions.svg: -------------------------------------------------------------------------------- 1 | Coverage:functions: 100%Coverage:functions100% -------------------------------------------------------------------------------- /docs/badge-lines.svg: -------------------------------------------------------------------------------- 1 | Coverage:lines: 91.79%Coverage:lines91.79% -------------------------------------------------------------------------------- /docs/badge-statements.svg: -------------------------------------------------------------------------------- 1 | Coverage:statements: 91.79%Coverage:statements91.79% -------------------------------------------------------------------------------- /docs/tron1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/joalisonpereira/reactotron-plugin-zustand/5e416068b3b886614abcec3955c5c23e595c30a4/docs/tron1.png -------------------------------------------------------------------------------- /docs/tron2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/joalisonpereira/reactotron-plugin-zustand/5e416068b3b886614abcec3955c5c23e595c30a4/docs/tron2.png -------------------------------------------------------------------------------- /example/.eslintrc.cjs: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | env: { browser: true, es2020: true }, 4 | extends: [ 5 | 'eslint:recommended', 6 | 'plugin:@typescript-eslint/recommended', 7 | 'plugin:react-hooks/recommended' 8 | ], 9 | ignorePatterns: ['dist', '.eslintrc.cjs'], 10 | parser: '@typescript-eslint/parser', 11 | plugins: ['react-refresh'], 12 | rules: { 13 | 'react-refresh/only-export-components': [ 14 | 'warn', 15 | { allowConstantExport: true } 16 | ] 17 | } 18 | }; 19 | -------------------------------------------------------------------------------- /example/.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /example/README.md: -------------------------------------------------------------------------------- 1 | # React + TypeScript + Vite 2 | 3 | This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. 4 | 5 | Currently, two official plugins are available: 6 | 7 | - [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh 8 | - [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh 9 | 10 | ## Expanding the ESLint configuration 11 | 12 | If you are developing a production application, we recommend updating the configuration to enable type aware lint rules: 13 | 14 | - Configure the top-level `parserOptions` property like this: 15 | 16 | ```js 17 | export default { 18 | // other rules... 19 | parserOptions: { 20 | ecmaVersion: 'latest', 21 | sourceType: 'module', 22 | project: ['./tsconfig.json', './tsconfig.node.json'], 23 | tsconfigRootDir: __dirname, 24 | }, 25 | } 26 | ``` 27 | 28 | - Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked` 29 | - Optionally add `plugin:@typescript-eslint/stylistic-type-checked` 30 | - Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` & `plugin:react/jsx-runtime` to the `extends` list 31 | -------------------------------------------------------------------------------- /example/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Reactotron Zustand 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /example/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "example", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "react": "^18.2.0", 12 | "react-dom": "^18.2.0", 13 | "zustand": "^4.4.7" 14 | }, 15 | "devDependencies": { 16 | "@types/react": "^18.2.43", 17 | "@types/react-dom": "^18.2.17", 18 | "@typescript-eslint/eslint-plugin": "^6.14.0", 19 | "@typescript-eslint/parser": "^6.14.0", 20 | "@vitejs/plugin-react": "^4.2.1", 21 | "eslint": "^8.55.0", 22 | "eslint-plugin-react-hooks": "^4.6.0", 23 | "eslint-plugin-react-refresh": "^0.4.5", 24 | "reactotron-react-js": "^3.3.9", 25 | "typescript": "^5.2.2", 26 | "vite": "^5.0.8" 27 | } 28 | }, 29 | "node_modules/@aashutoshrathi/word-wrap": { 30 | "version": "1.2.6", 31 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 32 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 33 | "dev": true, 34 | "engines": { 35 | "node": ">=0.10.0" 36 | } 37 | }, 38 | "node_modules/@ampproject/remapping": { 39 | "version": "2.2.1", 40 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 41 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 42 | "dev": true, 43 | "dependencies": { 44 | "@jridgewell/gen-mapping": "^0.3.0", 45 | "@jridgewell/trace-mapping": "^0.3.9" 46 | }, 47 | "engines": { 48 | "node": ">=6.0.0" 49 | } 50 | }, 51 | "node_modules/@babel/code-frame": { 52 | "version": "7.23.5", 53 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 54 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 55 | "dev": true, 56 | "dependencies": { 57 | "@babel/highlight": "^7.23.4", 58 | "chalk": "^2.4.2" 59 | }, 60 | "engines": { 61 | "node": ">=6.9.0" 62 | } 63 | }, 64 | "node_modules/@babel/compat-data": { 65 | "version": "7.23.5", 66 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", 67 | "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", 68 | "dev": true, 69 | "engines": { 70 | "node": ">=6.9.0" 71 | } 72 | }, 73 | "node_modules/@babel/core": { 74 | "version": "7.23.7", 75 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.7.tgz", 76 | "integrity": "sha512-+UpDgowcmqe36d4NwqvKsyPMlOLNGMsfMmQ5WGCu+siCe3t3dfe9njrzGfdN4qq+bcNUt0+Vw6haRxBOycs4dw==", 77 | "dev": true, 78 | "dependencies": { 79 | "@ampproject/remapping": "^2.2.0", 80 | "@babel/code-frame": "^7.23.5", 81 | "@babel/generator": "^7.23.6", 82 | "@babel/helper-compilation-targets": "^7.23.6", 83 | "@babel/helper-module-transforms": "^7.23.3", 84 | "@babel/helpers": "^7.23.7", 85 | "@babel/parser": "^7.23.6", 86 | "@babel/template": "^7.22.15", 87 | "@babel/traverse": "^7.23.7", 88 | "@babel/types": "^7.23.6", 89 | "convert-source-map": "^2.0.0", 90 | "debug": "^4.1.0", 91 | "gensync": "^1.0.0-beta.2", 92 | "json5": "^2.2.3", 93 | "semver": "^6.3.1" 94 | }, 95 | "engines": { 96 | "node": ">=6.9.0" 97 | }, 98 | "funding": { 99 | "type": "opencollective", 100 | "url": "https://opencollective.com/babel" 101 | } 102 | }, 103 | "node_modules/@babel/core/node_modules/semver": { 104 | "version": "6.3.1", 105 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 106 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 107 | "dev": true, 108 | "bin": { 109 | "semver": "bin/semver.js" 110 | } 111 | }, 112 | "node_modules/@babel/generator": { 113 | "version": "7.23.6", 114 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", 115 | "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", 116 | "dev": true, 117 | "dependencies": { 118 | "@babel/types": "^7.23.6", 119 | "@jridgewell/gen-mapping": "^0.3.2", 120 | "@jridgewell/trace-mapping": "^0.3.17", 121 | "jsesc": "^2.5.1" 122 | }, 123 | "engines": { 124 | "node": ">=6.9.0" 125 | } 126 | }, 127 | "node_modules/@babel/helper-compilation-targets": { 128 | "version": "7.23.6", 129 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", 130 | "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", 131 | "dev": true, 132 | "dependencies": { 133 | "@babel/compat-data": "^7.23.5", 134 | "@babel/helper-validator-option": "^7.23.5", 135 | "browserslist": "^4.22.2", 136 | "lru-cache": "^5.1.1", 137 | "semver": "^6.3.1" 138 | }, 139 | "engines": { 140 | "node": ">=6.9.0" 141 | } 142 | }, 143 | "node_modules/@babel/helper-compilation-targets/node_modules/semver": { 144 | "version": "6.3.1", 145 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 146 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 147 | "dev": true, 148 | "bin": { 149 | "semver": "bin/semver.js" 150 | } 151 | }, 152 | "node_modules/@babel/helper-environment-visitor": { 153 | "version": "7.22.20", 154 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", 155 | "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", 156 | "dev": true, 157 | "engines": { 158 | "node": ">=6.9.0" 159 | } 160 | }, 161 | "node_modules/@babel/helper-function-name": { 162 | "version": "7.23.0", 163 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", 164 | "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", 165 | "dev": true, 166 | "dependencies": { 167 | "@babel/template": "^7.22.15", 168 | "@babel/types": "^7.23.0" 169 | }, 170 | "engines": { 171 | "node": ">=6.9.0" 172 | } 173 | }, 174 | "node_modules/@babel/helper-hoist-variables": { 175 | "version": "7.22.5", 176 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 177 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 178 | "dev": true, 179 | "dependencies": { 180 | "@babel/types": "^7.22.5" 181 | }, 182 | "engines": { 183 | "node": ">=6.9.0" 184 | } 185 | }, 186 | "node_modules/@babel/helper-module-imports": { 187 | "version": "7.22.15", 188 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", 189 | "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", 190 | "dev": true, 191 | "dependencies": { 192 | "@babel/types": "^7.22.15" 193 | }, 194 | "engines": { 195 | "node": ">=6.9.0" 196 | } 197 | }, 198 | "node_modules/@babel/helper-module-transforms": { 199 | "version": "7.23.3", 200 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz", 201 | "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==", 202 | "dev": true, 203 | "dependencies": { 204 | "@babel/helper-environment-visitor": "^7.22.20", 205 | "@babel/helper-module-imports": "^7.22.15", 206 | "@babel/helper-simple-access": "^7.22.5", 207 | "@babel/helper-split-export-declaration": "^7.22.6", 208 | "@babel/helper-validator-identifier": "^7.22.20" 209 | }, 210 | "engines": { 211 | "node": ">=6.9.0" 212 | }, 213 | "peerDependencies": { 214 | "@babel/core": "^7.0.0" 215 | } 216 | }, 217 | "node_modules/@babel/helper-plugin-utils": { 218 | "version": "7.22.5", 219 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", 220 | "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", 221 | "dev": true, 222 | "engines": { 223 | "node": ">=6.9.0" 224 | } 225 | }, 226 | "node_modules/@babel/helper-simple-access": { 227 | "version": "7.22.5", 228 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 229 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 230 | "dev": true, 231 | "dependencies": { 232 | "@babel/types": "^7.22.5" 233 | }, 234 | "engines": { 235 | "node": ">=6.9.0" 236 | } 237 | }, 238 | "node_modules/@babel/helper-split-export-declaration": { 239 | "version": "7.22.6", 240 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 241 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 242 | "dev": true, 243 | "dependencies": { 244 | "@babel/types": "^7.22.5" 245 | }, 246 | "engines": { 247 | "node": ">=6.9.0" 248 | } 249 | }, 250 | "node_modules/@babel/helper-string-parser": { 251 | "version": "7.23.4", 252 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", 253 | "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", 254 | "dev": true, 255 | "engines": { 256 | "node": ">=6.9.0" 257 | } 258 | }, 259 | "node_modules/@babel/helper-validator-identifier": { 260 | "version": "7.22.20", 261 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 262 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 263 | "dev": true, 264 | "engines": { 265 | "node": ">=6.9.0" 266 | } 267 | }, 268 | "node_modules/@babel/helper-validator-option": { 269 | "version": "7.23.5", 270 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz", 271 | "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==", 272 | "dev": true, 273 | "engines": { 274 | "node": ">=6.9.0" 275 | } 276 | }, 277 | "node_modules/@babel/helpers": { 278 | "version": "7.23.8", 279 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.8.tgz", 280 | "integrity": "sha512-KDqYz4PiOWvDFrdHLPhKtCThtIcKVy6avWD2oG4GEvyQ+XDZwHD4YQd+H2vNMnq2rkdxsDkU82T+Vk8U/WXHRQ==", 281 | "dev": true, 282 | "dependencies": { 283 | "@babel/template": "^7.22.15", 284 | "@babel/traverse": "^7.23.7", 285 | "@babel/types": "^7.23.6" 286 | }, 287 | "engines": { 288 | "node": ">=6.9.0" 289 | } 290 | }, 291 | "node_modules/@babel/highlight": { 292 | "version": "7.23.4", 293 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 294 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 295 | "dev": true, 296 | "dependencies": { 297 | "@babel/helper-validator-identifier": "^7.22.20", 298 | "chalk": "^2.4.2", 299 | "js-tokens": "^4.0.0" 300 | }, 301 | "engines": { 302 | "node": ">=6.9.0" 303 | } 304 | }, 305 | "node_modules/@babel/parser": { 306 | "version": "7.23.6", 307 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz", 308 | "integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==", 309 | "dev": true, 310 | "bin": { 311 | "parser": "bin/babel-parser.js" 312 | }, 313 | "engines": { 314 | "node": ">=6.0.0" 315 | } 316 | }, 317 | "node_modules/@babel/plugin-transform-react-jsx-self": { 318 | "version": "7.23.3", 319 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.23.3.tgz", 320 | "integrity": "sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==", 321 | "dev": true, 322 | "dependencies": { 323 | "@babel/helper-plugin-utils": "^7.22.5" 324 | }, 325 | "engines": { 326 | "node": ">=6.9.0" 327 | }, 328 | "peerDependencies": { 329 | "@babel/core": "^7.0.0-0" 330 | } 331 | }, 332 | "node_modules/@babel/plugin-transform-react-jsx-source": { 333 | "version": "7.23.3", 334 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.23.3.tgz", 335 | "integrity": "sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==", 336 | "dev": true, 337 | "dependencies": { 338 | "@babel/helper-plugin-utils": "^7.22.5" 339 | }, 340 | "engines": { 341 | "node": ">=6.9.0" 342 | }, 343 | "peerDependencies": { 344 | "@babel/core": "^7.0.0-0" 345 | } 346 | }, 347 | "node_modules/@babel/template": { 348 | "version": "7.22.15", 349 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", 350 | "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", 351 | "dev": true, 352 | "dependencies": { 353 | "@babel/code-frame": "^7.22.13", 354 | "@babel/parser": "^7.22.15", 355 | "@babel/types": "^7.22.15" 356 | }, 357 | "engines": { 358 | "node": ">=6.9.0" 359 | } 360 | }, 361 | "node_modules/@babel/traverse": { 362 | "version": "7.23.7", 363 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.7.tgz", 364 | "integrity": "sha512-tY3mM8rH9jM0YHFGyfC0/xf+SB5eKUu7HPj7/k3fpi9dAlsMc5YbQvDi0Sh2QTPXqMhyaAtzAr807TIyfQrmyg==", 365 | "dev": true, 366 | "dependencies": { 367 | "@babel/code-frame": "^7.23.5", 368 | "@babel/generator": "^7.23.6", 369 | "@babel/helper-environment-visitor": "^7.22.20", 370 | "@babel/helper-function-name": "^7.23.0", 371 | "@babel/helper-hoist-variables": "^7.22.5", 372 | "@babel/helper-split-export-declaration": "^7.22.6", 373 | "@babel/parser": "^7.23.6", 374 | "@babel/types": "^7.23.6", 375 | "debug": "^4.3.1", 376 | "globals": "^11.1.0" 377 | }, 378 | "engines": { 379 | "node": ">=6.9.0" 380 | } 381 | }, 382 | "node_modules/@babel/types": { 383 | "version": "7.23.6", 384 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.6.tgz", 385 | "integrity": "sha512-+uarb83brBzPKN38NX1MkB6vb6+mwvR6amUulqAE7ccQw1pEl+bCia9TbdG1lsnFP7lZySvUn37CHyXQdfTwzg==", 386 | "dev": true, 387 | "dependencies": { 388 | "@babel/helper-string-parser": "^7.23.4", 389 | "@babel/helper-validator-identifier": "^7.22.20", 390 | "to-fast-properties": "^2.0.0" 391 | }, 392 | "engines": { 393 | "node": ">=6.9.0" 394 | } 395 | }, 396 | "node_modules/@esbuild/aix-ppc64": { 397 | "version": "0.19.11", 398 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.11.tgz", 399 | "integrity": "sha512-FnzU0LyE3ySQk7UntJO4+qIiQgI7KoODnZg5xzXIrFJlKd2P2gwHsHY4927xj9y5PJmJSzULiUCWmv7iWnNa7g==", 400 | "cpu": [ 401 | "ppc64" 402 | ], 403 | "dev": true, 404 | "optional": true, 405 | "os": [ 406 | "aix" 407 | ], 408 | "engines": { 409 | "node": ">=12" 410 | } 411 | }, 412 | "node_modules/@esbuild/android-arm": { 413 | "version": "0.19.11", 414 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.11.tgz", 415 | "integrity": "sha512-5OVapq0ClabvKvQ58Bws8+wkLCV+Rxg7tUVbo9xu034Nm536QTII4YzhaFriQ7rMrorfnFKUsArD2lqKbFY4vw==", 416 | "cpu": [ 417 | "arm" 418 | ], 419 | "dev": true, 420 | "optional": true, 421 | "os": [ 422 | "android" 423 | ], 424 | "engines": { 425 | "node": ">=12" 426 | } 427 | }, 428 | "node_modules/@esbuild/android-arm64": { 429 | "version": "0.19.11", 430 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.11.tgz", 431 | "integrity": "sha512-aiu7K/5JnLj//KOnOfEZ0D90obUkRzDMyqd/wNAUQ34m4YUPVhRZpnqKV9uqDGxT7cToSDnIHsGooyIczu9T+Q==", 432 | "cpu": [ 433 | "arm64" 434 | ], 435 | "dev": true, 436 | "optional": true, 437 | "os": [ 438 | "android" 439 | ], 440 | "engines": { 441 | "node": ">=12" 442 | } 443 | }, 444 | "node_modules/@esbuild/android-x64": { 445 | "version": "0.19.11", 446 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.11.tgz", 447 | "integrity": "sha512-eccxjlfGw43WYoY9QgB82SgGgDbibcqyDTlk3l3C0jOVHKxrjdc9CTwDUQd0vkvYg5um0OH+GpxYvp39r+IPOg==", 448 | "cpu": [ 449 | "x64" 450 | ], 451 | "dev": true, 452 | "optional": true, 453 | "os": [ 454 | "android" 455 | ], 456 | "engines": { 457 | "node": ">=12" 458 | } 459 | }, 460 | "node_modules/@esbuild/darwin-arm64": { 461 | "version": "0.19.11", 462 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.11.tgz", 463 | "integrity": "sha512-ETp87DRWuSt9KdDVkqSoKoLFHYTrkyz2+65fj9nfXsaV3bMhTCjtQfw3y+um88vGRKRiF7erPrh/ZuIdLUIVxQ==", 464 | "cpu": [ 465 | "arm64" 466 | ], 467 | "dev": true, 468 | "optional": true, 469 | "os": [ 470 | "darwin" 471 | ], 472 | "engines": { 473 | "node": ">=12" 474 | } 475 | }, 476 | "node_modules/@esbuild/darwin-x64": { 477 | "version": "0.19.11", 478 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.11.tgz", 479 | "integrity": "sha512-fkFUiS6IUK9WYUO/+22omwetaSNl5/A8giXvQlcinLIjVkxwTLSktbF5f/kJMftM2MJp9+fXqZ5ezS7+SALp4g==", 480 | "cpu": [ 481 | "x64" 482 | ], 483 | "dev": true, 484 | "optional": true, 485 | "os": [ 486 | "darwin" 487 | ], 488 | "engines": { 489 | "node": ">=12" 490 | } 491 | }, 492 | "node_modules/@esbuild/freebsd-arm64": { 493 | "version": "0.19.11", 494 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.11.tgz", 495 | "integrity": "sha512-lhoSp5K6bxKRNdXUtHoNc5HhbXVCS8V0iZmDvyWvYq9S5WSfTIHU2UGjcGt7UeS6iEYp9eeymIl5mJBn0yiuxA==", 496 | "cpu": [ 497 | "arm64" 498 | ], 499 | "dev": true, 500 | "optional": true, 501 | "os": [ 502 | "freebsd" 503 | ], 504 | "engines": { 505 | "node": ">=12" 506 | } 507 | }, 508 | "node_modules/@esbuild/freebsd-x64": { 509 | "version": "0.19.11", 510 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.11.tgz", 511 | "integrity": "sha512-JkUqn44AffGXitVI6/AbQdoYAq0TEullFdqcMY/PCUZ36xJ9ZJRtQabzMA+Vi7r78+25ZIBosLTOKnUXBSi1Kw==", 512 | "cpu": [ 513 | "x64" 514 | ], 515 | "dev": true, 516 | "optional": true, 517 | "os": [ 518 | "freebsd" 519 | ], 520 | "engines": { 521 | "node": ">=12" 522 | } 523 | }, 524 | "node_modules/@esbuild/linux-arm": { 525 | "version": "0.19.11", 526 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.11.tgz", 527 | "integrity": "sha512-3CRkr9+vCV2XJbjwgzjPtO8T0SZUmRZla+UL1jw+XqHZPkPgZiyWvbDvl9rqAN8Zl7qJF0O/9ycMtjU67HN9/Q==", 528 | "cpu": [ 529 | "arm" 530 | ], 531 | "dev": true, 532 | "optional": true, 533 | "os": [ 534 | "linux" 535 | ], 536 | "engines": { 537 | "node": ">=12" 538 | } 539 | }, 540 | "node_modules/@esbuild/linux-arm64": { 541 | "version": "0.19.11", 542 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.11.tgz", 543 | "integrity": "sha512-LneLg3ypEeveBSMuoa0kwMpCGmpu8XQUh+mL8XXwoYZ6Be2qBnVtcDI5azSvh7vioMDhoJFZzp9GWp9IWpYoUg==", 544 | "cpu": [ 545 | "arm64" 546 | ], 547 | "dev": true, 548 | "optional": true, 549 | "os": [ 550 | "linux" 551 | ], 552 | "engines": { 553 | "node": ">=12" 554 | } 555 | }, 556 | "node_modules/@esbuild/linux-ia32": { 557 | "version": "0.19.11", 558 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.11.tgz", 559 | "integrity": "sha512-caHy++CsD8Bgq2V5CodbJjFPEiDPq8JJmBdeyZ8GWVQMjRD0sU548nNdwPNvKjVpamYYVL40AORekgfIubwHoA==", 560 | "cpu": [ 561 | "ia32" 562 | ], 563 | "dev": true, 564 | "optional": true, 565 | "os": [ 566 | "linux" 567 | ], 568 | "engines": { 569 | "node": ">=12" 570 | } 571 | }, 572 | "node_modules/@esbuild/linux-loong64": { 573 | "version": "0.19.11", 574 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.11.tgz", 575 | "integrity": "sha512-ppZSSLVpPrwHccvC6nQVZaSHlFsvCQyjnvirnVjbKSHuE5N24Yl8F3UwYUUR1UEPaFObGD2tSvVKbvR+uT1Nrg==", 576 | "cpu": [ 577 | "loong64" 578 | ], 579 | "dev": true, 580 | "optional": true, 581 | "os": [ 582 | "linux" 583 | ], 584 | "engines": { 585 | "node": ">=12" 586 | } 587 | }, 588 | "node_modules/@esbuild/linux-mips64el": { 589 | "version": "0.19.11", 590 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.11.tgz", 591 | "integrity": "sha512-B5x9j0OgjG+v1dF2DkH34lr+7Gmv0kzX6/V0afF41FkPMMqaQ77pH7CrhWeR22aEeHKaeZVtZ6yFwlxOKPVFyg==", 592 | "cpu": [ 593 | "mips64el" 594 | ], 595 | "dev": true, 596 | "optional": true, 597 | "os": [ 598 | "linux" 599 | ], 600 | "engines": { 601 | "node": ">=12" 602 | } 603 | }, 604 | "node_modules/@esbuild/linux-ppc64": { 605 | "version": "0.19.11", 606 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.11.tgz", 607 | "integrity": "sha512-MHrZYLeCG8vXblMetWyttkdVRjQlQUb/oMgBNurVEnhj4YWOr4G5lmBfZjHYQHHN0g6yDmCAQRR8MUHldvvRDA==", 608 | "cpu": [ 609 | "ppc64" 610 | ], 611 | "dev": true, 612 | "optional": true, 613 | "os": [ 614 | "linux" 615 | ], 616 | "engines": { 617 | "node": ">=12" 618 | } 619 | }, 620 | "node_modules/@esbuild/linux-riscv64": { 621 | "version": "0.19.11", 622 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.11.tgz", 623 | "integrity": "sha512-f3DY++t94uVg141dozDu4CCUkYW+09rWtaWfnb3bqe4w5NqmZd6nPVBm+qbz7WaHZCoqXqHz5p6CM6qv3qnSSQ==", 624 | "cpu": [ 625 | "riscv64" 626 | ], 627 | "dev": true, 628 | "optional": true, 629 | "os": [ 630 | "linux" 631 | ], 632 | "engines": { 633 | "node": ">=12" 634 | } 635 | }, 636 | "node_modules/@esbuild/linux-s390x": { 637 | "version": "0.19.11", 638 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.11.tgz", 639 | "integrity": "sha512-A5xdUoyWJHMMlcSMcPGVLzYzpcY8QP1RtYzX5/bS4dvjBGVxdhuiYyFwp7z74ocV7WDc0n1harxmpq2ePOjI0Q==", 640 | "cpu": [ 641 | "s390x" 642 | ], 643 | "dev": true, 644 | "optional": true, 645 | "os": [ 646 | "linux" 647 | ], 648 | "engines": { 649 | "node": ">=12" 650 | } 651 | }, 652 | "node_modules/@esbuild/linux-x64": { 653 | "version": "0.19.11", 654 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.11.tgz", 655 | "integrity": "sha512-grbyMlVCvJSfxFQUndw5mCtWs5LO1gUlwP4CDi4iJBbVpZcqLVT29FxgGuBJGSzyOxotFG4LoO5X+M1350zmPA==", 656 | "cpu": [ 657 | "x64" 658 | ], 659 | "dev": true, 660 | "optional": true, 661 | "os": [ 662 | "linux" 663 | ], 664 | "engines": { 665 | "node": ">=12" 666 | } 667 | }, 668 | "node_modules/@esbuild/netbsd-x64": { 669 | "version": "0.19.11", 670 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.11.tgz", 671 | "integrity": "sha512-13jvrQZJc3P230OhU8xgwUnDeuC/9egsjTkXN49b3GcS5BKvJqZn86aGM8W9pd14Kd+u7HuFBMVtrNGhh6fHEQ==", 672 | "cpu": [ 673 | "x64" 674 | ], 675 | "dev": true, 676 | "optional": true, 677 | "os": [ 678 | "netbsd" 679 | ], 680 | "engines": { 681 | "node": ">=12" 682 | } 683 | }, 684 | "node_modules/@esbuild/openbsd-x64": { 685 | "version": "0.19.11", 686 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.11.tgz", 687 | "integrity": "sha512-ysyOGZuTp6SNKPE11INDUeFVVQFrhcNDVUgSQVDzqsqX38DjhPEPATpid04LCoUr2WXhQTEZ8ct/EgJCUDpyNw==", 688 | "cpu": [ 689 | "x64" 690 | ], 691 | "dev": true, 692 | "optional": true, 693 | "os": [ 694 | "openbsd" 695 | ], 696 | "engines": { 697 | "node": ">=12" 698 | } 699 | }, 700 | "node_modules/@esbuild/sunos-x64": { 701 | "version": "0.19.11", 702 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.11.tgz", 703 | "integrity": "sha512-Hf+Sad9nVwvtxy4DXCZQqLpgmRTQqyFyhT3bZ4F2XlJCjxGmRFF0Shwn9rzhOYRB61w9VMXUkxlBy56dk9JJiQ==", 704 | "cpu": [ 705 | "x64" 706 | ], 707 | "dev": true, 708 | "optional": true, 709 | "os": [ 710 | "sunos" 711 | ], 712 | "engines": { 713 | "node": ">=12" 714 | } 715 | }, 716 | "node_modules/@esbuild/win32-arm64": { 717 | "version": "0.19.11", 718 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.11.tgz", 719 | "integrity": "sha512-0P58Sbi0LctOMOQbpEOvOL44Ne0sqbS0XWHMvvrg6NE5jQ1xguCSSw9jQeUk2lfrXYsKDdOe6K+oZiwKPilYPQ==", 720 | "cpu": [ 721 | "arm64" 722 | ], 723 | "dev": true, 724 | "optional": true, 725 | "os": [ 726 | "win32" 727 | ], 728 | "engines": { 729 | "node": ">=12" 730 | } 731 | }, 732 | "node_modules/@esbuild/win32-ia32": { 733 | "version": "0.19.11", 734 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.11.tgz", 735 | "integrity": "sha512-6YOrWS+sDJDmshdBIQU+Uoyh7pQKrdykdefC1avn76ss5c+RN6gut3LZA4E2cH5xUEp5/cA0+YxRaVtRAb0xBg==", 736 | "cpu": [ 737 | "ia32" 738 | ], 739 | "dev": true, 740 | "optional": true, 741 | "os": [ 742 | "win32" 743 | ], 744 | "engines": { 745 | "node": ">=12" 746 | } 747 | }, 748 | "node_modules/@esbuild/win32-x64": { 749 | "version": "0.19.11", 750 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.11.tgz", 751 | "integrity": "sha512-vfkhltrjCAb603XaFhqhAF4LGDi2M4OrCRrFusyQ+iTLQ/o60QQXxc9cZC/FFpihBI9N1Grn6SMKVJ4KP7Fuiw==", 752 | "cpu": [ 753 | "x64" 754 | ], 755 | "dev": true, 756 | "optional": true, 757 | "os": [ 758 | "win32" 759 | ], 760 | "engines": { 761 | "node": ">=12" 762 | } 763 | }, 764 | "node_modules/@eslint-community/eslint-utils": { 765 | "version": "4.4.0", 766 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 767 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 768 | "dev": true, 769 | "dependencies": { 770 | "eslint-visitor-keys": "^3.3.0" 771 | }, 772 | "engines": { 773 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 774 | }, 775 | "peerDependencies": { 776 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 777 | } 778 | }, 779 | "node_modules/@eslint-community/regexpp": { 780 | "version": "4.10.0", 781 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 782 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 783 | "dev": true, 784 | "engines": { 785 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 786 | } 787 | }, 788 | "node_modules/@eslint/eslintrc": { 789 | "version": "2.1.4", 790 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 791 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 792 | "dev": true, 793 | "dependencies": { 794 | "ajv": "^6.12.4", 795 | "debug": "^4.3.2", 796 | "espree": "^9.6.0", 797 | "globals": "^13.19.0", 798 | "ignore": "^5.2.0", 799 | "import-fresh": "^3.2.1", 800 | "js-yaml": "^4.1.0", 801 | "minimatch": "^3.1.2", 802 | "strip-json-comments": "^3.1.1" 803 | }, 804 | "engines": { 805 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 806 | }, 807 | "funding": { 808 | "url": "https://opencollective.com/eslint" 809 | } 810 | }, 811 | "node_modules/@eslint/eslintrc/node_modules/brace-expansion": { 812 | "version": "1.1.11", 813 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 814 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 815 | "dev": true, 816 | "dependencies": { 817 | "balanced-match": "^1.0.0", 818 | "concat-map": "0.0.1" 819 | } 820 | }, 821 | "node_modules/@eslint/eslintrc/node_modules/globals": { 822 | "version": "13.24.0", 823 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 824 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 825 | "dev": true, 826 | "dependencies": { 827 | "type-fest": "^0.20.2" 828 | }, 829 | "engines": { 830 | "node": ">=8" 831 | }, 832 | "funding": { 833 | "url": "https://github.com/sponsors/sindresorhus" 834 | } 835 | }, 836 | "node_modules/@eslint/eslintrc/node_modules/minimatch": { 837 | "version": "3.1.2", 838 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 839 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 840 | "dev": true, 841 | "dependencies": { 842 | "brace-expansion": "^1.1.7" 843 | }, 844 | "engines": { 845 | "node": "*" 846 | } 847 | }, 848 | "node_modules/@eslint/js": { 849 | "version": "8.56.0", 850 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", 851 | "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==", 852 | "dev": true, 853 | "engines": { 854 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 855 | } 856 | }, 857 | "node_modules/@humanwhocodes/config-array": { 858 | "version": "0.11.14", 859 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 860 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 861 | "dev": true, 862 | "dependencies": { 863 | "@humanwhocodes/object-schema": "^2.0.2", 864 | "debug": "^4.3.1", 865 | "minimatch": "^3.0.5" 866 | }, 867 | "engines": { 868 | "node": ">=10.10.0" 869 | } 870 | }, 871 | "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": { 872 | "version": "1.1.11", 873 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 874 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 875 | "dev": true, 876 | "dependencies": { 877 | "balanced-match": "^1.0.0", 878 | "concat-map": "0.0.1" 879 | } 880 | }, 881 | "node_modules/@humanwhocodes/config-array/node_modules/minimatch": { 882 | "version": "3.1.2", 883 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 884 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 885 | "dev": true, 886 | "dependencies": { 887 | "brace-expansion": "^1.1.7" 888 | }, 889 | "engines": { 890 | "node": "*" 891 | } 892 | }, 893 | "node_modules/@humanwhocodes/module-importer": { 894 | "version": "1.0.1", 895 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 896 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 897 | "dev": true, 898 | "engines": { 899 | "node": ">=12.22" 900 | }, 901 | "funding": { 902 | "type": "github", 903 | "url": "https://github.com/sponsors/nzakas" 904 | } 905 | }, 906 | "node_modules/@humanwhocodes/object-schema": { 907 | "version": "2.0.2", 908 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 909 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 910 | "dev": true 911 | }, 912 | "node_modules/@jridgewell/gen-mapping": { 913 | "version": "0.3.3", 914 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 915 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 916 | "dev": true, 917 | "dependencies": { 918 | "@jridgewell/set-array": "^1.0.1", 919 | "@jridgewell/sourcemap-codec": "^1.4.10", 920 | "@jridgewell/trace-mapping": "^0.3.9" 921 | }, 922 | "engines": { 923 | "node": ">=6.0.0" 924 | } 925 | }, 926 | "node_modules/@jridgewell/resolve-uri": { 927 | "version": "3.1.1", 928 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 929 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 930 | "dev": true, 931 | "engines": { 932 | "node": ">=6.0.0" 933 | } 934 | }, 935 | "node_modules/@jridgewell/set-array": { 936 | "version": "1.1.2", 937 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 938 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 939 | "dev": true, 940 | "engines": { 941 | "node": ">=6.0.0" 942 | } 943 | }, 944 | "node_modules/@jridgewell/sourcemap-codec": { 945 | "version": "1.4.15", 946 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 947 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 948 | "dev": true 949 | }, 950 | "node_modules/@jridgewell/trace-mapping": { 951 | "version": "0.3.21", 952 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.21.tgz", 953 | "integrity": "sha512-SRfKmRe1KvYnxjEMtxEr+J4HIeMX5YBg/qhRHpxEIGjhX1rshcHlnFUE9K0GazhVKWM7B+nARSkV8LuvJdJ5/g==", 954 | "dev": true, 955 | "dependencies": { 956 | "@jridgewell/resolve-uri": "^3.1.0", 957 | "@jridgewell/sourcemap-codec": "^1.4.14" 958 | } 959 | }, 960 | "node_modules/@nodelib/fs.scandir": { 961 | "version": "2.1.5", 962 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 963 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 964 | "dev": true, 965 | "dependencies": { 966 | "@nodelib/fs.stat": "2.0.5", 967 | "run-parallel": "^1.1.9" 968 | }, 969 | "engines": { 970 | "node": ">= 8" 971 | } 972 | }, 973 | "node_modules/@nodelib/fs.stat": { 974 | "version": "2.0.5", 975 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 976 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 977 | "dev": true, 978 | "engines": { 979 | "node": ">= 8" 980 | } 981 | }, 982 | "node_modules/@nodelib/fs.walk": { 983 | "version": "1.2.8", 984 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 985 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 986 | "dev": true, 987 | "dependencies": { 988 | "@nodelib/fs.scandir": "2.1.5", 989 | "fastq": "^1.6.0" 990 | }, 991 | "engines": { 992 | "node": ">= 8" 993 | } 994 | }, 995 | "node_modules/@rollup/rollup-android-arm-eabi": { 996 | "version": "4.9.5", 997 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.5.tgz", 998 | "integrity": "sha512-idWaG8xeSRCfRq9KpRysDHJ/rEHBEXcHuJ82XY0yYFIWnLMjZv9vF/7DOq8djQ2n3Lk6+3qfSH8AqlmHlmi1MA==", 999 | "cpu": [ 1000 | "arm" 1001 | ], 1002 | "dev": true, 1003 | "optional": true, 1004 | "os": [ 1005 | "android" 1006 | ] 1007 | }, 1008 | "node_modules/@rollup/rollup-android-arm64": { 1009 | "version": "4.9.5", 1010 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.5.tgz", 1011 | "integrity": "sha512-f14d7uhAMtsCGjAYwZGv6TwuS3IFaM4ZnGMUn3aCBgkcHAYErhV1Ad97WzBvS2o0aaDv4mVz+syiN0ElMyfBPg==", 1012 | "cpu": [ 1013 | "arm64" 1014 | ], 1015 | "dev": true, 1016 | "optional": true, 1017 | "os": [ 1018 | "android" 1019 | ] 1020 | }, 1021 | "node_modules/@rollup/rollup-darwin-arm64": { 1022 | "version": "4.9.5", 1023 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.5.tgz", 1024 | "integrity": "sha512-ndoXeLx455FffL68OIUrVr89Xu1WLzAG4n65R8roDlCoYiQcGGg6MALvs2Ap9zs7AHg8mpHtMpwC8jBBjZrT/w==", 1025 | "cpu": [ 1026 | "arm64" 1027 | ], 1028 | "dev": true, 1029 | "optional": true, 1030 | "os": [ 1031 | "darwin" 1032 | ] 1033 | }, 1034 | "node_modules/@rollup/rollup-darwin-x64": { 1035 | "version": "4.9.5", 1036 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.5.tgz", 1037 | "integrity": "sha512-UmElV1OY2m/1KEEqTlIjieKfVwRg0Zwg4PLgNf0s3glAHXBN99KLpw5A5lrSYCa1Kp63czTpVll2MAqbZYIHoA==", 1038 | "cpu": [ 1039 | "x64" 1040 | ], 1041 | "dev": true, 1042 | "optional": true, 1043 | "os": [ 1044 | "darwin" 1045 | ] 1046 | }, 1047 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 1048 | "version": "4.9.5", 1049 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.5.tgz", 1050 | "integrity": "sha512-Q0LcU61v92tQB6ae+udZvOyZ0wfpGojtAKrrpAaIqmJ7+psq4cMIhT/9lfV6UQIpeItnq/2QDROhNLo00lOD1g==", 1051 | "cpu": [ 1052 | "arm" 1053 | ], 1054 | "dev": true, 1055 | "optional": true, 1056 | "os": [ 1057 | "linux" 1058 | ] 1059 | }, 1060 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1061 | "version": "4.9.5", 1062 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.5.tgz", 1063 | "integrity": "sha512-dkRscpM+RrR2Ee3eOQmRWFjmV/payHEOrjyq1VZegRUa5OrZJ2MAxBNs05bZuY0YCtpqETDy1Ix4i/hRqX98cA==", 1064 | "cpu": [ 1065 | "arm64" 1066 | ], 1067 | "dev": true, 1068 | "optional": true, 1069 | "os": [ 1070 | "linux" 1071 | ] 1072 | }, 1073 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1074 | "version": "4.9.5", 1075 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.5.tgz", 1076 | "integrity": "sha512-QaKFVOzzST2xzY4MAmiDmURagWLFh+zZtttuEnuNn19AiZ0T3fhPyjPPGwLNdiDT82ZE91hnfJsUiDwF9DClIQ==", 1077 | "cpu": [ 1078 | "arm64" 1079 | ], 1080 | "dev": true, 1081 | "optional": true, 1082 | "os": [ 1083 | "linux" 1084 | ] 1085 | }, 1086 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1087 | "version": "4.9.5", 1088 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.5.tgz", 1089 | "integrity": "sha512-HeGqmRJuyVg6/X6MpE2ur7GbymBPS8Np0S/vQFHDmocfORT+Zt76qu+69NUoxXzGqVP1pzaY6QIi0FJWLC3OPA==", 1090 | "cpu": [ 1091 | "riscv64" 1092 | ], 1093 | "dev": true, 1094 | "optional": true, 1095 | "os": [ 1096 | "linux" 1097 | ] 1098 | }, 1099 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1100 | "version": "4.9.5", 1101 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.5.tgz", 1102 | "integrity": "sha512-Dq1bqBdLaZ1Gb/l2e5/+o3B18+8TI9ANlA1SkejZqDgdU/jK/ThYaMPMJpVMMXy2uRHvGKbkz9vheVGdq3cJfA==", 1103 | "cpu": [ 1104 | "x64" 1105 | ], 1106 | "dev": true, 1107 | "optional": true, 1108 | "os": [ 1109 | "linux" 1110 | ] 1111 | }, 1112 | "node_modules/@rollup/rollup-linux-x64-musl": { 1113 | "version": "4.9.5", 1114 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.5.tgz", 1115 | "integrity": "sha512-ezyFUOwldYpj7AbkwyW9AJ203peub81CaAIVvckdkyH8EvhEIoKzaMFJj0G4qYJ5sw3BpqhFrsCc30t54HV8vg==", 1116 | "cpu": [ 1117 | "x64" 1118 | ], 1119 | "dev": true, 1120 | "optional": true, 1121 | "os": [ 1122 | "linux" 1123 | ] 1124 | }, 1125 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1126 | "version": "4.9.5", 1127 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.5.tgz", 1128 | "integrity": "sha512-aHSsMnUw+0UETB0Hlv7B/ZHOGY5bQdwMKJSzGfDfvyhnpmVxLMGnQPGNE9wgqkLUs3+gbG1Qx02S2LLfJ5GaRQ==", 1129 | "cpu": [ 1130 | "arm64" 1131 | ], 1132 | "dev": true, 1133 | "optional": true, 1134 | "os": [ 1135 | "win32" 1136 | ] 1137 | }, 1138 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1139 | "version": "4.9.5", 1140 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.5.tgz", 1141 | "integrity": "sha512-AiqiLkb9KSf7Lj/o1U3SEP9Zn+5NuVKgFdRIZkvd4N0+bYrTOovVd0+LmYCPQGbocT4kvFyK+LXCDiXPBF3fyA==", 1142 | "cpu": [ 1143 | "ia32" 1144 | ], 1145 | "dev": true, 1146 | "optional": true, 1147 | "os": [ 1148 | "win32" 1149 | ] 1150 | }, 1151 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1152 | "version": "4.9.5", 1153 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.5.tgz", 1154 | "integrity": "sha512-1q+mykKE3Vot1kaFJIDoUFv5TuW+QQVaf2FmTT9krg86pQrGStOSJJ0Zil7CFagyxDuouTepzt5Y5TVzyajOdQ==", 1155 | "cpu": [ 1156 | "x64" 1157 | ], 1158 | "dev": true, 1159 | "optional": true, 1160 | "os": [ 1161 | "win32" 1162 | ] 1163 | }, 1164 | "node_modules/@types/babel__core": { 1165 | "version": "7.20.5", 1166 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1167 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1168 | "dev": true, 1169 | "dependencies": { 1170 | "@babel/parser": "^7.20.7", 1171 | "@babel/types": "^7.20.7", 1172 | "@types/babel__generator": "*", 1173 | "@types/babel__template": "*", 1174 | "@types/babel__traverse": "*" 1175 | } 1176 | }, 1177 | "node_modules/@types/babel__generator": { 1178 | "version": "7.6.8", 1179 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 1180 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 1181 | "dev": true, 1182 | "dependencies": { 1183 | "@babel/types": "^7.0.0" 1184 | } 1185 | }, 1186 | "node_modules/@types/babel__template": { 1187 | "version": "7.4.4", 1188 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1189 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1190 | "dev": true, 1191 | "dependencies": { 1192 | "@babel/parser": "^7.1.0", 1193 | "@babel/types": "^7.0.0" 1194 | } 1195 | }, 1196 | "node_modules/@types/babel__traverse": { 1197 | "version": "7.20.5", 1198 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz", 1199 | "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==", 1200 | "dev": true, 1201 | "dependencies": { 1202 | "@babel/types": "^7.20.7" 1203 | } 1204 | }, 1205 | "node_modules/@types/estree": { 1206 | "version": "1.0.5", 1207 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1208 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1209 | "dev": true 1210 | }, 1211 | "node_modules/@types/json-schema": { 1212 | "version": "7.0.15", 1213 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 1214 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 1215 | "dev": true 1216 | }, 1217 | "node_modules/@types/prop-types": { 1218 | "version": "15.7.11", 1219 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", 1220 | "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", 1221 | "devOptional": true 1222 | }, 1223 | "node_modules/@types/react": { 1224 | "version": "18.2.48", 1225 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.48.tgz", 1226 | "integrity": "sha512-qboRCl6Ie70DQQG9hhNREz81jqC1cs9EVNcjQ1AU+jH6NFfSAhVVbrrY/+nSF+Bsk4AOwm9Qa61InvMCyV+H3w==", 1227 | "devOptional": true, 1228 | "dependencies": { 1229 | "@types/prop-types": "*", 1230 | "@types/scheduler": "*", 1231 | "csstype": "^3.0.2" 1232 | } 1233 | }, 1234 | "node_modules/@types/react-dom": { 1235 | "version": "18.2.18", 1236 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.18.tgz", 1237 | "integrity": "sha512-TJxDm6OfAX2KJWJdMEVTwWke5Sc/E/RlnPGvGfS0W7+6ocy2xhDVQVh/KvC2Uf7kACs+gDytdusDSdWfWkaNzw==", 1238 | "dev": true, 1239 | "dependencies": { 1240 | "@types/react": "*" 1241 | } 1242 | }, 1243 | "node_modules/@types/scheduler": { 1244 | "version": "0.16.8", 1245 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", 1246 | "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", 1247 | "devOptional": true 1248 | }, 1249 | "node_modules/@types/semver": { 1250 | "version": "7.5.6", 1251 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", 1252 | "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==", 1253 | "dev": true 1254 | }, 1255 | "node_modules/@typescript-eslint/eslint-plugin": { 1256 | "version": "6.19.0", 1257 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.19.0.tgz", 1258 | "integrity": "sha512-DUCUkQNklCQYnrBSSikjVChdc84/vMPDQSgJTHBZ64G9bA9w0Crc0rd2diujKbTdp6w2J47qkeHQLoi0rpLCdg==", 1259 | "dev": true, 1260 | "dependencies": { 1261 | "@eslint-community/regexpp": "^4.5.1", 1262 | "@typescript-eslint/scope-manager": "6.19.0", 1263 | "@typescript-eslint/type-utils": "6.19.0", 1264 | "@typescript-eslint/utils": "6.19.0", 1265 | "@typescript-eslint/visitor-keys": "6.19.0", 1266 | "debug": "^4.3.4", 1267 | "graphemer": "^1.4.0", 1268 | "ignore": "^5.2.4", 1269 | "natural-compare": "^1.4.0", 1270 | "semver": "^7.5.4", 1271 | "ts-api-utils": "^1.0.1" 1272 | }, 1273 | "engines": { 1274 | "node": "^16.0.0 || >=18.0.0" 1275 | }, 1276 | "funding": { 1277 | "type": "opencollective", 1278 | "url": "https://opencollective.com/typescript-eslint" 1279 | }, 1280 | "peerDependencies": { 1281 | "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha", 1282 | "eslint": "^7.0.0 || ^8.0.0" 1283 | }, 1284 | "peerDependenciesMeta": { 1285 | "typescript": { 1286 | "optional": true 1287 | } 1288 | } 1289 | }, 1290 | "node_modules/@typescript-eslint/parser": { 1291 | "version": "6.19.0", 1292 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.19.0.tgz", 1293 | "integrity": "sha512-1DyBLG5SH7PYCd00QlroiW60YJ4rWMuUGa/JBV0iZuqi4l4IK3twKPq5ZkEebmGqRjXWVgsUzfd3+nZveewgow==", 1294 | "dev": true, 1295 | "dependencies": { 1296 | "@typescript-eslint/scope-manager": "6.19.0", 1297 | "@typescript-eslint/types": "6.19.0", 1298 | "@typescript-eslint/typescript-estree": "6.19.0", 1299 | "@typescript-eslint/visitor-keys": "6.19.0", 1300 | "debug": "^4.3.4" 1301 | }, 1302 | "engines": { 1303 | "node": "^16.0.0 || >=18.0.0" 1304 | }, 1305 | "funding": { 1306 | "type": "opencollective", 1307 | "url": "https://opencollective.com/typescript-eslint" 1308 | }, 1309 | "peerDependencies": { 1310 | "eslint": "^7.0.0 || ^8.0.0" 1311 | }, 1312 | "peerDependenciesMeta": { 1313 | "typescript": { 1314 | "optional": true 1315 | } 1316 | } 1317 | }, 1318 | "node_modules/@typescript-eslint/scope-manager": { 1319 | "version": "6.19.0", 1320 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.19.0.tgz", 1321 | "integrity": "sha512-dO1XMhV2ehBI6QN8Ufi7I10wmUovmLU0Oru3n5LVlM2JuzB4M+dVphCPLkVpKvGij2j/pHBWuJ9piuXx+BhzxQ==", 1322 | "dev": true, 1323 | "dependencies": { 1324 | "@typescript-eslint/types": "6.19.0", 1325 | "@typescript-eslint/visitor-keys": "6.19.0" 1326 | }, 1327 | "engines": { 1328 | "node": "^16.0.0 || >=18.0.0" 1329 | }, 1330 | "funding": { 1331 | "type": "opencollective", 1332 | "url": "https://opencollective.com/typescript-eslint" 1333 | } 1334 | }, 1335 | "node_modules/@typescript-eslint/type-utils": { 1336 | "version": "6.19.0", 1337 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.19.0.tgz", 1338 | "integrity": "sha512-mcvS6WSWbjiSxKCwBcXtOM5pRkPQ6kcDds/juxcy/727IQr3xMEcwr/YLHW2A2+Fp5ql6khjbKBzOyjuPqGi/w==", 1339 | "dev": true, 1340 | "dependencies": { 1341 | "@typescript-eslint/typescript-estree": "6.19.0", 1342 | "@typescript-eslint/utils": "6.19.0", 1343 | "debug": "^4.3.4", 1344 | "ts-api-utils": "^1.0.1" 1345 | }, 1346 | "engines": { 1347 | "node": "^16.0.0 || >=18.0.0" 1348 | }, 1349 | "funding": { 1350 | "type": "opencollective", 1351 | "url": "https://opencollective.com/typescript-eslint" 1352 | }, 1353 | "peerDependencies": { 1354 | "eslint": "^7.0.0 || ^8.0.0" 1355 | }, 1356 | "peerDependenciesMeta": { 1357 | "typescript": { 1358 | "optional": true 1359 | } 1360 | } 1361 | }, 1362 | "node_modules/@typescript-eslint/types": { 1363 | "version": "6.19.0", 1364 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.19.0.tgz", 1365 | "integrity": "sha512-lFviGV/vYhOy3m8BJ/nAKoAyNhInTdXpftonhWle66XHAtT1ouBlkjL496b5H5hb8dWXHwtypTqgtb/DEa+j5A==", 1366 | "dev": true, 1367 | "engines": { 1368 | "node": "^16.0.0 || >=18.0.0" 1369 | }, 1370 | "funding": { 1371 | "type": "opencollective", 1372 | "url": "https://opencollective.com/typescript-eslint" 1373 | } 1374 | }, 1375 | "node_modules/@typescript-eslint/typescript-estree": { 1376 | "version": "6.19.0", 1377 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.19.0.tgz", 1378 | "integrity": "sha512-o/zefXIbbLBZ8YJ51NlkSAt2BamrK6XOmuxSR3hynMIzzyMY33KuJ9vuMdFSXW+H0tVvdF9qBPTHA91HDb4BIQ==", 1379 | "dev": true, 1380 | "dependencies": { 1381 | "@typescript-eslint/types": "6.19.0", 1382 | "@typescript-eslint/visitor-keys": "6.19.0", 1383 | "debug": "^4.3.4", 1384 | "globby": "^11.1.0", 1385 | "is-glob": "^4.0.3", 1386 | "minimatch": "9.0.3", 1387 | "semver": "^7.5.4", 1388 | "ts-api-utils": "^1.0.1" 1389 | }, 1390 | "engines": { 1391 | "node": "^16.0.0 || >=18.0.0" 1392 | }, 1393 | "funding": { 1394 | "type": "opencollective", 1395 | "url": "https://opencollective.com/typescript-eslint" 1396 | }, 1397 | "peerDependenciesMeta": { 1398 | "typescript": { 1399 | "optional": true 1400 | } 1401 | } 1402 | }, 1403 | "node_modules/@typescript-eslint/utils": { 1404 | "version": "6.19.0", 1405 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.19.0.tgz", 1406 | "integrity": "sha512-QR41YXySiuN++/dC9UArYOg4X86OAYP83OWTewpVx5ct1IZhjjgTLocj7QNxGhWoTqknsgpl7L+hGygCO+sdYw==", 1407 | "dev": true, 1408 | "dependencies": { 1409 | "@eslint-community/eslint-utils": "^4.4.0", 1410 | "@types/json-schema": "^7.0.12", 1411 | "@types/semver": "^7.5.0", 1412 | "@typescript-eslint/scope-manager": "6.19.0", 1413 | "@typescript-eslint/types": "6.19.0", 1414 | "@typescript-eslint/typescript-estree": "6.19.0", 1415 | "semver": "^7.5.4" 1416 | }, 1417 | "engines": { 1418 | "node": "^16.0.0 || >=18.0.0" 1419 | }, 1420 | "funding": { 1421 | "type": "opencollective", 1422 | "url": "https://opencollective.com/typescript-eslint" 1423 | }, 1424 | "peerDependencies": { 1425 | "eslint": "^7.0.0 || ^8.0.0" 1426 | } 1427 | }, 1428 | "node_modules/@typescript-eslint/visitor-keys": { 1429 | "version": "6.19.0", 1430 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.19.0.tgz", 1431 | "integrity": "sha512-hZaUCORLgubBvtGpp1JEFEazcuEdfxta9j4iUwdSAr7mEsYYAp3EAUyCZk3VEEqGj6W+AV4uWyrDGtrlawAsgQ==", 1432 | "dev": true, 1433 | "dependencies": { 1434 | "@typescript-eslint/types": "6.19.0", 1435 | "eslint-visitor-keys": "^3.4.1" 1436 | }, 1437 | "engines": { 1438 | "node": "^16.0.0 || >=18.0.0" 1439 | }, 1440 | "funding": { 1441 | "type": "opencollective", 1442 | "url": "https://opencollective.com/typescript-eslint" 1443 | } 1444 | }, 1445 | "node_modules/@ungap/structured-clone": { 1446 | "version": "1.2.0", 1447 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 1448 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 1449 | "dev": true 1450 | }, 1451 | "node_modules/@vitejs/plugin-react": { 1452 | "version": "4.2.1", 1453 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.2.1.tgz", 1454 | "integrity": "sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==", 1455 | "dev": true, 1456 | "dependencies": { 1457 | "@babel/core": "^7.23.5", 1458 | "@babel/plugin-transform-react-jsx-self": "^7.23.3", 1459 | "@babel/plugin-transform-react-jsx-source": "^7.23.3", 1460 | "@types/babel__core": "^7.20.5", 1461 | "react-refresh": "^0.14.0" 1462 | }, 1463 | "engines": { 1464 | "node": "^14.18.0 || >=16.0.0" 1465 | }, 1466 | "peerDependencies": { 1467 | "vite": "^4.2.0 || ^5.0.0" 1468 | } 1469 | }, 1470 | "node_modules/acorn": { 1471 | "version": "8.11.3", 1472 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1473 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1474 | "dev": true, 1475 | "bin": { 1476 | "acorn": "bin/acorn" 1477 | }, 1478 | "engines": { 1479 | "node": ">=0.4.0" 1480 | } 1481 | }, 1482 | "node_modules/acorn-jsx": { 1483 | "version": "5.3.2", 1484 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1485 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1486 | "dev": true, 1487 | "peerDependencies": { 1488 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1489 | } 1490 | }, 1491 | "node_modules/ajv": { 1492 | "version": "6.12.6", 1493 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1494 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1495 | "dev": true, 1496 | "dependencies": { 1497 | "fast-deep-equal": "^3.1.1", 1498 | "fast-json-stable-stringify": "^2.0.0", 1499 | "json-schema-traverse": "^0.4.1", 1500 | "uri-js": "^4.2.2" 1501 | }, 1502 | "funding": { 1503 | "type": "github", 1504 | "url": "https://github.com/sponsors/epoberezkin" 1505 | } 1506 | }, 1507 | "node_modules/ansi-regex": { 1508 | "version": "5.0.1", 1509 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1510 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1511 | "dev": true, 1512 | "engines": { 1513 | "node": ">=8" 1514 | } 1515 | }, 1516 | "node_modules/ansi-styles": { 1517 | "version": "3.2.1", 1518 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1519 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "color-convert": "^1.9.0" 1523 | }, 1524 | "engines": { 1525 | "node": ">=4" 1526 | } 1527 | }, 1528 | "node_modules/argparse": { 1529 | "version": "2.0.1", 1530 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1531 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1532 | "dev": true 1533 | }, 1534 | "node_modules/array-union": { 1535 | "version": "2.1.0", 1536 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 1537 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 1538 | "dev": true, 1539 | "engines": { 1540 | "node": ">=8" 1541 | } 1542 | }, 1543 | "node_modules/balanced-match": { 1544 | "version": "1.0.2", 1545 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1546 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1547 | "dev": true 1548 | }, 1549 | "node_modules/brace-expansion": { 1550 | "version": "2.0.1", 1551 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1552 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1553 | "dev": true, 1554 | "dependencies": { 1555 | "balanced-match": "^1.0.0" 1556 | } 1557 | }, 1558 | "node_modules/braces": { 1559 | "version": "3.0.2", 1560 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1561 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1562 | "dev": true, 1563 | "dependencies": { 1564 | "fill-range": "^7.0.1" 1565 | }, 1566 | "engines": { 1567 | "node": ">=8" 1568 | } 1569 | }, 1570 | "node_modules/browserslist": { 1571 | "version": "4.22.2", 1572 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", 1573 | "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", 1574 | "dev": true, 1575 | "funding": [ 1576 | { 1577 | "type": "opencollective", 1578 | "url": "https://opencollective.com/browserslist" 1579 | }, 1580 | { 1581 | "type": "tidelift", 1582 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1583 | }, 1584 | { 1585 | "type": "github", 1586 | "url": "https://github.com/sponsors/ai" 1587 | } 1588 | ], 1589 | "dependencies": { 1590 | "caniuse-lite": "^1.0.30001565", 1591 | "electron-to-chromium": "^1.4.601", 1592 | "node-releases": "^2.0.14", 1593 | "update-browserslist-db": "^1.0.13" 1594 | }, 1595 | "bin": { 1596 | "browserslist": "cli.js" 1597 | }, 1598 | "engines": { 1599 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1600 | } 1601 | }, 1602 | "node_modules/callsites": { 1603 | "version": "3.1.0", 1604 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1605 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1606 | "dev": true, 1607 | "engines": { 1608 | "node": ">=6" 1609 | } 1610 | }, 1611 | "node_modules/caniuse-lite": { 1612 | "version": "1.0.30001576", 1613 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001576.tgz", 1614 | "integrity": "sha512-ff5BdakGe2P3SQsMsiqmt1Lc8221NR1VzHj5jXN5vBny9A6fpze94HiVV/n7XRosOlsShJcvMv5mdnpjOGCEgg==", 1615 | "dev": true, 1616 | "funding": [ 1617 | { 1618 | "type": "opencollective", 1619 | "url": "https://opencollective.com/browserslist" 1620 | }, 1621 | { 1622 | "type": "tidelift", 1623 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1624 | }, 1625 | { 1626 | "type": "github", 1627 | "url": "https://github.com/sponsors/ai" 1628 | } 1629 | ] 1630 | }, 1631 | "node_modules/chalk": { 1632 | "version": "2.4.2", 1633 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1634 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1635 | "dev": true, 1636 | "dependencies": { 1637 | "ansi-styles": "^3.2.1", 1638 | "escape-string-regexp": "^1.0.5", 1639 | "supports-color": "^5.3.0" 1640 | }, 1641 | "engines": { 1642 | "node": ">=4" 1643 | } 1644 | }, 1645 | "node_modules/color-convert": { 1646 | "version": "1.9.3", 1647 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1648 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1649 | "dev": true, 1650 | "dependencies": { 1651 | "color-name": "1.1.3" 1652 | } 1653 | }, 1654 | "node_modules/color-name": { 1655 | "version": "1.1.3", 1656 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1657 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1658 | "dev": true 1659 | }, 1660 | "node_modules/concat-map": { 1661 | "version": "0.0.1", 1662 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1663 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1664 | "dev": true 1665 | }, 1666 | "node_modules/convert-source-map": { 1667 | "version": "2.0.0", 1668 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1669 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1670 | "dev": true 1671 | }, 1672 | "node_modules/cross-spawn": { 1673 | "version": "7.0.3", 1674 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1675 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1676 | "dev": true, 1677 | "dependencies": { 1678 | "path-key": "^3.1.0", 1679 | "shebang-command": "^2.0.0", 1680 | "which": "^2.0.1" 1681 | }, 1682 | "engines": { 1683 | "node": ">= 8" 1684 | } 1685 | }, 1686 | "node_modules/csstype": { 1687 | "version": "3.1.3", 1688 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 1689 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 1690 | "devOptional": true 1691 | }, 1692 | "node_modules/debug": { 1693 | "version": "4.3.4", 1694 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1695 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1696 | "dev": true, 1697 | "dependencies": { 1698 | "ms": "2.1.2" 1699 | }, 1700 | "engines": { 1701 | "node": ">=6.0" 1702 | }, 1703 | "peerDependenciesMeta": { 1704 | "supports-color": { 1705 | "optional": true 1706 | } 1707 | } 1708 | }, 1709 | "node_modules/deep-is": { 1710 | "version": "0.1.4", 1711 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1712 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1713 | "dev": true 1714 | }, 1715 | "node_modules/dir-glob": { 1716 | "version": "3.0.1", 1717 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1718 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1719 | "dev": true, 1720 | "dependencies": { 1721 | "path-type": "^4.0.0" 1722 | }, 1723 | "engines": { 1724 | "node": ">=8" 1725 | } 1726 | }, 1727 | "node_modules/doctrine": { 1728 | "version": "3.0.0", 1729 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1730 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1731 | "dev": true, 1732 | "dependencies": { 1733 | "esutils": "^2.0.2" 1734 | }, 1735 | "engines": { 1736 | "node": ">=6.0.0" 1737 | } 1738 | }, 1739 | "node_modules/electron-to-chromium": { 1740 | "version": "1.4.631", 1741 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.631.tgz", 1742 | "integrity": "sha512-g73CJB/rMPjdxpiNJYmV1homV7mLVUNe/R0z/HhqMfpjkt58FpYmkTjbtuv3zymdbTTJ+VOEqe1c+lkTjSOhmQ==", 1743 | "dev": true 1744 | }, 1745 | "node_modules/error-stack-parser": { 1746 | "version": "2.1.4", 1747 | "resolved": "https://registry.npmjs.org/error-stack-parser/-/error-stack-parser-2.1.4.tgz", 1748 | "integrity": "sha512-Sk5V6wVazPhq5MhpO+AUxJn5x7XSXGl1R93Vn7i+zS15KDVxQijejNCrz8340/2bgLBjR9GtEG8ZVKONDjcqGQ==", 1749 | "dev": true, 1750 | "dependencies": { 1751 | "stackframe": "^1.3.4" 1752 | } 1753 | }, 1754 | "node_modules/esbuild": { 1755 | "version": "0.19.11", 1756 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.11.tgz", 1757 | "integrity": "sha512-HJ96Hev2hX/6i5cDVwcqiJBBtuo9+FeIJOtZ9W1kA5M6AMJRHUZlpYZ1/SbEwtO0ioNAW8rUooVpC/WehY2SfA==", 1758 | "dev": true, 1759 | "hasInstallScript": true, 1760 | "bin": { 1761 | "esbuild": "bin/esbuild" 1762 | }, 1763 | "engines": { 1764 | "node": ">=12" 1765 | }, 1766 | "optionalDependencies": { 1767 | "@esbuild/aix-ppc64": "0.19.11", 1768 | "@esbuild/android-arm": "0.19.11", 1769 | "@esbuild/android-arm64": "0.19.11", 1770 | "@esbuild/android-x64": "0.19.11", 1771 | "@esbuild/darwin-arm64": "0.19.11", 1772 | "@esbuild/darwin-x64": "0.19.11", 1773 | "@esbuild/freebsd-arm64": "0.19.11", 1774 | "@esbuild/freebsd-x64": "0.19.11", 1775 | "@esbuild/linux-arm": "0.19.11", 1776 | "@esbuild/linux-arm64": "0.19.11", 1777 | "@esbuild/linux-ia32": "0.19.11", 1778 | "@esbuild/linux-loong64": "0.19.11", 1779 | "@esbuild/linux-mips64el": "0.19.11", 1780 | "@esbuild/linux-ppc64": "0.19.11", 1781 | "@esbuild/linux-riscv64": "0.19.11", 1782 | "@esbuild/linux-s390x": "0.19.11", 1783 | "@esbuild/linux-x64": "0.19.11", 1784 | "@esbuild/netbsd-x64": "0.19.11", 1785 | "@esbuild/openbsd-x64": "0.19.11", 1786 | "@esbuild/sunos-x64": "0.19.11", 1787 | "@esbuild/win32-arm64": "0.19.11", 1788 | "@esbuild/win32-ia32": "0.19.11", 1789 | "@esbuild/win32-x64": "0.19.11" 1790 | } 1791 | }, 1792 | "node_modules/escalade": { 1793 | "version": "3.1.1", 1794 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1795 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1796 | "dev": true, 1797 | "engines": { 1798 | "node": ">=6" 1799 | } 1800 | }, 1801 | "node_modules/escape-string-regexp": { 1802 | "version": "1.0.5", 1803 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1804 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1805 | "dev": true, 1806 | "engines": { 1807 | "node": ">=0.8.0" 1808 | } 1809 | }, 1810 | "node_modules/eslint": { 1811 | "version": "8.56.0", 1812 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", 1813 | "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", 1814 | "dev": true, 1815 | "dependencies": { 1816 | "@eslint-community/eslint-utils": "^4.2.0", 1817 | "@eslint-community/regexpp": "^4.6.1", 1818 | "@eslint/eslintrc": "^2.1.4", 1819 | "@eslint/js": "8.56.0", 1820 | "@humanwhocodes/config-array": "^0.11.13", 1821 | "@humanwhocodes/module-importer": "^1.0.1", 1822 | "@nodelib/fs.walk": "^1.2.8", 1823 | "@ungap/structured-clone": "^1.2.0", 1824 | "ajv": "^6.12.4", 1825 | "chalk": "^4.0.0", 1826 | "cross-spawn": "^7.0.2", 1827 | "debug": "^4.3.2", 1828 | "doctrine": "^3.0.0", 1829 | "escape-string-regexp": "^4.0.0", 1830 | "eslint-scope": "^7.2.2", 1831 | "eslint-visitor-keys": "^3.4.3", 1832 | "espree": "^9.6.1", 1833 | "esquery": "^1.4.2", 1834 | "esutils": "^2.0.2", 1835 | "fast-deep-equal": "^3.1.3", 1836 | "file-entry-cache": "^6.0.1", 1837 | "find-up": "^5.0.0", 1838 | "glob-parent": "^6.0.2", 1839 | "globals": "^13.19.0", 1840 | "graphemer": "^1.4.0", 1841 | "ignore": "^5.2.0", 1842 | "imurmurhash": "^0.1.4", 1843 | "is-glob": "^4.0.0", 1844 | "is-path-inside": "^3.0.3", 1845 | "js-yaml": "^4.1.0", 1846 | "json-stable-stringify-without-jsonify": "^1.0.1", 1847 | "levn": "^0.4.1", 1848 | "lodash.merge": "^4.6.2", 1849 | "minimatch": "^3.1.2", 1850 | "natural-compare": "^1.4.0", 1851 | "optionator": "^0.9.3", 1852 | "strip-ansi": "^6.0.1", 1853 | "text-table": "^0.2.0" 1854 | }, 1855 | "bin": { 1856 | "eslint": "bin/eslint.js" 1857 | }, 1858 | "engines": { 1859 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1860 | }, 1861 | "funding": { 1862 | "url": "https://opencollective.com/eslint" 1863 | } 1864 | }, 1865 | "node_modules/eslint-plugin-react-hooks": { 1866 | "version": "4.6.0", 1867 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", 1868 | "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", 1869 | "dev": true, 1870 | "engines": { 1871 | "node": ">=10" 1872 | }, 1873 | "peerDependencies": { 1874 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 1875 | } 1876 | }, 1877 | "node_modules/eslint-plugin-react-refresh": { 1878 | "version": "0.4.5", 1879 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.5.tgz", 1880 | "integrity": "sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==", 1881 | "dev": true, 1882 | "peerDependencies": { 1883 | "eslint": ">=7" 1884 | } 1885 | }, 1886 | "node_modules/eslint-scope": { 1887 | "version": "7.2.2", 1888 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 1889 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 1890 | "dev": true, 1891 | "dependencies": { 1892 | "esrecurse": "^4.3.0", 1893 | "estraverse": "^5.2.0" 1894 | }, 1895 | "engines": { 1896 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1897 | }, 1898 | "funding": { 1899 | "url": "https://opencollective.com/eslint" 1900 | } 1901 | }, 1902 | "node_modules/eslint-visitor-keys": { 1903 | "version": "3.4.3", 1904 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1905 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1906 | "dev": true, 1907 | "engines": { 1908 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1909 | }, 1910 | "funding": { 1911 | "url": "https://opencollective.com/eslint" 1912 | } 1913 | }, 1914 | "node_modules/eslint/node_modules/ansi-styles": { 1915 | "version": "4.3.0", 1916 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1917 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1918 | "dev": true, 1919 | "dependencies": { 1920 | "color-convert": "^2.0.1" 1921 | }, 1922 | "engines": { 1923 | "node": ">=8" 1924 | }, 1925 | "funding": { 1926 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1927 | } 1928 | }, 1929 | "node_modules/eslint/node_modules/brace-expansion": { 1930 | "version": "1.1.11", 1931 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1932 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1933 | "dev": true, 1934 | "dependencies": { 1935 | "balanced-match": "^1.0.0", 1936 | "concat-map": "0.0.1" 1937 | } 1938 | }, 1939 | "node_modules/eslint/node_modules/chalk": { 1940 | "version": "4.1.2", 1941 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1942 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1943 | "dev": true, 1944 | "dependencies": { 1945 | "ansi-styles": "^4.1.0", 1946 | "supports-color": "^7.1.0" 1947 | }, 1948 | "engines": { 1949 | "node": ">=10" 1950 | }, 1951 | "funding": { 1952 | "url": "https://github.com/chalk/chalk?sponsor=1" 1953 | } 1954 | }, 1955 | "node_modules/eslint/node_modules/color-convert": { 1956 | "version": "2.0.1", 1957 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1958 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1959 | "dev": true, 1960 | "dependencies": { 1961 | "color-name": "~1.1.4" 1962 | }, 1963 | "engines": { 1964 | "node": ">=7.0.0" 1965 | } 1966 | }, 1967 | "node_modules/eslint/node_modules/color-name": { 1968 | "version": "1.1.4", 1969 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1970 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1971 | "dev": true 1972 | }, 1973 | "node_modules/eslint/node_modules/escape-string-regexp": { 1974 | "version": "4.0.0", 1975 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1976 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1977 | "dev": true, 1978 | "engines": { 1979 | "node": ">=10" 1980 | }, 1981 | "funding": { 1982 | "url": "https://github.com/sponsors/sindresorhus" 1983 | } 1984 | }, 1985 | "node_modules/eslint/node_modules/globals": { 1986 | "version": "13.24.0", 1987 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 1988 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 1989 | "dev": true, 1990 | "dependencies": { 1991 | "type-fest": "^0.20.2" 1992 | }, 1993 | "engines": { 1994 | "node": ">=8" 1995 | }, 1996 | "funding": { 1997 | "url": "https://github.com/sponsors/sindresorhus" 1998 | } 1999 | }, 2000 | "node_modules/eslint/node_modules/has-flag": { 2001 | "version": "4.0.0", 2002 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2003 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2004 | "dev": true, 2005 | "engines": { 2006 | "node": ">=8" 2007 | } 2008 | }, 2009 | "node_modules/eslint/node_modules/minimatch": { 2010 | "version": "3.1.2", 2011 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2012 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2013 | "dev": true, 2014 | "dependencies": { 2015 | "brace-expansion": "^1.1.7" 2016 | }, 2017 | "engines": { 2018 | "node": "*" 2019 | } 2020 | }, 2021 | "node_modules/eslint/node_modules/supports-color": { 2022 | "version": "7.2.0", 2023 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2024 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2025 | "dev": true, 2026 | "dependencies": { 2027 | "has-flag": "^4.0.0" 2028 | }, 2029 | "engines": { 2030 | "node": ">=8" 2031 | } 2032 | }, 2033 | "node_modules/espree": { 2034 | "version": "9.6.1", 2035 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2036 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2037 | "dev": true, 2038 | "dependencies": { 2039 | "acorn": "^8.9.0", 2040 | "acorn-jsx": "^5.3.2", 2041 | "eslint-visitor-keys": "^3.4.1" 2042 | }, 2043 | "engines": { 2044 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2045 | }, 2046 | "funding": { 2047 | "url": "https://opencollective.com/eslint" 2048 | } 2049 | }, 2050 | "node_modules/esquery": { 2051 | "version": "1.5.0", 2052 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2053 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2054 | "dev": true, 2055 | "dependencies": { 2056 | "estraverse": "^5.1.0" 2057 | }, 2058 | "engines": { 2059 | "node": ">=0.10" 2060 | } 2061 | }, 2062 | "node_modules/esrecurse": { 2063 | "version": "4.3.0", 2064 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2065 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2066 | "dev": true, 2067 | "dependencies": { 2068 | "estraverse": "^5.2.0" 2069 | }, 2070 | "engines": { 2071 | "node": ">=4.0" 2072 | } 2073 | }, 2074 | "node_modules/estraverse": { 2075 | "version": "5.3.0", 2076 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2077 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2078 | "dev": true, 2079 | "engines": { 2080 | "node": ">=4.0" 2081 | } 2082 | }, 2083 | "node_modules/esutils": { 2084 | "version": "2.0.3", 2085 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2086 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2087 | "dev": true, 2088 | "engines": { 2089 | "node": ">=0.10.0" 2090 | } 2091 | }, 2092 | "node_modules/fast-deep-equal": { 2093 | "version": "3.1.3", 2094 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2095 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2096 | "dev": true 2097 | }, 2098 | "node_modules/fast-glob": { 2099 | "version": "3.3.2", 2100 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 2101 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 2102 | "dev": true, 2103 | "dependencies": { 2104 | "@nodelib/fs.stat": "^2.0.2", 2105 | "@nodelib/fs.walk": "^1.2.3", 2106 | "glob-parent": "^5.1.2", 2107 | "merge2": "^1.3.0", 2108 | "micromatch": "^4.0.4" 2109 | }, 2110 | "engines": { 2111 | "node": ">=8.6.0" 2112 | } 2113 | }, 2114 | "node_modules/fast-glob/node_modules/glob-parent": { 2115 | "version": "5.1.2", 2116 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2117 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2118 | "dev": true, 2119 | "dependencies": { 2120 | "is-glob": "^4.0.1" 2121 | }, 2122 | "engines": { 2123 | "node": ">= 6" 2124 | } 2125 | }, 2126 | "node_modules/fast-json-stable-stringify": { 2127 | "version": "2.1.0", 2128 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2129 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2130 | "dev": true 2131 | }, 2132 | "node_modules/fast-levenshtein": { 2133 | "version": "2.0.6", 2134 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2135 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2136 | "dev": true 2137 | }, 2138 | "node_modules/fastq": { 2139 | "version": "1.16.0", 2140 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", 2141 | "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", 2142 | "dev": true, 2143 | "dependencies": { 2144 | "reusify": "^1.0.4" 2145 | } 2146 | }, 2147 | "node_modules/file-entry-cache": { 2148 | "version": "6.0.1", 2149 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2150 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2151 | "dev": true, 2152 | "dependencies": { 2153 | "flat-cache": "^3.0.4" 2154 | }, 2155 | "engines": { 2156 | "node": "^10.12.0 || >=12.0.0" 2157 | } 2158 | }, 2159 | "node_modules/fill-range": { 2160 | "version": "7.0.1", 2161 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2162 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2163 | "dev": true, 2164 | "dependencies": { 2165 | "to-regex-range": "^5.0.1" 2166 | }, 2167 | "engines": { 2168 | "node": ">=8" 2169 | } 2170 | }, 2171 | "node_modules/find-up": { 2172 | "version": "5.0.0", 2173 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2174 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2175 | "dev": true, 2176 | "dependencies": { 2177 | "locate-path": "^6.0.0", 2178 | "path-exists": "^4.0.0" 2179 | }, 2180 | "engines": { 2181 | "node": ">=10" 2182 | }, 2183 | "funding": { 2184 | "url": "https://github.com/sponsors/sindresorhus" 2185 | } 2186 | }, 2187 | "node_modules/flat-cache": { 2188 | "version": "3.2.0", 2189 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2190 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2191 | "dev": true, 2192 | "dependencies": { 2193 | "flatted": "^3.2.9", 2194 | "keyv": "^4.5.3", 2195 | "rimraf": "^3.0.2" 2196 | }, 2197 | "engines": { 2198 | "node": "^10.12.0 || >=12.0.0" 2199 | } 2200 | }, 2201 | "node_modules/flatted": { 2202 | "version": "3.2.9", 2203 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 2204 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 2205 | "dev": true 2206 | }, 2207 | "node_modules/fs.realpath": { 2208 | "version": "1.0.0", 2209 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2210 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2211 | "dev": true 2212 | }, 2213 | "node_modules/fsevents": { 2214 | "version": "2.3.3", 2215 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2216 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2217 | "dev": true, 2218 | "hasInstallScript": true, 2219 | "optional": true, 2220 | "os": [ 2221 | "darwin" 2222 | ], 2223 | "engines": { 2224 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2225 | } 2226 | }, 2227 | "node_modules/gensync": { 2228 | "version": "1.0.0-beta.2", 2229 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2230 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2231 | "dev": true, 2232 | "engines": { 2233 | "node": ">=6.9.0" 2234 | } 2235 | }, 2236 | "node_modules/glob": { 2237 | "version": "7.2.3", 2238 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2239 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2240 | "dev": true, 2241 | "dependencies": { 2242 | "fs.realpath": "^1.0.0", 2243 | "inflight": "^1.0.4", 2244 | "inherits": "2", 2245 | "minimatch": "^3.1.1", 2246 | "once": "^1.3.0", 2247 | "path-is-absolute": "^1.0.0" 2248 | }, 2249 | "engines": { 2250 | "node": "*" 2251 | }, 2252 | "funding": { 2253 | "url": "https://github.com/sponsors/isaacs" 2254 | } 2255 | }, 2256 | "node_modules/glob-parent": { 2257 | "version": "6.0.2", 2258 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2259 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2260 | "dev": true, 2261 | "dependencies": { 2262 | "is-glob": "^4.0.3" 2263 | }, 2264 | "engines": { 2265 | "node": ">=10.13.0" 2266 | } 2267 | }, 2268 | "node_modules/glob/node_modules/brace-expansion": { 2269 | "version": "1.1.11", 2270 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2271 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2272 | "dev": true, 2273 | "dependencies": { 2274 | "balanced-match": "^1.0.0", 2275 | "concat-map": "0.0.1" 2276 | } 2277 | }, 2278 | "node_modules/glob/node_modules/minimatch": { 2279 | "version": "3.1.2", 2280 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2281 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2282 | "dev": true, 2283 | "dependencies": { 2284 | "brace-expansion": "^1.1.7" 2285 | }, 2286 | "engines": { 2287 | "node": "*" 2288 | } 2289 | }, 2290 | "node_modules/globals": { 2291 | "version": "11.12.0", 2292 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2293 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2294 | "dev": true, 2295 | "engines": { 2296 | "node": ">=4" 2297 | } 2298 | }, 2299 | "node_modules/globby": { 2300 | "version": "11.1.0", 2301 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2302 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2303 | "dev": true, 2304 | "dependencies": { 2305 | "array-union": "^2.1.0", 2306 | "dir-glob": "^3.0.1", 2307 | "fast-glob": "^3.2.9", 2308 | "ignore": "^5.2.0", 2309 | "merge2": "^1.4.1", 2310 | "slash": "^3.0.0" 2311 | }, 2312 | "engines": { 2313 | "node": ">=10" 2314 | }, 2315 | "funding": { 2316 | "url": "https://github.com/sponsors/sindresorhus" 2317 | } 2318 | }, 2319 | "node_modules/graphemer": { 2320 | "version": "1.4.0", 2321 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2322 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2323 | "dev": true 2324 | }, 2325 | "node_modules/has-flag": { 2326 | "version": "3.0.0", 2327 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2328 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2329 | "dev": true, 2330 | "engines": { 2331 | "node": ">=4" 2332 | } 2333 | }, 2334 | "node_modules/ignore": { 2335 | "version": "5.3.0", 2336 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", 2337 | "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", 2338 | "dev": true, 2339 | "engines": { 2340 | "node": ">= 4" 2341 | } 2342 | }, 2343 | "node_modules/import-fresh": { 2344 | "version": "3.3.0", 2345 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2346 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2347 | "dev": true, 2348 | "dependencies": { 2349 | "parent-module": "^1.0.0", 2350 | "resolve-from": "^4.0.0" 2351 | }, 2352 | "engines": { 2353 | "node": ">=6" 2354 | }, 2355 | "funding": { 2356 | "url": "https://github.com/sponsors/sindresorhus" 2357 | } 2358 | }, 2359 | "node_modules/imurmurhash": { 2360 | "version": "0.1.4", 2361 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2362 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2363 | "dev": true, 2364 | "engines": { 2365 | "node": ">=0.8.19" 2366 | } 2367 | }, 2368 | "node_modules/inflight": { 2369 | "version": "1.0.6", 2370 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2371 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2372 | "dev": true, 2373 | "dependencies": { 2374 | "once": "^1.3.0", 2375 | "wrappy": "1" 2376 | } 2377 | }, 2378 | "node_modules/inherits": { 2379 | "version": "2.0.4", 2380 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2381 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2382 | "dev": true 2383 | }, 2384 | "node_modules/is-extglob": { 2385 | "version": "2.1.1", 2386 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2387 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2388 | "dev": true, 2389 | "engines": { 2390 | "node": ">=0.10.0" 2391 | } 2392 | }, 2393 | "node_modules/is-glob": { 2394 | "version": "4.0.3", 2395 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2396 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2397 | "dev": true, 2398 | "dependencies": { 2399 | "is-extglob": "^2.1.1" 2400 | }, 2401 | "engines": { 2402 | "node": ">=0.10.0" 2403 | } 2404 | }, 2405 | "node_modules/is-number": { 2406 | "version": "7.0.0", 2407 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2408 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2409 | "dev": true, 2410 | "engines": { 2411 | "node": ">=0.12.0" 2412 | } 2413 | }, 2414 | "node_modules/is-path-inside": { 2415 | "version": "3.0.3", 2416 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2417 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2418 | "dev": true, 2419 | "engines": { 2420 | "node": ">=8" 2421 | } 2422 | }, 2423 | "node_modules/isexe": { 2424 | "version": "2.0.0", 2425 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2426 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2427 | "dev": true 2428 | }, 2429 | "node_modules/js-tokens": { 2430 | "version": "4.0.0", 2431 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2432 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2433 | }, 2434 | "node_modules/js-yaml": { 2435 | "version": "4.1.0", 2436 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2437 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2438 | "dev": true, 2439 | "dependencies": { 2440 | "argparse": "^2.0.1" 2441 | }, 2442 | "bin": { 2443 | "js-yaml": "bin/js-yaml.js" 2444 | } 2445 | }, 2446 | "node_modules/jsesc": { 2447 | "version": "2.5.2", 2448 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2449 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2450 | "dev": true, 2451 | "bin": { 2452 | "jsesc": "bin/jsesc" 2453 | }, 2454 | "engines": { 2455 | "node": ">=4" 2456 | } 2457 | }, 2458 | "node_modules/json-buffer": { 2459 | "version": "3.0.1", 2460 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2461 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2462 | "dev": true 2463 | }, 2464 | "node_modules/json-schema-traverse": { 2465 | "version": "0.4.1", 2466 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2467 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2468 | "dev": true 2469 | }, 2470 | "node_modules/json-stable-stringify-without-jsonify": { 2471 | "version": "1.0.1", 2472 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2473 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2474 | "dev": true 2475 | }, 2476 | "node_modules/json5": { 2477 | "version": "2.2.3", 2478 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2479 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2480 | "dev": true, 2481 | "bin": { 2482 | "json5": "lib/cli.js" 2483 | }, 2484 | "engines": { 2485 | "node": ">=6" 2486 | } 2487 | }, 2488 | "node_modules/keyv": { 2489 | "version": "4.5.4", 2490 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2491 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2492 | "dev": true, 2493 | "dependencies": { 2494 | "json-buffer": "3.0.1" 2495 | } 2496 | }, 2497 | "node_modules/levn": { 2498 | "version": "0.4.1", 2499 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2500 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2501 | "dev": true, 2502 | "dependencies": { 2503 | "prelude-ls": "^1.2.1", 2504 | "type-check": "~0.4.0" 2505 | }, 2506 | "engines": { 2507 | "node": ">= 0.8.0" 2508 | } 2509 | }, 2510 | "node_modules/locate-path": { 2511 | "version": "6.0.0", 2512 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2513 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2514 | "dev": true, 2515 | "dependencies": { 2516 | "p-locate": "^5.0.0" 2517 | }, 2518 | "engines": { 2519 | "node": ">=10" 2520 | }, 2521 | "funding": { 2522 | "url": "https://github.com/sponsors/sindresorhus" 2523 | } 2524 | }, 2525 | "node_modules/lodash.merge": { 2526 | "version": "4.6.2", 2527 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2528 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2529 | "dev": true 2530 | }, 2531 | "node_modules/loose-envify": { 2532 | "version": "1.4.0", 2533 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2534 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2535 | "dependencies": { 2536 | "js-tokens": "^3.0.0 || ^4.0.0" 2537 | }, 2538 | "bin": { 2539 | "loose-envify": "cli.js" 2540 | } 2541 | }, 2542 | "node_modules/lru-cache": { 2543 | "version": "5.1.1", 2544 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2545 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2546 | "dev": true, 2547 | "dependencies": { 2548 | "yallist": "^3.0.2" 2549 | } 2550 | }, 2551 | "node_modules/merge2": { 2552 | "version": "1.4.1", 2553 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2554 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2555 | "dev": true, 2556 | "engines": { 2557 | "node": ">= 8" 2558 | } 2559 | }, 2560 | "node_modules/micromatch": { 2561 | "version": "4.0.5", 2562 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2563 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2564 | "dev": true, 2565 | "dependencies": { 2566 | "braces": "^3.0.2", 2567 | "picomatch": "^2.3.1" 2568 | }, 2569 | "engines": { 2570 | "node": ">=8.6" 2571 | } 2572 | }, 2573 | "node_modules/minimatch": { 2574 | "version": "9.0.3", 2575 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 2576 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 2577 | "dev": true, 2578 | "dependencies": { 2579 | "brace-expansion": "^2.0.1" 2580 | }, 2581 | "engines": { 2582 | "node": ">=16 || 14 >=14.17" 2583 | }, 2584 | "funding": { 2585 | "url": "https://github.com/sponsors/isaacs" 2586 | } 2587 | }, 2588 | "node_modules/ms": { 2589 | "version": "2.1.2", 2590 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2591 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2592 | "dev": true 2593 | }, 2594 | "node_modules/nanoid": { 2595 | "version": "3.3.7", 2596 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 2597 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 2598 | "dev": true, 2599 | "funding": [ 2600 | { 2601 | "type": "github", 2602 | "url": "https://github.com/sponsors/ai" 2603 | } 2604 | ], 2605 | "bin": { 2606 | "nanoid": "bin/nanoid.cjs" 2607 | }, 2608 | "engines": { 2609 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2610 | } 2611 | }, 2612 | "node_modules/natural-compare": { 2613 | "version": "1.4.0", 2614 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2615 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2616 | "dev": true 2617 | }, 2618 | "node_modules/node-releases": { 2619 | "version": "2.0.14", 2620 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", 2621 | "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", 2622 | "dev": true 2623 | }, 2624 | "node_modules/once": { 2625 | "version": "1.4.0", 2626 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2627 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2628 | "dev": true, 2629 | "dependencies": { 2630 | "wrappy": "1" 2631 | } 2632 | }, 2633 | "node_modules/optionator": { 2634 | "version": "0.9.3", 2635 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2636 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2637 | "dev": true, 2638 | "dependencies": { 2639 | "@aashutoshrathi/word-wrap": "^1.2.3", 2640 | "deep-is": "^0.1.3", 2641 | "fast-levenshtein": "^2.0.6", 2642 | "levn": "^0.4.1", 2643 | "prelude-ls": "^1.2.1", 2644 | "type-check": "^0.4.0" 2645 | }, 2646 | "engines": { 2647 | "node": ">= 0.8.0" 2648 | } 2649 | }, 2650 | "node_modules/p-limit": { 2651 | "version": "3.1.0", 2652 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2653 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2654 | "dev": true, 2655 | "dependencies": { 2656 | "yocto-queue": "^0.1.0" 2657 | }, 2658 | "engines": { 2659 | "node": ">=10" 2660 | }, 2661 | "funding": { 2662 | "url": "https://github.com/sponsors/sindresorhus" 2663 | } 2664 | }, 2665 | "node_modules/p-locate": { 2666 | "version": "5.0.0", 2667 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2668 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2669 | "dev": true, 2670 | "dependencies": { 2671 | "p-limit": "^3.0.2" 2672 | }, 2673 | "engines": { 2674 | "node": ">=10" 2675 | }, 2676 | "funding": { 2677 | "url": "https://github.com/sponsors/sindresorhus" 2678 | } 2679 | }, 2680 | "node_modules/parent-module": { 2681 | "version": "1.0.1", 2682 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2683 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2684 | "dev": true, 2685 | "dependencies": { 2686 | "callsites": "^3.0.0" 2687 | }, 2688 | "engines": { 2689 | "node": ">=6" 2690 | } 2691 | }, 2692 | "node_modules/path-exists": { 2693 | "version": "4.0.0", 2694 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2695 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2696 | "dev": true, 2697 | "engines": { 2698 | "node": ">=8" 2699 | } 2700 | }, 2701 | "node_modules/path-is-absolute": { 2702 | "version": "1.0.1", 2703 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2704 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2705 | "dev": true, 2706 | "engines": { 2707 | "node": ">=0.10.0" 2708 | } 2709 | }, 2710 | "node_modules/path-key": { 2711 | "version": "3.1.1", 2712 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2713 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2714 | "dev": true, 2715 | "engines": { 2716 | "node": ">=8" 2717 | } 2718 | }, 2719 | "node_modules/path-type": { 2720 | "version": "4.0.0", 2721 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2722 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2723 | "dev": true, 2724 | "engines": { 2725 | "node": ">=8" 2726 | } 2727 | }, 2728 | "node_modules/picocolors": { 2729 | "version": "1.0.0", 2730 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2731 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2732 | "dev": true 2733 | }, 2734 | "node_modules/picomatch": { 2735 | "version": "2.3.1", 2736 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2737 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2738 | "dev": true, 2739 | "engines": { 2740 | "node": ">=8.6" 2741 | }, 2742 | "funding": { 2743 | "url": "https://github.com/sponsors/jonschlinkert" 2744 | } 2745 | }, 2746 | "node_modules/postcss": { 2747 | "version": "8.4.33", 2748 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.33.tgz", 2749 | "integrity": "sha512-Kkpbhhdjw2qQs2O2DGX+8m5OVqEcbB9HRBvuYM9pgrjEFUg30A9LmXNlTAUj4S9kgtGyrMbTzVjH7E+s5Re2yg==", 2750 | "dev": true, 2751 | "funding": [ 2752 | { 2753 | "type": "opencollective", 2754 | "url": "https://opencollective.com/postcss/" 2755 | }, 2756 | { 2757 | "type": "tidelift", 2758 | "url": "https://tidelift.com/funding/github/npm/postcss" 2759 | }, 2760 | { 2761 | "type": "github", 2762 | "url": "https://github.com/sponsors/ai" 2763 | } 2764 | ], 2765 | "dependencies": { 2766 | "nanoid": "^3.3.7", 2767 | "picocolors": "^1.0.0", 2768 | "source-map-js": "^1.0.2" 2769 | }, 2770 | "engines": { 2771 | "node": "^10 || ^12 || >=14" 2772 | } 2773 | }, 2774 | "node_modules/prelude-ls": { 2775 | "version": "1.2.1", 2776 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2777 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2778 | "dev": true, 2779 | "engines": { 2780 | "node": ">= 0.8.0" 2781 | } 2782 | }, 2783 | "node_modules/punycode": { 2784 | "version": "2.3.1", 2785 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2786 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2787 | "dev": true, 2788 | "engines": { 2789 | "node": ">=6" 2790 | } 2791 | }, 2792 | "node_modules/queue-microtask": { 2793 | "version": "1.2.3", 2794 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2795 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2796 | "dev": true, 2797 | "funding": [ 2798 | { 2799 | "type": "github", 2800 | "url": "https://github.com/sponsors/feross" 2801 | }, 2802 | { 2803 | "type": "patreon", 2804 | "url": "https://www.patreon.com/feross" 2805 | }, 2806 | { 2807 | "type": "consulting", 2808 | "url": "https://feross.org/support" 2809 | } 2810 | ] 2811 | }, 2812 | "node_modules/react": { 2813 | "version": "18.2.0", 2814 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 2815 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 2816 | "dependencies": { 2817 | "loose-envify": "^1.1.0" 2818 | }, 2819 | "engines": { 2820 | "node": ">=0.10.0" 2821 | } 2822 | }, 2823 | "node_modules/react-dom": { 2824 | "version": "18.2.0", 2825 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 2826 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 2827 | "dependencies": { 2828 | "loose-envify": "^1.1.0", 2829 | "scheduler": "^0.23.0" 2830 | }, 2831 | "peerDependencies": { 2832 | "react": "^18.2.0" 2833 | } 2834 | }, 2835 | "node_modules/react-refresh": { 2836 | "version": "0.14.0", 2837 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 2838 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 2839 | "dev": true, 2840 | "engines": { 2841 | "node": ">=0.10.0" 2842 | } 2843 | }, 2844 | "node_modules/reactotron-core-client": { 2845 | "version": "2.8.11", 2846 | "resolved": "https://registry.npmjs.org/reactotron-core-client/-/reactotron-core-client-2.8.11.tgz", 2847 | "integrity": "sha512-zoqKrAqWjTPpa1s1AtVZPZItYE8Kjgs99v9gcKMCW2Ejcba9fYOoRCwu0zqoHU8iWyBzJsOWVai0FdRVRUHf8Q==", 2848 | "dev": true, 2849 | "dependencies": { 2850 | "reactotron-core-contract": "0.1.1" 2851 | } 2852 | }, 2853 | "node_modules/reactotron-core-contract": { 2854 | "version": "0.1.1", 2855 | "resolved": "https://registry.npmjs.org/reactotron-core-contract/-/reactotron-core-contract-0.1.1.tgz", 2856 | "integrity": "sha512-NmmojG6Pz97NJe8ov0oZgIxxaaEkXsVAiFOeFTI4QH03qMqAs6d28nUd5bTrKLipxWy5rPr4PXITE7AHdT0kaw==", 2857 | "dev": true 2858 | }, 2859 | "node_modules/reactotron-react-js": { 2860 | "version": "3.3.9", 2861 | "resolved": "https://registry.npmjs.org/reactotron-react-js/-/reactotron-react-js-3.3.9.tgz", 2862 | "integrity": "sha512-EKql8RumpNPTOEYHHO8/th7Ckb0YXQoZmJLyjv8N2ckNO2+5EVMSe1Tg4BQxJ2bFGeypbp2wZ2Vuhk2WEU1XyA==", 2863 | "dev": true, 2864 | "dependencies": { 2865 | "reactotron-core-client": "2.8.11", 2866 | "stacktrace-js": "2.0.1" 2867 | } 2868 | }, 2869 | "node_modules/resolve-from": { 2870 | "version": "4.0.0", 2871 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2872 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2873 | "dev": true, 2874 | "engines": { 2875 | "node": ">=4" 2876 | } 2877 | }, 2878 | "node_modules/reusify": { 2879 | "version": "1.0.4", 2880 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2881 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2882 | "dev": true, 2883 | "engines": { 2884 | "iojs": ">=1.0.0", 2885 | "node": ">=0.10.0" 2886 | } 2887 | }, 2888 | "node_modules/rimraf": { 2889 | "version": "3.0.2", 2890 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2891 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2892 | "dev": true, 2893 | "dependencies": { 2894 | "glob": "^7.1.3" 2895 | }, 2896 | "bin": { 2897 | "rimraf": "bin.js" 2898 | }, 2899 | "funding": { 2900 | "url": "https://github.com/sponsors/isaacs" 2901 | } 2902 | }, 2903 | "node_modules/rollup": { 2904 | "version": "4.9.5", 2905 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.5.tgz", 2906 | "integrity": "sha512-E4vQW0H/mbNMw2yLSqJyjtkHY9dslf/p0zuT1xehNRqUTBOFMqEjguDvqhXr7N7r/4ttb2jr4T41d3dncmIgbQ==", 2907 | "dev": true, 2908 | "dependencies": { 2909 | "@types/estree": "1.0.5" 2910 | }, 2911 | "bin": { 2912 | "rollup": "dist/bin/rollup" 2913 | }, 2914 | "engines": { 2915 | "node": ">=18.0.0", 2916 | "npm": ">=8.0.0" 2917 | }, 2918 | "optionalDependencies": { 2919 | "@rollup/rollup-android-arm-eabi": "4.9.5", 2920 | "@rollup/rollup-android-arm64": "4.9.5", 2921 | "@rollup/rollup-darwin-arm64": "4.9.5", 2922 | "@rollup/rollup-darwin-x64": "4.9.5", 2923 | "@rollup/rollup-linux-arm-gnueabihf": "4.9.5", 2924 | "@rollup/rollup-linux-arm64-gnu": "4.9.5", 2925 | "@rollup/rollup-linux-arm64-musl": "4.9.5", 2926 | "@rollup/rollup-linux-riscv64-gnu": "4.9.5", 2927 | "@rollup/rollup-linux-x64-gnu": "4.9.5", 2928 | "@rollup/rollup-linux-x64-musl": "4.9.5", 2929 | "@rollup/rollup-win32-arm64-msvc": "4.9.5", 2930 | "@rollup/rollup-win32-ia32-msvc": "4.9.5", 2931 | "@rollup/rollup-win32-x64-msvc": "4.9.5", 2932 | "fsevents": "~2.3.2" 2933 | } 2934 | }, 2935 | "node_modules/run-parallel": { 2936 | "version": "1.2.0", 2937 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2938 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2939 | "dev": true, 2940 | "funding": [ 2941 | { 2942 | "type": "github", 2943 | "url": "https://github.com/sponsors/feross" 2944 | }, 2945 | { 2946 | "type": "patreon", 2947 | "url": "https://www.patreon.com/feross" 2948 | }, 2949 | { 2950 | "type": "consulting", 2951 | "url": "https://feross.org/support" 2952 | } 2953 | ], 2954 | "dependencies": { 2955 | "queue-microtask": "^1.2.2" 2956 | } 2957 | }, 2958 | "node_modules/scheduler": { 2959 | "version": "0.23.0", 2960 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 2961 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 2962 | "dependencies": { 2963 | "loose-envify": "^1.1.0" 2964 | } 2965 | }, 2966 | "node_modules/semver": { 2967 | "version": "7.5.4", 2968 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 2969 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 2970 | "dev": true, 2971 | "dependencies": { 2972 | "lru-cache": "^6.0.0" 2973 | }, 2974 | "bin": { 2975 | "semver": "bin/semver.js" 2976 | }, 2977 | "engines": { 2978 | "node": ">=10" 2979 | } 2980 | }, 2981 | "node_modules/semver/node_modules/lru-cache": { 2982 | "version": "6.0.0", 2983 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2984 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2985 | "dev": true, 2986 | "dependencies": { 2987 | "yallist": "^4.0.0" 2988 | }, 2989 | "engines": { 2990 | "node": ">=10" 2991 | } 2992 | }, 2993 | "node_modules/semver/node_modules/yallist": { 2994 | "version": "4.0.0", 2995 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2996 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2997 | "dev": true 2998 | }, 2999 | "node_modules/shebang-command": { 3000 | "version": "2.0.0", 3001 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3002 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3003 | "dev": true, 3004 | "dependencies": { 3005 | "shebang-regex": "^3.0.0" 3006 | }, 3007 | "engines": { 3008 | "node": ">=8" 3009 | } 3010 | }, 3011 | "node_modules/shebang-regex": { 3012 | "version": "3.0.0", 3013 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3014 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3015 | "dev": true, 3016 | "engines": { 3017 | "node": ">=8" 3018 | } 3019 | }, 3020 | "node_modules/slash": { 3021 | "version": "3.0.0", 3022 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3023 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3024 | "dev": true, 3025 | "engines": { 3026 | "node": ">=8" 3027 | } 3028 | }, 3029 | "node_modules/source-map": { 3030 | "version": "0.5.6", 3031 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", 3032 | "integrity": "sha512-MjZkVp0NHr5+TPihLcadqnlVoGIoWo4IBHptutGh9wI3ttUYvCG26HkSuDi+K6lsZ25syXJXcctwgyVCt//xqA==", 3033 | "dev": true, 3034 | "engines": { 3035 | "node": ">=0.10.0" 3036 | } 3037 | }, 3038 | "node_modules/source-map-js": { 3039 | "version": "1.0.2", 3040 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 3041 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 3042 | "dev": true, 3043 | "engines": { 3044 | "node": ">=0.10.0" 3045 | } 3046 | }, 3047 | "node_modules/stack-generator": { 3048 | "version": "2.0.10", 3049 | "resolved": "https://registry.npmjs.org/stack-generator/-/stack-generator-2.0.10.tgz", 3050 | "integrity": "sha512-mwnua/hkqM6pF4k8SnmZ2zfETsRUpWXREfA/goT8SLCV4iOFa4bzOX2nDipWAZFPTjLvQB82f5yaodMVhK0yJQ==", 3051 | "dev": true, 3052 | "dependencies": { 3053 | "stackframe": "^1.3.4" 3054 | } 3055 | }, 3056 | "node_modules/stackframe": { 3057 | "version": "1.3.4", 3058 | "resolved": "https://registry.npmjs.org/stackframe/-/stackframe-1.3.4.tgz", 3059 | "integrity": "sha512-oeVtt7eWQS+Na6F//S4kJ2K2VbRlS9D43mAlMyVpVWovy9o+jfgH8O9agzANzaiLjclA0oYzUXEM4PurhSUChw==", 3060 | "dev": true 3061 | }, 3062 | "node_modules/stacktrace-gps": { 3063 | "version": "3.1.2", 3064 | "resolved": "https://registry.npmjs.org/stacktrace-gps/-/stacktrace-gps-3.1.2.tgz", 3065 | "integrity": "sha512-GcUgbO4Jsqqg6RxfyTHFiPxdPqF+3LFmQhm7MgCuYQOYuWyqxo5pwRPz5d/u6/WYJdEnWfK4r+jGbyD8TSggXQ==", 3066 | "dev": true, 3067 | "dependencies": { 3068 | "source-map": "0.5.6", 3069 | "stackframe": "^1.3.4" 3070 | } 3071 | }, 3072 | "node_modules/stacktrace-js": { 3073 | "version": "2.0.1", 3074 | "resolved": "https://registry.npmjs.org/stacktrace-js/-/stacktrace-js-2.0.1.tgz", 3075 | "integrity": "sha512-13oDNgBSeWtdGa4/2BycNyKqe+VktCoJ8VLx4pDoJkwGGJVtiHdfMOAj3aW9xTi8oR2v34z9IcvfCvT6XNdNAw==", 3076 | "dev": true, 3077 | "dependencies": { 3078 | "error-stack-parser": "^2.0.4", 3079 | "stack-generator": "^2.0.4", 3080 | "stacktrace-gps": "^3.0.3" 3081 | } 3082 | }, 3083 | "node_modules/strip-ansi": { 3084 | "version": "6.0.1", 3085 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3086 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3087 | "dev": true, 3088 | "dependencies": { 3089 | "ansi-regex": "^5.0.1" 3090 | }, 3091 | "engines": { 3092 | "node": ">=8" 3093 | } 3094 | }, 3095 | "node_modules/strip-json-comments": { 3096 | "version": "3.1.1", 3097 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3098 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3099 | "dev": true, 3100 | "engines": { 3101 | "node": ">=8" 3102 | }, 3103 | "funding": { 3104 | "url": "https://github.com/sponsors/sindresorhus" 3105 | } 3106 | }, 3107 | "node_modules/supports-color": { 3108 | "version": "5.5.0", 3109 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3110 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3111 | "dev": true, 3112 | "dependencies": { 3113 | "has-flag": "^3.0.0" 3114 | }, 3115 | "engines": { 3116 | "node": ">=4" 3117 | } 3118 | }, 3119 | "node_modules/text-table": { 3120 | "version": "0.2.0", 3121 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3122 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3123 | "dev": true 3124 | }, 3125 | "node_modules/to-fast-properties": { 3126 | "version": "2.0.0", 3127 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3128 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 3129 | "dev": true, 3130 | "engines": { 3131 | "node": ">=4" 3132 | } 3133 | }, 3134 | "node_modules/to-regex-range": { 3135 | "version": "5.0.1", 3136 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3137 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3138 | "dev": true, 3139 | "dependencies": { 3140 | "is-number": "^7.0.0" 3141 | }, 3142 | "engines": { 3143 | "node": ">=8.0" 3144 | } 3145 | }, 3146 | "node_modules/ts-api-utils": { 3147 | "version": "1.0.3", 3148 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", 3149 | "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", 3150 | "dev": true, 3151 | "engines": { 3152 | "node": ">=16.13.0" 3153 | }, 3154 | "peerDependencies": { 3155 | "typescript": ">=4.2.0" 3156 | } 3157 | }, 3158 | "node_modules/type-check": { 3159 | "version": "0.4.0", 3160 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3161 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3162 | "dev": true, 3163 | "dependencies": { 3164 | "prelude-ls": "^1.2.1" 3165 | }, 3166 | "engines": { 3167 | "node": ">= 0.8.0" 3168 | } 3169 | }, 3170 | "node_modules/type-fest": { 3171 | "version": "0.20.2", 3172 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3173 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3174 | "dev": true, 3175 | "engines": { 3176 | "node": ">=10" 3177 | }, 3178 | "funding": { 3179 | "url": "https://github.com/sponsors/sindresorhus" 3180 | } 3181 | }, 3182 | "node_modules/typescript": { 3183 | "version": "5.3.3", 3184 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", 3185 | "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", 3186 | "dev": true, 3187 | "bin": { 3188 | "tsc": "bin/tsc", 3189 | "tsserver": "bin/tsserver" 3190 | }, 3191 | "engines": { 3192 | "node": ">=14.17" 3193 | } 3194 | }, 3195 | "node_modules/update-browserslist-db": { 3196 | "version": "1.0.13", 3197 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", 3198 | "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", 3199 | "dev": true, 3200 | "funding": [ 3201 | { 3202 | "type": "opencollective", 3203 | "url": "https://opencollective.com/browserslist" 3204 | }, 3205 | { 3206 | "type": "tidelift", 3207 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3208 | }, 3209 | { 3210 | "type": "github", 3211 | "url": "https://github.com/sponsors/ai" 3212 | } 3213 | ], 3214 | "dependencies": { 3215 | "escalade": "^3.1.1", 3216 | "picocolors": "^1.0.0" 3217 | }, 3218 | "bin": { 3219 | "update-browserslist-db": "cli.js" 3220 | }, 3221 | "peerDependencies": { 3222 | "browserslist": ">= 4.21.0" 3223 | } 3224 | }, 3225 | "node_modules/uri-js": { 3226 | "version": "4.4.1", 3227 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3228 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3229 | "dev": true, 3230 | "dependencies": { 3231 | "punycode": "^2.1.0" 3232 | } 3233 | }, 3234 | "node_modules/use-sync-external-store": { 3235 | "version": "1.2.0", 3236 | "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", 3237 | "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", 3238 | "peerDependencies": { 3239 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 3240 | } 3241 | }, 3242 | "node_modules/vite": { 3243 | "version": "5.0.11", 3244 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.0.11.tgz", 3245 | "integrity": "sha512-XBMnDjZcNAw/G1gEiskiM1v6yzM4GE5aMGvhWTlHAYYhxb7S3/V1s3m2LDHa8Vh6yIWYYB0iJwsEaS523c4oYA==", 3246 | "dev": true, 3247 | "dependencies": { 3248 | "esbuild": "^0.19.3", 3249 | "postcss": "^8.4.32", 3250 | "rollup": "^4.2.0" 3251 | }, 3252 | "bin": { 3253 | "vite": "bin/vite.js" 3254 | }, 3255 | "engines": { 3256 | "node": "^18.0.0 || >=20.0.0" 3257 | }, 3258 | "funding": { 3259 | "url": "https://github.com/vitejs/vite?sponsor=1" 3260 | }, 3261 | "optionalDependencies": { 3262 | "fsevents": "~2.3.3" 3263 | }, 3264 | "peerDependencies": { 3265 | "@types/node": "^18.0.0 || >=20.0.0", 3266 | "less": "*", 3267 | "lightningcss": "^1.21.0", 3268 | "sass": "*", 3269 | "stylus": "*", 3270 | "sugarss": "*", 3271 | "terser": "^5.4.0" 3272 | }, 3273 | "peerDependenciesMeta": { 3274 | "@types/node": { 3275 | "optional": true 3276 | }, 3277 | "less": { 3278 | "optional": true 3279 | }, 3280 | "lightningcss": { 3281 | "optional": true 3282 | }, 3283 | "sass": { 3284 | "optional": true 3285 | }, 3286 | "stylus": { 3287 | "optional": true 3288 | }, 3289 | "sugarss": { 3290 | "optional": true 3291 | }, 3292 | "terser": { 3293 | "optional": true 3294 | } 3295 | } 3296 | }, 3297 | "node_modules/which": { 3298 | "version": "2.0.2", 3299 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3300 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3301 | "dev": true, 3302 | "dependencies": { 3303 | "isexe": "^2.0.0" 3304 | }, 3305 | "bin": { 3306 | "node-which": "bin/node-which" 3307 | }, 3308 | "engines": { 3309 | "node": ">= 8" 3310 | } 3311 | }, 3312 | "node_modules/wrappy": { 3313 | "version": "1.0.2", 3314 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3315 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3316 | "dev": true 3317 | }, 3318 | "node_modules/yallist": { 3319 | "version": "3.1.1", 3320 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 3321 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 3322 | "dev": true 3323 | }, 3324 | "node_modules/yocto-queue": { 3325 | "version": "0.1.0", 3326 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3327 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3328 | "dev": true, 3329 | "engines": { 3330 | "node": ">=10" 3331 | }, 3332 | "funding": { 3333 | "url": "https://github.com/sponsors/sindresorhus" 3334 | } 3335 | }, 3336 | "node_modules/zustand": { 3337 | "version": "4.4.7", 3338 | "resolved": "https://registry.npmjs.org/zustand/-/zustand-4.4.7.tgz", 3339 | "integrity": "sha512-QFJWJMdlETcI69paJwhSMJz7PPWjVP8Sjhclxmxmxv/RYI7ZOvR5BHX+ktH0we9gTWQMxcne8q1OY8xxz604gw==", 3340 | "dependencies": { 3341 | "use-sync-external-store": "1.2.0" 3342 | }, 3343 | "engines": { 3344 | "node": ">=12.7.0" 3345 | }, 3346 | "peerDependencies": { 3347 | "@types/react": ">=16.8", 3348 | "immer": ">=9.0", 3349 | "react": ">=16.8" 3350 | }, 3351 | "peerDependenciesMeta": { 3352 | "@types/react": { 3353 | "optional": true 3354 | }, 3355 | "immer": { 3356 | "optional": true 3357 | }, 3358 | "react": { 3359 | "optional": true 3360 | } 3361 | } 3362 | } 3363 | } 3364 | } 3365 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc && vite build", 9 | "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "react": "^18.2.0", 14 | "react-dom": "^18.2.0", 15 | "zustand": "^4.4.7" 16 | }, 17 | "devDependencies": { 18 | "@types/react": "^18.2.43", 19 | "@types/react-dom": "^18.2.17", 20 | "@typescript-eslint/eslint-plugin": "^6.14.0", 21 | "@typescript-eslint/parser": "^6.14.0", 22 | "@vitejs/plugin-react": "^4.2.1", 23 | "eslint": "^8.55.0", 24 | "eslint-plugin-react-hooks": "^4.6.0", 25 | "eslint-plugin-react-refresh": "^0.4.5", 26 | "reactotron-react-js": "^3.3.9", 27 | "typescript": "^5.2.2", 28 | "vite": "^5.0.8" 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /example/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /example/src/App.tsx: -------------------------------------------------------------------------------- 1 | import { useCounter } from './store/useCounter'; 2 | import { useOtherCounter } from './store/useOtherCounter'; 3 | 4 | function App() { 5 | const { count, setCount } = useCounter(); 6 | 7 | const { otherCount, setOtherCount } = useOtherCounter(); 8 | 9 | return ( 10 | <> 11 |
12 | 13 | Count: {count} 14 | 15 |
16 |
17 | 18 | 19 | Other count: {otherCount} 20 | 21 | 22 |
23 | 24 | ); 25 | } 26 | 27 | export default App; 28 | -------------------------------------------------------------------------------- /example/src/Reactotron.ts: -------------------------------------------------------------------------------- 1 | import Reactotron from 'reactotron-react-js'; 2 | import { useCounter } from './store/useCounter'; 3 | import { useOtherCounter } from './store/useOtherCounter'; 4 | import reactotronPluginZustand from '../../src'; 5 | 6 | Reactotron.configure({ 7 | name: 'Reactotron Plugin Zustand' 8 | }) 9 | .use( 10 | reactotronPluginZustand({ 11 | stores: [ 12 | { 13 | name: 'useCounter', 14 | store: useCounter 15 | }, 16 | { 17 | name: 'useOtherCounter', 18 | store: useOtherCounter 19 | } 20 | ], 21 | omitFunctionKeys: true 22 | }) 23 | ) 24 | .connect(); 25 | -------------------------------------------------------------------------------- /example/src/main.tsx: -------------------------------------------------------------------------------- 1 | import './Reactotron.ts'; 2 | 3 | import React from 'react'; 4 | import ReactDOM from 'react-dom/client'; 5 | import App from './App.tsx'; 6 | 7 | ReactDOM.createRoot(document.getElementById('root')!).render( 8 | 9 | 10 | 11 | ); 12 | -------------------------------------------------------------------------------- /example/src/store/useCounter.ts: -------------------------------------------------------------------------------- 1 | import { create } from 'zustand'; 2 | 3 | interface CounterState { 4 | count: number; 5 | setCount: (value: number) => void; 6 | user: any; 7 | } 8 | 9 | export const useCounter = create()((set) => ({ 10 | count: 0, 11 | user: null, 12 | setCount: (value) => set({ count: value }) 13 | })); 14 | -------------------------------------------------------------------------------- /example/src/store/useOtherCounter.ts: -------------------------------------------------------------------------------- 1 | import { create } from 'zustand'; 2 | 3 | interface OtherCounterState { 4 | otherCount: number; 5 | setOtherCount: (value: number) => void; 6 | } 7 | 8 | export const useOtherCounter = create()((set) => ({ 9 | otherCount: 0, 10 | setOtherCount: (value) => set({ otherCount: value }) 11 | })); 12 | -------------------------------------------------------------------------------- /example/src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /example/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES2020", 4 | "useDefineForClassFields": true, 5 | "lib": ["ES2020", "DOM", "DOM.Iterable"], 6 | "module": "ESNext", 7 | "skipLibCheck": true, 8 | 9 | /* Bundler mode */ 10 | "moduleResolution": "bundler", 11 | "allowImportingTsExtensions": true, 12 | "resolveJsonModule": true, 13 | "isolatedModules": true, 14 | "noEmit": true, 15 | "jsx": "react-jsx", 16 | 17 | /* Linting */ 18 | "strict": true, 19 | "noUnusedLocals": true, 20 | "noUnusedParameters": true, 21 | "noFallthroughCasesInSwitch": true 22 | }, 23 | "include": ["src"], 24 | "references": [{ "path": "./tsconfig.node.json" }] 25 | } 26 | -------------------------------------------------------------------------------- /example/tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "skipLibCheck": true, 5 | "module": "ESNext", 6 | "moduleResolution": "bundler", 7 | "allowSyntheticDefaultImports": true 8 | }, 9 | "include": ["vite.config.ts"] 10 | } 11 | -------------------------------------------------------------------------------- /example/vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import react from '@vitejs/plugin-react'; 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | optimizeDeps: { 8 | esbuildOptions: { 9 | define: { 10 | global: 'globalThis' 11 | } 12 | } 13 | } 14 | }); 15 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | module.exports = require('./dist/index'); 2 | -------------------------------------------------------------------------------- /lint-staged.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | 'src/**/*.ts': 'eslint --fix' 3 | }; 4 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "reactotron-plugin-zustand", 3 | "version": "2.0.8", 4 | "description": "Plugin to monitor states from zustand", 5 | "main": "./dist/index.js", 6 | "scripts": { 7 | "start": "node dist/index.js", 8 | "dev": "tsx watch src", 9 | "build": "tsup", 10 | "test": "vitest", 11 | "test:coverage": "vitest run --coverage && jest-coverage-badges -o --output './docs'", 12 | "lint": "npx eslint src --fix", 13 | "check-types": "tsc --noemit", 14 | "prepare": "husky install", 15 | "prepublish": "npm run build" 16 | }, 17 | "files": [ 18 | "dist" 19 | ], 20 | "repository": { 21 | "type": "git", 22 | "url": "https://github.com/joalisonpereira/reactotron-plugin-zustand/" 23 | }, 24 | "author": "joalisonpereira", 25 | "license": "MIT", 26 | "bugs": { 27 | "url": "https://github.com/joalisonpereira/reactotron-plugin-zustand/issues" 28 | }, 29 | "keywords": [ 30 | "reactotron", 31 | "react", 32 | "react-native", 33 | "debug", 34 | "zustand", 35 | "plugin", 36 | "store", 37 | "monitor" 38 | ], 39 | "homepage": "https://github.com/joalisonpereira/reactotron-plugin-zustand#readme", 40 | "devDependencies": { 41 | "@commitlint/cli": "^17.7.1", 42 | "@commitlint/config-conventional": "^17.7.0", 43 | "@typescript-eslint/eslint-plugin": "^6.7.0", 44 | "@vitest/coverage-v8": "^0.34.4", 45 | "eslint": "^8.49.0", 46 | "eslint-config-prettier": "^9.0.0", 47 | "eslint-config-standard-with-typescript": "^39.0.0", 48 | "eslint-plugin-import": "^2.28.1", 49 | "eslint-plugin-n": "^16.1.0", 50 | "eslint-plugin-promise": "^6.1.1", 51 | "husky": "^8.0.3", 52 | "jest-coverage-badges": "^1.1.2", 53 | "lint-staged": "^14.0.1", 54 | "prettier": "^3.0.3", 55 | "reactotron-plugin-zustand": "^2.0.5", 56 | "reactotron-react-js": "^3.3.9", 57 | "reactotron-react-native": "^5.1.10", 58 | "tsup": "^7.2.0", 59 | "tsx": "^3.12.9", 60 | "typescript": "^5.2.2", 61 | "vite": "^4.4.9", 62 | "vitest": "^0.34.4", 63 | "zustand": "^4.4.1" 64 | }, 65 | "dependencies": { 66 | "deepmerge": "^4.3.1" 67 | } 68 | } 69 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | import deepmerge from 'deepmerge'; 2 | import { omitFunctionRecursively } from './utils'; 3 | import { 4 | type ReactotronCore, 5 | type Change, 6 | type PluginConfig, 7 | type Subscription, 8 | type ReactotronCoreNative 9 | } from './types'; 10 | 11 | const WILDCARDS = ['*']; 12 | 13 | function reactotronPluginZustand({ 14 | stores, 15 | omitFunctionKeys = false 16 | }: PluginConfig) { 17 | return (reactotron: ReactotronCore | ReactotronCoreNative) => { 18 | let subscriptions: Subscription[] = []; 19 | 20 | return { 21 | onCommand: (command: any) => { 22 | // Backup state 23 | if (command?.type === 'state.backup.request') { 24 | reactotron.send('state.backup.response', { 25 | state: stores.map((item) => ({ 26 | path: item.name, 27 | value: omitFunctionRecursively( 28 | item.store.getState(), 29 | true // always backup without functions 30 | ) 31 | })) 32 | }); 33 | } 34 | 35 | // Restore backup state 36 | if (command?.type === 'state.restore.request') { 37 | command.payload.state.forEach((item: Change) => { 38 | const store = stores.find((sub) => sub.name === item.path)?.store; 39 | 40 | if (store != null) { 41 | store.setState((state: never) => 42 | deepmerge(state, item.value ?? {}) 43 | ); 44 | } 45 | }); 46 | } 47 | 48 | if (command?.type === 'state.values.subscribe') { 49 | const subPaths: string[] = command?.payload?.paths; 50 | 51 | // Unsubscribe stores and clean stron state 52 | if (subPaths.length === 0) { 53 | subscriptions.forEach((item) => { 54 | item.unsub(); 55 | }); 56 | 57 | reactotron.send('state.values.change', { changes: [] }); 58 | 59 | return; 60 | } 61 | 62 | // Filter monit stores 63 | const subStores = subPaths.some((item) => WILDCARDS.includes(item)) 64 | ? stores 65 | : stores.filter((item) => subPaths.includes(item.name)); 66 | 67 | const getTronState = () => 68 | subStores.map((item) => ({ 69 | path: item.name, 70 | value: omitFunctionRecursively( 71 | item.store.getState(), 72 | omitFunctionKeys 73 | ) 74 | })); 75 | 76 | // Initialize clean state 77 | reactotron.send('state.values.change', { changes: getTronState() }); 78 | 79 | // Subscribe stores 80 | subscriptions = subStores.map((item) => { 81 | return { 82 | name: item.name, 83 | store: item.store, 84 | unsub: item.store.subscribe((changes) => { 85 | const newState = getTronState().filter( 86 | (tStore) => tStore.path !== item.name 87 | ); 88 | 89 | reactotron.send('state.values.change', { 90 | changes: newState.concat({ 91 | path: item.name, 92 | value: omitFunctionRecursively(changes, omitFunctionKeys) 93 | }) 94 | }); 95 | }) 96 | }; 97 | }); 98 | } 99 | } 100 | }; 101 | }; 102 | } 103 | 104 | export { reactotronPluginZustand as default, WILDCARDS, type PluginConfig }; 105 | -------------------------------------------------------------------------------- /src/test/index.spec.ts: -------------------------------------------------------------------------------- 1 | import { describe, it, expect, vi } from 'vitest'; 2 | import { createStore } from 'zustand'; 3 | import reactotronZustand from '..'; 4 | 5 | vi.mock('zustand'); 6 | 7 | describe('Index', () => { 8 | const mockReactotron = vi.fn().mockReturnValue({ 9 | onCommand: vi.fn(), 10 | send: vi.fn(), 11 | features: {} 12 | }); 13 | 14 | it('should return reactotron valid config', () => { 15 | const useFooStore = createStore(() => ({ count: 0 })); 16 | 17 | const plugin = reactotronZustand({ 18 | stores: [{ name: 'foo', store: useFooStore }] 19 | })(mockReactotron()); 20 | 21 | expect(plugin.onCommand).toBeTruthy(); 22 | }); 23 | 24 | it('should monit state values change', () => { 25 | const useFooStore = createStore(() => ({ count: 0 })); 26 | 27 | const plugin: any = reactotronZustand({ 28 | stores: [{ name: 'foo', store: useFooStore }] 29 | })(mockReactotron()); 30 | 31 | plugin.onCommand({ 32 | type: 'state.values.subscribe', 33 | payload: { paths: ['foo'] } 34 | }); 35 | }); 36 | 37 | it('should monit state values change with wildcards', () => { 38 | const useFooStore = createStore(() => ({ count: 0 })); 39 | 40 | const plugin: any = reactotronZustand({ 41 | stores: [{ name: 'foo', store: useFooStore }] 42 | })(mockReactotron()); 43 | 44 | plugin.onCommand({ 45 | type: 'state.values.subscribe', 46 | payload: { paths: ['*'] } 47 | }); 48 | }); 49 | 50 | it('should call persist snapshot functions', () => { 51 | const useFooStore = createStore(() => ({ count: 0 })); 52 | 53 | const plugin: any = reactotronZustand({ 54 | stores: [{ name: 'foo', store: useFooStore }] 55 | })(mockReactotron()); 56 | 57 | plugin.onCommand({ 58 | type: 'state.backup.request' 59 | }); 60 | 61 | const backup = { count: 1 }; 62 | 63 | plugin.onCommand({ 64 | type: 'state.restore.request', 65 | payload: { 66 | state: [{ path: 'foo', value: backup }] 67 | } 68 | }); 69 | 70 | expect(backup).toEqual(useFooStore.getState()); 71 | }); 72 | 73 | it('should call clear functions', () => { 74 | const useFooStore = createStore(() => ({ count: 0 })); 75 | 76 | const plugin: any = reactotronZustand({ 77 | stores: [{ name: 'foo', store: useFooStore }] 78 | })(mockReactotron()); 79 | 80 | plugin.onCommand({ 81 | type: 'state.values.subscribe', 82 | payload: { paths: [] } 83 | }); 84 | }); 85 | }); 86 | -------------------------------------------------------------------------------- /src/test/utils.spec.ts: -------------------------------------------------------------------------------- 1 | import { describe, it, expect } from 'vitest'; 2 | import { omitFunctionRecursively } from '../utils'; 3 | 4 | describe('omitFunctionRecursively', () => { 5 | it('should return the input as is when enable is false', () => { 6 | const input = { a: 1, b: () => {}, c: { d: 2 } }; 7 | 8 | const result = omitFunctionRecursively(input, false); 9 | 10 | expect(result).toEqual(input); 11 | }); 12 | 13 | it('should omit functions from an object', () => { 14 | const input = { a: 1, b: () => {}, c: { d: 2, e: () => {} } }; 15 | 16 | const expected = { a: 1, c: { d: 2 } }; 17 | 18 | const result = omitFunctionRecursively(input, true); 19 | 20 | expect(result).toEqual(expected); 21 | }); 22 | 23 | it('should omit functions from an array', () => { 24 | const input = [1, () => {}, { a: 2, b: () => {} }]; 25 | 26 | const expected = [1, { a: 2 }]; 27 | 28 | const result = omitFunctionRecursively(input, true); 29 | 30 | expect(result).toEqual(expected); 31 | }); 32 | 33 | it('should handle nested structures', () => { 34 | const input = { a: 1, b: { c: () => {}, d: { e: 2, f: () => {} } } }; 35 | 36 | const expected = { a: 1, b: { d: { e: 2 } } }; 37 | 38 | const result = omitFunctionRecursively(input, true); 39 | 40 | expect(result).toEqual(expected); 41 | }); 42 | 43 | it('should handle arrays within objects', () => { 44 | const input = { a: [1, () => {}, 2], b: { c: [3, () => {}, 4] } }; 45 | 46 | const expected = { a: [1, 2], b: { c: [3, 4] } }; 47 | 48 | const result = omitFunctionRecursively(input, true); 49 | 50 | expect(result).toEqual(expected); 51 | }); 52 | 53 | it('should handle empty objects and arrays', () => { 54 | const input = { a: {}, b: [] }; 55 | 56 | const expected = { a: {}, b: [] }; 57 | 58 | const result = omitFunctionRecursively(input, true); 59 | 60 | expect(result).toEqual(expected); 61 | }); 62 | }); 63 | -------------------------------------------------------------------------------- /src/types.ts: -------------------------------------------------------------------------------- 1 | import { type StoreApi } from 'zustand'; 2 | import type Reactotron from 'reactotron-react-js'; 3 | import type ReactotronNative from 'reactotron-react-native'; 4 | 5 | export type ReactotronCore = ReturnType; 6 | 7 | export type ReactotronCoreNative = ReturnType< 8 | typeof ReactotronNative.configure 9 | >; 10 | 11 | export interface PluginConfig { 12 | stores: Array<{ 13 | name: string; 14 | store: StoreApi; 15 | }>; 16 | omitFunctionKeys?: boolean; 17 | } 18 | 19 | export interface Subscription { 20 | name: string; 21 | store: StoreApi; 22 | unsub: ReturnType['subscribe']>; 23 | } 24 | 25 | export interface Change { 26 | path: string; 27 | value: unknown; 28 | } 29 | -------------------------------------------------------------------------------- /src/utils.ts: -------------------------------------------------------------------------------- 1 | export function omitFunctionRecursively(input: T, enable: boolean): T { 2 | if (!enable) { 3 | return input; 4 | } 5 | 6 | return removeFunctions(input); 7 | } 8 | 9 | function removeFunctions(value: any): any { 10 | if (typeof value !== 'object' || value === null) { 11 | return value; 12 | } 13 | 14 | if (Array.isArray(value)) { 15 | return value 16 | .map(removeFunctions) 17 | .filter((item) => typeof item !== 'function'); 18 | } 19 | 20 | const newObj: any = {}; 21 | 22 | for (const key in value) { 23 | if (value.hasOwnProperty(key)) { 24 | const cleanedValue = removeFunctions(value[key]); 25 | if (typeof cleanedValue !== 'function') { 26 | newObj[key] = cleanedValue; 27 | } 28 | } 29 | } 30 | 31 | return newObj; 32 | } 33 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | /* Visit https://aka.ms/tsconfig to read more about this file */ 4 | 5 | /* Projects */ 6 | // "incremental": true, /* Save .tsbuildinfo files to allow for incremental compilation of projects. */ 7 | // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ 8 | // "tsBuildInfoFile": "./.tsbuildinfo", /* Specify the path to .tsbuildinfo incremental compilation file. */ 9 | // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects. */ 10 | // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ 11 | // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ 12 | 13 | /* Language and Environment */ 14 | "target": "es2017" /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */, 15 | // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ 16 | // "jsx": "preserve", /* Specify what JSX code is generated. */ 17 | // "experimentalDecorators": true, /* Enable experimental support for legacy experimental decorators. */ 18 | // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ 19 | // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'. */ 20 | // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ 21 | // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'. */ 22 | // "reactNamespace": "", /* Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit. */ 23 | // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ 24 | // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ 25 | // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */ 26 | 27 | /* Modules */ 28 | "module": "ES2022" /* Specify what module code is generated. */, 29 | // "rootDir": "./", /* Specify the root folder within your source files. */ 30 | "moduleResolution": "node10" /* Specify how TypeScript looks up a file from a given module specifier. */, 31 | // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ 32 | // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ 33 | // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ 34 | // "typeRoots": [], /* Specify multiple folders that act like './node_modules/@types'. */ 35 | // "types": [], /* Specify type package names to be included without being referenced in a source file. */ 36 | // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ 37 | // "moduleSuffixes": [], /* List of file name suffixes to search when resolving a module. */ 38 | // "allowImportingTsExtensions": true, /* Allow imports to include TypeScript file extensions. Requires '--moduleResolution bundler' and either '--noEmit' or '--emitDeclarationOnly' to be set. */ 39 | // "resolvePackageJsonExports": true, /* Use the package.json 'exports' field when resolving package imports. */ 40 | // "resolvePackageJsonImports": true, /* Use the package.json 'imports' field when resolving imports. */ 41 | // "customConditions": [], /* Conditions to set in addition to the resolver-specific defaults when resolving imports. */ 42 | // "resolveJsonModule": true, /* Enable importing .json files. */ 43 | // "allowArbitraryExtensions": true, /* Enable importing files with any extension, provided a declaration file is present. */ 44 | // "noResolve": true, /* Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project. */ 45 | 46 | /* JavaScript Support */ 47 | "allowJs": true /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */, 48 | // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ 49 | // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */ 50 | 51 | /* Emit */ 52 | // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ 53 | // "declarationMap": true, /* Create sourcemaps for d.ts files. */ 54 | // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ 55 | // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ 56 | // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ 57 | // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output. */ 58 | // "outDir": "./", /* Specify an output folder for all emitted files. */ 59 | // "removeComments": true, /* Disable emitting comments. */ 60 | // "noEmit": true, /* Disable emitting files from a compilation. */ 61 | // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ 62 | // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types. */ 63 | // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ 64 | // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ 65 | // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ 66 | // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ 67 | // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ 68 | // "newLine": "crlf", /* Set the newline character for emitting files. */ 69 | // "stripInternal": true, /* Disable emitting declarations that have '@internal' in their JSDoc comments. */ 70 | // "noEmitHelpers": true, /* Disable generating custom helper functions like '__extends' in compiled output. */ 71 | // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ 72 | // "preserveConstEnums": true, /* Disable erasing 'const enum' declarations in generated code. */ 73 | // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ 74 | // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ 75 | 76 | /* Interop Constraints */ 77 | // "isolatedModules": true, /* Ensure that each file can be safely transpiled without relying on other imports. */ 78 | // "verbatimModuleSyntax": true, /* Do not transform or elide any imports or exports not marked as type-only, ensuring they are written in the output file's format based on the 'module' setting. */ 79 | // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ 80 | "esModuleInterop": true /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */, 81 | // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ 82 | "forceConsistentCasingInFileNames": true /* Ensure that casing is correct in imports. */, 83 | 84 | /* Type Checking */ 85 | "strict": true /* Enable all strict type-checking options. */, 86 | // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied 'any' type. */ 87 | // "strictNullChecks": true, /* When type checking, take into account 'null' and 'undefined'. */ 88 | // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ 89 | // "strictBindCallApply": true, /* Check that the arguments for 'bind', 'call', and 'apply' methods match the original function. */ 90 | // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ 91 | // "noImplicitThis": true, /* Enable error reporting when 'this' is given the type 'any'. */ 92 | // "useUnknownInCatchVariables": true, /* Default catch clause variables as 'unknown' instead of 'any'. */ 93 | // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ 94 | // "noUnusedLocals": true, /* Enable error reporting when local variables aren't read. */ 95 | // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read. */ 96 | // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ 97 | // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ 98 | // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ 99 | // "noUncheckedIndexedAccess": true, /* Add 'undefined' to a type when accessed using an index. */ 100 | // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ 101 | // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type. */ 102 | // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ 103 | // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ 104 | 105 | /* Completeness */ 106 | // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ 107 | "skipLibCheck": true /* Skip type checking all .d.ts files. */ 108 | }, 109 | "exclude": ["./example"] 110 | } 111 | -------------------------------------------------------------------------------- /tsup.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'tsup'; 2 | 3 | export default defineConfig({ 4 | entry: ['src', '!src/**/*.spec.*', '!src/tests/**', '!src/**/mocks/**'], 5 | splitting: false, 6 | sourcemap: false, 7 | clean: false, 8 | dts: true 9 | }); 10 | -------------------------------------------------------------------------------- /vitest.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import path from 'node:path'; 3 | 4 | export default defineConfig({ 5 | test: { 6 | coverage: { 7 | reporter: ['json-summary', 'lcov', 'text', 'html'], 8 | exclude: ['**/__mocks__/**'] 9 | }, 10 | globals: true 11 | }, 12 | resolve: { 13 | alias: { 14 | src: path.resolve(__dirname, './src') 15 | } 16 | } 17 | }); 18 | --------------------------------------------------------------------------------