├── .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 | --------------------------------------------------------------------------------