) => {
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 |
--------------------------------------------------------------------------------
/docs/badge-functions.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/docs/badge-lines.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/docs/badge-statements.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/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 |
--------------------------------------------------------------------------------