├── .gitignore
├── README.md
├── eslint.config.js
├── index.html
├── package-lock.json
├── package.json
├── src
├── App.tsx
├── Container.tsx
├── formSchema.ts
└── main.tsx
├── tsconfig.app.json
├── tsconfig.json
├── tsconfig.node.json
├── tutorial.md
└── vite.config.ts
/.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 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Dynamic Forms in React Using Zod and React Hook Form
2 |
3 | This project demonstrates how to implement dynamic forms in React using TypeScript, Zod, and React Hook Form. The forms adapt their validation logic based on user input, making it a flexible and powerful tool for handling complex form scenarios.
4 |
5 | ## Features
6 |
7 | - React with TypeScript for strong type safety
8 | - Vite 5 for fast development and build setup
9 | - Zod for schema validation and discriminated unions
10 | - React Hook Form for managing form state and validation
11 | - Dynamic form inputs like radio button groups and checkboxes
12 | - Extensible design to support any dynamic form scenario
13 |
14 | ## Getting Started
15 |
16 | ### Prerequisites
17 |
18 | - Node.js version 18 or higher
19 |
20 | ### Installation
21 |
22 | 1. Clone the repository:
23 |
24 | ```bash
25 | git clone https://github.com/your-username/your-repo-name.git
26 | ```
27 |
28 | 2. Navigate to the project directory:
29 |
30 | ```bash
31 | cd your-repo-name
32 | ```
33 |
34 | 3. Install dependencies:
35 |
36 | ```bash
37 | npm install
38 | ```
39 |
40 | 4. Start the development server:
41 |
42 | ```bash
43 | npm run dev
44 | ```
45 |
46 | ### Build
47 |
48 | To build the project for production:
49 |
50 | ```bash
51 | npm run build
52 | ```
53 |
54 | ## Watch the Tutorial
55 |
56 | This project is part of a [tutorial available](https://youtu.be/HSr7pMSjC1I) on my [YouTube channel](https://www.youtube.com/@codegenix), where I walk through the entire process of building dynamic forms with Zod and React Hook Form. Be sure to check it out!
57 |
--------------------------------------------------------------------------------
/eslint.config.js:
--------------------------------------------------------------------------------
1 | import js from '@eslint/js'
2 | import globals from 'globals'
3 | import reactHooks from 'eslint-plugin-react-hooks'
4 | import reactRefresh from 'eslint-plugin-react-refresh'
5 | import tseslint from 'typescript-eslint'
6 |
7 | export default tseslint.config(
8 | { ignores: ['dist'] },
9 | {
10 | extends: [js.configs.recommended, ...tseslint.configs.recommended],
11 | files: ['**/*.{ts,tsx}'],
12 | languageOptions: {
13 | ecmaVersion: 2020,
14 | globals: globals.browser,
15 | },
16 | plugins: {
17 | 'react-hooks': reactHooks,
18 | 'react-refresh': reactRefresh,
19 | },
20 | rules: {
21 | ...reactHooks.configs.recommended.rules,
22 | 'react-refresh/only-export-components': [
23 | 'warn',
24 | { allowConstantExport: true },
25 | ],
26 | },
27 | },
28 | )
29 |
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | Vite + React + TS
8 |
9 |
10 |
11 |
12 |
13 |
14 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "dynamic-form",
3 | "version": "0.0.0",
4 | "lockfileVersion": 3,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "dynamic-form",
9 | "version": "0.0.0",
10 | "dependencies": {
11 | "@emotion/react": "^11.13.3",
12 | "@emotion/styled": "^11.13.0",
13 | "@hookform/resolvers": "^3.9.0",
14 | "@mui/icons-material": "^6.0.2",
15 | "@mui/material": "^6.0.2",
16 | "react": "^18.3.1",
17 | "react-dom": "^18.3.1",
18 | "react-hook-form": "^7.53.0",
19 | "zod": "^3.23.8"
20 | },
21 | "devDependencies": {
22 | "@eslint/js": "^9.9.0",
23 | "@types/react": "^18.3.3",
24 | "@types/react-dom": "^18.3.0",
25 | "@vitejs/plugin-react-swc": "^3.5.0",
26 | "eslint": "^9.9.0",
27 | "eslint-plugin-react-hooks": "^5.1.0-rc.0",
28 | "eslint-plugin-react-refresh": "^0.4.9",
29 | "globals": "^15.9.0",
30 | "typescript": "^5.5.3",
31 | "typescript-eslint": "^8.0.1",
32 | "vite": "^5.4.1"
33 | }
34 | },
35 | "node_modules/@babel/code-frame": {
36 | "version": "7.24.7",
37 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz",
38 | "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==",
39 | "dependencies": {
40 | "@babel/highlight": "^7.24.7",
41 | "picocolors": "^1.0.0"
42 | },
43 | "engines": {
44 | "node": ">=6.9.0"
45 | }
46 | },
47 | "node_modules/@babel/generator": {
48 | "version": "7.25.6",
49 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.6.tgz",
50 | "integrity": "sha512-VPC82gr1seXOpkjAAKoLhP50vx4vGNlF4msF64dSFq1P8RfB+QAuJWGHPXXPc8QyfVWwwB/TNNU4+ayZmHNbZw==",
51 | "dependencies": {
52 | "@babel/types": "^7.25.6",
53 | "@jridgewell/gen-mapping": "^0.3.5",
54 | "@jridgewell/trace-mapping": "^0.3.25",
55 | "jsesc": "^2.5.1"
56 | },
57 | "engines": {
58 | "node": ">=6.9.0"
59 | }
60 | },
61 | "node_modules/@babel/helper-module-imports": {
62 | "version": "7.24.7",
63 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz",
64 | "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==",
65 | "dependencies": {
66 | "@babel/traverse": "^7.24.7",
67 | "@babel/types": "^7.24.7"
68 | },
69 | "engines": {
70 | "node": ">=6.9.0"
71 | }
72 | },
73 | "node_modules/@babel/helper-string-parser": {
74 | "version": "7.24.8",
75 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz",
76 | "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==",
77 | "engines": {
78 | "node": ">=6.9.0"
79 | }
80 | },
81 | "node_modules/@babel/helper-validator-identifier": {
82 | "version": "7.24.7",
83 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz",
84 | "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==",
85 | "engines": {
86 | "node": ">=6.9.0"
87 | }
88 | },
89 | "node_modules/@babel/highlight": {
90 | "version": "7.24.7",
91 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz",
92 | "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==",
93 | "dependencies": {
94 | "@babel/helper-validator-identifier": "^7.24.7",
95 | "chalk": "^2.4.2",
96 | "js-tokens": "^4.0.0",
97 | "picocolors": "^1.0.0"
98 | },
99 | "engines": {
100 | "node": ">=6.9.0"
101 | }
102 | },
103 | "node_modules/@babel/highlight/node_modules/ansi-styles": {
104 | "version": "3.2.1",
105 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
106 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
107 | "dependencies": {
108 | "color-convert": "^1.9.0"
109 | },
110 | "engines": {
111 | "node": ">=4"
112 | }
113 | },
114 | "node_modules/@babel/highlight/node_modules/chalk": {
115 | "version": "2.4.2",
116 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
117 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
118 | "dependencies": {
119 | "ansi-styles": "^3.2.1",
120 | "escape-string-regexp": "^1.0.5",
121 | "supports-color": "^5.3.0"
122 | },
123 | "engines": {
124 | "node": ">=4"
125 | }
126 | },
127 | "node_modules/@babel/highlight/node_modules/color-convert": {
128 | "version": "1.9.3",
129 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
130 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
131 | "dependencies": {
132 | "color-name": "1.1.3"
133 | }
134 | },
135 | "node_modules/@babel/highlight/node_modules/color-name": {
136 | "version": "1.1.3",
137 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
138 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw=="
139 | },
140 | "node_modules/@babel/highlight/node_modules/escape-string-regexp": {
141 | "version": "1.0.5",
142 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
143 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
144 | "engines": {
145 | "node": ">=0.8.0"
146 | }
147 | },
148 | "node_modules/@babel/highlight/node_modules/has-flag": {
149 | "version": "3.0.0",
150 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
151 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==",
152 | "engines": {
153 | "node": ">=4"
154 | }
155 | },
156 | "node_modules/@babel/highlight/node_modules/supports-color": {
157 | "version": "5.5.0",
158 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
159 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
160 | "dependencies": {
161 | "has-flag": "^3.0.0"
162 | },
163 | "engines": {
164 | "node": ">=4"
165 | }
166 | },
167 | "node_modules/@babel/parser": {
168 | "version": "7.25.6",
169 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.6.tgz",
170 | "integrity": "sha512-trGdfBdbD0l1ZPmcJ83eNxB9rbEax4ALFTF7fN386TMYbeCQbyme5cOEXQhbGXKebwGaB/J52w1mrklMcbgy6Q==",
171 | "dependencies": {
172 | "@babel/types": "^7.25.6"
173 | },
174 | "bin": {
175 | "parser": "bin/babel-parser.js"
176 | },
177 | "engines": {
178 | "node": ">=6.0.0"
179 | }
180 | },
181 | "node_modules/@babel/runtime": {
182 | "version": "7.25.6",
183 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.25.6.tgz",
184 | "integrity": "sha512-VBj9MYyDb9tuLq7yzqjgzt6Q+IBQLrGZfdjOekyEirZPHxXWoTSGUTMrpsfi58Up73d13NfYLv8HT9vmznjzhQ==",
185 | "dependencies": {
186 | "regenerator-runtime": "^0.14.0"
187 | },
188 | "engines": {
189 | "node": ">=6.9.0"
190 | }
191 | },
192 | "node_modules/@babel/template": {
193 | "version": "7.25.0",
194 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz",
195 | "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==",
196 | "dependencies": {
197 | "@babel/code-frame": "^7.24.7",
198 | "@babel/parser": "^7.25.0",
199 | "@babel/types": "^7.25.0"
200 | },
201 | "engines": {
202 | "node": ">=6.9.0"
203 | }
204 | },
205 | "node_modules/@babel/traverse": {
206 | "version": "7.25.6",
207 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.6.tgz",
208 | "integrity": "sha512-9Vrcx5ZW6UwK5tvqsj0nGpp/XzqthkT0dqIc9g1AdtygFToNtTF67XzYS//dm+SAK9cp3B9R4ZO/46p63SCjlQ==",
209 | "dependencies": {
210 | "@babel/code-frame": "^7.24.7",
211 | "@babel/generator": "^7.25.6",
212 | "@babel/parser": "^7.25.6",
213 | "@babel/template": "^7.25.0",
214 | "@babel/types": "^7.25.6",
215 | "debug": "^4.3.1",
216 | "globals": "^11.1.0"
217 | },
218 | "engines": {
219 | "node": ">=6.9.0"
220 | }
221 | },
222 | "node_modules/@babel/traverse/node_modules/globals": {
223 | "version": "11.12.0",
224 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
225 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
226 | "engines": {
227 | "node": ">=4"
228 | }
229 | },
230 | "node_modules/@babel/types": {
231 | "version": "7.25.6",
232 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.6.tgz",
233 | "integrity": "sha512-/l42B1qxpG6RdfYf343Uw1vmDjeNhneUXtzhojE7pDgfpEypmRhI6j1kr17XCVv4Cgl9HdAiQY2x0GwKm7rWCw==",
234 | "dependencies": {
235 | "@babel/helper-string-parser": "^7.24.8",
236 | "@babel/helper-validator-identifier": "^7.24.7",
237 | "to-fast-properties": "^2.0.0"
238 | },
239 | "engines": {
240 | "node": ">=6.9.0"
241 | }
242 | },
243 | "node_modules/@emotion/babel-plugin": {
244 | "version": "11.12.0",
245 | "resolved": "https://registry.npmjs.org/@emotion/babel-plugin/-/babel-plugin-11.12.0.tgz",
246 | "integrity": "sha512-y2WQb+oP8Jqvvclh8Q55gLUyb7UFvgv7eJfsj7td5TToBrIUtPay2kMrZi4xjq9qw2vD0ZR5fSho0yqoFgX7Rw==",
247 | "dependencies": {
248 | "@babel/helper-module-imports": "^7.16.7",
249 | "@babel/runtime": "^7.18.3",
250 | "@emotion/hash": "^0.9.2",
251 | "@emotion/memoize": "^0.9.0",
252 | "@emotion/serialize": "^1.2.0",
253 | "babel-plugin-macros": "^3.1.0",
254 | "convert-source-map": "^1.5.0",
255 | "escape-string-regexp": "^4.0.0",
256 | "find-root": "^1.1.0",
257 | "source-map": "^0.5.7",
258 | "stylis": "4.2.0"
259 | }
260 | },
261 | "node_modules/@emotion/cache": {
262 | "version": "11.13.1",
263 | "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-11.13.1.tgz",
264 | "integrity": "sha512-iqouYkuEblRcXmylXIwwOodiEK5Ifl7JcX7o6V4jI3iW4mLXX3dmt5xwBtIkJiQEXFAI+pC8X0i67yiPkH9Ucw==",
265 | "dependencies": {
266 | "@emotion/memoize": "^0.9.0",
267 | "@emotion/sheet": "^1.4.0",
268 | "@emotion/utils": "^1.4.0",
269 | "@emotion/weak-memoize": "^0.4.0",
270 | "stylis": "4.2.0"
271 | }
272 | },
273 | "node_modules/@emotion/hash": {
274 | "version": "0.9.2",
275 | "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.2.tgz",
276 | "integrity": "sha512-MyqliTZGuOm3+5ZRSaaBGP3USLw6+EGykkwZns2EPC5g8jJ4z9OrdZY9apkl3+UP9+sdz76YYkwCKP5gh8iY3g=="
277 | },
278 | "node_modules/@emotion/is-prop-valid": {
279 | "version": "1.3.0",
280 | "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.3.0.tgz",
281 | "integrity": "sha512-SHetuSLvJDzuNbOdtPVbq6yMMMlLoW5Q94uDqJZqy50gcmAjxFkVqmzqSGEFq9gT2iMuIeKV1PXVWmvUhuZLlQ==",
282 | "dependencies": {
283 | "@emotion/memoize": "^0.9.0"
284 | }
285 | },
286 | "node_modules/@emotion/memoize": {
287 | "version": "0.9.0",
288 | "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.9.0.tgz",
289 | "integrity": "sha512-30FAj7/EoJ5mwVPOWhAyCX+FPfMDrVecJAM+Iw9NRoSl4BBAQeqj4cApHHUXOVvIPgLVDsCFoz/hGD+5QQD1GQ=="
290 | },
291 | "node_modules/@emotion/react": {
292 | "version": "11.13.3",
293 | "resolved": "https://registry.npmjs.org/@emotion/react/-/react-11.13.3.tgz",
294 | "integrity": "sha512-lIsdU6JNrmYfJ5EbUCf4xW1ovy5wKQ2CkPRM4xogziOxH1nXxBSjpC9YqbFAP7circxMfYp+6x676BqWcEiixg==",
295 | "dependencies": {
296 | "@babel/runtime": "^7.18.3",
297 | "@emotion/babel-plugin": "^11.12.0",
298 | "@emotion/cache": "^11.13.0",
299 | "@emotion/serialize": "^1.3.1",
300 | "@emotion/use-insertion-effect-with-fallbacks": "^1.1.0",
301 | "@emotion/utils": "^1.4.0",
302 | "@emotion/weak-memoize": "^0.4.0",
303 | "hoist-non-react-statics": "^3.3.1"
304 | },
305 | "peerDependencies": {
306 | "react": ">=16.8.0"
307 | },
308 | "peerDependenciesMeta": {
309 | "@types/react": {
310 | "optional": true
311 | }
312 | }
313 | },
314 | "node_modules/@emotion/serialize": {
315 | "version": "1.3.1",
316 | "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.3.1.tgz",
317 | "integrity": "sha512-dEPNKzBPU+vFPGa+z3axPRn8XVDetYORmDC0wAiej+TNcOZE70ZMJa0X7JdeoM6q/nWTMZeLpN/fTnD9o8MQBA==",
318 | "dependencies": {
319 | "@emotion/hash": "^0.9.2",
320 | "@emotion/memoize": "^0.9.0",
321 | "@emotion/unitless": "^0.10.0",
322 | "@emotion/utils": "^1.4.0",
323 | "csstype": "^3.0.2"
324 | }
325 | },
326 | "node_modules/@emotion/sheet": {
327 | "version": "1.4.0",
328 | "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.4.0.tgz",
329 | "integrity": "sha512-fTBW9/8r2w3dXWYM4HCB1Rdp8NLibOw2+XELH5m5+AkWiL/KqYX6dc0kKYlaYyKjrQ6ds33MCdMPEwgs2z1rqg=="
330 | },
331 | "node_modules/@emotion/styled": {
332 | "version": "11.13.0",
333 | "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-11.13.0.tgz",
334 | "integrity": "sha512-tkzkY7nQhW/zC4hztlwucpT8QEZ6eUzpXDRhww/Eej4tFfO0FxQYWRyg/c5CCXa4d/f174kqeXYjuQRnhzf6dA==",
335 | "dependencies": {
336 | "@babel/runtime": "^7.18.3",
337 | "@emotion/babel-plugin": "^11.12.0",
338 | "@emotion/is-prop-valid": "^1.3.0",
339 | "@emotion/serialize": "^1.3.0",
340 | "@emotion/use-insertion-effect-with-fallbacks": "^1.1.0",
341 | "@emotion/utils": "^1.4.0"
342 | },
343 | "peerDependencies": {
344 | "@emotion/react": "^11.0.0-rc.0",
345 | "react": ">=16.8.0"
346 | },
347 | "peerDependenciesMeta": {
348 | "@types/react": {
349 | "optional": true
350 | }
351 | }
352 | },
353 | "node_modules/@emotion/unitless": {
354 | "version": "0.10.0",
355 | "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.10.0.tgz",
356 | "integrity": "sha512-dFoMUuQA20zvtVTuxZww6OHoJYgrzfKM1t52mVySDJnMSEa08ruEvdYQbhvyu6soU+NeLVd3yKfTfT0NeV6qGg=="
357 | },
358 | "node_modules/@emotion/use-insertion-effect-with-fallbacks": {
359 | "version": "1.1.0",
360 | "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.1.0.tgz",
361 | "integrity": "sha512-+wBOcIV5snwGgI2ya3u99D7/FJquOIniQT1IKyDsBmEgwvpxMNeS65Oib7OnE2d2aY+3BU4OiH+0Wchf8yk3Hw==",
362 | "peerDependencies": {
363 | "react": ">=16.8.0"
364 | }
365 | },
366 | "node_modules/@emotion/utils": {
367 | "version": "1.4.0",
368 | "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-1.4.0.tgz",
369 | "integrity": "sha512-spEnrA1b6hDR/C68lC2M7m6ALPUHZC0lIY7jAS/B/9DuuO1ZP04eov8SMv/6fwRd8pzmsn2AuJEznRREWlQrlQ=="
370 | },
371 | "node_modules/@emotion/weak-memoize": {
372 | "version": "0.4.0",
373 | "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.4.0.tgz",
374 | "integrity": "sha512-snKqtPW01tN0ui7yu9rGv69aJXr/a/Ywvl11sUjNtEcRc+ng/mQriFL0wLXMef74iHa/EkftbDzU9F8iFbH+zg=="
375 | },
376 | "node_modules/@esbuild/aix-ppc64": {
377 | "version": "0.21.5",
378 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz",
379 | "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==",
380 | "cpu": [
381 | "ppc64"
382 | ],
383 | "dev": true,
384 | "optional": true,
385 | "os": [
386 | "aix"
387 | ],
388 | "engines": {
389 | "node": ">=12"
390 | }
391 | },
392 | "node_modules/@esbuild/android-arm": {
393 | "version": "0.21.5",
394 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz",
395 | "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==",
396 | "cpu": [
397 | "arm"
398 | ],
399 | "dev": true,
400 | "optional": true,
401 | "os": [
402 | "android"
403 | ],
404 | "engines": {
405 | "node": ">=12"
406 | }
407 | },
408 | "node_modules/@esbuild/android-arm64": {
409 | "version": "0.21.5",
410 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz",
411 | "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==",
412 | "cpu": [
413 | "arm64"
414 | ],
415 | "dev": true,
416 | "optional": true,
417 | "os": [
418 | "android"
419 | ],
420 | "engines": {
421 | "node": ">=12"
422 | }
423 | },
424 | "node_modules/@esbuild/android-x64": {
425 | "version": "0.21.5",
426 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz",
427 | "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==",
428 | "cpu": [
429 | "x64"
430 | ],
431 | "dev": true,
432 | "optional": true,
433 | "os": [
434 | "android"
435 | ],
436 | "engines": {
437 | "node": ">=12"
438 | }
439 | },
440 | "node_modules/@esbuild/darwin-arm64": {
441 | "version": "0.21.5",
442 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz",
443 | "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==",
444 | "cpu": [
445 | "arm64"
446 | ],
447 | "dev": true,
448 | "optional": true,
449 | "os": [
450 | "darwin"
451 | ],
452 | "engines": {
453 | "node": ">=12"
454 | }
455 | },
456 | "node_modules/@esbuild/darwin-x64": {
457 | "version": "0.21.5",
458 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz",
459 | "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==",
460 | "cpu": [
461 | "x64"
462 | ],
463 | "dev": true,
464 | "optional": true,
465 | "os": [
466 | "darwin"
467 | ],
468 | "engines": {
469 | "node": ">=12"
470 | }
471 | },
472 | "node_modules/@esbuild/freebsd-arm64": {
473 | "version": "0.21.5",
474 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz",
475 | "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==",
476 | "cpu": [
477 | "arm64"
478 | ],
479 | "dev": true,
480 | "optional": true,
481 | "os": [
482 | "freebsd"
483 | ],
484 | "engines": {
485 | "node": ">=12"
486 | }
487 | },
488 | "node_modules/@esbuild/freebsd-x64": {
489 | "version": "0.21.5",
490 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz",
491 | "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==",
492 | "cpu": [
493 | "x64"
494 | ],
495 | "dev": true,
496 | "optional": true,
497 | "os": [
498 | "freebsd"
499 | ],
500 | "engines": {
501 | "node": ">=12"
502 | }
503 | },
504 | "node_modules/@esbuild/linux-arm": {
505 | "version": "0.21.5",
506 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz",
507 | "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==",
508 | "cpu": [
509 | "arm"
510 | ],
511 | "dev": true,
512 | "optional": true,
513 | "os": [
514 | "linux"
515 | ],
516 | "engines": {
517 | "node": ">=12"
518 | }
519 | },
520 | "node_modules/@esbuild/linux-arm64": {
521 | "version": "0.21.5",
522 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz",
523 | "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==",
524 | "cpu": [
525 | "arm64"
526 | ],
527 | "dev": true,
528 | "optional": true,
529 | "os": [
530 | "linux"
531 | ],
532 | "engines": {
533 | "node": ">=12"
534 | }
535 | },
536 | "node_modules/@esbuild/linux-ia32": {
537 | "version": "0.21.5",
538 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz",
539 | "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==",
540 | "cpu": [
541 | "ia32"
542 | ],
543 | "dev": true,
544 | "optional": true,
545 | "os": [
546 | "linux"
547 | ],
548 | "engines": {
549 | "node": ">=12"
550 | }
551 | },
552 | "node_modules/@esbuild/linux-loong64": {
553 | "version": "0.21.5",
554 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz",
555 | "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==",
556 | "cpu": [
557 | "loong64"
558 | ],
559 | "dev": true,
560 | "optional": true,
561 | "os": [
562 | "linux"
563 | ],
564 | "engines": {
565 | "node": ">=12"
566 | }
567 | },
568 | "node_modules/@esbuild/linux-mips64el": {
569 | "version": "0.21.5",
570 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz",
571 | "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==",
572 | "cpu": [
573 | "mips64el"
574 | ],
575 | "dev": true,
576 | "optional": true,
577 | "os": [
578 | "linux"
579 | ],
580 | "engines": {
581 | "node": ">=12"
582 | }
583 | },
584 | "node_modules/@esbuild/linux-ppc64": {
585 | "version": "0.21.5",
586 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz",
587 | "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==",
588 | "cpu": [
589 | "ppc64"
590 | ],
591 | "dev": true,
592 | "optional": true,
593 | "os": [
594 | "linux"
595 | ],
596 | "engines": {
597 | "node": ">=12"
598 | }
599 | },
600 | "node_modules/@esbuild/linux-riscv64": {
601 | "version": "0.21.5",
602 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz",
603 | "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==",
604 | "cpu": [
605 | "riscv64"
606 | ],
607 | "dev": true,
608 | "optional": true,
609 | "os": [
610 | "linux"
611 | ],
612 | "engines": {
613 | "node": ">=12"
614 | }
615 | },
616 | "node_modules/@esbuild/linux-s390x": {
617 | "version": "0.21.5",
618 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz",
619 | "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==",
620 | "cpu": [
621 | "s390x"
622 | ],
623 | "dev": true,
624 | "optional": true,
625 | "os": [
626 | "linux"
627 | ],
628 | "engines": {
629 | "node": ">=12"
630 | }
631 | },
632 | "node_modules/@esbuild/linux-x64": {
633 | "version": "0.21.5",
634 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz",
635 | "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==",
636 | "cpu": [
637 | "x64"
638 | ],
639 | "dev": true,
640 | "optional": true,
641 | "os": [
642 | "linux"
643 | ],
644 | "engines": {
645 | "node": ">=12"
646 | }
647 | },
648 | "node_modules/@esbuild/netbsd-x64": {
649 | "version": "0.21.5",
650 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz",
651 | "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==",
652 | "cpu": [
653 | "x64"
654 | ],
655 | "dev": true,
656 | "optional": true,
657 | "os": [
658 | "netbsd"
659 | ],
660 | "engines": {
661 | "node": ">=12"
662 | }
663 | },
664 | "node_modules/@esbuild/openbsd-x64": {
665 | "version": "0.21.5",
666 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz",
667 | "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==",
668 | "cpu": [
669 | "x64"
670 | ],
671 | "dev": true,
672 | "optional": true,
673 | "os": [
674 | "openbsd"
675 | ],
676 | "engines": {
677 | "node": ">=12"
678 | }
679 | },
680 | "node_modules/@esbuild/sunos-x64": {
681 | "version": "0.21.5",
682 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz",
683 | "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==",
684 | "cpu": [
685 | "x64"
686 | ],
687 | "dev": true,
688 | "optional": true,
689 | "os": [
690 | "sunos"
691 | ],
692 | "engines": {
693 | "node": ">=12"
694 | }
695 | },
696 | "node_modules/@esbuild/win32-arm64": {
697 | "version": "0.21.5",
698 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz",
699 | "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==",
700 | "cpu": [
701 | "arm64"
702 | ],
703 | "dev": true,
704 | "optional": true,
705 | "os": [
706 | "win32"
707 | ],
708 | "engines": {
709 | "node": ">=12"
710 | }
711 | },
712 | "node_modules/@esbuild/win32-ia32": {
713 | "version": "0.21.5",
714 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz",
715 | "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==",
716 | "cpu": [
717 | "ia32"
718 | ],
719 | "dev": true,
720 | "optional": true,
721 | "os": [
722 | "win32"
723 | ],
724 | "engines": {
725 | "node": ">=12"
726 | }
727 | },
728 | "node_modules/@esbuild/win32-x64": {
729 | "version": "0.21.5",
730 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz",
731 | "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==",
732 | "cpu": [
733 | "x64"
734 | ],
735 | "dev": true,
736 | "optional": true,
737 | "os": [
738 | "win32"
739 | ],
740 | "engines": {
741 | "node": ">=12"
742 | }
743 | },
744 | "node_modules/@eslint-community/eslint-utils": {
745 | "version": "4.4.0",
746 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
747 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
748 | "dev": true,
749 | "dependencies": {
750 | "eslint-visitor-keys": "^3.3.0"
751 | },
752 | "engines": {
753 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
754 | },
755 | "peerDependencies": {
756 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
757 | }
758 | },
759 | "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": {
760 | "version": "3.4.3",
761 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
762 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
763 | "dev": true,
764 | "engines": {
765 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
766 | },
767 | "funding": {
768 | "url": "https://opencollective.com/eslint"
769 | }
770 | },
771 | "node_modules/@eslint-community/regexpp": {
772 | "version": "4.11.0",
773 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.0.tgz",
774 | "integrity": "sha512-G/M/tIiMrTAxEWRfLfQJMmGNX28IxBg4PBz8XqQhqUHLFI6TL2htpIB1iQCj144V5ee/JaKyT9/WZ0MGZWfA7A==",
775 | "dev": true,
776 | "engines": {
777 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
778 | }
779 | },
780 | "node_modules/@eslint/config-array": {
781 | "version": "0.18.0",
782 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.18.0.tgz",
783 | "integrity": "sha512-fTxvnS1sRMu3+JjXwJG0j/i4RT9u4qJ+lqS/yCGap4lH4zZGzQ7tu+xZqQmcMZq5OBZDL4QRxQzRjkWcGt8IVw==",
784 | "dev": true,
785 | "dependencies": {
786 | "@eslint/object-schema": "^2.1.4",
787 | "debug": "^4.3.1",
788 | "minimatch": "^3.1.2"
789 | },
790 | "engines": {
791 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
792 | }
793 | },
794 | "node_modules/@eslint/eslintrc": {
795 | "version": "3.1.0",
796 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz",
797 | "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==",
798 | "dev": true,
799 | "dependencies": {
800 | "ajv": "^6.12.4",
801 | "debug": "^4.3.2",
802 | "espree": "^10.0.1",
803 | "globals": "^14.0.0",
804 | "ignore": "^5.2.0",
805 | "import-fresh": "^3.2.1",
806 | "js-yaml": "^4.1.0",
807 | "minimatch": "^3.1.2",
808 | "strip-json-comments": "^3.1.1"
809 | },
810 | "engines": {
811 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
812 | },
813 | "funding": {
814 | "url": "https://opencollective.com/eslint"
815 | }
816 | },
817 | "node_modules/@eslint/eslintrc/node_modules/globals": {
818 | "version": "14.0.0",
819 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz",
820 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==",
821 | "dev": true,
822 | "engines": {
823 | "node": ">=18"
824 | },
825 | "funding": {
826 | "url": "https://github.com/sponsors/sindresorhus"
827 | }
828 | },
829 | "node_modules/@eslint/js": {
830 | "version": "9.10.0",
831 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.10.0.tgz",
832 | "integrity": "sha512-fuXtbiP5GWIn8Fz+LWoOMVf/Jxm+aajZYkhi6CuEm4SxymFM+eUWzbO9qXT+L0iCkL5+KGYMCSGxo686H19S1g==",
833 | "dev": true,
834 | "engines": {
835 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
836 | }
837 | },
838 | "node_modules/@eslint/object-schema": {
839 | "version": "2.1.4",
840 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz",
841 | "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==",
842 | "dev": true,
843 | "engines": {
844 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
845 | }
846 | },
847 | "node_modules/@eslint/plugin-kit": {
848 | "version": "0.1.0",
849 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.1.0.tgz",
850 | "integrity": "sha512-autAXT203ixhqei9xt+qkYOvY8l6LAFIdT2UXc/RPNeUVfqRF1BV94GTJyVPFKT8nFM6MyVJhjLj9E8JWvf5zQ==",
851 | "dev": true,
852 | "dependencies": {
853 | "levn": "^0.4.1"
854 | },
855 | "engines": {
856 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
857 | }
858 | },
859 | "node_modules/@hookform/resolvers": {
860 | "version": "3.9.0",
861 | "resolved": "https://registry.npmjs.org/@hookform/resolvers/-/resolvers-3.9.0.tgz",
862 | "integrity": "sha512-bU0Gr4EepJ/EQsH/IwEzYLsT/PEj5C0ynLQ4m+GSHS+xKH4TfSelhluTgOaoc4kA5s7eCsQbM4wvZLzELmWzUg==",
863 | "peerDependencies": {
864 | "react-hook-form": "^7.0.0"
865 | }
866 | },
867 | "node_modules/@humanwhocodes/module-importer": {
868 | "version": "1.0.1",
869 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
870 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
871 | "dev": true,
872 | "engines": {
873 | "node": ">=12.22"
874 | },
875 | "funding": {
876 | "type": "github",
877 | "url": "https://github.com/sponsors/nzakas"
878 | }
879 | },
880 | "node_modules/@humanwhocodes/retry": {
881 | "version": "0.3.0",
882 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.0.tgz",
883 | "integrity": "sha512-d2CGZR2o7fS6sWB7DG/3a95bGKQyHMACZ5aW8qGkkqQpUoZV6C0X7Pc7l4ZNMZkfNBf4VWNe9E1jRsf0G146Ew==",
884 | "dev": true,
885 | "engines": {
886 | "node": ">=18.18"
887 | },
888 | "funding": {
889 | "type": "github",
890 | "url": "https://github.com/sponsors/nzakas"
891 | }
892 | },
893 | "node_modules/@jridgewell/gen-mapping": {
894 | "version": "0.3.5",
895 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz",
896 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==",
897 | "dependencies": {
898 | "@jridgewell/set-array": "^1.2.1",
899 | "@jridgewell/sourcemap-codec": "^1.4.10",
900 | "@jridgewell/trace-mapping": "^0.3.24"
901 | },
902 | "engines": {
903 | "node": ">=6.0.0"
904 | }
905 | },
906 | "node_modules/@jridgewell/resolve-uri": {
907 | "version": "3.1.2",
908 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz",
909 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==",
910 | "engines": {
911 | "node": ">=6.0.0"
912 | }
913 | },
914 | "node_modules/@jridgewell/set-array": {
915 | "version": "1.2.1",
916 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz",
917 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==",
918 | "engines": {
919 | "node": ">=6.0.0"
920 | }
921 | },
922 | "node_modules/@jridgewell/sourcemap-codec": {
923 | "version": "1.5.0",
924 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
925 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ=="
926 | },
927 | "node_modules/@jridgewell/trace-mapping": {
928 | "version": "0.3.25",
929 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz",
930 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==",
931 | "dependencies": {
932 | "@jridgewell/resolve-uri": "^3.1.0",
933 | "@jridgewell/sourcemap-codec": "^1.4.14"
934 | }
935 | },
936 | "node_modules/@mui/core-downloads-tracker": {
937 | "version": "6.0.2",
938 | "resolved": "https://registry.npmjs.org/@mui/core-downloads-tracker/-/core-downloads-tracker-6.0.2.tgz",
939 | "integrity": "sha512-Cg68oOlAfbJgMgvbCwcX3Y3HdygCl6X1nREYTdEWcEKUQhNarrC45Cc35mP+zA7p3ZXE/7FLiaTCCgwuSoef/Q==",
940 | "funding": {
941 | "type": "opencollective",
942 | "url": "https://opencollective.com/mui-org"
943 | }
944 | },
945 | "node_modules/@mui/icons-material": {
946 | "version": "6.0.2",
947 | "resolved": "https://registry.npmjs.org/@mui/icons-material/-/icons-material-6.0.2.tgz",
948 | "integrity": "sha512-WaTPSvKcx8X7NdWAHzJWDZv+YXvK0MUY8+JI/r4/q2GgIa5RW+n4+08CGX6jB7sWhU1R3zy28NfsDUwwQjOThw==",
949 | "dependencies": {
950 | "@babel/runtime": "^7.25.0"
951 | },
952 | "engines": {
953 | "node": ">=14.0.0"
954 | },
955 | "funding": {
956 | "type": "opencollective",
957 | "url": "https://opencollective.com/mui-org"
958 | },
959 | "peerDependencies": {
960 | "@mui/material": "^6.0.2",
961 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0",
962 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
963 | },
964 | "peerDependenciesMeta": {
965 | "@types/react": {
966 | "optional": true
967 | }
968 | }
969 | },
970 | "node_modules/@mui/material": {
971 | "version": "6.0.2",
972 | "resolved": "https://registry.npmjs.org/@mui/material/-/material-6.0.2.tgz",
973 | "integrity": "sha512-KrnkJFSyhsAh8V30DNUbWyRyxMi4ZHjFg1ikQGx+mUAIffFTYIEx9Q+Kxd3vCT0FUFGOmbsuh6F6yRhpybsjkg==",
974 | "dependencies": {
975 | "@babel/runtime": "^7.25.0",
976 | "@mui/core-downloads-tracker": "^6.0.2",
977 | "@mui/system": "^6.0.2",
978 | "@mui/types": "^7.2.16",
979 | "@mui/utils": "^6.0.2",
980 | "@popperjs/core": "^2.11.8",
981 | "@types/react-transition-group": "^4.4.11",
982 | "clsx": "^2.1.1",
983 | "csstype": "^3.1.3",
984 | "prop-types": "^15.8.1",
985 | "react-is": "^18.3.1",
986 | "react-transition-group": "^4.4.5"
987 | },
988 | "engines": {
989 | "node": ">=14.0.0"
990 | },
991 | "funding": {
992 | "type": "opencollective",
993 | "url": "https://opencollective.com/mui-org"
994 | },
995 | "peerDependencies": {
996 | "@emotion/react": "^11.5.0",
997 | "@emotion/styled": "^11.3.0",
998 | "@mui/material-pigment-css": "^6.0.2",
999 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0",
1000 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0",
1001 | "react-dom": "^17.0.0 || ^18.0.0 || ^19.0.0"
1002 | },
1003 | "peerDependenciesMeta": {
1004 | "@emotion/react": {
1005 | "optional": true
1006 | },
1007 | "@emotion/styled": {
1008 | "optional": true
1009 | },
1010 | "@mui/material-pigment-css": {
1011 | "optional": true
1012 | },
1013 | "@types/react": {
1014 | "optional": true
1015 | }
1016 | }
1017 | },
1018 | "node_modules/@mui/private-theming": {
1019 | "version": "6.0.2",
1020 | "resolved": "https://registry.npmjs.org/@mui/private-theming/-/private-theming-6.0.2.tgz",
1021 | "integrity": "sha512-emddFcRhA0hPGVIwIbW5g0V8vtCgw2g/H/A7jTdGe7dpCWEPpp6jPIXRRKcEUWgmg91R6rBNfV+LFHxBxmZXOQ==",
1022 | "dependencies": {
1023 | "@babel/runtime": "^7.25.0",
1024 | "@mui/utils": "^6.0.2",
1025 | "prop-types": "^15.8.1"
1026 | },
1027 | "engines": {
1028 | "node": ">=14.0.0"
1029 | },
1030 | "funding": {
1031 | "type": "opencollective",
1032 | "url": "https://opencollective.com/mui-org"
1033 | },
1034 | "peerDependencies": {
1035 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0",
1036 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
1037 | },
1038 | "peerDependenciesMeta": {
1039 | "@types/react": {
1040 | "optional": true
1041 | }
1042 | }
1043 | },
1044 | "node_modules/@mui/styled-engine": {
1045 | "version": "6.0.2",
1046 | "resolved": "https://registry.npmjs.org/@mui/styled-engine/-/styled-engine-6.0.2.tgz",
1047 | "integrity": "sha512-qd3Vlhted0SYVGotnCfVNcxff7vW2WN0fclbAexff60NeNS1qs/H/CImHEHUBiUGeNWMPRochbN6VF1arQ7/jA==",
1048 | "dependencies": {
1049 | "@babel/runtime": "^7.25.0",
1050 | "@emotion/cache": "^11.13.1",
1051 | "csstype": "^3.1.3",
1052 | "prop-types": "^15.8.1"
1053 | },
1054 | "engines": {
1055 | "node": ">=14.0.0"
1056 | },
1057 | "funding": {
1058 | "type": "opencollective",
1059 | "url": "https://opencollective.com/mui-org"
1060 | },
1061 | "peerDependencies": {
1062 | "@emotion/react": "^11.4.1",
1063 | "@emotion/styled": "^11.3.0",
1064 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
1065 | },
1066 | "peerDependenciesMeta": {
1067 | "@emotion/react": {
1068 | "optional": true
1069 | },
1070 | "@emotion/styled": {
1071 | "optional": true
1072 | }
1073 | }
1074 | },
1075 | "node_modules/@mui/system": {
1076 | "version": "6.0.2",
1077 | "resolved": "https://registry.npmjs.org/@mui/system/-/system-6.0.2.tgz",
1078 | "integrity": "sha512-AZv1/C4PuHgWFTA8YraIzl3FTVLdRz0RIMRwEADWZBdIhnuTHS/4+r8qE9+3CcpTHg1WsEu8btaO3AhQahSM9A==",
1079 | "dependencies": {
1080 | "@babel/runtime": "^7.25.0",
1081 | "@mui/private-theming": "^6.0.2",
1082 | "@mui/styled-engine": "^6.0.2",
1083 | "@mui/types": "^7.2.16",
1084 | "@mui/utils": "^6.0.2",
1085 | "clsx": "^2.1.1",
1086 | "csstype": "^3.1.3",
1087 | "prop-types": "^15.8.1"
1088 | },
1089 | "engines": {
1090 | "node": ">=14.0.0"
1091 | },
1092 | "funding": {
1093 | "type": "opencollective",
1094 | "url": "https://opencollective.com/mui-org"
1095 | },
1096 | "peerDependencies": {
1097 | "@emotion/react": "^11.5.0",
1098 | "@emotion/styled": "^11.3.0",
1099 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0",
1100 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
1101 | },
1102 | "peerDependenciesMeta": {
1103 | "@emotion/react": {
1104 | "optional": true
1105 | },
1106 | "@emotion/styled": {
1107 | "optional": true
1108 | },
1109 | "@types/react": {
1110 | "optional": true
1111 | }
1112 | }
1113 | },
1114 | "node_modules/@mui/types": {
1115 | "version": "7.2.16",
1116 | "resolved": "https://registry.npmjs.org/@mui/types/-/types-7.2.16.tgz",
1117 | "integrity": "sha512-qI8TV3M7ShITEEc8Ih15A2vLzZGLhD+/UPNwck/hcls2gwg7dyRjNGXcQYHKLB5Q7PuTRfrTkAoPa2VV1s67Ag==",
1118 | "peerDependencies": {
1119 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0"
1120 | },
1121 | "peerDependenciesMeta": {
1122 | "@types/react": {
1123 | "optional": true
1124 | }
1125 | }
1126 | },
1127 | "node_modules/@mui/utils": {
1128 | "version": "6.0.2",
1129 | "resolved": "https://registry.npmjs.org/@mui/utils/-/utils-6.0.2.tgz",
1130 | "integrity": "sha512-TeFrYsxcmeoDSlkoPhX+LjIuuqC5Pyj+xz2kRceKCkUpwMNTEeVOfowXDPe+mboZwmpJ5ZxP4eiAgQMdeEasjg==",
1131 | "dependencies": {
1132 | "@babel/runtime": "^7.25.0",
1133 | "@mui/types": "^7.2.16",
1134 | "@types/prop-types": "^15.7.12",
1135 | "clsx": "^2.1.1",
1136 | "prop-types": "^15.8.1",
1137 | "react-is": "^18.3.1"
1138 | },
1139 | "engines": {
1140 | "node": ">=14.0.0"
1141 | },
1142 | "funding": {
1143 | "type": "opencollective",
1144 | "url": "https://opencollective.com/mui-org"
1145 | },
1146 | "peerDependencies": {
1147 | "@types/react": "^17.0.0 || ^18.0.0 || ^19.0.0",
1148 | "react": "^17.0.0 || ^18.0.0 || ^19.0.0"
1149 | },
1150 | "peerDependenciesMeta": {
1151 | "@types/react": {
1152 | "optional": true
1153 | }
1154 | }
1155 | },
1156 | "node_modules/@nodelib/fs.scandir": {
1157 | "version": "2.1.5",
1158 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
1159 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
1160 | "dev": true,
1161 | "dependencies": {
1162 | "@nodelib/fs.stat": "2.0.5",
1163 | "run-parallel": "^1.1.9"
1164 | },
1165 | "engines": {
1166 | "node": ">= 8"
1167 | }
1168 | },
1169 | "node_modules/@nodelib/fs.stat": {
1170 | "version": "2.0.5",
1171 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
1172 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
1173 | "dev": true,
1174 | "engines": {
1175 | "node": ">= 8"
1176 | }
1177 | },
1178 | "node_modules/@nodelib/fs.walk": {
1179 | "version": "1.2.8",
1180 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
1181 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
1182 | "dev": true,
1183 | "dependencies": {
1184 | "@nodelib/fs.scandir": "2.1.5",
1185 | "fastq": "^1.6.0"
1186 | },
1187 | "engines": {
1188 | "node": ">= 8"
1189 | }
1190 | },
1191 | "node_modules/@popperjs/core": {
1192 | "version": "2.11.8",
1193 | "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz",
1194 | "integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==",
1195 | "funding": {
1196 | "type": "opencollective",
1197 | "url": "https://opencollective.com/popperjs"
1198 | }
1199 | },
1200 | "node_modules/@rollup/rollup-android-arm-eabi": {
1201 | "version": "4.21.2",
1202 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.21.2.tgz",
1203 | "integrity": "sha512-fSuPrt0ZO8uXeS+xP3b+yYTCBUd05MoSp2N/MFOgjhhUhMmchXlpTQrTpI8T+YAwAQuK7MafsCOxW7VrPMrJcg==",
1204 | "cpu": [
1205 | "arm"
1206 | ],
1207 | "dev": true,
1208 | "optional": true,
1209 | "os": [
1210 | "android"
1211 | ]
1212 | },
1213 | "node_modules/@rollup/rollup-android-arm64": {
1214 | "version": "4.21.2",
1215 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.21.2.tgz",
1216 | "integrity": "sha512-xGU5ZQmPlsjQS6tzTTGwMsnKUtu0WVbl0hYpTPauvbRAnmIvpInhJtgjj3mcuJpEiuUw4v1s4BimkdfDWlh7gA==",
1217 | "cpu": [
1218 | "arm64"
1219 | ],
1220 | "dev": true,
1221 | "optional": true,
1222 | "os": [
1223 | "android"
1224 | ]
1225 | },
1226 | "node_modules/@rollup/rollup-darwin-arm64": {
1227 | "version": "4.21.2",
1228 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.21.2.tgz",
1229 | "integrity": "sha512-99AhQ3/ZMxU7jw34Sq8brzXqWH/bMnf7ZVhvLk9QU2cOepbQSVTns6qoErJmSiAvU3InRqC2RRZ5ovh1KN0d0Q==",
1230 | "cpu": [
1231 | "arm64"
1232 | ],
1233 | "dev": true,
1234 | "optional": true,
1235 | "os": [
1236 | "darwin"
1237 | ]
1238 | },
1239 | "node_modules/@rollup/rollup-darwin-x64": {
1240 | "version": "4.21.2",
1241 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.21.2.tgz",
1242 | "integrity": "sha512-ZbRaUvw2iN/y37x6dY50D8m2BnDbBjlnMPotDi/qITMJ4sIxNY33HArjikDyakhSv0+ybdUxhWxE6kTI4oX26w==",
1243 | "cpu": [
1244 | "x64"
1245 | ],
1246 | "dev": true,
1247 | "optional": true,
1248 | "os": [
1249 | "darwin"
1250 | ]
1251 | },
1252 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
1253 | "version": "4.21.2",
1254 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.21.2.tgz",
1255 | "integrity": "sha512-ztRJJMiE8nnU1YFcdbd9BcH6bGWG1z+jP+IPW2oDUAPxPjo9dverIOyXz76m6IPA6udEL12reYeLojzW2cYL7w==",
1256 | "cpu": [
1257 | "arm"
1258 | ],
1259 | "dev": true,
1260 | "optional": true,
1261 | "os": [
1262 | "linux"
1263 | ]
1264 | },
1265 | "node_modules/@rollup/rollup-linux-arm-musleabihf": {
1266 | "version": "4.21.2",
1267 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.21.2.tgz",
1268 | "integrity": "sha512-flOcGHDZajGKYpLV0JNc0VFH361M7rnV1ee+NTeC/BQQ1/0pllYcFmxpagltANYt8FYf9+kL6RSk80Ziwyhr7w==",
1269 | "cpu": [
1270 | "arm"
1271 | ],
1272 | "dev": true,
1273 | "optional": true,
1274 | "os": [
1275 | "linux"
1276 | ]
1277 | },
1278 | "node_modules/@rollup/rollup-linux-arm64-gnu": {
1279 | "version": "4.21.2",
1280 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.21.2.tgz",
1281 | "integrity": "sha512-69CF19Kp3TdMopyteO/LJbWufOzqqXzkrv4L2sP8kfMaAQ6iwky7NoXTp7bD6/irKgknDKM0P9E/1l5XxVQAhw==",
1282 | "cpu": [
1283 | "arm64"
1284 | ],
1285 | "dev": true,
1286 | "optional": true,
1287 | "os": [
1288 | "linux"
1289 | ]
1290 | },
1291 | "node_modules/@rollup/rollup-linux-arm64-musl": {
1292 | "version": "4.21.2",
1293 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.21.2.tgz",
1294 | "integrity": "sha512-48pD/fJkTiHAZTnZwR0VzHrao70/4MlzJrq0ZsILjLW/Ab/1XlVUStYyGt7tdyIiVSlGZbnliqmult/QGA2O2w==",
1295 | "cpu": [
1296 | "arm64"
1297 | ],
1298 | "dev": true,
1299 | "optional": true,
1300 | "os": [
1301 | "linux"
1302 | ]
1303 | },
1304 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": {
1305 | "version": "4.21.2",
1306 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.21.2.tgz",
1307 | "integrity": "sha512-cZdyuInj0ofc7mAQpKcPR2a2iu4YM4FQfuUzCVA2u4HI95lCwzjoPtdWjdpDKyHxI0UO82bLDoOaLfpZ/wviyQ==",
1308 | "cpu": [
1309 | "ppc64"
1310 | ],
1311 | "dev": true,
1312 | "optional": true,
1313 | "os": [
1314 | "linux"
1315 | ]
1316 | },
1317 | "node_modules/@rollup/rollup-linux-riscv64-gnu": {
1318 | "version": "4.21.2",
1319 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.21.2.tgz",
1320 | "integrity": "sha512-RL56JMT6NwQ0lXIQmMIWr1SW28z4E4pOhRRNqwWZeXpRlykRIlEpSWdsgNWJbYBEWD84eocjSGDu/XxbYeCmwg==",
1321 | "cpu": [
1322 | "riscv64"
1323 | ],
1324 | "dev": true,
1325 | "optional": true,
1326 | "os": [
1327 | "linux"
1328 | ]
1329 | },
1330 | "node_modules/@rollup/rollup-linux-s390x-gnu": {
1331 | "version": "4.21.2",
1332 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.21.2.tgz",
1333 | "integrity": "sha512-PMxkrWS9z38bCr3rWvDFVGD6sFeZJw4iQlhrup7ReGmfn7Oukrr/zweLhYX6v2/8J6Cep9IEA/SmjXjCmSbrMQ==",
1334 | "cpu": [
1335 | "s390x"
1336 | ],
1337 | "dev": true,
1338 | "optional": true,
1339 | "os": [
1340 | "linux"
1341 | ]
1342 | },
1343 | "node_modules/@rollup/rollup-linux-x64-gnu": {
1344 | "version": "4.21.2",
1345 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.21.2.tgz",
1346 | "integrity": "sha512-B90tYAUoLhU22olrafY3JQCFLnT3NglazdwkHyxNDYF/zAxJt5fJUB/yBoWFoIQ7SQj+KLe3iL4BhOMa9fzgpw==",
1347 | "cpu": [
1348 | "x64"
1349 | ],
1350 | "dev": true,
1351 | "optional": true,
1352 | "os": [
1353 | "linux"
1354 | ]
1355 | },
1356 | "node_modules/@rollup/rollup-linux-x64-musl": {
1357 | "version": "4.21.2",
1358 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.21.2.tgz",
1359 | "integrity": "sha512-7twFizNXudESmC9oneLGIUmoHiiLppz/Xs5uJQ4ShvE6234K0VB1/aJYU3f/4g7PhssLGKBVCC37uRkkOi8wjg==",
1360 | "cpu": [
1361 | "x64"
1362 | ],
1363 | "dev": true,
1364 | "optional": true,
1365 | "os": [
1366 | "linux"
1367 | ]
1368 | },
1369 | "node_modules/@rollup/rollup-win32-arm64-msvc": {
1370 | "version": "4.21.2",
1371 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.21.2.tgz",
1372 | "integrity": "sha512-9rRero0E7qTeYf6+rFh3AErTNU1VCQg2mn7CQcI44vNUWM9Ze7MSRS/9RFuSsox+vstRt97+x3sOhEey024FRQ==",
1373 | "cpu": [
1374 | "arm64"
1375 | ],
1376 | "dev": true,
1377 | "optional": true,
1378 | "os": [
1379 | "win32"
1380 | ]
1381 | },
1382 | "node_modules/@rollup/rollup-win32-ia32-msvc": {
1383 | "version": "4.21.2",
1384 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.21.2.tgz",
1385 | "integrity": "sha512-5rA4vjlqgrpbFVVHX3qkrCo/fZTj1q0Xxpg+Z7yIo3J2AilW7t2+n6Q8Jrx+4MrYpAnjttTYF8rr7bP46BPzRw==",
1386 | "cpu": [
1387 | "ia32"
1388 | ],
1389 | "dev": true,
1390 | "optional": true,
1391 | "os": [
1392 | "win32"
1393 | ]
1394 | },
1395 | "node_modules/@rollup/rollup-win32-x64-msvc": {
1396 | "version": "4.21.2",
1397 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.21.2.tgz",
1398 | "integrity": "sha512-6UUxd0+SKomjdzuAcp+HAmxw1FlGBnl1v2yEPSabtx4lBfdXHDVsW7+lQkgz9cNFJGY3AWR7+V8P5BqkD9L9nA==",
1399 | "cpu": [
1400 | "x64"
1401 | ],
1402 | "dev": true,
1403 | "optional": true,
1404 | "os": [
1405 | "win32"
1406 | ]
1407 | },
1408 | "node_modules/@swc/core": {
1409 | "version": "1.7.24",
1410 | "resolved": "https://registry.npmjs.org/@swc/core/-/core-1.7.24.tgz",
1411 | "integrity": "sha512-FzJaai6z6DYdICAY1UKNN5pzTn296ksK2zzEjjaXlpZtoMkGktWT0ttS7hbdBCPGhLOu5Q9TA2zdPejKUFjgig==",
1412 | "dev": true,
1413 | "hasInstallScript": true,
1414 | "dependencies": {
1415 | "@swc/counter": "^0.1.3",
1416 | "@swc/types": "^0.1.12"
1417 | },
1418 | "engines": {
1419 | "node": ">=10"
1420 | },
1421 | "funding": {
1422 | "type": "opencollective",
1423 | "url": "https://opencollective.com/swc"
1424 | },
1425 | "optionalDependencies": {
1426 | "@swc/core-darwin-arm64": "1.7.24",
1427 | "@swc/core-darwin-x64": "1.7.24",
1428 | "@swc/core-linux-arm-gnueabihf": "1.7.24",
1429 | "@swc/core-linux-arm64-gnu": "1.7.24",
1430 | "@swc/core-linux-arm64-musl": "1.7.24",
1431 | "@swc/core-linux-x64-gnu": "1.7.24",
1432 | "@swc/core-linux-x64-musl": "1.7.24",
1433 | "@swc/core-win32-arm64-msvc": "1.7.24",
1434 | "@swc/core-win32-ia32-msvc": "1.7.24",
1435 | "@swc/core-win32-x64-msvc": "1.7.24"
1436 | },
1437 | "peerDependencies": {
1438 | "@swc/helpers": "*"
1439 | },
1440 | "peerDependenciesMeta": {
1441 | "@swc/helpers": {
1442 | "optional": true
1443 | }
1444 | }
1445 | },
1446 | "node_modules/@swc/core-darwin-arm64": {
1447 | "version": "1.7.24",
1448 | "resolved": "https://registry.npmjs.org/@swc/core-darwin-arm64/-/core-darwin-arm64-1.7.24.tgz",
1449 | "integrity": "sha512-s0k09qAcsoa8jIncwgRRd43VApYqXu28R4OmICtDffV4S01HtsRLRarXsMuLutoZk3tbxqitep+A8MPBuqNgdg==",
1450 | "cpu": [
1451 | "arm64"
1452 | ],
1453 | "dev": true,
1454 | "optional": true,
1455 | "os": [
1456 | "darwin"
1457 | ],
1458 | "engines": {
1459 | "node": ">=10"
1460 | }
1461 | },
1462 | "node_modules/@swc/core-darwin-x64": {
1463 | "version": "1.7.24",
1464 | "resolved": "https://registry.npmjs.org/@swc/core-darwin-x64/-/core-darwin-x64-1.7.24.tgz",
1465 | "integrity": "sha512-1dlsulJ/fiOoJoJyQgaCewIEaZ7Sh6aJN4r5Uhl4lIZuNWa27XOb28A3K29/6HDO9JML3IJrvXPnl5o0vxDQuQ==",
1466 | "cpu": [
1467 | "x64"
1468 | ],
1469 | "dev": true,
1470 | "optional": true,
1471 | "os": [
1472 | "darwin"
1473 | ],
1474 | "engines": {
1475 | "node": ">=10"
1476 | }
1477 | },
1478 | "node_modules/@swc/core-linux-arm-gnueabihf": {
1479 | "version": "1.7.24",
1480 | "resolved": "https://registry.npmjs.org/@swc/core-linux-arm-gnueabihf/-/core-linux-arm-gnueabihf-1.7.24.tgz",
1481 | "integrity": "sha512-2ft1NmxyvHCu5CY4r2rNVybPqZtJaxpRSzvCcPlVjN/2D5Q3QgM5kBoo1t+0RCFfk4TS2V0KWJhtqKz0CNX62Q==",
1482 | "cpu": [
1483 | "arm"
1484 | ],
1485 | "dev": true,
1486 | "optional": true,
1487 | "os": [
1488 | "linux"
1489 | ],
1490 | "engines": {
1491 | "node": ">=10"
1492 | }
1493 | },
1494 | "node_modules/@swc/core-linux-arm64-gnu": {
1495 | "version": "1.7.24",
1496 | "resolved": "https://registry.npmjs.org/@swc/core-linux-arm64-gnu/-/core-linux-arm64-gnu-1.7.24.tgz",
1497 | "integrity": "sha512-v/Z8I9tUUNkNHKa1Sw4r1Q7Wp66ezbRhe6xMIxvPNKVJQFaMOsRpe0t8T5qbk5sV2hJGOCKpQynSpZqQXLcJDQ==",
1498 | "cpu": [
1499 | "arm64"
1500 | ],
1501 | "dev": true,
1502 | "optional": true,
1503 | "os": [
1504 | "linux"
1505 | ],
1506 | "engines": {
1507 | "node": ">=10"
1508 | }
1509 | },
1510 | "node_modules/@swc/core-linux-arm64-musl": {
1511 | "version": "1.7.24",
1512 | "resolved": "https://registry.npmjs.org/@swc/core-linux-arm64-musl/-/core-linux-arm64-musl-1.7.24.tgz",
1513 | "integrity": "sha512-0jJx0IcajcyOXaJsx1jXy86lYVrbupyy2VUj/OiJux/ic4oBJLjfL+WOuc8T8/hZj2p6X0X4jvfSCqWSuic4kA==",
1514 | "cpu": [
1515 | "arm64"
1516 | ],
1517 | "dev": true,
1518 | "optional": true,
1519 | "os": [
1520 | "linux"
1521 | ],
1522 | "engines": {
1523 | "node": ">=10"
1524 | }
1525 | },
1526 | "node_modules/@swc/core-linux-x64-gnu": {
1527 | "version": "1.7.24",
1528 | "resolved": "https://registry.npmjs.org/@swc/core-linux-x64-gnu/-/core-linux-x64-gnu-1.7.24.tgz",
1529 | "integrity": "sha512-2+3aKQpSGjVnWKDTKUPuJzitQlTQrGorg+PVFMRkv6l+RcNCHZQNe/8VYpMhyBhxDMb3LUlbp7776FRevcruxg==",
1530 | "cpu": [
1531 | "x64"
1532 | ],
1533 | "dev": true,
1534 | "optional": true,
1535 | "os": [
1536 | "linux"
1537 | ],
1538 | "engines": {
1539 | "node": ">=10"
1540 | }
1541 | },
1542 | "node_modules/@swc/core-linux-x64-musl": {
1543 | "version": "1.7.24",
1544 | "resolved": "https://registry.npmjs.org/@swc/core-linux-x64-musl/-/core-linux-x64-musl-1.7.24.tgz",
1545 | "integrity": "sha512-PMQ6SkCtMoj0Ks77DiishpEmIuHpYjFLDuVOzzJCzGeGoii0yRP5lKy/VeglFYLPqJzmhK9BHlpVehVf/8ZpvA==",
1546 | "cpu": [
1547 | "x64"
1548 | ],
1549 | "dev": true,
1550 | "optional": true,
1551 | "os": [
1552 | "linux"
1553 | ],
1554 | "engines": {
1555 | "node": ">=10"
1556 | }
1557 | },
1558 | "node_modules/@swc/core-win32-arm64-msvc": {
1559 | "version": "1.7.24",
1560 | "resolved": "https://registry.npmjs.org/@swc/core-win32-arm64-msvc/-/core-win32-arm64-msvc-1.7.24.tgz",
1561 | "integrity": "sha512-SNdCa4DtGXNWrPVHqctVUxgEVZVETuqERpqF50KFHO0Bvf5V/m1IJ4hFr2BxXlrzgnIW4t1Dpi6YOJbcGbEmnA==",
1562 | "cpu": [
1563 | "arm64"
1564 | ],
1565 | "dev": true,
1566 | "optional": true,
1567 | "os": [
1568 | "win32"
1569 | ],
1570 | "engines": {
1571 | "node": ">=10"
1572 | }
1573 | },
1574 | "node_modules/@swc/core-win32-ia32-msvc": {
1575 | "version": "1.7.24",
1576 | "resolved": "https://registry.npmjs.org/@swc/core-win32-ia32-msvc/-/core-win32-ia32-msvc-1.7.24.tgz",
1577 | "integrity": "sha512-5p3olHqwibMfrVFg2yVuSIPh9HArDYYlJXNZ9JKqeZk23A19J1pl9MuPmXDw+sxsiPfYJ/nUedIGeUHPF/+EDw==",
1578 | "cpu": [
1579 | "ia32"
1580 | ],
1581 | "dev": true,
1582 | "optional": true,
1583 | "os": [
1584 | "win32"
1585 | ],
1586 | "engines": {
1587 | "node": ">=10"
1588 | }
1589 | },
1590 | "node_modules/@swc/core-win32-x64-msvc": {
1591 | "version": "1.7.24",
1592 | "resolved": "https://registry.npmjs.org/@swc/core-win32-x64-msvc/-/core-win32-x64-msvc-1.7.24.tgz",
1593 | "integrity": "sha512-gRyPIxDznS8d2ClfmWbytjp2d48bij6swHnDLWhukNuOvXdQkEmaIzjEsionFG/zhcFLnz8zKfTvjEjInAMzxg==",
1594 | "cpu": [
1595 | "x64"
1596 | ],
1597 | "dev": true,
1598 | "optional": true,
1599 | "os": [
1600 | "win32"
1601 | ],
1602 | "engines": {
1603 | "node": ">=10"
1604 | }
1605 | },
1606 | "node_modules/@swc/counter": {
1607 | "version": "0.1.3",
1608 | "resolved": "https://registry.npmjs.org/@swc/counter/-/counter-0.1.3.tgz",
1609 | "integrity": "sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ==",
1610 | "dev": true
1611 | },
1612 | "node_modules/@swc/types": {
1613 | "version": "0.1.12",
1614 | "resolved": "https://registry.npmjs.org/@swc/types/-/types-0.1.12.tgz",
1615 | "integrity": "sha512-wBJA+SdtkbFhHjTMYH+dEH1y4VpfGdAc2Kw/LK09i9bXd/K6j6PkDcFCEzb6iVfZMkPRrl/q0e3toqTAJdkIVA==",
1616 | "dev": true,
1617 | "dependencies": {
1618 | "@swc/counter": "^0.1.3"
1619 | }
1620 | },
1621 | "node_modules/@types/estree": {
1622 | "version": "1.0.5",
1623 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz",
1624 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==",
1625 | "dev": true
1626 | },
1627 | "node_modules/@types/parse-json": {
1628 | "version": "4.0.2",
1629 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.2.tgz",
1630 | "integrity": "sha512-dISoDXWWQwUquiKsyZ4Ng+HX2KsPL7LyHKHQwgGFEA3IaKac4Obd+h2a/a6waisAoepJlBcx9paWqjA8/HVjCw=="
1631 | },
1632 | "node_modules/@types/prop-types": {
1633 | "version": "15.7.12",
1634 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.12.tgz",
1635 | "integrity": "sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q=="
1636 | },
1637 | "node_modules/@types/react": {
1638 | "version": "18.3.5",
1639 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.5.tgz",
1640 | "integrity": "sha512-WeqMfGJLGuLCqHGYRGHxnKrXcTitc6L/nBUWfWPcTarG3t9PsquqUMuVeXZeca+mglY4Vo5GZjCi0A3Or2lnxA==",
1641 | "dependencies": {
1642 | "@types/prop-types": "*",
1643 | "csstype": "^3.0.2"
1644 | }
1645 | },
1646 | "node_modules/@types/react-dom": {
1647 | "version": "18.3.0",
1648 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.0.tgz",
1649 | "integrity": "sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==",
1650 | "dev": true,
1651 | "dependencies": {
1652 | "@types/react": "*"
1653 | }
1654 | },
1655 | "node_modules/@types/react-transition-group": {
1656 | "version": "4.4.11",
1657 | "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.11.tgz",
1658 | "integrity": "sha512-RM05tAniPZ5DZPzzNFP+DmrcOdD0efDUxMy3145oljWSl3x9ZV5vhme98gTxFrj2lhXvmGNnUiuDyJgY9IKkNA==",
1659 | "dependencies": {
1660 | "@types/react": "*"
1661 | }
1662 | },
1663 | "node_modules/@typescript-eslint/eslint-plugin": {
1664 | "version": "8.5.0",
1665 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.5.0.tgz",
1666 | "integrity": "sha512-lHS5hvz33iUFQKuPFGheAB84LwcJ60G8vKnEhnfcK1l8kGVLro2SFYW6K0/tj8FUhRJ0VHyg1oAfg50QGbPPHw==",
1667 | "dev": true,
1668 | "dependencies": {
1669 | "@eslint-community/regexpp": "^4.10.0",
1670 | "@typescript-eslint/scope-manager": "8.5.0",
1671 | "@typescript-eslint/type-utils": "8.5.0",
1672 | "@typescript-eslint/utils": "8.5.0",
1673 | "@typescript-eslint/visitor-keys": "8.5.0",
1674 | "graphemer": "^1.4.0",
1675 | "ignore": "^5.3.1",
1676 | "natural-compare": "^1.4.0",
1677 | "ts-api-utils": "^1.3.0"
1678 | },
1679 | "engines": {
1680 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1681 | },
1682 | "funding": {
1683 | "type": "opencollective",
1684 | "url": "https://opencollective.com/typescript-eslint"
1685 | },
1686 | "peerDependencies": {
1687 | "@typescript-eslint/parser": "^8.0.0 || ^8.0.0-alpha.0",
1688 | "eslint": "^8.57.0 || ^9.0.0"
1689 | },
1690 | "peerDependenciesMeta": {
1691 | "typescript": {
1692 | "optional": true
1693 | }
1694 | }
1695 | },
1696 | "node_modules/@typescript-eslint/parser": {
1697 | "version": "8.5.0",
1698 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.5.0.tgz",
1699 | "integrity": "sha512-gF77eNv0Xz2UJg/NbpWJ0kqAm35UMsvZf1GHj8D9MRFTj/V3tAciIWXfmPLsAAF/vUlpWPvUDyH1jjsr0cMVWw==",
1700 | "dev": true,
1701 | "dependencies": {
1702 | "@typescript-eslint/scope-manager": "8.5.0",
1703 | "@typescript-eslint/types": "8.5.0",
1704 | "@typescript-eslint/typescript-estree": "8.5.0",
1705 | "@typescript-eslint/visitor-keys": "8.5.0",
1706 | "debug": "^4.3.4"
1707 | },
1708 | "engines": {
1709 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1710 | },
1711 | "funding": {
1712 | "type": "opencollective",
1713 | "url": "https://opencollective.com/typescript-eslint"
1714 | },
1715 | "peerDependencies": {
1716 | "eslint": "^8.57.0 || ^9.0.0"
1717 | },
1718 | "peerDependenciesMeta": {
1719 | "typescript": {
1720 | "optional": true
1721 | }
1722 | }
1723 | },
1724 | "node_modules/@typescript-eslint/scope-manager": {
1725 | "version": "8.5.0",
1726 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.5.0.tgz",
1727 | "integrity": "sha512-06JOQ9Qgj33yvBEx6tpC8ecP9o860rsR22hWMEd12WcTRrfaFgHr2RB/CA/B+7BMhHkXT4chg2MyboGdFGawYg==",
1728 | "dev": true,
1729 | "dependencies": {
1730 | "@typescript-eslint/types": "8.5.0",
1731 | "@typescript-eslint/visitor-keys": "8.5.0"
1732 | },
1733 | "engines": {
1734 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1735 | },
1736 | "funding": {
1737 | "type": "opencollective",
1738 | "url": "https://opencollective.com/typescript-eslint"
1739 | }
1740 | },
1741 | "node_modules/@typescript-eslint/type-utils": {
1742 | "version": "8.5.0",
1743 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.5.0.tgz",
1744 | "integrity": "sha512-N1K8Ix+lUM+cIDhL2uekVn/ZD7TZW+9/rwz8DclQpcQ9rk4sIL5CAlBC0CugWKREmDjBzI/kQqU4wkg46jWLYA==",
1745 | "dev": true,
1746 | "dependencies": {
1747 | "@typescript-eslint/typescript-estree": "8.5.0",
1748 | "@typescript-eslint/utils": "8.5.0",
1749 | "debug": "^4.3.4",
1750 | "ts-api-utils": "^1.3.0"
1751 | },
1752 | "engines": {
1753 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1754 | },
1755 | "funding": {
1756 | "type": "opencollective",
1757 | "url": "https://opencollective.com/typescript-eslint"
1758 | },
1759 | "peerDependenciesMeta": {
1760 | "typescript": {
1761 | "optional": true
1762 | }
1763 | }
1764 | },
1765 | "node_modules/@typescript-eslint/types": {
1766 | "version": "8.5.0",
1767 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.5.0.tgz",
1768 | "integrity": "sha512-qjkormnQS5wF9pjSi6q60bKUHH44j2APxfh9TQRXK8wbYVeDYYdYJGIROL87LGZZ2gz3Rbmjc736qyL8deVtdw==",
1769 | "dev": true,
1770 | "engines": {
1771 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1772 | },
1773 | "funding": {
1774 | "type": "opencollective",
1775 | "url": "https://opencollective.com/typescript-eslint"
1776 | }
1777 | },
1778 | "node_modules/@typescript-eslint/typescript-estree": {
1779 | "version": "8.5.0",
1780 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.5.0.tgz",
1781 | "integrity": "sha512-vEG2Sf9P8BPQ+d0pxdfndw3xIXaoSjliG0/Ejk7UggByZPKXmJmw3GW5jV2gHNQNawBUyfahoSiCFVov0Ruf7Q==",
1782 | "dev": true,
1783 | "dependencies": {
1784 | "@typescript-eslint/types": "8.5.0",
1785 | "@typescript-eslint/visitor-keys": "8.5.0",
1786 | "debug": "^4.3.4",
1787 | "fast-glob": "^3.3.2",
1788 | "is-glob": "^4.0.3",
1789 | "minimatch": "^9.0.4",
1790 | "semver": "^7.6.0",
1791 | "ts-api-utils": "^1.3.0"
1792 | },
1793 | "engines": {
1794 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1795 | },
1796 | "funding": {
1797 | "type": "opencollective",
1798 | "url": "https://opencollective.com/typescript-eslint"
1799 | },
1800 | "peerDependenciesMeta": {
1801 | "typescript": {
1802 | "optional": true
1803 | }
1804 | }
1805 | },
1806 | "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion": {
1807 | "version": "2.0.1",
1808 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
1809 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
1810 | "dev": true,
1811 | "dependencies": {
1812 | "balanced-match": "^1.0.0"
1813 | }
1814 | },
1815 | "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": {
1816 | "version": "9.0.5",
1817 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz",
1818 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==",
1819 | "dev": true,
1820 | "dependencies": {
1821 | "brace-expansion": "^2.0.1"
1822 | },
1823 | "engines": {
1824 | "node": ">=16 || 14 >=14.17"
1825 | },
1826 | "funding": {
1827 | "url": "https://github.com/sponsors/isaacs"
1828 | }
1829 | },
1830 | "node_modules/@typescript-eslint/utils": {
1831 | "version": "8.5.0",
1832 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.5.0.tgz",
1833 | "integrity": "sha512-6yyGYVL0e+VzGYp60wvkBHiqDWOpT63pdMV2CVG4LVDd5uR6q1qQN/7LafBZtAtNIn/mqXjsSeS5ggv/P0iECw==",
1834 | "dev": true,
1835 | "dependencies": {
1836 | "@eslint-community/eslint-utils": "^4.4.0",
1837 | "@typescript-eslint/scope-manager": "8.5.0",
1838 | "@typescript-eslint/types": "8.5.0",
1839 | "@typescript-eslint/typescript-estree": "8.5.0"
1840 | },
1841 | "engines": {
1842 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1843 | },
1844 | "funding": {
1845 | "type": "opencollective",
1846 | "url": "https://opencollective.com/typescript-eslint"
1847 | },
1848 | "peerDependencies": {
1849 | "eslint": "^8.57.0 || ^9.0.0"
1850 | }
1851 | },
1852 | "node_modules/@typescript-eslint/visitor-keys": {
1853 | "version": "8.5.0",
1854 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.5.0.tgz",
1855 | "integrity": "sha512-yTPqMnbAZJNy2Xq2XU8AdtOW9tJIr+UQb64aXB9f3B1498Zx9JorVgFJcZpEc9UBuCCrdzKID2RGAMkYcDtZOw==",
1856 | "dev": true,
1857 | "dependencies": {
1858 | "@typescript-eslint/types": "8.5.0",
1859 | "eslint-visitor-keys": "^3.4.3"
1860 | },
1861 | "engines": {
1862 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1863 | },
1864 | "funding": {
1865 | "type": "opencollective",
1866 | "url": "https://opencollective.com/typescript-eslint"
1867 | }
1868 | },
1869 | "node_modules/@typescript-eslint/visitor-keys/node_modules/eslint-visitor-keys": {
1870 | "version": "3.4.3",
1871 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
1872 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
1873 | "dev": true,
1874 | "engines": {
1875 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
1876 | },
1877 | "funding": {
1878 | "url": "https://opencollective.com/eslint"
1879 | }
1880 | },
1881 | "node_modules/@vitejs/plugin-react-swc": {
1882 | "version": "3.7.0",
1883 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react-swc/-/plugin-react-swc-3.7.0.tgz",
1884 | "integrity": "sha512-yrknSb3Dci6svCd/qhHqhFPDSw0QtjumcqdKMoNNzmOl5lMXTTiqzjWtG4Qask2HdvvzaNgSunbQGet8/GrKdA==",
1885 | "dev": true,
1886 | "dependencies": {
1887 | "@swc/core": "^1.5.7"
1888 | },
1889 | "peerDependencies": {
1890 | "vite": "^4 || ^5"
1891 | }
1892 | },
1893 | "node_modules/acorn": {
1894 | "version": "8.12.1",
1895 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz",
1896 | "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==",
1897 | "dev": true,
1898 | "bin": {
1899 | "acorn": "bin/acorn"
1900 | },
1901 | "engines": {
1902 | "node": ">=0.4.0"
1903 | }
1904 | },
1905 | "node_modules/acorn-jsx": {
1906 | "version": "5.3.2",
1907 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
1908 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
1909 | "dev": true,
1910 | "peerDependencies": {
1911 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
1912 | }
1913 | },
1914 | "node_modules/ajv": {
1915 | "version": "6.12.6",
1916 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
1917 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
1918 | "dev": true,
1919 | "dependencies": {
1920 | "fast-deep-equal": "^3.1.1",
1921 | "fast-json-stable-stringify": "^2.0.0",
1922 | "json-schema-traverse": "^0.4.1",
1923 | "uri-js": "^4.2.2"
1924 | },
1925 | "funding": {
1926 | "type": "github",
1927 | "url": "https://github.com/sponsors/epoberezkin"
1928 | }
1929 | },
1930 | "node_modules/ansi-regex": {
1931 | "version": "5.0.1",
1932 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
1933 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
1934 | "dev": true,
1935 | "engines": {
1936 | "node": ">=8"
1937 | }
1938 | },
1939 | "node_modules/ansi-styles": {
1940 | "version": "4.3.0",
1941 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
1942 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
1943 | "dev": true,
1944 | "dependencies": {
1945 | "color-convert": "^2.0.1"
1946 | },
1947 | "engines": {
1948 | "node": ">=8"
1949 | },
1950 | "funding": {
1951 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1952 | }
1953 | },
1954 | "node_modules/argparse": {
1955 | "version": "2.0.1",
1956 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
1957 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
1958 | "dev": true
1959 | },
1960 | "node_modules/babel-plugin-macros": {
1961 | "version": "3.1.0",
1962 | "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz",
1963 | "integrity": "sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg==",
1964 | "dependencies": {
1965 | "@babel/runtime": "^7.12.5",
1966 | "cosmiconfig": "^7.0.0",
1967 | "resolve": "^1.19.0"
1968 | },
1969 | "engines": {
1970 | "node": ">=10",
1971 | "npm": ">=6"
1972 | }
1973 | },
1974 | "node_modules/balanced-match": {
1975 | "version": "1.0.2",
1976 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
1977 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
1978 | "dev": true
1979 | },
1980 | "node_modules/brace-expansion": {
1981 | "version": "1.1.11",
1982 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
1983 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
1984 | "dev": true,
1985 | "dependencies": {
1986 | "balanced-match": "^1.0.0",
1987 | "concat-map": "0.0.1"
1988 | }
1989 | },
1990 | "node_modules/braces": {
1991 | "version": "3.0.3",
1992 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz",
1993 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==",
1994 | "dev": true,
1995 | "dependencies": {
1996 | "fill-range": "^7.1.1"
1997 | },
1998 | "engines": {
1999 | "node": ">=8"
2000 | }
2001 | },
2002 | "node_modules/callsites": {
2003 | "version": "3.1.0",
2004 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
2005 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
2006 | "engines": {
2007 | "node": ">=6"
2008 | }
2009 | },
2010 | "node_modules/chalk": {
2011 | "version": "4.1.2",
2012 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
2013 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
2014 | "dev": true,
2015 | "dependencies": {
2016 | "ansi-styles": "^4.1.0",
2017 | "supports-color": "^7.1.0"
2018 | },
2019 | "engines": {
2020 | "node": ">=10"
2021 | },
2022 | "funding": {
2023 | "url": "https://github.com/chalk/chalk?sponsor=1"
2024 | }
2025 | },
2026 | "node_modules/clsx": {
2027 | "version": "2.1.1",
2028 | "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz",
2029 | "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==",
2030 | "engines": {
2031 | "node": ">=6"
2032 | }
2033 | },
2034 | "node_modules/color-convert": {
2035 | "version": "2.0.1",
2036 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2037 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2038 | "dev": true,
2039 | "dependencies": {
2040 | "color-name": "~1.1.4"
2041 | },
2042 | "engines": {
2043 | "node": ">=7.0.0"
2044 | }
2045 | },
2046 | "node_modules/color-name": {
2047 | "version": "1.1.4",
2048 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2049 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
2050 | "dev": true
2051 | },
2052 | "node_modules/concat-map": {
2053 | "version": "0.0.1",
2054 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
2055 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
2056 | "dev": true
2057 | },
2058 | "node_modules/convert-source-map": {
2059 | "version": "1.9.0",
2060 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
2061 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A=="
2062 | },
2063 | "node_modules/cosmiconfig": {
2064 | "version": "7.1.0",
2065 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
2066 | "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
2067 | "dependencies": {
2068 | "@types/parse-json": "^4.0.0",
2069 | "import-fresh": "^3.2.1",
2070 | "parse-json": "^5.0.0",
2071 | "path-type": "^4.0.0",
2072 | "yaml": "^1.10.0"
2073 | },
2074 | "engines": {
2075 | "node": ">=10"
2076 | }
2077 | },
2078 | "node_modules/cross-spawn": {
2079 | "version": "7.0.3",
2080 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
2081 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
2082 | "dev": true,
2083 | "dependencies": {
2084 | "path-key": "^3.1.0",
2085 | "shebang-command": "^2.0.0",
2086 | "which": "^2.0.1"
2087 | },
2088 | "engines": {
2089 | "node": ">= 8"
2090 | }
2091 | },
2092 | "node_modules/csstype": {
2093 | "version": "3.1.3",
2094 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
2095 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw=="
2096 | },
2097 | "node_modules/debug": {
2098 | "version": "4.3.7",
2099 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz",
2100 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==",
2101 | "dependencies": {
2102 | "ms": "^2.1.3"
2103 | },
2104 | "engines": {
2105 | "node": ">=6.0"
2106 | },
2107 | "peerDependenciesMeta": {
2108 | "supports-color": {
2109 | "optional": true
2110 | }
2111 | }
2112 | },
2113 | "node_modules/deep-is": {
2114 | "version": "0.1.4",
2115 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
2116 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
2117 | "dev": true
2118 | },
2119 | "node_modules/dom-helpers": {
2120 | "version": "5.2.1",
2121 | "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.2.1.tgz",
2122 | "integrity": "sha512-nRCa7CK3VTrM2NmGkIy4cbK7IZlgBE/PYMn55rrXefr5xXDP0LdtfPnblFDoVdcAfslJ7or6iqAUnx0CCGIWQA==",
2123 | "dependencies": {
2124 | "@babel/runtime": "^7.8.7",
2125 | "csstype": "^3.0.2"
2126 | }
2127 | },
2128 | "node_modules/error-ex": {
2129 | "version": "1.3.2",
2130 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
2131 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
2132 | "dependencies": {
2133 | "is-arrayish": "^0.2.1"
2134 | }
2135 | },
2136 | "node_modules/esbuild": {
2137 | "version": "0.21.5",
2138 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz",
2139 | "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==",
2140 | "dev": true,
2141 | "hasInstallScript": true,
2142 | "bin": {
2143 | "esbuild": "bin/esbuild"
2144 | },
2145 | "engines": {
2146 | "node": ">=12"
2147 | },
2148 | "optionalDependencies": {
2149 | "@esbuild/aix-ppc64": "0.21.5",
2150 | "@esbuild/android-arm": "0.21.5",
2151 | "@esbuild/android-arm64": "0.21.5",
2152 | "@esbuild/android-x64": "0.21.5",
2153 | "@esbuild/darwin-arm64": "0.21.5",
2154 | "@esbuild/darwin-x64": "0.21.5",
2155 | "@esbuild/freebsd-arm64": "0.21.5",
2156 | "@esbuild/freebsd-x64": "0.21.5",
2157 | "@esbuild/linux-arm": "0.21.5",
2158 | "@esbuild/linux-arm64": "0.21.5",
2159 | "@esbuild/linux-ia32": "0.21.5",
2160 | "@esbuild/linux-loong64": "0.21.5",
2161 | "@esbuild/linux-mips64el": "0.21.5",
2162 | "@esbuild/linux-ppc64": "0.21.5",
2163 | "@esbuild/linux-riscv64": "0.21.5",
2164 | "@esbuild/linux-s390x": "0.21.5",
2165 | "@esbuild/linux-x64": "0.21.5",
2166 | "@esbuild/netbsd-x64": "0.21.5",
2167 | "@esbuild/openbsd-x64": "0.21.5",
2168 | "@esbuild/sunos-x64": "0.21.5",
2169 | "@esbuild/win32-arm64": "0.21.5",
2170 | "@esbuild/win32-ia32": "0.21.5",
2171 | "@esbuild/win32-x64": "0.21.5"
2172 | }
2173 | },
2174 | "node_modules/escape-string-regexp": {
2175 | "version": "4.0.0",
2176 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
2177 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
2178 | "engines": {
2179 | "node": ">=10"
2180 | },
2181 | "funding": {
2182 | "url": "https://github.com/sponsors/sindresorhus"
2183 | }
2184 | },
2185 | "node_modules/eslint": {
2186 | "version": "9.10.0",
2187 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.10.0.tgz",
2188 | "integrity": "sha512-Y4D0IgtBZfOcOUAIQTSXBKoNGfY0REGqHJG6+Q81vNippW5YlKjHFj4soMxamKK1NXHUWuBZTLdU3Km+L/pcHw==",
2189 | "dev": true,
2190 | "dependencies": {
2191 | "@eslint-community/eslint-utils": "^4.2.0",
2192 | "@eslint-community/regexpp": "^4.11.0",
2193 | "@eslint/config-array": "^0.18.0",
2194 | "@eslint/eslintrc": "^3.1.0",
2195 | "@eslint/js": "9.10.0",
2196 | "@eslint/plugin-kit": "^0.1.0",
2197 | "@humanwhocodes/module-importer": "^1.0.1",
2198 | "@humanwhocodes/retry": "^0.3.0",
2199 | "@nodelib/fs.walk": "^1.2.8",
2200 | "ajv": "^6.12.4",
2201 | "chalk": "^4.0.0",
2202 | "cross-spawn": "^7.0.2",
2203 | "debug": "^4.3.2",
2204 | "escape-string-regexp": "^4.0.0",
2205 | "eslint-scope": "^8.0.2",
2206 | "eslint-visitor-keys": "^4.0.0",
2207 | "espree": "^10.1.0",
2208 | "esquery": "^1.5.0",
2209 | "esutils": "^2.0.2",
2210 | "fast-deep-equal": "^3.1.3",
2211 | "file-entry-cache": "^8.0.0",
2212 | "find-up": "^5.0.0",
2213 | "glob-parent": "^6.0.2",
2214 | "ignore": "^5.2.0",
2215 | "imurmurhash": "^0.1.4",
2216 | "is-glob": "^4.0.0",
2217 | "is-path-inside": "^3.0.3",
2218 | "json-stable-stringify-without-jsonify": "^1.0.1",
2219 | "lodash.merge": "^4.6.2",
2220 | "minimatch": "^3.1.2",
2221 | "natural-compare": "^1.4.0",
2222 | "optionator": "^0.9.3",
2223 | "strip-ansi": "^6.0.1",
2224 | "text-table": "^0.2.0"
2225 | },
2226 | "bin": {
2227 | "eslint": "bin/eslint.js"
2228 | },
2229 | "engines": {
2230 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2231 | },
2232 | "funding": {
2233 | "url": "https://eslint.org/donate"
2234 | },
2235 | "peerDependencies": {
2236 | "jiti": "*"
2237 | },
2238 | "peerDependenciesMeta": {
2239 | "jiti": {
2240 | "optional": true
2241 | }
2242 | }
2243 | },
2244 | "node_modules/eslint-plugin-react-hooks": {
2245 | "version": "5.1.0-rc-fb9a90fa48-20240614",
2246 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.1.0-rc-fb9a90fa48-20240614.tgz",
2247 | "integrity": "sha512-xsiRwaDNF5wWNC4ZHLut+x/YcAxksUd9Rizt7LaEn3bV8VyYRpXnRJQlLOfYaVy9esk4DFP4zPPnoNVjq5Gc0w==",
2248 | "dev": true,
2249 | "engines": {
2250 | "node": ">=10"
2251 | },
2252 | "peerDependencies": {
2253 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0"
2254 | }
2255 | },
2256 | "node_modules/eslint-plugin-react-refresh": {
2257 | "version": "0.4.11",
2258 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.11.tgz",
2259 | "integrity": "sha512-wrAKxMbVr8qhXTtIKfXqAn5SAtRZt0aXxe5P23Fh4pUAdC6XEsybGLB8P0PI4j1yYqOgUEUlzKAGDfo7rJOjcw==",
2260 | "dev": true,
2261 | "peerDependencies": {
2262 | "eslint": ">=7"
2263 | }
2264 | },
2265 | "node_modules/eslint-scope": {
2266 | "version": "8.0.2",
2267 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.0.2.tgz",
2268 | "integrity": "sha512-6E4xmrTw5wtxnLA5wYL3WDfhZ/1bUBGOXV0zQvVRDOtrR8D0p6W7fs3JweNYhwRYeGvd/1CKX2se0/2s7Q/nJA==",
2269 | "dev": true,
2270 | "dependencies": {
2271 | "esrecurse": "^4.3.0",
2272 | "estraverse": "^5.2.0"
2273 | },
2274 | "engines": {
2275 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2276 | },
2277 | "funding": {
2278 | "url": "https://opencollective.com/eslint"
2279 | }
2280 | },
2281 | "node_modules/eslint-visitor-keys": {
2282 | "version": "4.0.0",
2283 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz",
2284 | "integrity": "sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw==",
2285 | "dev": true,
2286 | "engines": {
2287 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2288 | },
2289 | "funding": {
2290 | "url": "https://opencollective.com/eslint"
2291 | }
2292 | },
2293 | "node_modules/espree": {
2294 | "version": "10.1.0",
2295 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.1.0.tgz",
2296 | "integrity": "sha512-M1M6CpiE6ffoigIOWYO9UDP8TMUw9kqb21tf+08IgDYjCsOvCuDt4jQcZmoYxx+w7zlKw9/N0KXfto+I8/FrXA==",
2297 | "dev": true,
2298 | "dependencies": {
2299 | "acorn": "^8.12.0",
2300 | "acorn-jsx": "^5.3.2",
2301 | "eslint-visitor-keys": "^4.0.0"
2302 | },
2303 | "engines": {
2304 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2305 | },
2306 | "funding": {
2307 | "url": "https://opencollective.com/eslint"
2308 | }
2309 | },
2310 | "node_modules/esquery": {
2311 | "version": "1.6.0",
2312 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz",
2313 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==",
2314 | "dev": true,
2315 | "dependencies": {
2316 | "estraverse": "^5.1.0"
2317 | },
2318 | "engines": {
2319 | "node": ">=0.10"
2320 | }
2321 | },
2322 | "node_modules/esrecurse": {
2323 | "version": "4.3.0",
2324 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
2325 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
2326 | "dev": true,
2327 | "dependencies": {
2328 | "estraverse": "^5.2.0"
2329 | },
2330 | "engines": {
2331 | "node": ">=4.0"
2332 | }
2333 | },
2334 | "node_modules/estraverse": {
2335 | "version": "5.3.0",
2336 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
2337 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
2338 | "dev": true,
2339 | "engines": {
2340 | "node": ">=4.0"
2341 | }
2342 | },
2343 | "node_modules/esutils": {
2344 | "version": "2.0.3",
2345 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
2346 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
2347 | "dev": true,
2348 | "engines": {
2349 | "node": ">=0.10.0"
2350 | }
2351 | },
2352 | "node_modules/fast-deep-equal": {
2353 | "version": "3.1.3",
2354 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
2355 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
2356 | "dev": true
2357 | },
2358 | "node_modules/fast-glob": {
2359 | "version": "3.3.2",
2360 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz",
2361 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==",
2362 | "dev": true,
2363 | "dependencies": {
2364 | "@nodelib/fs.stat": "^2.0.2",
2365 | "@nodelib/fs.walk": "^1.2.3",
2366 | "glob-parent": "^5.1.2",
2367 | "merge2": "^1.3.0",
2368 | "micromatch": "^4.0.4"
2369 | },
2370 | "engines": {
2371 | "node": ">=8.6.0"
2372 | }
2373 | },
2374 | "node_modules/fast-glob/node_modules/glob-parent": {
2375 | "version": "5.1.2",
2376 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
2377 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
2378 | "dev": true,
2379 | "dependencies": {
2380 | "is-glob": "^4.0.1"
2381 | },
2382 | "engines": {
2383 | "node": ">= 6"
2384 | }
2385 | },
2386 | "node_modules/fast-json-stable-stringify": {
2387 | "version": "2.1.0",
2388 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
2389 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
2390 | "dev": true
2391 | },
2392 | "node_modules/fast-levenshtein": {
2393 | "version": "2.0.6",
2394 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
2395 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
2396 | "dev": true
2397 | },
2398 | "node_modules/fastq": {
2399 | "version": "1.17.1",
2400 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz",
2401 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==",
2402 | "dev": true,
2403 | "dependencies": {
2404 | "reusify": "^1.0.4"
2405 | }
2406 | },
2407 | "node_modules/file-entry-cache": {
2408 | "version": "8.0.0",
2409 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
2410 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
2411 | "dev": true,
2412 | "dependencies": {
2413 | "flat-cache": "^4.0.0"
2414 | },
2415 | "engines": {
2416 | "node": ">=16.0.0"
2417 | }
2418 | },
2419 | "node_modules/fill-range": {
2420 | "version": "7.1.1",
2421 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz",
2422 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==",
2423 | "dev": true,
2424 | "dependencies": {
2425 | "to-regex-range": "^5.0.1"
2426 | },
2427 | "engines": {
2428 | "node": ">=8"
2429 | }
2430 | },
2431 | "node_modules/find-root": {
2432 | "version": "1.1.0",
2433 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz",
2434 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng=="
2435 | },
2436 | "node_modules/find-up": {
2437 | "version": "5.0.0",
2438 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
2439 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
2440 | "dev": true,
2441 | "dependencies": {
2442 | "locate-path": "^6.0.0",
2443 | "path-exists": "^4.0.0"
2444 | },
2445 | "engines": {
2446 | "node": ">=10"
2447 | },
2448 | "funding": {
2449 | "url": "https://github.com/sponsors/sindresorhus"
2450 | }
2451 | },
2452 | "node_modules/flat-cache": {
2453 | "version": "4.0.1",
2454 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
2455 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
2456 | "dev": true,
2457 | "dependencies": {
2458 | "flatted": "^3.2.9",
2459 | "keyv": "^4.5.4"
2460 | },
2461 | "engines": {
2462 | "node": ">=16"
2463 | }
2464 | },
2465 | "node_modules/flatted": {
2466 | "version": "3.3.1",
2467 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz",
2468 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==",
2469 | "dev": true
2470 | },
2471 | "node_modules/fsevents": {
2472 | "version": "2.3.3",
2473 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
2474 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
2475 | "dev": true,
2476 | "hasInstallScript": true,
2477 | "optional": true,
2478 | "os": [
2479 | "darwin"
2480 | ],
2481 | "engines": {
2482 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
2483 | }
2484 | },
2485 | "node_modules/function-bind": {
2486 | "version": "1.1.2",
2487 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
2488 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
2489 | "funding": {
2490 | "url": "https://github.com/sponsors/ljharb"
2491 | }
2492 | },
2493 | "node_modules/glob-parent": {
2494 | "version": "6.0.2",
2495 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
2496 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
2497 | "dev": true,
2498 | "dependencies": {
2499 | "is-glob": "^4.0.3"
2500 | },
2501 | "engines": {
2502 | "node": ">=10.13.0"
2503 | }
2504 | },
2505 | "node_modules/globals": {
2506 | "version": "15.9.0",
2507 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.9.0.tgz",
2508 | "integrity": "sha512-SmSKyLLKFbSr6rptvP8izbyxJL4ILwqO9Jg23UA0sDlGlu58V59D1//I3vlc0KJphVdUR7vMjHIplYnzBxorQA==",
2509 | "dev": true,
2510 | "engines": {
2511 | "node": ">=18"
2512 | },
2513 | "funding": {
2514 | "url": "https://github.com/sponsors/sindresorhus"
2515 | }
2516 | },
2517 | "node_modules/graphemer": {
2518 | "version": "1.4.0",
2519 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
2520 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==",
2521 | "dev": true
2522 | },
2523 | "node_modules/has-flag": {
2524 | "version": "4.0.0",
2525 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2526 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2527 | "dev": true,
2528 | "engines": {
2529 | "node": ">=8"
2530 | }
2531 | },
2532 | "node_modules/hasown": {
2533 | "version": "2.0.2",
2534 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz",
2535 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==",
2536 | "dependencies": {
2537 | "function-bind": "^1.1.2"
2538 | },
2539 | "engines": {
2540 | "node": ">= 0.4"
2541 | }
2542 | },
2543 | "node_modules/hoist-non-react-statics": {
2544 | "version": "3.3.2",
2545 | "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz",
2546 | "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==",
2547 | "dependencies": {
2548 | "react-is": "^16.7.0"
2549 | }
2550 | },
2551 | "node_modules/hoist-non-react-statics/node_modules/react-is": {
2552 | "version": "16.13.1",
2553 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
2554 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="
2555 | },
2556 | "node_modules/ignore": {
2557 | "version": "5.3.2",
2558 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
2559 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
2560 | "dev": true,
2561 | "engines": {
2562 | "node": ">= 4"
2563 | }
2564 | },
2565 | "node_modules/import-fresh": {
2566 | "version": "3.3.0",
2567 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
2568 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
2569 | "dependencies": {
2570 | "parent-module": "^1.0.0",
2571 | "resolve-from": "^4.0.0"
2572 | },
2573 | "engines": {
2574 | "node": ">=6"
2575 | },
2576 | "funding": {
2577 | "url": "https://github.com/sponsors/sindresorhus"
2578 | }
2579 | },
2580 | "node_modules/imurmurhash": {
2581 | "version": "0.1.4",
2582 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
2583 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
2584 | "dev": true,
2585 | "engines": {
2586 | "node": ">=0.8.19"
2587 | }
2588 | },
2589 | "node_modules/is-arrayish": {
2590 | "version": "0.2.1",
2591 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
2592 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg=="
2593 | },
2594 | "node_modules/is-core-module": {
2595 | "version": "2.15.1",
2596 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz",
2597 | "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==",
2598 | "dependencies": {
2599 | "hasown": "^2.0.2"
2600 | },
2601 | "engines": {
2602 | "node": ">= 0.4"
2603 | },
2604 | "funding": {
2605 | "url": "https://github.com/sponsors/ljharb"
2606 | }
2607 | },
2608 | "node_modules/is-extglob": {
2609 | "version": "2.1.1",
2610 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2611 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
2612 | "dev": true,
2613 | "engines": {
2614 | "node": ">=0.10.0"
2615 | }
2616 | },
2617 | "node_modules/is-glob": {
2618 | "version": "4.0.3",
2619 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
2620 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
2621 | "dev": true,
2622 | "dependencies": {
2623 | "is-extglob": "^2.1.1"
2624 | },
2625 | "engines": {
2626 | "node": ">=0.10.0"
2627 | }
2628 | },
2629 | "node_modules/is-number": {
2630 | "version": "7.0.0",
2631 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
2632 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
2633 | "dev": true,
2634 | "engines": {
2635 | "node": ">=0.12.0"
2636 | }
2637 | },
2638 | "node_modules/is-path-inside": {
2639 | "version": "3.0.3",
2640 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz",
2641 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==",
2642 | "dev": true,
2643 | "engines": {
2644 | "node": ">=8"
2645 | }
2646 | },
2647 | "node_modules/isexe": {
2648 | "version": "2.0.0",
2649 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
2650 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
2651 | "dev": true
2652 | },
2653 | "node_modules/js-tokens": {
2654 | "version": "4.0.0",
2655 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
2656 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ=="
2657 | },
2658 | "node_modules/js-yaml": {
2659 | "version": "4.1.0",
2660 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
2661 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
2662 | "dev": true,
2663 | "dependencies": {
2664 | "argparse": "^2.0.1"
2665 | },
2666 | "bin": {
2667 | "js-yaml": "bin/js-yaml.js"
2668 | }
2669 | },
2670 | "node_modules/jsesc": {
2671 | "version": "2.5.2",
2672 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
2673 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
2674 | "bin": {
2675 | "jsesc": "bin/jsesc"
2676 | },
2677 | "engines": {
2678 | "node": ">=4"
2679 | }
2680 | },
2681 | "node_modules/json-buffer": {
2682 | "version": "3.0.1",
2683 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
2684 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
2685 | "dev": true
2686 | },
2687 | "node_modules/json-parse-even-better-errors": {
2688 | "version": "2.3.1",
2689 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
2690 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w=="
2691 | },
2692 | "node_modules/json-schema-traverse": {
2693 | "version": "0.4.1",
2694 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
2695 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
2696 | "dev": true
2697 | },
2698 | "node_modules/json-stable-stringify-without-jsonify": {
2699 | "version": "1.0.1",
2700 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
2701 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
2702 | "dev": true
2703 | },
2704 | "node_modules/keyv": {
2705 | "version": "4.5.4",
2706 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
2707 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
2708 | "dev": true,
2709 | "dependencies": {
2710 | "json-buffer": "3.0.1"
2711 | }
2712 | },
2713 | "node_modules/levn": {
2714 | "version": "0.4.1",
2715 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
2716 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
2717 | "dev": true,
2718 | "dependencies": {
2719 | "prelude-ls": "^1.2.1",
2720 | "type-check": "~0.4.0"
2721 | },
2722 | "engines": {
2723 | "node": ">= 0.8.0"
2724 | }
2725 | },
2726 | "node_modules/lines-and-columns": {
2727 | "version": "1.2.4",
2728 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
2729 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg=="
2730 | },
2731 | "node_modules/locate-path": {
2732 | "version": "6.0.0",
2733 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
2734 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
2735 | "dev": true,
2736 | "dependencies": {
2737 | "p-locate": "^5.0.0"
2738 | },
2739 | "engines": {
2740 | "node": ">=10"
2741 | },
2742 | "funding": {
2743 | "url": "https://github.com/sponsors/sindresorhus"
2744 | }
2745 | },
2746 | "node_modules/lodash.merge": {
2747 | "version": "4.6.2",
2748 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
2749 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
2750 | "dev": true
2751 | },
2752 | "node_modules/loose-envify": {
2753 | "version": "1.4.0",
2754 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz",
2755 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==",
2756 | "dependencies": {
2757 | "js-tokens": "^3.0.0 || ^4.0.0"
2758 | },
2759 | "bin": {
2760 | "loose-envify": "cli.js"
2761 | }
2762 | },
2763 | "node_modules/merge2": {
2764 | "version": "1.4.1",
2765 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
2766 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
2767 | "dev": true,
2768 | "engines": {
2769 | "node": ">= 8"
2770 | }
2771 | },
2772 | "node_modules/micromatch": {
2773 | "version": "4.0.8",
2774 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz",
2775 | "integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==",
2776 | "dev": true,
2777 | "dependencies": {
2778 | "braces": "^3.0.3",
2779 | "picomatch": "^2.3.1"
2780 | },
2781 | "engines": {
2782 | "node": ">=8.6"
2783 | }
2784 | },
2785 | "node_modules/minimatch": {
2786 | "version": "3.1.2",
2787 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
2788 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
2789 | "dev": true,
2790 | "dependencies": {
2791 | "brace-expansion": "^1.1.7"
2792 | },
2793 | "engines": {
2794 | "node": "*"
2795 | }
2796 | },
2797 | "node_modules/ms": {
2798 | "version": "2.1.3",
2799 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
2800 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
2801 | },
2802 | "node_modules/nanoid": {
2803 | "version": "3.3.7",
2804 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz",
2805 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==",
2806 | "dev": true,
2807 | "funding": [
2808 | {
2809 | "type": "github",
2810 | "url": "https://github.com/sponsors/ai"
2811 | }
2812 | ],
2813 | "bin": {
2814 | "nanoid": "bin/nanoid.cjs"
2815 | },
2816 | "engines": {
2817 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
2818 | }
2819 | },
2820 | "node_modules/natural-compare": {
2821 | "version": "1.4.0",
2822 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
2823 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
2824 | "dev": true
2825 | },
2826 | "node_modules/object-assign": {
2827 | "version": "4.1.1",
2828 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
2829 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
2830 | "engines": {
2831 | "node": ">=0.10.0"
2832 | }
2833 | },
2834 | "node_modules/optionator": {
2835 | "version": "0.9.4",
2836 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz",
2837 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==",
2838 | "dev": true,
2839 | "dependencies": {
2840 | "deep-is": "^0.1.3",
2841 | "fast-levenshtein": "^2.0.6",
2842 | "levn": "^0.4.1",
2843 | "prelude-ls": "^1.2.1",
2844 | "type-check": "^0.4.0",
2845 | "word-wrap": "^1.2.5"
2846 | },
2847 | "engines": {
2848 | "node": ">= 0.8.0"
2849 | }
2850 | },
2851 | "node_modules/p-limit": {
2852 | "version": "3.1.0",
2853 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
2854 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
2855 | "dev": true,
2856 | "dependencies": {
2857 | "yocto-queue": "^0.1.0"
2858 | },
2859 | "engines": {
2860 | "node": ">=10"
2861 | },
2862 | "funding": {
2863 | "url": "https://github.com/sponsors/sindresorhus"
2864 | }
2865 | },
2866 | "node_modules/p-locate": {
2867 | "version": "5.0.0",
2868 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
2869 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
2870 | "dev": true,
2871 | "dependencies": {
2872 | "p-limit": "^3.0.2"
2873 | },
2874 | "engines": {
2875 | "node": ">=10"
2876 | },
2877 | "funding": {
2878 | "url": "https://github.com/sponsors/sindresorhus"
2879 | }
2880 | },
2881 | "node_modules/parent-module": {
2882 | "version": "1.0.1",
2883 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
2884 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
2885 | "dependencies": {
2886 | "callsites": "^3.0.0"
2887 | },
2888 | "engines": {
2889 | "node": ">=6"
2890 | }
2891 | },
2892 | "node_modules/parse-json": {
2893 | "version": "5.2.0",
2894 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
2895 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
2896 | "dependencies": {
2897 | "@babel/code-frame": "^7.0.0",
2898 | "error-ex": "^1.3.1",
2899 | "json-parse-even-better-errors": "^2.3.0",
2900 | "lines-and-columns": "^1.1.6"
2901 | },
2902 | "engines": {
2903 | "node": ">=8"
2904 | },
2905 | "funding": {
2906 | "url": "https://github.com/sponsors/sindresorhus"
2907 | }
2908 | },
2909 | "node_modules/path-exists": {
2910 | "version": "4.0.0",
2911 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
2912 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
2913 | "dev": true,
2914 | "engines": {
2915 | "node": ">=8"
2916 | }
2917 | },
2918 | "node_modules/path-key": {
2919 | "version": "3.1.1",
2920 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
2921 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
2922 | "dev": true,
2923 | "engines": {
2924 | "node": ">=8"
2925 | }
2926 | },
2927 | "node_modules/path-parse": {
2928 | "version": "1.0.7",
2929 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
2930 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw=="
2931 | },
2932 | "node_modules/path-type": {
2933 | "version": "4.0.0",
2934 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
2935 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
2936 | "engines": {
2937 | "node": ">=8"
2938 | }
2939 | },
2940 | "node_modules/picocolors": {
2941 | "version": "1.1.0",
2942 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz",
2943 | "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw=="
2944 | },
2945 | "node_modules/picomatch": {
2946 | "version": "2.3.1",
2947 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
2948 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
2949 | "dev": true,
2950 | "engines": {
2951 | "node": ">=8.6"
2952 | },
2953 | "funding": {
2954 | "url": "https://github.com/sponsors/jonschlinkert"
2955 | }
2956 | },
2957 | "node_modules/postcss": {
2958 | "version": "8.4.45",
2959 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.45.tgz",
2960 | "integrity": "sha512-7KTLTdzdZZYscUc65XmjFiB73vBhBfbPztCYdUNvlaso9PrzjzcmjqBPR0lNGkcVlcO4BjiO5rK/qNz+XAen1Q==",
2961 | "dev": true,
2962 | "funding": [
2963 | {
2964 | "type": "opencollective",
2965 | "url": "https://opencollective.com/postcss/"
2966 | },
2967 | {
2968 | "type": "tidelift",
2969 | "url": "https://tidelift.com/funding/github/npm/postcss"
2970 | },
2971 | {
2972 | "type": "github",
2973 | "url": "https://github.com/sponsors/ai"
2974 | }
2975 | ],
2976 | "dependencies": {
2977 | "nanoid": "^3.3.7",
2978 | "picocolors": "^1.0.1",
2979 | "source-map-js": "^1.2.0"
2980 | },
2981 | "engines": {
2982 | "node": "^10 || ^12 || >=14"
2983 | }
2984 | },
2985 | "node_modules/prelude-ls": {
2986 | "version": "1.2.1",
2987 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
2988 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
2989 | "dev": true,
2990 | "engines": {
2991 | "node": ">= 0.8.0"
2992 | }
2993 | },
2994 | "node_modules/prop-types": {
2995 | "version": "15.8.1",
2996 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz",
2997 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==",
2998 | "dependencies": {
2999 | "loose-envify": "^1.4.0",
3000 | "object-assign": "^4.1.1",
3001 | "react-is": "^16.13.1"
3002 | }
3003 | },
3004 | "node_modules/prop-types/node_modules/react-is": {
3005 | "version": "16.13.1",
3006 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
3007 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="
3008 | },
3009 | "node_modules/punycode": {
3010 | "version": "2.3.1",
3011 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
3012 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
3013 | "dev": true,
3014 | "engines": {
3015 | "node": ">=6"
3016 | }
3017 | },
3018 | "node_modules/queue-microtask": {
3019 | "version": "1.2.3",
3020 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
3021 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
3022 | "dev": true,
3023 | "funding": [
3024 | {
3025 | "type": "github",
3026 | "url": "https://github.com/sponsors/feross"
3027 | },
3028 | {
3029 | "type": "patreon",
3030 | "url": "https://www.patreon.com/feross"
3031 | },
3032 | {
3033 | "type": "consulting",
3034 | "url": "https://feross.org/support"
3035 | }
3036 | ]
3037 | },
3038 | "node_modules/react": {
3039 | "version": "18.3.1",
3040 | "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz",
3041 | "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==",
3042 | "dependencies": {
3043 | "loose-envify": "^1.1.0"
3044 | },
3045 | "engines": {
3046 | "node": ">=0.10.0"
3047 | }
3048 | },
3049 | "node_modules/react-dom": {
3050 | "version": "18.3.1",
3051 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz",
3052 | "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==",
3053 | "dependencies": {
3054 | "loose-envify": "^1.1.0",
3055 | "scheduler": "^0.23.2"
3056 | },
3057 | "peerDependencies": {
3058 | "react": "^18.3.1"
3059 | }
3060 | },
3061 | "node_modules/react-hook-form": {
3062 | "version": "7.53.0",
3063 | "resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.53.0.tgz",
3064 | "integrity": "sha512-M1n3HhqCww6S2hxLxciEXy2oISPnAzxY7gvwVPrtlczTM/1dDadXgUxDpHMrMTblDOcm/AXtXxHwZ3jpg1mqKQ==",
3065 | "engines": {
3066 | "node": ">=18.0.0"
3067 | },
3068 | "funding": {
3069 | "type": "opencollective",
3070 | "url": "https://opencollective.com/react-hook-form"
3071 | },
3072 | "peerDependencies": {
3073 | "react": "^16.8.0 || ^17 || ^18 || ^19"
3074 | }
3075 | },
3076 | "node_modules/react-is": {
3077 | "version": "18.3.1",
3078 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz",
3079 | "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg=="
3080 | },
3081 | "node_modules/react-transition-group": {
3082 | "version": "4.4.5",
3083 | "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.5.tgz",
3084 | "integrity": "sha512-pZcd1MCJoiKiBR2NRxeCRg13uCXbydPnmB4EOeRrY7480qNWO8IIgQG6zlDkm6uRMsURXPuKq0GWtiM59a5Q6g==",
3085 | "dependencies": {
3086 | "@babel/runtime": "^7.5.5",
3087 | "dom-helpers": "^5.0.1",
3088 | "loose-envify": "^1.4.0",
3089 | "prop-types": "^15.6.2"
3090 | },
3091 | "peerDependencies": {
3092 | "react": ">=16.6.0",
3093 | "react-dom": ">=16.6.0"
3094 | }
3095 | },
3096 | "node_modules/regenerator-runtime": {
3097 | "version": "0.14.1",
3098 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz",
3099 | "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw=="
3100 | },
3101 | "node_modules/resolve": {
3102 | "version": "1.22.8",
3103 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz",
3104 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==",
3105 | "dependencies": {
3106 | "is-core-module": "^2.13.0",
3107 | "path-parse": "^1.0.7",
3108 | "supports-preserve-symlinks-flag": "^1.0.0"
3109 | },
3110 | "bin": {
3111 | "resolve": "bin/resolve"
3112 | },
3113 | "funding": {
3114 | "url": "https://github.com/sponsors/ljharb"
3115 | }
3116 | },
3117 | "node_modules/resolve-from": {
3118 | "version": "4.0.0",
3119 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
3120 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
3121 | "engines": {
3122 | "node": ">=4"
3123 | }
3124 | },
3125 | "node_modules/reusify": {
3126 | "version": "1.0.4",
3127 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz",
3128 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==",
3129 | "dev": true,
3130 | "engines": {
3131 | "iojs": ">=1.0.0",
3132 | "node": ">=0.10.0"
3133 | }
3134 | },
3135 | "node_modules/rollup": {
3136 | "version": "4.21.2",
3137 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.21.2.tgz",
3138 | "integrity": "sha512-e3TapAgYf9xjdLvKQCkQTnbTKd4a6jwlpQSJJFokHGaX2IVjoEqkIIhiQfqsi0cdwlOD+tQGuOd5AJkc5RngBw==",
3139 | "dev": true,
3140 | "dependencies": {
3141 | "@types/estree": "1.0.5"
3142 | },
3143 | "bin": {
3144 | "rollup": "dist/bin/rollup"
3145 | },
3146 | "engines": {
3147 | "node": ">=18.0.0",
3148 | "npm": ">=8.0.0"
3149 | },
3150 | "optionalDependencies": {
3151 | "@rollup/rollup-android-arm-eabi": "4.21.2",
3152 | "@rollup/rollup-android-arm64": "4.21.2",
3153 | "@rollup/rollup-darwin-arm64": "4.21.2",
3154 | "@rollup/rollup-darwin-x64": "4.21.2",
3155 | "@rollup/rollup-linux-arm-gnueabihf": "4.21.2",
3156 | "@rollup/rollup-linux-arm-musleabihf": "4.21.2",
3157 | "@rollup/rollup-linux-arm64-gnu": "4.21.2",
3158 | "@rollup/rollup-linux-arm64-musl": "4.21.2",
3159 | "@rollup/rollup-linux-powerpc64le-gnu": "4.21.2",
3160 | "@rollup/rollup-linux-riscv64-gnu": "4.21.2",
3161 | "@rollup/rollup-linux-s390x-gnu": "4.21.2",
3162 | "@rollup/rollup-linux-x64-gnu": "4.21.2",
3163 | "@rollup/rollup-linux-x64-musl": "4.21.2",
3164 | "@rollup/rollup-win32-arm64-msvc": "4.21.2",
3165 | "@rollup/rollup-win32-ia32-msvc": "4.21.2",
3166 | "@rollup/rollup-win32-x64-msvc": "4.21.2",
3167 | "fsevents": "~2.3.2"
3168 | }
3169 | },
3170 | "node_modules/run-parallel": {
3171 | "version": "1.2.0",
3172 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
3173 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
3174 | "dev": true,
3175 | "funding": [
3176 | {
3177 | "type": "github",
3178 | "url": "https://github.com/sponsors/feross"
3179 | },
3180 | {
3181 | "type": "patreon",
3182 | "url": "https://www.patreon.com/feross"
3183 | },
3184 | {
3185 | "type": "consulting",
3186 | "url": "https://feross.org/support"
3187 | }
3188 | ],
3189 | "dependencies": {
3190 | "queue-microtask": "^1.2.2"
3191 | }
3192 | },
3193 | "node_modules/scheduler": {
3194 | "version": "0.23.2",
3195 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz",
3196 | "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==",
3197 | "dependencies": {
3198 | "loose-envify": "^1.1.0"
3199 | }
3200 | },
3201 | "node_modules/semver": {
3202 | "version": "7.6.3",
3203 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz",
3204 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==",
3205 | "dev": true,
3206 | "bin": {
3207 | "semver": "bin/semver.js"
3208 | },
3209 | "engines": {
3210 | "node": ">=10"
3211 | }
3212 | },
3213 | "node_modules/shebang-command": {
3214 | "version": "2.0.0",
3215 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
3216 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
3217 | "dev": true,
3218 | "dependencies": {
3219 | "shebang-regex": "^3.0.0"
3220 | },
3221 | "engines": {
3222 | "node": ">=8"
3223 | }
3224 | },
3225 | "node_modules/shebang-regex": {
3226 | "version": "3.0.0",
3227 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
3228 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
3229 | "dev": true,
3230 | "engines": {
3231 | "node": ">=8"
3232 | }
3233 | },
3234 | "node_modules/source-map": {
3235 | "version": "0.5.7",
3236 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
3237 | "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==",
3238 | "engines": {
3239 | "node": ">=0.10.0"
3240 | }
3241 | },
3242 | "node_modules/source-map-js": {
3243 | "version": "1.2.1",
3244 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
3245 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
3246 | "dev": true,
3247 | "engines": {
3248 | "node": ">=0.10.0"
3249 | }
3250 | },
3251 | "node_modules/strip-ansi": {
3252 | "version": "6.0.1",
3253 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
3254 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
3255 | "dev": true,
3256 | "dependencies": {
3257 | "ansi-regex": "^5.0.1"
3258 | },
3259 | "engines": {
3260 | "node": ">=8"
3261 | }
3262 | },
3263 | "node_modules/strip-json-comments": {
3264 | "version": "3.1.1",
3265 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
3266 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
3267 | "dev": true,
3268 | "engines": {
3269 | "node": ">=8"
3270 | },
3271 | "funding": {
3272 | "url": "https://github.com/sponsors/sindresorhus"
3273 | }
3274 | },
3275 | "node_modules/stylis": {
3276 | "version": "4.2.0",
3277 | "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.2.0.tgz",
3278 | "integrity": "sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw=="
3279 | },
3280 | "node_modules/supports-color": {
3281 | "version": "7.2.0",
3282 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
3283 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
3284 | "dev": true,
3285 | "dependencies": {
3286 | "has-flag": "^4.0.0"
3287 | },
3288 | "engines": {
3289 | "node": ">=8"
3290 | }
3291 | },
3292 | "node_modules/supports-preserve-symlinks-flag": {
3293 | "version": "1.0.0",
3294 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
3295 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
3296 | "engines": {
3297 | "node": ">= 0.4"
3298 | },
3299 | "funding": {
3300 | "url": "https://github.com/sponsors/ljharb"
3301 | }
3302 | },
3303 | "node_modules/text-table": {
3304 | "version": "0.2.0",
3305 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
3306 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
3307 | "dev": true
3308 | },
3309 | "node_modules/to-fast-properties": {
3310 | "version": "2.0.0",
3311 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
3312 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==",
3313 | "engines": {
3314 | "node": ">=4"
3315 | }
3316 | },
3317 | "node_modules/to-regex-range": {
3318 | "version": "5.0.1",
3319 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
3320 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
3321 | "dev": true,
3322 | "dependencies": {
3323 | "is-number": "^7.0.0"
3324 | },
3325 | "engines": {
3326 | "node": ">=8.0"
3327 | }
3328 | },
3329 | "node_modules/ts-api-utils": {
3330 | "version": "1.3.0",
3331 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz",
3332 | "integrity": "sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ==",
3333 | "dev": true,
3334 | "engines": {
3335 | "node": ">=16"
3336 | },
3337 | "peerDependencies": {
3338 | "typescript": ">=4.2.0"
3339 | }
3340 | },
3341 | "node_modules/type-check": {
3342 | "version": "0.4.0",
3343 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
3344 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
3345 | "dev": true,
3346 | "dependencies": {
3347 | "prelude-ls": "^1.2.1"
3348 | },
3349 | "engines": {
3350 | "node": ">= 0.8.0"
3351 | }
3352 | },
3353 | "node_modules/typescript": {
3354 | "version": "5.6.2",
3355 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.2.tgz",
3356 | "integrity": "sha512-NW8ByodCSNCwZeghjN3o+JX5OFH0Ojg6sadjEKY4huZ52TqbJTJnDo5+Tw98lSy63NZvi4n+ez5m2u5d4PkZyw==",
3357 | "dev": true,
3358 | "bin": {
3359 | "tsc": "bin/tsc",
3360 | "tsserver": "bin/tsserver"
3361 | },
3362 | "engines": {
3363 | "node": ">=14.17"
3364 | }
3365 | },
3366 | "node_modules/typescript-eslint": {
3367 | "version": "8.5.0",
3368 | "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.5.0.tgz",
3369 | "integrity": "sha512-uD+XxEoSIvqtm4KE97etm32Tn5MfaZWgWfMMREStLxR6JzvHkc2Tkj7zhTEK5XmtpTmKHNnG8Sot6qDfhHtR1Q==",
3370 | "dev": true,
3371 | "dependencies": {
3372 | "@typescript-eslint/eslint-plugin": "8.5.0",
3373 | "@typescript-eslint/parser": "8.5.0",
3374 | "@typescript-eslint/utils": "8.5.0"
3375 | },
3376 | "engines": {
3377 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
3378 | },
3379 | "funding": {
3380 | "type": "opencollective",
3381 | "url": "https://opencollective.com/typescript-eslint"
3382 | },
3383 | "peerDependenciesMeta": {
3384 | "typescript": {
3385 | "optional": true
3386 | }
3387 | }
3388 | },
3389 | "node_modules/uri-js": {
3390 | "version": "4.4.1",
3391 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
3392 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
3393 | "dev": true,
3394 | "dependencies": {
3395 | "punycode": "^2.1.0"
3396 | }
3397 | },
3398 | "node_modules/vite": {
3399 | "version": "5.4.3",
3400 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.3.tgz",
3401 | "integrity": "sha512-IH+nl64eq9lJjFqU+/yrRnrHPVTlgy42/+IzbOdaFDVlyLgI/wDlf+FCobXLX1cT0X5+7LMyH1mIy2xJdLfo8Q==",
3402 | "dev": true,
3403 | "dependencies": {
3404 | "esbuild": "^0.21.3",
3405 | "postcss": "^8.4.43",
3406 | "rollup": "^4.20.0"
3407 | },
3408 | "bin": {
3409 | "vite": "bin/vite.js"
3410 | },
3411 | "engines": {
3412 | "node": "^18.0.0 || >=20.0.0"
3413 | },
3414 | "funding": {
3415 | "url": "https://github.com/vitejs/vite?sponsor=1"
3416 | },
3417 | "optionalDependencies": {
3418 | "fsevents": "~2.3.3"
3419 | },
3420 | "peerDependencies": {
3421 | "@types/node": "^18.0.0 || >=20.0.0",
3422 | "less": "*",
3423 | "lightningcss": "^1.21.0",
3424 | "sass": "*",
3425 | "sass-embedded": "*",
3426 | "stylus": "*",
3427 | "sugarss": "*",
3428 | "terser": "^5.4.0"
3429 | },
3430 | "peerDependenciesMeta": {
3431 | "@types/node": {
3432 | "optional": true
3433 | },
3434 | "less": {
3435 | "optional": true
3436 | },
3437 | "lightningcss": {
3438 | "optional": true
3439 | },
3440 | "sass": {
3441 | "optional": true
3442 | },
3443 | "sass-embedded": {
3444 | "optional": true
3445 | },
3446 | "stylus": {
3447 | "optional": true
3448 | },
3449 | "sugarss": {
3450 | "optional": true
3451 | },
3452 | "terser": {
3453 | "optional": true
3454 | }
3455 | }
3456 | },
3457 | "node_modules/which": {
3458 | "version": "2.0.2",
3459 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
3460 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
3461 | "dev": true,
3462 | "dependencies": {
3463 | "isexe": "^2.0.0"
3464 | },
3465 | "bin": {
3466 | "node-which": "bin/node-which"
3467 | },
3468 | "engines": {
3469 | "node": ">= 8"
3470 | }
3471 | },
3472 | "node_modules/word-wrap": {
3473 | "version": "1.2.5",
3474 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz",
3475 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==",
3476 | "dev": true,
3477 | "engines": {
3478 | "node": ">=0.10.0"
3479 | }
3480 | },
3481 | "node_modules/yaml": {
3482 | "version": "1.10.2",
3483 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
3484 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
3485 | "engines": {
3486 | "node": ">= 6"
3487 | }
3488 | },
3489 | "node_modules/yocto-queue": {
3490 | "version": "0.1.0",
3491 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
3492 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
3493 | "dev": true,
3494 | "engines": {
3495 | "node": ">=10"
3496 | },
3497 | "funding": {
3498 | "url": "https://github.com/sponsors/sindresorhus"
3499 | }
3500 | },
3501 | "node_modules/zod": {
3502 | "version": "3.23.8",
3503 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.23.8.tgz",
3504 | "integrity": "sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==",
3505 | "funding": {
3506 | "url": "https://github.com/sponsors/colinhacks"
3507 | }
3508 | }
3509 | }
3510 | }
3511 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "dynamic-form",
3 | "private": true,
4 | "version": "0.0.0",
5 | "type": "module",
6 | "scripts": {
7 | "dev": "vite",
8 | "build": "tsc -b && vite build",
9 | "lint": "eslint .",
10 | "preview": "vite preview"
11 | },
12 | "dependencies": {
13 | "@emotion/react": "^11.13.3",
14 | "@emotion/styled": "^11.13.0",
15 | "@hookform/resolvers": "^3.9.0",
16 | "@mui/icons-material": "^6.0.2",
17 | "@mui/material": "^6.0.2",
18 | "react": "^18.3.1",
19 | "react-dom": "^18.3.1",
20 | "react-hook-form": "^7.53.0",
21 | "zod": "^3.23.8"
22 | },
23 | "devDependencies": {
24 | "@eslint/js": "^9.9.0",
25 | "@types/react": "^18.3.3",
26 | "@types/react-dom": "^18.3.0",
27 | "@vitejs/plugin-react-swc": "^3.5.0",
28 | "eslint": "^9.9.0",
29 | "eslint-plugin-react-hooks": "^5.1.0-rc.0",
30 | "eslint-plugin-react-refresh": "^0.4.9",
31 | "globals": "^15.9.0",
32 | "typescript": "^5.5.3",
33 | "typescript-eslint": "^8.0.1",
34 | "vite": "^5.4.1"
35 | }
36 | }
37 |
--------------------------------------------------------------------------------
/src/App.tsx:
--------------------------------------------------------------------------------
1 | import { zodResolver } from "@hookform/resolvers/zod";
2 | import AddCircleRoundedIcon from "@mui/icons-material/AddCircleRounded";
3 | import DeleteForeverRoundedIcon from "@mui/icons-material/DeleteForeverRounded";
4 | import {
5 | Button,
6 | Checkbox,
7 | FormControl,
8 | FormControlLabel,
9 | FormLabel,
10 | IconButton,
11 | Radio,
12 | RadioGroup,
13 | TextField,
14 | } from "@mui/material";
15 | import { useEffect } from "react";
16 | import {
17 | Controller,
18 | FieldErrors,
19 | SubmitHandler,
20 | useFieldArray,
21 | useForm,
22 | useWatch,
23 | } from "react-hook-form";
24 | import { Container } from "./Container";
25 | import { formDefaultValues, FormSchema, formSchema } from "./formSchema";
26 |
27 | function App() {
28 | const {
29 | register,
30 | control,
31 | formState: { errors },
32 | handleSubmit,
33 | } = useForm({
34 | mode: "all",
35 | resolver: zodResolver(formSchema),
36 | defaultValues: formDefaultValues,
37 | });
38 |
39 | const {
40 | fields: languagesFields,
41 | replace: replaceLanguages,
42 | append: appendLanguages,
43 | remove: removeLanguages,
44 | } = useFieldArray({
45 | control,
46 | name: "languages",
47 | });
48 |
49 | const fullErrors: FieldErrors<
50 | Extract
51 | > &
52 | FieldErrors> &
53 | FieldErrors> &
54 | FieldErrors> &
55 | FieldErrors> = errors;
56 |
57 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
58 | const knowsOtherLanguages = useWatch({
59 | control,
60 | name: "knowsOtherLanguages",
61 | });
62 | const educationLevel = useWatch({ control, name: "educationLevel" });
63 |
64 | useEffect(() => {
65 | if (knowsOtherLanguages) {
66 | replaceLanguages([{ name: "" }]);
67 | }
68 | }, [knowsOtherLanguages, replaceLanguages]);
69 |
70 | const onSubmit: SubmitHandler = (data) => {
71 | alert(JSON.stringify(data, null, 2));
72 | };
73 |
74 | return (
75 |
76 |
82 | }
86 | />
87 | {hasWorkExperience && (
88 |
94 | )}
95 | }
99 | />
100 |
101 | {knowsOtherLanguages && (
102 | <>
103 | {languagesFields.map((field, index) => (
104 |
105 |
112 | removeLanguages(index)}
115 | color="error"
116 | >
117 |
118 |
119 |
120 | ))}
121 | appendLanguages({ name: "" })}
124 | color="success"
125 | >
126 |
127 |
128 | >
129 | )}
130 |
131 |
132 | Education Level
133 | (
137 |
138 | }
141 | label="No Formal Education"
142 | />
143 | }
146 | label="High School Diploma"
147 | />
148 | }
151 | label="Bachelors Degree"
152 | />
153 |
154 | )}
155 | />
156 |
157 |
158 | {educationLevel === "highSchoolDiploma" && (
159 |
165 | )}
166 | {educationLevel === "bachelorsDegree" && (
167 |
173 | )}
174 |
177 |
178 | );
179 | }
180 | export { App };
181 |
--------------------------------------------------------------------------------
/src/Container.tsx:
--------------------------------------------------------------------------------
1 | import { Box, Paper, Stack, Typography } from "@mui/material";
2 | import { ReactNode } from "react";
3 |
4 | type Props = {
5 | children: ReactNode;
6 | };
7 | function Container({ children }: Props) {
8 | return (
9 |
17 |
18 |
19 | Employment Form
20 | {children}
21 |
22 |
23 |
24 | );
25 | }
26 |
27 | export { Container };
28 |
--------------------------------------------------------------------------------
/src/formSchema.ts:
--------------------------------------------------------------------------------
1 | import { z } from "zod";
2 |
3 | const workExperienceSchema = z.discriminatedUnion("hasWorkExperience", [
4 | z.object({
5 | hasWorkExperience: z.literal(true),
6 | companyName: z.string().min(1),
7 | }),
8 | z.object({ hasWorkExperience: z.literal(false) }),
9 | ]);
10 |
11 | const educationSchema = z.discriminatedUnion("educationLevel", [
12 | z.object({
13 | educationLevel: z.literal("noFormalEducation"),
14 | }),
15 | z.object({
16 | educationLevel: z.literal("highSchoolDiploma"),
17 | schoolName: z.string().min(1),
18 | }),
19 | z.object({
20 | educationLevel: z.literal("bachelorsDegree"),
21 | universityName: z.string().min(1),
22 | }),
23 | ]);
24 |
25 | const languageKnowledgeSchema = z.discriminatedUnion("knowsOtherLanguages", [
26 | z.object({
27 | knowsOtherLanguages: z.literal(true),
28 | languages: z
29 | .array(
30 | z.object({
31 | name: z.string().min(1),
32 | })
33 | )
34 | .min(1),
35 | }),
36 | z.object({ knowsOtherLanguages: z.literal(false) }),
37 | ]);
38 |
39 | const formSchema = z
40 | .object({
41 | fullName: z.string().min(1),
42 | })
43 | .and(workExperienceSchema)
44 | .and(educationSchema)
45 | .and(languageKnowledgeSchema);
46 |
47 | type FormSchema = z.infer;
48 |
49 | const formDefaultValues: FormSchema = {
50 | fullName: "",
51 | educationLevel: "noFormalEducation",
52 | hasWorkExperience: false,
53 | knowsOtherLanguages: false,
54 | };
55 |
56 | export { formDefaultValues, formSchema, type FormSchema };
57 |
--------------------------------------------------------------------------------
/src/main.tsx:
--------------------------------------------------------------------------------
1 | import { StrictMode } from "react";
2 | import { createRoot } from "react-dom/client";
3 | import { App } from "./App";
4 | import { createTheme, CssBaseline, ThemeProvider } from "@mui/material";
5 |
6 | createRoot(document.getElementById("root")!).render(
7 |
8 |
15 |
16 |
17 |
18 |
19 |
20 |
21 | );
22 |
--------------------------------------------------------------------------------
/tsconfig.app.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 | "isolatedModules": true,
13 | "moduleDetection": "force",
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 | }
25 |
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "files": [],
3 | "references": [
4 | { "path": "./tsconfig.app.json" },
5 | { "path": "./tsconfig.node.json" }
6 | ]
7 | }
8 |
--------------------------------------------------------------------------------
/tsconfig.node.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "target": "ES2022",
4 | "lib": ["ES2023"],
5 | "module": "ESNext",
6 | "skipLibCheck": true,
7 |
8 | /* Bundler mode */
9 | "moduleResolution": "bundler",
10 | "allowImportingTsExtensions": true,
11 | "isolatedModules": true,
12 | "moduleDetection": "force",
13 | "noEmit": true,
14 |
15 | /* Linting */
16 | "strict": true,
17 | "noUnusedLocals": true,
18 | "noUnusedParameters": true,
19 | "noFallthroughCasesInSwitch": true
20 | },
21 | "include": ["vite.config.ts"]
22 | }
23 |
--------------------------------------------------------------------------------
/tutorial.md:
--------------------------------------------------------------------------------
1 | show final project:
2 | Creating dynamic forms where validation changes based on user actions is essential for handling complex forms. For example, if a user does not check the "Work Experience" box, the form's validation will differ compared to when it is checked. If the user selects the checkbox, additional validation is required, such as making the "Company Name" field mandatory for the form to be submitted. Similarly, for a "Known Languages" checkbox, if checked, the user should be able to add or remove languages, with each field having its own validation rules. This dynamic behavior can also apply to this radio group and any other dynamic form behavior that you desire.
3 | Implementing such functionality can be a bit tricky, but it can be done in a clear and concise manner with minimal code. So let's implement it together.
4 |
5 | # Tutorial Script
6 |
7 | npm create vite@latest .
8 | npm i
9 | remove unnecessary also change app to named export and reimport it
10 |
11 | install packages
12 |
13 | ```bash
14 | npm i @emotion/react @emotion/styled @mui/icons-material @mui/material react-hook-form zod @hookform/resolvers
15 | ```
16 |
17 | show package.json
18 |
19 | ```tsx main.tsx
20 |
27 |
28 |
29 |
30 |
31 | ```
32 |
33 | for better organization and not making the main part of the tutorial complex, we create a container to put our app inside it
34 |
35 | ```tsx Container.tsx
36 | import { Box, Paper, Stack, Typography } from "@mui/material";
37 | import { ReactNode } from "react";
38 |
39 | type Props = {
40 | children: ReactNode;
41 | };
42 | function Container({ children }: Props) {
43 | return (
44 |
52 |
53 |
54 | Employment Form
55 | {children}
56 |
57 |
58 |
59 | );
60 | }
61 |
62 | export { Container };
63 | ```
64 |
65 | ```tsx App.tsx
66 | import { TextField } from "@mui/material";
67 | import { Container } from "./Container";
68 |
69 | function App() {
70 | return (
71 |
72 |
73 |
74 | );
75 | }
76 |
77 | export { App };
78 | ```
79 |
80 | but before we continue liking and subscribing can really help my career on youtube. I really appreciate it
81 |
82 | ```typescript formSchema.ts
83 | import { z } from "zod";
84 |
85 | const formSchema = z.object({
86 | fullName: z.string().min(1),
87 | });
88 |
89 | type FormSchema = z.infer;
90 |
91 | const formDefaultValues: FormSchema = {
92 | fullName: "",
93 | };
94 |
95 | export { formDefaultValues, formSchema, type FormSchema };
96 | ```
97 |
98 | ```tsx App.tsx
99 | import { TextField } from "@mui/material";
100 | import { Container } from "./Container";
101 | import { useForm } from "react-hook-form";
102 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
103 | import { zodResolver } from "@hookform/resolvers/zod";
104 |
105 | function App() {
106 | const {
107 | // [!code ++]
108 | register, // [!code ++]
109 | formState: { errors }, // [!code ++]
110 | } = useForm({
111 | // [!code ++]
112 | mode: "all", // [!code ++]
113 | resolver: zodResolver(formSchema), // [!code ++]
114 | defaultValues: formDefaultValues, // [!code ++]
115 | }); // [!code ++]
116 |
117 | return (
118 |
119 | {/* [!code --] */}
120 | {/* [!code ++] */}
126 |
127 | );
128 | }
129 |
130 | export { App };
131 | ```
132 |
133 | show errors are working
134 |
135 | now show full app and hasWorkExperience and its functionality
136 | we need to improve our schema to add this dynamic validation behavior
137 |
138 | ```typescript formSchema.ts
139 | import { z } from "zod";
140 |
141 | const workExperienceSchema = z.discriminatedUnion("hasWorkExperience", [
142 | z.object({
143 | hasWorkExperience: z.literal(true),
144 | companyName: z.string().min(1),
145 | }),
146 | z.object({ hasWorkExperience: z.literal(false) }),
147 | ]);
148 |
149 | const formSchema = z
150 | .object({
151 | fullName: z.string().min(1),
152 | })
153 | .and(workExperienceSchema); // [!code ++]
154 |
155 | type FormSchema = z.infer;
156 |
157 | const formDefaultValues: FormSchema = {
158 | fullName: "",
159 | hasWorkExperience: false, // [!code ++]
160 | };
161 |
162 | export { formDefaultValues, formSchema, type FormSchema };
163 | ```
164 |
165 | now show typescript capabilities in defaultValues object and tag types
166 |
167 | ```tsx App.tsx
168 | import { Checkbox, FormControlLabel, TextField } from "@mui/material";
169 | import { Container } from "./Container";
170 | import { useForm } from "react-hook-form";
171 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
172 | import { zodResolver } from "@hookform/resolvers/zod";
173 |
174 | function App() {
175 | const {
176 | register,
177 | formState: { errors },
178 | control, // [!code ++]
179 | handleSubmit, // [!code ++]
180 | } = useForm({
181 | mode: "all",
182 | resolver: zodResolver(formSchema),
183 | defaultValues: formDefaultValues,
184 | });
185 |
186 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" }); // [!code ++]
187 |
188 | const onSubmit: SubmitHandler = (data) => {
189 | // [!code ++]
190 | alert(JSON.stringify(data, null, 2)); // [!code ++]
191 | }; // [!code ++]
192 |
193 | return (
194 |
195 |
201 | } // [!code ++]
205 | /> {/* [!code ++] */}
206 | {hasWorkExperience && ( // [!code ++]
207 | // [!code ++]
213 | )}{" "}
214 | {/* [!code ++] */}
215 | {/* [!code ++] */}
220 |
221 | );
222 | }
223 |
224 | export { App };
225 | ```
226 |
227 | now show the submit button that only works when form is validated
228 |
229 | now the problem here is that the typescript is not smart enough to guess the errors from formState so we need to extend it a little for errors to be gone
230 |
231 | ```tsx App.tsx
232 | import { Checkbox, FormControlLabel, TextField } from "@mui/material";
233 | import { Container } from "./Container";
234 | import { useForm } from "react-hook-form";
235 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
236 | import { zodResolver } from "@hookform/resolvers/zod";
237 |
238 | function App() {
239 | const {
240 | register,
241 | formState: { errors },
242 | control,
243 | handleSubmit,
244 | } = useForm({
245 | mode: "all",
246 | resolver: zodResolver(formSchema),
247 | defaultValues: formDefaultValues,
248 | });
249 |
250 | const fullErrors: FieldErrors<
251 | // [!code ++]
252 | Extract // [!code ++]
253 | > = errors; // [!code ++]
254 |
255 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
256 |
257 | const onSubmit: SubmitHandler = (data) => {
258 | alert(JSON.stringify(data, null, 2));
259 | };
260 |
261 | return (
262 |
263 |
271 | }
275 | />
276 | {hasWorkExperience && (
277 |
285 | )}{" "}
286 |
290 |
291 | );
292 | }
293 |
294 | export { App };
295 | ```
296 |
297 | CTA
298 |
299 | now show knowsOtherLanguages checkbox from final app
300 |
301 | ```typescript formSchema.ts
302 | import { z } from "zod";
303 |
304 | const workExperienceSchema = z.discriminatedUnion("hasWorkExperience", [
305 | z.object({
306 | hasWorkExperience: z.literal(true),
307 | companyName: z.string().min(1),
308 | }),
309 | z.object({ hasWorkExperience: z.literal(false) }),
310 | ]);
311 |
312 | const languageKnowledgeSchema = z.discriminatedUnion("knowsOtherLanguages", [
313 | // [!code ++]
314 | z.object({
315 | // [!code ++]
316 | knowsOtherLanguages: z.literal(true), // [!code ++]
317 | languages: z // [!code ++]
318 | .array(
319 | // [!code ++]
320 | z.object({
321 | // [!code ++]
322 | name: z.string().min(1), // [!code ++]
323 | }) // [!code ++]
324 | ) // [!code ++]
325 | .min(1), // [!code ++]
326 | }), // [!code ++]
327 | z.object({ knowsOtherLanguages: z.literal(false) }), // [!code ++]
328 | ]); // [!code ++]
329 |
330 | const formSchema = z
331 | .object({
332 | fullName: z.string().min(1),
333 | })
334 | .and(workExperienceSchema)
335 | .and(languageKnowledgeSchema); // [!code ++]
336 |
337 | type FormSchema = z.infer;
338 |
339 | const formDefaultValues: FormSchema = {
340 | fullName: "",
341 | hasWorkExperience: false,
342 | knowsOtherLanguages: false, // [!code ++]
343 | };
344 |
345 | export { formDefaultValues, formSchema, type FormSchema };
346 | ```
347 |
348 | ```tsx App.tsx
349 | import { Button, Checkbox, FormControlLabel, TextField } from "@mui/material";
350 | import { Container } from "./Container";
351 | import { FieldErrors, SubmitHandler, useForm, useWatch } from "react-hook-form";
352 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
353 | import { zodResolver } from "@hookform/resolvers/zod";
354 |
355 | function App() {
356 | const {
357 | register,
358 | formState: { errors },
359 | control,
360 | handleSubmit,
361 | } = useForm({
362 | mode: "all",
363 | resolver: zodResolver(formSchema),
364 | defaultValues: formDefaultValues,
365 | });
366 |
367 | const fullErrors: FieldErrors<
368 | Extract
369 | > = errors;
370 |
371 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
372 |
373 | const onSubmit: SubmitHandler = (data) => {
374 | alert(JSON.stringify(data, null, 2));
375 | };
376 |
377 | return (
378 |
379 |
385 | }
389 | />
390 | {hasWorkExperience && (
391 |
397 | )}
398 | } // [!code ++]
402 | /> {/* [!code ++] */}
403 |
406 |
407 | );
408 | }
409 |
410 | export { App };
411 | ```
412 |
413 | now show from final app that when we click on the knowsOtherLanguages checkbox, we need to see array fields and add or remove languages
414 |
415 | to do that:
416 |
417 | ```tsx App.tsx
418 | import { Button, Checkbox, FormControlLabel, TextField } from "@mui/material";
419 | import { Container } from "./Container";
420 | import { FieldErrors, SubmitHandler, useForm, useWatch } from "react-hook-form";
421 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
422 | import { zodResolver } from "@hookform/resolvers/zod";
423 |
424 | function App() {
425 | const {
426 | register,
427 | formState: { errors },
428 | control,
429 | handleSubmit,
430 | } = useForm({
431 | mode: "all",
432 | resolver: zodResolver(formSchema),
433 | defaultValues: formDefaultValues,
434 | });
435 |
436 | const fullErrors: FieldErrors<
437 | Extract
438 | > = errors;
439 |
440 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
441 | const knowsOtherLanguages = useWatch({
442 | // [!code ++]
443 | control, // [!code ++]
444 | name: "knowsOtherLanguages", // [!code ++]
445 | }); // [!code ++]
446 |
447 | const onSubmit: SubmitHandler = (data) => {
448 | alert(JSON.stringify(data, null, 2));
449 | };
450 |
451 | return (
452 |
453 |
459 | }
463 | />
464 | {hasWorkExperience && (
465 |
471 | )}
472 | }
476 | />
477 | {knowsOtherLanguages && <>array fields here>} {/* [!code ++] */}
478 |
481 |
482 | );
483 | }
484 |
485 | export { App };
486 | ```
487 |
488 | so we need to use the amazing array fields from rhf:
489 |
490 | ```tsx App.tsx
491 | import { Button, Checkbox, FormControlLabel, TextField } from "@mui/material";
492 | import { Container } from "./Container";
493 | import {
494 | FieldErrors,
495 | SubmitHandler,
496 | useFieldArray,
497 | useForm,
498 | useWatch,
499 | } from "react-hook-form";
500 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
501 | import { zodResolver } from "@hookform/resolvers/zod";
502 |
503 | function App() {
504 | const {
505 | register,
506 | formState: { errors },
507 | control,
508 | handleSubmit,
509 | } = useForm({
510 | mode: "all",
511 | resolver: zodResolver(formSchema),
512 | defaultValues: formDefaultValues,
513 | });
514 |
515 | const {
516 | // [!code ++]
517 | fields: languagesFields, // [!code ++]
518 | replace: replaceLanguages, // [!code ++]
519 | append: appendLanguages, // [!code ++]
520 | remove: removeLanguages, // [!code ++]
521 | } = useFieldArray({
522 | // [!code ++]
523 | control, // [!code ++]
524 | name: "languages", // [!code ++]
525 | }); // [!code ++]
526 |
527 | const fullErrors: FieldErrors<
528 | Extract
529 | > = errors;
530 |
531 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
532 | const knowsOtherLanguages = useWatch({
533 | control,
534 | name: "knowsOtherLanguages",
535 | });
536 |
537 | const onSubmit: SubmitHandler = (data) => {
538 | alert(JSON.stringify(data, null, 2));
539 | };
540 |
541 | return (
542 |
543 |
549 | }
553 | />
554 |
555 | {hasWorkExperience && (
556 |
562 | )}
563 | }
567 | />
568 | {knowsOtherLanguages && <>array fields here>}
569 |
572 |
573 | );
574 | }
575 |
576 | export { App };
577 | ```
578 |
579 | ```tsx App.tsx
580 | import {
581 | Button,
582 | Checkbox,
583 | FormControlLabel,
584 | IconButton,
585 | TextField,
586 | } from "@mui/material";
587 | import { Container } from "./Container";
588 |
589 | import { zodResolver } from "@hookform/resolvers/zod";
590 | import DeleteForeverRoundedIcon from "@mui/icons-material/DeleteForeverRounded";
591 | import {
592 | FieldErrors,
593 | SubmitHandler,
594 | useFieldArray,
595 | useForm,
596 | useWatch,
597 | } from "react-hook-form";
598 | import { formDefaultValues, formSchema, FormSchema } from "./formSchema";
599 |
600 | function App() {
601 | const {
602 | register,
603 | formState: { errors },
604 | control,
605 | handleSubmit,
606 | } = useForm({
607 | mode: "all",
608 | resolver: zodResolver(formSchema),
609 | defaultValues: formDefaultValues,
610 | });
611 |
612 | const {
613 | fields: languagesFields,
614 | replace: replaceLanguages,
615 | append: appendLanguages,
616 | remove: removeLanguages,
617 | } = useFieldArray({
618 | control,
619 | name: "languages",
620 | });
621 |
622 | const fullErrors: FieldErrors<
623 | Extract
624 | > = errors;
625 |
626 | const hasWorkExperience = useWatch({ control, name: "hasWorkExperience" });
627 | const knowsOtherLanguages = useWatch({
628 | control,
629 | name: "knowsOtherLanguages",
630 | });
631 |
632 | const onSubmit: SubmitHandler = (data) => {
633 | alert(JSON.stringify(data, null, 2));
634 | };
635 |
636 | return (
637 |
638 |
644 | }
648 | />
649 | {hasWorkExperience && (
650 |
656 | )}
657 | }
661 | />
662 | {knowsOtherLanguages && (
663 | <>
664 | {languagesFields.map(
665 | (
666 | field,
667 | index // [!code ++]
668 | ) => (
669 |
670 | {" "}
677 | // [!code ++]
678 | removeLanguages(index)} // [!code ++]
681 | color="error" // [!code ++]
682 | >
683 | {" "}
684 | // [!code ++]
685 | // [!code ++]
686 | // [!code ++]
687 |
// [!code ++]
688 | )
689 | )}{" "}
690 | // [!code ++]
691 | appendLanguages({ name: "" })} // [!code ++]
694 | color="success" // [!code ++]
695 | >
696 | {" "}
697 | // [!code ++]
698 | // [!code ++]
699 | // [!code ++]
700 | > // [!code ++]
701 | )}{" "}
702 | // [!code ++]
703 |
706 |
707 | );
708 | }
709 |
710 | export { App };
711 | ```
712 |
713 | now we have errors on fullErrors on languages so we need to extended
714 |
715 | ```tsx App.tsx
716 | const fullErrors: FieldErrors<
717 | Extract
718 | > &
719 | FieldErrors> = // [!code ++]
720 | errors;
721 | ```
722 |
723 | now if check the box we see nothing is showing because we did not add anything in here (hover over fields.map) to show. to do that
724 |
725 | ```tsx App.tsx
726 | // above return
727 | useEffect(() => {
728 | if (knowsOtherLanguages) {
729 | replaceLanguages([{ name: "" }]);
730 | }
731 | }, [knowsOtherLanguages, replaceLanguages]);
732 | ```
733 |
734 | show education level on final project
735 |
736 | ```typescript formSchema.tsx
737 | const educationSchema = z.discriminatedUnion("educationLevel", [
738 | z.object({
739 | educationLevel: z.literal("noFormalEducation"),
740 | }),
741 | z.object({
742 | educationLevel: z.literal("highSchoolDiploma"),
743 | schoolName: z.string().min(1),
744 | }),
745 | z.object({
746 | educationLevel: z.literal("bachelorsDegree"),
747 | universityName: z.string().min(1),
748 | }),
749 | ]);
750 |
751 | // on the formSchema
752 | .and(educationSchema)
753 | ```
754 |
755 | ```tsx App.tsx
756 | // above submit button
757 |
758 | Education Level
759 | (
763 |
764 | }
767 | label="No Formal Education"
768 | />
769 | }
772 | label="High School Diploma"
773 | />
774 | }
777 | label="Bachelors Degree"
778 | />
779 |
780 | )}
781 | />
782 |
783 | ```
784 |
785 | ```tsx App.tsx
786 | const educationLevel = useWatch({ control, name: "educationLevel" });
787 | ```
788 |
789 | ```tsx App.tsx
790 | // above submit button
791 | {
792 | educationLevel === "highSchoolDiploma" && (
793 |
799 | );
800 | }
801 | {
802 | educationLevel === "bachelorsDegree" && (
803 |
809 | );
810 | }
811 | ```
812 |
813 | ```tsx App.tsx
814 | FieldErrors> &
815 | FieldErrors> &
816 | FieldErrors>;
817 | ```
818 |
--------------------------------------------------------------------------------
/vite.config.ts:
--------------------------------------------------------------------------------
1 | import { defineConfig } from 'vite'
2 | import react from '@vitejs/plugin-react-swc'
3 |
4 | // https://vitejs.dev/config/
5 | export default defineConfig({
6 | plugins: [react()],
7 | })
8 |
--------------------------------------------------------------------------------