├── .gitignore ├── README.md ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.css ├── App.jsx ├── assets │ └── react.svg ├── index.css └── main.jsx └── vite.config.js /.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 | ## React Hook Form Tutorial 2 | 3 | This is a tutorial on how to use React Hook Form. It is a library that helps you validate your forms in React. It is a very simple and easy to use library. It is also very lightweight and fast. It is a great alternative to Formik. 4 | 5 | ## Installation 6 | 7 | ```bash 8 | git clone https://github.com/fazt/react-hook-form-tutorial 9 | cd react-hook-form-tutorial 10 | npm install 11 | npm run dev 12 | ``` 13 | 14 | or you can try the live demo: https://fazt.github.io/react-hook-form-tutorial/ 15 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-hook-form-tutorial", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "react-hook-form-tutorial", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "react": "^18.2.0", 12 | "react-dom": "^18.2.0", 13 | "react-hook-form": "^7.45.2" 14 | }, 15 | "devDependencies": { 16 | "@types/react": "^18.0.26", 17 | "@types/react-dom": "^18.0.9", 18 | "@vitejs/plugin-react": "^3.0.0", 19 | "gh-pages": "^5.0.0", 20 | "vite": "^4.0.0" 21 | } 22 | }, 23 | "node_modules/@ampproject/remapping": { 24 | "version": "2.2.1", 25 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 26 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 27 | "dev": true, 28 | "dependencies": { 29 | "@jridgewell/gen-mapping": "^0.3.0", 30 | "@jridgewell/trace-mapping": "^0.3.9" 31 | }, 32 | "engines": { 33 | "node": ">=6.0.0" 34 | } 35 | }, 36 | "node_modules/@babel/code-frame": { 37 | "version": "7.22.5", 38 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.5.tgz", 39 | "integrity": "sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ==", 40 | "dev": true, 41 | "dependencies": { 42 | "@babel/highlight": "^7.22.5" 43 | }, 44 | "engines": { 45 | "node": ">=6.9.0" 46 | } 47 | }, 48 | "node_modules/@babel/compat-data": { 49 | "version": "7.22.9", 50 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", 51 | "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", 52 | "dev": true, 53 | "engines": { 54 | "node": ">=6.9.0" 55 | } 56 | }, 57 | "node_modules/@babel/core": { 58 | "version": "7.22.9", 59 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", 60 | "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", 61 | "dev": true, 62 | "dependencies": { 63 | "@ampproject/remapping": "^2.2.0", 64 | "@babel/code-frame": "^7.22.5", 65 | "@babel/generator": "^7.22.9", 66 | "@babel/helper-compilation-targets": "^7.22.9", 67 | "@babel/helper-module-transforms": "^7.22.9", 68 | "@babel/helpers": "^7.22.6", 69 | "@babel/parser": "^7.22.7", 70 | "@babel/template": "^7.22.5", 71 | "@babel/traverse": "^7.22.8", 72 | "@babel/types": "^7.22.5", 73 | "convert-source-map": "^1.7.0", 74 | "debug": "^4.1.0", 75 | "gensync": "^1.0.0-beta.2", 76 | "json5": "^2.2.2", 77 | "semver": "^6.3.1" 78 | }, 79 | "engines": { 80 | "node": ">=6.9.0" 81 | }, 82 | "funding": { 83 | "type": "opencollective", 84 | "url": "https://opencollective.com/babel" 85 | } 86 | }, 87 | "node_modules/@babel/generator": { 88 | "version": "7.22.9", 89 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.9.tgz", 90 | "integrity": "sha512-KtLMbmicyuK2Ak/FTCJVbDnkN1SlT8/kceFTiuDiiRUUSMnHMidxSCdG4ndkTOHHpoomWe/4xkvHkEOncwjYIw==", 91 | "dev": true, 92 | "dependencies": { 93 | "@babel/types": "^7.22.5", 94 | "@jridgewell/gen-mapping": "^0.3.2", 95 | "@jridgewell/trace-mapping": "^0.3.17", 96 | "jsesc": "^2.5.1" 97 | }, 98 | "engines": { 99 | "node": ">=6.9.0" 100 | } 101 | }, 102 | "node_modules/@babel/helper-compilation-targets": { 103 | "version": "7.22.9", 104 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", 105 | "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", 106 | "dev": true, 107 | "dependencies": { 108 | "@babel/compat-data": "^7.22.9", 109 | "@babel/helper-validator-option": "^7.22.5", 110 | "browserslist": "^4.21.9", 111 | "lru-cache": "^5.1.1", 112 | "semver": "^6.3.1" 113 | }, 114 | "engines": { 115 | "node": ">=6.9.0" 116 | }, 117 | "peerDependencies": { 118 | "@babel/core": "^7.0.0" 119 | } 120 | }, 121 | "node_modules/@babel/helper-environment-visitor": { 122 | "version": "7.22.5", 123 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", 124 | "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", 125 | "dev": true, 126 | "engines": { 127 | "node": ">=6.9.0" 128 | } 129 | }, 130 | "node_modules/@babel/helper-function-name": { 131 | "version": "7.22.5", 132 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz", 133 | "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==", 134 | "dev": true, 135 | "dependencies": { 136 | "@babel/template": "^7.22.5", 137 | "@babel/types": "^7.22.5" 138 | }, 139 | "engines": { 140 | "node": ">=6.9.0" 141 | } 142 | }, 143 | "node_modules/@babel/helper-hoist-variables": { 144 | "version": "7.22.5", 145 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 146 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 147 | "dev": true, 148 | "dependencies": { 149 | "@babel/types": "^7.22.5" 150 | }, 151 | "engines": { 152 | "node": ">=6.9.0" 153 | } 154 | }, 155 | "node_modules/@babel/helper-module-imports": { 156 | "version": "7.22.5", 157 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", 158 | "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", 159 | "dev": true, 160 | "dependencies": { 161 | "@babel/types": "^7.22.5" 162 | }, 163 | "engines": { 164 | "node": ">=6.9.0" 165 | } 166 | }, 167 | "node_modules/@babel/helper-module-transforms": { 168 | "version": "7.22.9", 169 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", 170 | "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", 171 | "dev": true, 172 | "dependencies": { 173 | "@babel/helper-environment-visitor": "^7.22.5", 174 | "@babel/helper-module-imports": "^7.22.5", 175 | "@babel/helper-simple-access": "^7.22.5", 176 | "@babel/helper-split-export-declaration": "^7.22.6", 177 | "@babel/helper-validator-identifier": "^7.22.5" 178 | }, 179 | "engines": { 180 | "node": ">=6.9.0" 181 | }, 182 | "peerDependencies": { 183 | "@babel/core": "^7.0.0" 184 | } 185 | }, 186 | "node_modules/@babel/helper-plugin-utils": { 187 | "version": "7.22.5", 188 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", 189 | "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", 190 | "dev": true, 191 | "engines": { 192 | "node": ">=6.9.0" 193 | } 194 | }, 195 | "node_modules/@babel/helper-simple-access": { 196 | "version": "7.22.5", 197 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 198 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 199 | "dev": true, 200 | "dependencies": { 201 | "@babel/types": "^7.22.5" 202 | }, 203 | "engines": { 204 | "node": ">=6.9.0" 205 | } 206 | }, 207 | "node_modules/@babel/helper-split-export-declaration": { 208 | "version": "7.22.6", 209 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 210 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 211 | "dev": true, 212 | "dependencies": { 213 | "@babel/types": "^7.22.5" 214 | }, 215 | "engines": { 216 | "node": ">=6.9.0" 217 | } 218 | }, 219 | "node_modules/@babel/helper-string-parser": { 220 | "version": "7.22.5", 221 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", 222 | "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", 223 | "dev": true, 224 | "engines": { 225 | "node": ">=6.9.0" 226 | } 227 | }, 228 | "node_modules/@babel/helper-validator-identifier": { 229 | "version": "7.22.5", 230 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", 231 | "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==", 232 | "dev": true, 233 | "engines": { 234 | "node": ">=6.9.0" 235 | } 236 | }, 237 | "node_modules/@babel/helper-validator-option": { 238 | "version": "7.22.5", 239 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", 240 | "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", 241 | "dev": true, 242 | "engines": { 243 | "node": ">=6.9.0" 244 | } 245 | }, 246 | "node_modules/@babel/helpers": { 247 | "version": "7.22.6", 248 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", 249 | "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", 250 | "dev": true, 251 | "dependencies": { 252 | "@babel/template": "^7.22.5", 253 | "@babel/traverse": "^7.22.6", 254 | "@babel/types": "^7.22.5" 255 | }, 256 | "engines": { 257 | "node": ">=6.9.0" 258 | } 259 | }, 260 | "node_modules/@babel/highlight": { 261 | "version": "7.22.5", 262 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.5.tgz", 263 | "integrity": "sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw==", 264 | "dev": true, 265 | "dependencies": { 266 | "@babel/helper-validator-identifier": "^7.22.5", 267 | "chalk": "^2.0.0", 268 | "js-tokens": "^4.0.0" 269 | }, 270 | "engines": { 271 | "node": ">=6.9.0" 272 | } 273 | }, 274 | "node_modules/@babel/parser": { 275 | "version": "7.22.7", 276 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.7.tgz", 277 | "integrity": "sha512-7NF8pOkHP5o2vpmGgNGcfAeCvOYhGLyA3Z4eBQkT1RJlWu47n63bCs93QfJ2hIAFCil7L5P2IWhs1oToVgrL0Q==", 278 | "dev": true, 279 | "bin": { 280 | "parser": "bin/babel-parser.js" 281 | }, 282 | "engines": { 283 | "node": ">=6.0.0" 284 | } 285 | }, 286 | "node_modules/@babel/plugin-transform-react-jsx-self": { 287 | "version": "7.22.5", 288 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.22.5.tgz", 289 | "integrity": "sha512-nTh2ogNUtxbiSbxaT4Ds6aXnXEipHweN9YRgOX/oNXdf0cCrGn/+2LozFa3lnPV5D90MkjhgckCPBrsoSc1a7g==", 290 | "dev": true, 291 | "dependencies": { 292 | "@babel/helper-plugin-utils": "^7.22.5" 293 | }, 294 | "engines": { 295 | "node": ">=6.9.0" 296 | }, 297 | "peerDependencies": { 298 | "@babel/core": "^7.0.0-0" 299 | } 300 | }, 301 | "node_modules/@babel/plugin-transform-react-jsx-source": { 302 | "version": "7.22.5", 303 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.22.5.tgz", 304 | "integrity": "sha512-yIiRO6yobeEIaI0RTbIr8iAK9FcBHLtZq0S89ZPjDLQXBA4xvghaKqI0etp/tF3htTM0sazJKKLz9oEiGRtu7w==", 305 | "dev": true, 306 | "dependencies": { 307 | "@babel/helper-plugin-utils": "^7.22.5" 308 | }, 309 | "engines": { 310 | "node": ">=6.9.0" 311 | }, 312 | "peerDependencies": { 313 | "@babel/core": "^7.0.0-0" 314 | } 315 | }, 316 | "node_modules/@babel/template": { 317 | "version": "7.22.5", 318 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", 319 | "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", 320 | "dev": true, 321 | "dependencies": { 322 | "@babel/code-frame": "^7.22.5", 323 | "@babel/parser": "^7.22.5", 324 | "@babel/types": "^7.22.5" 325 | }, 326 | "engines": { 327 | "node": ">=6.9.0" 328 | } 329 | }, 330 | "node_modules/@babel/traverse": { 331 | "version": "7.22.8", 332 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.8.tgz", 333 | "integrity": "sha512-y6LPR+wpM2I3qJrsheCTwhIinzkETbplIgPBbwvqPKc+uljeA5gP+3nP8irdYt1mjQaDnlIcG+dw8OjAco4GXw==", 334 | "dev": true, 335 | "dependencies": { 336 | "@babel/code-frame": "^7.22.5", 337 | "@babel/generator": "^7.22.7", 338 | "@babel/helper-environment-visitor": "^7.22.5", 339 | "@babel/helper-function-name": "^7.22.5", 340 | "@babel/helper-hoist-variables": "^7.22.5", 341 | "@babel/helper-split-export-declaration": "^7.22.6", 342 | "@babel/parser": "^7.22.7", 343 | "@babel/types": "^7.22.5", 344 | "debug": "^4.1.0", 345 | "globals": "^11.1.0" 346 | }, 347 | "engines": { 348 | "node": ">=6.9.0" 349 | } 350 | }, 351 | "node_modules/@babel/types": { 352 | "version": "7.22.5", 353 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.5.tgz", 354 | "integrity": "sha512-zo3MIHGOkPOfoRXitsgHLjEXmlDaD/5KU1Uzuc9GNiZPhSqVxVRtxuPaSBZDsYZ9qV88AjtMtWW7ww98loJ9KA==", 355 | "dev": true, 356 | "dependencies": { 357 | "@babel/helper-string-parser": "^7.22.5", 358 | "@babel/helper-validator-identifier": "^7.22.5", 359 | "to-fast-properties": "^2.0.0" 360 | }, 361 | "engines": { 362 | "node": ">=6.9.0" 363 | } 364 | }, 365 | "node_modules/@esbuild/android-arm": { 366 | "version": "0.18.17", 367 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.17.tgz", 368 | "integrity": "sha512-wHsmJG/dnL3OkpAcwbgoBTTMHVi4Uyou3F5mf58ZtmUyIKfcdA7TROav/6tCzET4A3QW2Q2FC+eFneMU+iyOxg==", 369 | "cpu": [ 370 | "arm" 371 | ], 372 | "dev": true, 373 | "optional": true, 374 | "os": [ 375 | "android" 376 | ], 377 | "engines": { 378 | "node": ">=12" 379 | } 380 | }, 381 | "node_modules/@esbuild/android-arm64": { 382 | "version": "0.18.17", 383 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.17.tgz", 384 | "integrity": "sha512-9np+YYdNDed5+Jgr1TdWBsozZ85U1Oa3xW0c7TWqH0y2aGghXtZsuT8nYRbzOMcl0bXZXjOGbksoTtVOlWrRZg==", 385 | "cpu": [ 386 | "arm64" 387 | ], 388 | "dev": true, 389 | "optional": true, 390 | "os": [ 391 | "android" 392 | ], 393 | "engines": { 394 | "node": ">=12" 395 | } 396 | }, 397 | "node_modules/@esbuild/android-x64": { 398 | "version": "0.18.17", 399 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.17.tgz", 400 | "integrity": "sha512-O+FeWB/+xya0aLg23hHEM2E3hbfwZzjqumKMSIqcHbNvDa+dza2D0yLuymRBQQnC34CWrsJUXyH2MG5VnLd6uw==", 401 | "cpu": [ 402 | "x64" 403 | ], 404 | "dev": true, 405 | "optional": true, 406 | "os": [ 407 | "android" 408 | ], 409 | "engines": { 410 | "node": ">=12" 411 | } 412 | }, 413 | "node_modules/@esbuild/darwin-arm64": { 414 | "version": "0.18.17", 415 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.17.tgz", 416 | "integrity": "sha512-M9uJ9VSB1oli2BE/dJs3zVr9kcCBBsE883prage1NWz6pBS++1oNn/7soPNS3+1DGj0FrkSvnED4Bmlu1VAE9g==", 417 | "cpu": [ 418 | "arm64" 419 | ], 420 | "dev": true, 421 | "optional": true, 422 | "os": [ 423 | "darwin" 424 | ], 425 | "engines": { 426 | "node": ">=12" 427 | } 428 | }, 429 | "node_modules/@esbuild/darwin-x64": { 430 | "version": "0.18.17", 431 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.17.tgz", 432 | "integrity": "sha512-XDre+J5YeIJDMfp3n0279DFNrGCXlxOuGsWIkRb1NThMZ0BsrWXoTg23Jer7fEXQ9Ye5QjrvXpxnhzl3bHtk0g==", 433 | "cpu": [ 434 | "x64" 435 | ], 436 | "dev": true, 437 | "optional": true, 438 | "os": [ 439 | "darwin" 440 | ], 441 | "engines": { 442 | "node": ">=12" 443 | } 444 | }, 445 | "node_modules/@esbuild/freebsd-arm64": { 446 | "version": "0.18.17", 447 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.17.tgz", 448 | "integrity": "sha512-cjTzGa3QlNfERa0+ptykyxs5A6FEUQQF0MuilYXYBGdBxD3vxJcKnzDlhDCa1VAJCmAxed6mYhA2KaJIbtiNuQ==", 449 | "cpu": [ 450 | "arm64" 451 | ], 452 | "dev": true, 453 | "optional": true, 454 | "os": [ 455 | "freebsd" 456 | ], 457 | "engines": { 458 | "node": ">=12" 459 | } 460 | }, 461 | "node_modules/@esbuild/freebsd-x64": { 462 | "version": "0.18.17", 463 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.17.tgz", 464 | "integrity": "sha512-sOxEvR8d7V7Kw8QqzxWc7bFfnWnGdaFBut1dRUYtu+EIRXefBc/eIsiUiShnW0hM3FmQ5Zf27suDuHsKgZ5QrA==", 465 | "cpu": [ 466 | "x64" 467 | ], 468 | "dev": true, 469 | "optional": true, 470 | "os": [ 471 | "freebsd" 472 | ], 473 | "engines": { 474 | "node": ">=12" 475 | } 476 | }, 477 | "node_modules/@esbuild/linux-arm": { 478 | "version": "0.18.17", 479 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.17.tgz", 480 | "integrity": "sha512-2d3Lw6wkwgSLC2fIvXKoMNGVaeY8qdN0IC3rfuVxJp89CRfA3e3VqWifGDfuakPmp90+ZirmTfye1n4ncjv2lg==", 481 | "cpu": [ 482 | "arm" 483 | ], 484 | "dev": true, 485 | "optional": true, 486 | "os": [ 487 | "linux" 488 | ], 489 | "engines": { 490 | "node": ">=12" 491 | } 492 | }, 493 | "node_modules/@esbuild/linux-arm64": { 494 | "version": "0.18.17", 495 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.17.tgz", 496 | "integrity": "sha512-c9w3tE7qA3CYWjT+M3BMbwMt+0JYOp3vCMKgVBrCl1nwjAlOMYzEo+gG7QaZ9AtqZFj5MbUc885wuBBmu6aADQ==", 497 | "cpu": [ 498 | "arm64" 499 | ], 500 | "dev": true, 501 | "optional": true, 502 | "os": [ 503 | "linux" 504 | ], 505 | "engines": { 506 | "node": ">=12" 507 | } 508 | }, 509 | "node_modules/@esbuild/linux-ia32": { 510 | "version": "0.18.17", 511 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.17.tgz", 512 | "integrity": "sha512-1DS9F966pn5pPnqXYz16dQqWIB0dmDfAQZd6jSSpiT9eX1NzKh07J6VKR3AoXXXEk6CqZMojiVDSZi1SlmKVdg==", 513 | "cpu": [ 514 | "ia32" 515 | ], 516 | "dev": true, 517 | "optional": true, 518 | "os": [ 519 | "linux" 520 | ], 521 | "engines": { 522 | "node": ">=12" 523 | } 524 | }, 525 | "node_modules/@esbuild/linux-loong64": { 526 | "version": "0.18.17", 527 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.17.tgz", 528 | "integrity": "sha512-EvLsxCk6ZF0fpCB6w6eOI2Fc8KW5N6sHlIovNe8uOFObL2O+Mr0bflPHyHwLT6rwMg9r77WOAWb2FqCQrVnwFg==", 529 | "cpu": [ 530 | "loong64" 531 | ], 532 | "dev": true, 533 | "optional": true, 534 | "os": [ 535 | "linux" 536 | ], 537 | "engines": { 538 | "node": ">=12" 539 | } 540 | }, 541 | "node_modules/@esbuild/linux-mips64el": { 542 | "version": "0.18.17", 543 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.17.tgz", 544 | "integrity": "sha512-e0bIdHA5p6l+lwqTE36NAW5hHtw2tNRmHlGBygZC14QObsA3bD4C6sXLJjvnDIjSKhW1/0S3eDy+QmX/uZWEYQ==", 545 | "cpu": [ 546 | "mips64el" 547 | ], 548 | "dev": true, 549 | "optional": true, 550 | "os": [ 551 | "linux" 552 | ], 553 | "engines": { 554 | "node": ">=12" 555 | } 556 | }, 557 | "node_modules/@esbuild/linux-ppc64": { 558 | "version": "0.18.17", 559 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.17.tgz", 560 | "integrity": "sha512-BAAilJ0M5O2uMxHYGjFKn4nJKF6fNCdP1E0o5t5fvMYYzeIqy2JdAP88Az5LHt9qBoUa4tDaRpfWt21ep5/WqQ==", 561 | "cpu": [ 562 | "ppc64" 563 | ], 564 | "dev": true, 565 | "optional": true, 566 | "os": [ 567 | "linux" 568 | ], 569 | "engines": { 570 | "node": ">=12" 571 | } 572 | }, 573 | "node_modules/@esbuild/linux-riscv64": { 574 | "version": "0.18.17", 575 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.17.tgz", 576 | "integrity": "sha512-Wh/HW2MPnC3b8BqRSIme/9Zhab36PPH+3zam5pqGRH4pE+4xTrVLx2+XdGp6fVS3L2x+DrsIcsbMleex8fbE6g==", 577 | "cpu": [ 578 | "riscv64" 579 | ], 580 | "dev": true, 581 | "optional": true, 582 | "os": [ 583 | "linux" 584 | ], 585 | "engines": { 586 | "node": ">=12" 587 | } 588 | }, 589 | "node_modules/@esbuild/linux-s390x": { 590 | "version": "0.18.17", 591 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.17.tgz", 592 | "integrity": "sha512-j/34jAl3ul3PNcK3pfI0NSlBANduT2UO5kZ7FCaK33XFv3chDhICLY8wJJWIhiQ+YNdQ9dxqQctRg2bvrMlYgg==", 593 | "cpu": [ 594 | "s390x" 595 | ], 596 | "dev": true, 597 | "optional": true, 598 | "os": [ 599 | "linux" 600 | ], 601 | "engines": { 602 | "node": ">=12" 603 | } 604 | }, 605 | "node_modules/@esbuild/linux-x64": { 606 | "version": "0.18.17", 607 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.17.tgz", 608 | "integrity": "sha512-QM50vJ/y+8I60qEmFxMoxIx4de03pGo2HwxdBeFd4nMh364X6TIBZ6VQ5UQmPbQWUVWHWws5MmJXlHAXvJEmpQ==", 609 | "cpu": [ 610 | "x64" 611 | ], 612 | "dev": true, 613 | "optional": true, 614 | "os": [ 615 | "linux" 616 | ], 617 | "engines": { 618 | "node": ">=12" 619 | } 620 | }, 621 | "node_modules/@esbuild/netbsd-x64": { 622 | "version": "0.18.17", 623 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.17.tgz", 624 | "integrity": "sha512-/jGlhWR7Sj9JPZHzXyyMZ1RFMkNPjC6QIAan0sDOtIo2TYk3tZn5UDrkE0XgsTQCxWTTOcMPf9p6Rh2hXtl5TQ==", 625 | "cpu": [ 626 | "x64" 627 | ], 628 | "dev": true, 629 | "optional": true, 630 | "os": [ 631 | "netbsd" 632 | ], 633 | "engines": { 634 | "node": ">=12" 635 | } 636 | }, 637 | "node_modules/@esbuild/openbsd-x64": { 638 | "version": "0.18.17", 639 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.17.tgz", 640 | "integrity": "sha512-rSEeYaGgyGGf4qZM2NonMhMOP/5EHp4u9ehFiBrg7stH6BYEEjlkVREuDEcQ0LfIl53OXLxNbfuIj7mr5m29TA==", 641 | "cpu": [ 642 | "x64" 643 | ], 644 | "dev": true, 645 | "optional": true, 646 | "os": [ 647 | "openbsd" 648 | ], 649 | "engines": { 650 | "node": ">=12" 651 | } 652 | }, 653 | "node_modules/@esbuild/sunos-x64": { 654 | "version": "0.18.17", 655 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.17.tgz", 656 | "integrity": "sha512-Y7ZBbkLqlSgn4+zot4KUNYst0bFoO68tRgI6mY2FIM+b7ZbyNVtNbDP5y8qlu4/knZZ73fgJDlXID+ohY5zt5g==", 657 | "cpu": [ 658 | "x64" 659 | ], 660 | "dev": true, 661 | "optional": true, 662 | "os": [ 663 | "sunos" 664 | ], 665 | "engines": { 666 | "node": ">=12" 667 | } 668 | }, 669 | "node_modules/@esbuild/win32-arm64": { 670 | "version": "0.18.17", 671 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.17.tgz", 672 | "integrity": "sha512-bwPmTJsEQcbZk26oYpc4c/8PvTY3J5/QK8jM19DVlEsAB41M39aWovWoHtNm78sd6ip6prilxeHosPADXtEJFw==", 673 | "cpu": [ 674 | "arm64" 675 | ], 676 | "dev": true, 677 | "optional": true, 678 | "os": [ 679 | "win32" 680 | ], 681 | "engines": { 682 | "node": ">=12" 683 | } 684 | }, 685 | "node_modules/@esbuild/win32-ia32": { 686 | "version": "0.18.17", 687 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.17.tgz", 688 | "integrity": "sha512-H/XaPtPKli2MhW+3CQueo6Ni3Avggi6hP/YvgkEe1aSaxw+AeO8MFjq8DlgfTd9Iz4Yih3QCZI6YLMoyccnPRg==", 689 | "cpu": [ 690 | "ia32" 691 | ], 692 | "dev": true, 693 | "optional": true, 694 | "os": [ 695 | "win32" 696 | ], 697 | "engines": { 698 | "node": ">=12" 699 | } 700 | }, 701 | "node_modules/@esbuild/win32-x64": { 702 | "version": "0.18.17", 703 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.17.tgz", 704 | "integrity": "sha512-fGEb8f2BSA3CW7riJVurug65ACLuQAzKq0SSqkY2b2yHHH0MzDfbLyKIGzHwOI/gkHcxM/leuSW6D5w/LMNitA==", 705 | "cpu": [ 706 | "x64" 707 | ], 708 | "dev": true, 709 | "optional": true, 710 | "os": [ 711 | "win32" 712 | ], 713 | "engines": { 714 | "node": ">=12" 715 | } 716 | }, 717 | "node_modules/@jridgewell/gen-mapping": { 718 | "version": "0.3.3", 719 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 720 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 721 | "dev": true, 722 | "dependencies": { 723 | "@jridgewell/set-array": "^1.0.1", 724 | "@jridgewell/sourcemap-codec": "^1.4.10", 725 | "@jridgewell/trace-mapping": "^0.3.9" 726 | }, 727 | "engines": { 728 | "node": ">=6.0.0" 729 | } 730 | }, 731 | "node_modules/@jridgewell/resolve-uri": { 732 | "version": "3.1.0", 733 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 734 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 735 | "dev": true, 736 | "engines": { 737 | "node": ">=6.0.0" 738 | } 739 | }, 740 | "node_modules/@jridgewell/set-array": { 741 | "version": "1.1.2", 742 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 743 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 744 | "dev": true, 745 | "engines": { 746 | "node": ">=6.0.0" 747 | } 748 | }, 749 | "node_modules/@jridgewell/sourcemap-codec": { 750 | "version": "1.4.15", 751 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 752 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 753 | "dev": true 754 | }, 755 | "node_modules/@jridgewell/trace-mapping": { 756 | "version": "0.3.18", 757 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", 758 | "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", 759 | "dev": true, 760 | "dependencies": { 761 | "@jridgewell/resolve-uri": "3.1.0", 762 | "@jridgewell/sourcemap-codec": "1.4.14" 763 | } 764 | }, 765 | "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { 766 | "version": "1.4.14", 767 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 768 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 769 | "dev": true 770 | }, 771 | "node_modules/@types/prop-types": { 772 | "version": "15.7.5", 773 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", 774 | "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", 775 | "dev": true 776 | }, 777 | "node_modules/@types/react": { 778 | "version": "18.2.17", 779 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.17.tgz", 780 | "integrity": "sha512-u+e7OlgPPh+aryjOm5UJMX32OvB2E3QASOAqVMY6Ahs90djagxwv2ya0IctglNbNTexC12qCSMZG47KPfy1hAA==", 781 | "dev": true, 782 | "dependencies": { 783 | "@types/prop-types": "*", 784 | "@types/scheduler": "*", 785 | "csstype": "^3.0.2" 786 | } 787 | }, 788 | "node_modules/@types/react-dom": { 789 | "version": "18.2.7", 790 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.7.tgz", 791 | "integrity": "sha512-GRaAEriuT4zp9N4p1i8BDBYmEyfo+xQ3yHjJU4eiK5NDa1RmUZG+unZABUTK4/Ox/M+GaHwb6Ow8rUITrtjszA==", 792 | "dev": true, 793 | "dependencies": { 794 | "@types/react": "*" 795 | } 796 | }, 797 | "node_modules/@types/scheduler": { 798 | "version": "0.16.3", 799 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.3.tgz", 800 | "integrity": "sha512-5cJ8CB4yAx7BH1oMvdU0Jh9lrEXyPkar6F9G/ERswkCuvP4KQZfZkSjcMbAICCpQTN4OuZn8tz0HiKv9TGZgrQ==", 801 | "dev": true 802 | }, 803 | "node_modules/@vitejs/plugin-react": { 804 | "version": "3.1.0", 805 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-3.1.0.tgz", 806 | "integrity": "sha512-AfgcRL8ZBhAlc3BFdigClmTUMISmmzHn7sB2h9U1odvc5U/MjWXsAaz18b/WoppUTDBzxOJwo2VdClfUcItu9g==", 807 | "dev": true, 808 | "dependencies": { 809 | "@babel/core": "^7.20.12", 810 | "@babel/plugin-transform-react-jsx-self": "^7.18.6", 811 | "@babel/plugin-transform-react-jsx-source": "^7.19.6", 812 | "magic-string": "^0.27.0", 813 | "react-refresh": "^0.14.0" 814 | }, 815 | "engines": { 816 | "node": "^14.18.0 || >=16.0.0" 817 | }, 818 | "peerDependencies": { 819 | "vite": "^4.1.0-beta.0" 820 | } 821 | }, 822 | "node_modules/ansi-styles": { 823 | "version": "3.2.1", 824 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 825 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 826 | "dev": true, 827 | "dependencies": { 828 | "color-convert": "^1.9.0" 829 | }, 830 | "engines": { 831 | "node": ">=4" 832 | } 833 | }, 834 | "node_modules/array-union": { 835 | "version": "1.0.2", 836 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 837 | "integrity": "sha512-Dxr6QJj/RdU/hCaBjOfxW+q6lyuVE6JFWIrAUpuOOhoJJoQ99cUn3igRaHVB5P9WrgFVN0FfArM3x0cueOU8ng==", 838 | "dev": true, 839 | "dependencies": { 840 | "array-uniq": "^1.0.1" 841 | }, 842 | "engines": { 843 | "node": ">=0.10.0" 844 | } 845 | }, 846 | "node_modules/array-uniq": { 847 | "version": "1.0.3", 848 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 849 | "integrity": "sha512-MNha4BWQ6JbwhFhj03YK552f7cb3AzoE8SzeljgChvL1dl3IcvggXVz1DilzySZkCja+CXuZbdW7yATchWn8/Q==", 850 | "dev": true, 851 | "engines": { 852 | "node": ">=0.10.0" 853 | } 854 | }, 855 | "node_modules/async": { 856 | "version": "3.2.4", 857 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.4.tgz", 858 | "integrity": "sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==", 859 | "dev": true 860 | }, 861 | "node_modules/balanced-match": { 862 | "version": "1.0.2", 863 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 864 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 865 | "dev": true 866 | }, 867 | "node_modules/brace-expansion": { 868 | "version": "1.1.11", 869 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 870 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 871 | "dev": true, 872 | "dependencies": { 873 | "balanced-match": "^1.0.0", 874 | "concat-map": "0.0.1" 875 | } 876 | }, 877 | "node_modules/browserslist": { 878 | "version": "4.21.9", 879 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.9.tgz", 880 | "integrity": "sha512-M0MFoZzbUrRU4KNfCrDLnvyE7gub+peetoTid3TBIqtunaDJyXlwhakT+/VkvSXcfIzFfK/nkCs4nmyTmxdNSg==", 881 | "dev": true, 882 | "funding": [ 883 | { 884 | "type": "opencollective", 885 | "url": "https://opencollective.com/browserslist" 886 | }, 887 | { 888 | "type": "tidelift", 889 | "url": "https://tidelift.com/funding/github/npm/browserslist" 890 | }, 891 | { 892 | "type": "github", 893 | "url": "https://github.com/sponsors/ai" 894 | } 895 | ], 896 | "dependencies": { 897 | "caniuse-lite": "^1.0.30001503", 898 | "electron-to-chromium": "^1.4.431", 899 | "node-releases": "^2.0.12", 900 | "update-browserslist-db": "^1.0.11" 901 | }, 902 | "bin": { 903 | "browserslist": "cli.js" 904 | }, 905 | "engines": { 906 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 907 | } 908 | }, 909 | "node_modules/caniuse-lite": { 910 | "version": "1.0.30001517", 911 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001517.tgz", 912 | "integrity": "sha512-Vdhm5S11DaFVLlyiKu4hiUTkpZu+y1KA/rZZqVQfOD5YdDT/eQKlkt7NaE0WGOFgX32diqt9MiP9CAiFeRklaA==", 913 | "dev": true, 914 | "funding": [ 915 | { 916 | "type": "opencollective", 917 | "url": "https://opencollective.com/browserslist" 918 | }, 919 | { 920 | "type": "tidelift", 921 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 922 | }, 923 | { 924 | "type": "github", 925 | "url": "https://github.com/sponsors/ai" 926 | } 927 | ] 928 | }, 929 | "node_modules/chalk": { 930 | "version": "2.4.2", 931 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 932 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 933 | "dev": true, 934 | "dependencies": { 935 | "ansi-styles": "^3.2.1", 936 | "escape-string-regexp": "^1.0.5", 937 | "supports-color": "^5.3.0" 938 | }, 939 | "engines": { 940 | "node": ">=4" 941 | } 942 | }, 943 | "node_modules/color-convert": { 944 | "version": "1.9.3", 945 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 946 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 947 | "dev": true, 948 | "dependencies": { 949 | "color-name": "1.1.3" 950 | } 951 | }, 952 | "node_modules/color-name": { 953 | "version": "1.1.3", 954 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 955 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 956 | "dev": true 957 | }, 958 | "node_modules/commander": { 959 | "version": "2.20.3", 960 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 961 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 962 | "dev": true 963 | }, 964 | "node_modules/commondir": { 965 | "version": "1.0.1", 966 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 967 | "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", 968 | "dev": true 969 | }, 970 | "node_modules/concat-map": { 971 | "version": "0.0.1", 972 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 973 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 974 | "dev": true 975 | }, 976 | "node_modules/convert-source-map": { 977 | "version": "1.9.0", 978 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 979 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", 980 | "dev": true 981 | }, 982 | "node_modules/csstype": { 983 | "version": "3.1.2", 984 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.2.tgz", 985 | "integrity": "sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ==", 986 | "dev": true 987 | }, 988 | "node_modules/debug": { 989 | "version": "4.3.4", 990 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 991 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 992 | "dev": true, 993 | "dependencies": { 994 | "ms": "2.1.2" 995 | }, 996 | "engines": { 997 | "node": ">=6.0" 998 | }, 999 | "peerDependenciesMeta": { 1000 | "supports-color": { 1001 | "optional": true 1002 | } 1003 | } 1004 | }, 1005 | "node_modules/electron-to-chromium": { 1006 | "version": "1.4.473", 1007 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.473.tgz", 1008 | "integrity": "sha512-aVfC8+440vGfl06l8HKKn8/PD5jRfSnLkTTD65EFvU46igbpQRri1gxSzW9/+TeUlwYzrXk1sw867T96zlyECA==", 1009 | "dev": true 1010 | }, 1011 | "node_modules/email-addresses": { 1012 | "version": "5.0.0", 1013 | "resolved": "https://registry.npmjs.org/email-addresses/-/email-addresses-5.0.0.tgz", 1014 | "integrity": "sha512-4OIPYlA6JXqtVn8zpHpGiI7vE6EQOAg16aGnDMIAlZVinnoZ8208tW1hAbjWydgN/4PLTT9q+O1K6AH/vALJGw==", 1015 | "dev": true 1016 | }, 1017 | "node_modules/esbuild": { 1018 | "version": "0.18.17", 1019 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.17.tgz", 1020 | "integrity": "sha512-1GJtYnUxsJreHYA0Y+iQz2UEykonY66HNWOb0yXYZi9/kNrORUEHVg87eQsCtqh59PEJ5YVZJO98JHznMJSWjg==", 1021 | "dev": true, 1022 | "hasInstallScript": true, 1023 | "bin": { 1024 | "esbuild": "bin/esbuild" 1025 | }, 1026 | "engines": { 1027 | "node": ">=12" 1028 | }, 1029 | "optionalDependencies": { 1030 | "@esbuild/android-arm": "0.18.17", 1031 | "@esbuild/android-arm64": "0.18.17", 1032 | "@esbuild/android-x64": "0.18.17", 1033 | "@esbuild/darwin-arm64": "0.18.17", 1034 | "@esbuild/darwin-x64": "0.18.17", 1035 | "@esbuild/freebsd-arm64": "0.18.17", 1036 | "@esbuild/freebsd-x64": "0.18.17", 1037 | "@esbuild/linux-arm": "0.18.17", 1038 | "@esbuild/linux-arm64": "0.18.17", 1039 | "@esbuild/linux-ia32": "0.18.17", 1040 | "@esbuild/linux-loong64": "0.18.17", 1041 | "@esbuild/linux-mips64el": "0.18.17", 1042 | "@esbuild/linux-ppc64": "0.18.17", 1043 | "@esbuild/linux-riscv64": "0.18.17", 1044 | "@esbuild/linux-s390x": "0.18.17", 1045 | "@esbuild/linux-x64": "0.18.17", 1046 | "@esbuild/netbsd-x64": "0.18.17", 1047 | "@esbuild/openbsd-x64": "0.18.17", 1048 | "@esbuild/sunos-x64": "0.18.17", 1049 | "@esbuild/win32-arm64": "0.18.17", 1050 | "@esbuild/win32-ia32": "0.18.17", 1051 | "@esbuild/win32-x64": "0.18.17" 1052 | } 1053 | }, 1054 | "node_modules/escalade": { 1055 | "version": "3.1.1", 1056 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1057 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1058 | "dev": true, 1059 | "engines": { 1060 | "node": ">=6" 1061 | } 1062 | }, 1063 | "node_modules/escape-string-regexp": { 1064 | "version": "1.0.5", 1065 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1066 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1067 | "dev": true, 1068 | "engines": { 1069 | "node": ">=0.8.0" 1070 | } 1071 | }, 1072 | "node_modules/filename-reserved-regex": { 1073 | "version": "2.0.0", 1074 | "resolved": "https://registry.npmjs.org/filename-reserved-regex/-/filename-reserved-regex-2.0.0.tgz", 1075 | "integrity": "sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==", 1076 | "dev": true, 1077 | "engines": { 1078 | "node": ">=4" 1079 | } 1080 | }, 1081 | "node_modules/filenamify": { 1082 | "version": "4.3.0", 1083 | "resolved": "https://registry.npmjs.org/filenamify/-/filenamify-4.3.0.tgz", 1084 | "integrity": "sha512-hcFKyUG57yWGAzu1CMt/dPzYZuv+jAJUT85bL8mrXvNe6hWj6yEHEc4EdcgiA6Z3oi1/9wXJdZPXF2dZNgwgOg==", 1085 | "dev": true, 1086 | "dependencies": { 1087 | "filename-reserved-regex": "^2.0.0", 1088 | "strip-outer": "^1.0.1", 1089 | "trim-repeated": "^1.0.0" 1090 | }, 1091 | "engines": { 1092 | "node": ">=8" 1093 | }, 1094 | "funding": { 1095 | "url": "https://github.com/sponsors/sindresorhus" 1096 | } 1097 | }, 1098 | "node_modules/find-cache-dir": { 1099 | "version": "3.3.2", 1100 | "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", 1101 | "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", 1102 | "dev": true, 1103 | "dependencies": { 1104 | "commondir": "^1.0.1", 1105 | "make-dir": "^3.0.2", 1106 | "pkg-dir": "^4.1.0" 1107 | }, 1108 | "engines": { 1109 | "node": ">=8" 1110 | }, 1111 | "funding": { 1112 | "url": "https://github.com/avajs/find-cache-dir?sponsor=1" 1113 | } 1114 | }, 1115 | "node_modules/find-up": { 1116 | "version": "4.1.0", 1117 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1118 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1119 | "dev": true, 1120 | "dependencies": { 1121 | "locate-path": "^5.0.0", 1122 | "path-exists": "^4.0.0" 1123 | }, 1124 | "engines": { 1125 | "node": ">=8" 1126 | } 1127 | }, 1128 | "node_modules/fs-extra": { 1129 | "version": "8.1.0", 1130 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 1131 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 1132 | "dev": true, 1133 | "dependencies": { 1134 | "graceful-fs": "^4.2.0", 1135 | "jsonfile": "^4.0.0", 1136 | "universalify": "^0.1.0" 1137 | }, 1138 | "engines": { 1139 | "node": ">=6 <7 || >=8" 1140 | } 1141 | }, 1142 | "node_modules/fs.realpath": { 1143 | "version": "1.0.0", 1144 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1145 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1146 | "dev": true 1147 | }, 1148 | "node_modules/fsevents": { 1149 | "version": "2.3.2", 1150 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1151 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1152 | "dev": true, 1153 | "hasInstallScript": true, 1154 | "optional": true, 1155 | "os": [ 1156 | "darwin" 1157 | ], 1158 | "engines": { 1159 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1160 | } 1161 | }, 1162 | "node_modules/gensync": { 1163 | "version": "1.0.0-beta.2", 1164 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 1165 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 1166 | "dev": true, 1167 | "engines": { 1168 | "node": ">=6.9.0" 1169 | } 1170 | }, 1171 | "node_modules/gh-pages": { 1172 | "version": "5.0.0", 1173 | "resolved": "https://registry.npmjs.org/gh-pages/-/gh-pages-5.0.0.tgz", 1174 | "integrity": "sha512-Nqp1SjkPIB94Xw/3yYNTUL+G2dxlhjvv1zeN/4kMC1jfViTEqhtVz/Ba1zSXHuvXCN9ADNS1dN4r5/J/nZWEQQ==", 1175 | "dev": true, 1176 | "dependencies": { 1177 | "async": "^3.2.4", 1178 | "commander": "^2.18.0", 1179 | "email-addresses": "^5.0.0", 1180 | "filenamify": "^4.3.0", 1181 | "find-cache-dir": "^3.3.1", 1182 | "fs-extra": "^8.1.0", 1183 | "globby": "^6.1.0" 1184 | }, 1185 | "bin": { 1186 | "gh-pages": "bin/gh-pages.js", 1187 | "gh-pages-clean": "bin/gh-pages-clean.js" 1188 | }, 1189 | "engines": { 1190 | "node": ">=10" 1191 | } 1192 | }, 1193 | "node_modules/glob": { 1194 | "version": "7.2.3", 1195 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1196 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1197 | "dev": true, 1198 | "dependencies": { 1199 | "fs.realpath": "^1.0.0", 1200 | "inflight": "^1.0.4", 1201 | "inherits": "2", 1202 | "minimatch": "^3.1.1", 1203 | "once": "^1.3.0", 1204 | "path-is-absolute": "^1.0.0" 1205 | }, 1206 | "engines": { 1207 | "node": "*" 1208 | }, 1209 | "funding": { 1210 | "url": "https://github.com/sponsors/isaacs" 1211 | } 1212 | }, 1213 | "node_modules/globals": { 1214 | "version": "11.12.0", 1215 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1216 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1217 | "dev": true, 1218 | "engines": { 1219 | "node": ">=4" 1220 | } 1221 | }, 1222 | "node_modules/globby": { 1223 | "version": "6.1.0", 1224 | "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", 1225 | "integrity": "sha512-KVbFv2TQtbzCoxAnfD6JcHZTYCzyliEaaeM/gH8qQdkKr5s0OP9scEgvdcngyk7AVdY6YVW/TJHd+lQ/Df3Daw==", 1226 | "dev": true, 1227 | "dependencies": { 1228 | "array-union": "^1.0.1", 1229 | "glob": "^7.0.3", 1230 | "object-assign": "^4.0.1", 1231 | "pify": "^2.0.0", 1232 | "pinkie-promise": "^2.0.0" 1233 | }, 1234 | "engines": { 1235 | "node": ">=0.10.0" 1236 | } 1237 | }, 1238 | "node_modules/graceful-fs": { 1239 | "version": "4.2.11", 1240 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1241 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1242 | "dev": true 1243 | }, 1244 | "node_modules/has-flag": { 1245 | "version": "3.0.0", 1246 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1247 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1248 | "dev": true, 1249 | "engines": { 1250 | "node": ">=4" 1251 | } 1252 | }, 1253 | "node_modules/inflight": { 1254 | "version": "1.0.6", 1255 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1256 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1257 | "dev": true, 1258 | "dependencies": { 1259 | "once": "^1.3.0", 1260 | "wrappy": "1" 1261 | } 1262 | }, 1263 | "node_modules/inherits": { 1264 | "version": "2.0.4", 1265 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1266 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1267 | "dev": true 1268 | }, 1269 | "node_modules/js-tokens": { 1270 | "version": "4.0.0", 1271 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1272 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 1273 | }, 1274 | "node_modules/jsesc": { 1275 | "version": "2.5.2", 1276 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1277 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1278 | "dev": true, 1279 | "bin": { 1280 | "jsesc": "bin/jsesc" 1281 | }, 1282 | "engines": { 1283 | "node": ">=4" 1284 | } 1285 | }, 1286 | "node_modules/json5": { 1287 | "version": "2.2.3", 1288 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 1289 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 1290 | "dev": true, 1291 | "bin": { 1292 | "json5": "lib/cli.js" 1293 | }, 1294 | "engines": { 1295 | "node": ">=6" 1296 | } 1297 | }, 1298 | "node_modules/jsonfile": { 1299 | "version": "4.0.0", 1300 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 1301 | "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", 1302 | "dev": true, 1303 | "optionalDependencies": { 1304 | "graceful-fs": "^4.1.6" 1305 | } 1306 | }, 1307 | "node_modules/locate-path": { 1308 | "version": "5.0.0", 1309 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 1310 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 1311 | "dev": true, 1312 | "dependencies": { 1313 | "p-locate": "^4.1.0" 1314 | }, 1315 | "engines": { 1316 | "node": ">=8" 1317 | } 1318 | }, 1319 | "node_modules/loose-envify": { 1320 | "version": "1.4.0", 1321 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1322 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1323 | "dependencies": { 1324 | "js-tokens": "^3.0.0 || ^4.0.0" 1325 | }, 1326 | "bin": { 1327 | "loose-envify": "cli.js" 1328 | } 1329 | }, 1330 | "node_modules/lru-cache": { 1331 | "version": "5.1.1", 1332 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 1333 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 1334 | "dev": true, 1335 | "dependencies": { 1336 | "yallist": "^3.0.2" 1337 | } 1338 | }, 1339 | "node_modules/magic-string": { 1340 | "version": "0.27.0", 1341 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.27.0.tgz", 1342 | "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==", 1343 | "dev": true, 1344 | "dependencies": { 1345 | "@jridgewell/sourcemap-codec": "^1.4.13" 1346 | }, 1347 | "engines": { 1348 | "node": ">=12" 1349 | } 1350 | }, 1351 | "node_modules/make-dir": { 1352 | "version": "3.1.0", 1353 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1354 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1355 | "dev": true, 1356 | "dependencies": { 1357 | "semver": "^6.0.0" 1358 | }, 1359 | "engines": { 1360 | "node": ">=8" 1361 | }, 1362 | "funding": { 1363 | "url": "https://github.com/sponsors/sindresorhus" 1364 | } 1365 | }, 1366 | "node_modules/minimatch": { 1367 | "version": "3.1.2", 1368 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1369 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1370 | "dev": true, 1371 | "dependencies": { 1372 | "brace-expansion": "^1.1.7" 1373 | }, 1374 | "engines": { 1375 | "node": "*" 1376 | } 1377 | }, 1378 | "node_modules/ms": { 1379 | "version": "2.1.2", 1380 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1381 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1382 | "dev": true 1383 | }, 1384 | "node_modules/nanoid": { 1385 | "version": "3.3.6", 1386 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 1387 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 1388 | "dev": true, 1389 | "funding": [ 1390 | { 1391 | "type": "github", 1392 | "url": "https://github.com/sponsors/ai" 1393 | } 1394 | ], 1395 | "bin": { 1396 | "nanoid": "bin/nanoid.cjs" 1397 | }, 1398 | "engines": { 1399 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1400 | } 1401 | }, 1402 | "node_modules/node-releases": { 1403 | "version": "2.0.13", 1404 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", 1405 | "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==", 1406 | "dev": true 1407 | }, 1408 | "node_modules/object-assign": { 1409 | "version": "4.1.1", 1410 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1411 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 1412 | "dev": true, 1413 | "engines": { 1414 | "node": ">=0.10.0" 1415 | } 1416 | }, 1417 | "node_modules/once": { 1418 | "version": "1.4.0", 1419 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1420 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1421 | "dev": true, 1422 | "dependencies": { 1423 | "wrappy": "1" 1424 | } 1425 | }, 1426 | "node_modules/p-limit": { 1427 | "version": "2.3.0", 1428 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 1429 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 1430 | "dev": true, 1431 | "dependencies": { 1432 | "p-try": "^2.0.0" 1433 | }, 1434 | "engines": { 1435 | "node": ">=6" 1436 | }, 1437 | "funding": { 1438 | "url": "https://github.com/sponsors/sindresorhus" 1439 | } 1440 | }, 1441 | "node_modules/p-locate": { 1442 | "version": "4.1.0", 1443 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 1444 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 1445 | "dev": true, 1446 | "dependencies": { 1447 | "p-limit": "^2.2.0" 1448 | }, 1449 | "engines": { 1450 | "node": ">=8" 1451 | } 1452 | }, 1453 | "node_modules/p-try": { 1454 | "version": "2.2.0", 1455 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1456 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1457 | "dev": true, 1458 | "engines": { 1459 | "node": ">=6" 1460 | } 1461 | }, 1462 | "node_modules/path-exists": { 1463 | "version": "4.0.0", 1464 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1465 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1466 | "dev": true, 1467 | "engines": { 1468 | "node": ">=8" 1469 | } 1470 | }, 1471 | "node_modules/path-is-absolute": { 1472 | "version": "1.0.1", 1473 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1474 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1475 | "dev": true, 1476 | "engines": { 1477 | "node": ">=0.10.0" 1478 | } 1479 | }, 1480 | "node_modules/picocolors": { 1481 | "version": "1.0.0", 1482 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1483 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 1484 | "dev": true 1485 | }, 1486 | "node_modules/pify": { 1487 | "version": "2.3.0", 1488 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1489 | "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", 1490 | "dev": true, 1491 | "engines": { 1492 | "node": ">=0.10.0" 1493 | } 1494 | }, 1495 | "node_modules/pinkie": { 1496 | "version": "2.0.4", 1497 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1498 | "integrity": "sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg==", 1499 | "dev": true, 1500 | "engines": { 1501 | "node": ">=0.10.0" 1502 | } 1503 | }, 1504 | "node_modules/pinkie-promise": { 1505 | "version": "2.0.1", 1506 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1507 | "integrity": "sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw==", 1508 | "dev": true, 1509 | "dependencies": { 1510 | "pinkie": "^2.0.0" 1511 | }, 1512 | "engines": { 1513 | "node": ">=0.10.0" 1514 | } 1515 | }, 1516 | "node_modules/pkg-dir": { 1517 | "version": "4.2.0", 1518 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 1519 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "find-up": "^4.0.0" 1523 | }, 1524 | "engines": { 1525 | "node": ">=8" 1526 | } 1527 | }, 1528 | "node_modules/postcss": { 1529 | "version": "8.4.27", 1530 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.27.tgz", 1531 | "integrity": "sha512-gY/ACJtJPSmUFPDCHtX78+01fHa64FaU4zaaWfuh1MhGJISufJAH4cun6k/8fwsHYeK4UQmENQK+tRLCFJE8JQ==", 1532 | "dev": true, 1533 | "funding": [ 1534 | { 1535 | "type": "opencollective", 1536 | "url": "https://opencollective.com/postcss/" 1537 | }, 1538 | { 1539 | "type": "tidelift", 1540 | "url": "https://tidelift.com/funding/github/npm/postcss" 1541 | }, 1542 | { 1543 | "type": "github", 1544 | "url": "https://github.com/sponsors/ai" 1545 | } 1546 | ], 1547 | "dependencies": { 1548 | "nanoid": "^3.3.6", 1549 | "picocolors": "^1.0.0", 1550 | "source-map-js": "^1.0.2" 1551 | }, 1552 | "engines": { 1553 | "node": "^10 || ^12 || >=14" 1554 | } 1555 | }, 1556 | "node_modules/react": { 1557 | "version": "18.2.0", 1558 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 1559 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 1560 | "dependencies": { 1561 | "loose-envify": "^1.1.0" 1562 | }, 1563 | "engines": { 1564 | "node": ">=0.10.0" 1565 | } 1566 | }, 1567 | "node_modules/react-dom": { 1568 | "version": "18.2.0", 1569 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 1570 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 1571 | "dependencies": { 1572 | "loose-envify": "^1.1.0", 1573 | "scheduler": "^0.23.0" 1574 | }, 1575 | "peerDependencies": { 1576 | "react": "^18.2.0" 1577 | } 1578 | }, 1579 | "node_modules/react-hook-form": { 1580 | "version": "7.45.2", 1581 | "resolved": "https://registry.npmjs.org/react-hook-form/-/react-hook-form-7.45.2.tgz", 1582 | "integrity": "sha512-9s45OdTaKN+4NSTbXVqeDITd/nwIg++nxJGL8+OD5uf1DxvhsXQ641kaYHk5K28cpIOTYm71O/fYk7rFaygb3A==", 1583 | "engines": { 1584 | "node": ">=12.22.0" 1585 | }, 1586 | "funding": { 1587 | "type": "opencollective", 1588 | "url": "https://opencollective.com/react-hook-form" 1589 | }, 1590 | "peerDependencies": { 1591 | "react": "^16.8.0 || ^17 || ^18" 1592 | } 1593 | }, 1594 | "node_modules/react-refresh": { 1595 | "version": "0.14.0", 1596 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 1597 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 1598 | "dev": true, 1599 | "engines": { 1600 | "node": ">=0.10.0" 1601 | } 1602 | }, 1603 | "node_modules/rollup": { 1604 | "version": "3.26.3", 1605 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.26.3.tgz", 1606 | "integrity": "sha512-7Tin0C8l86TkpcMtXvQu6saWH93nhG3dGQ1/+l5V2TDMceTxO7kDiK6GzbfLWNNxqJXm591PcEZUozZm51ogwQ==", 1607 | "dev": true, 1608 | "bin": { 1609 | "rollup": "dist/bin/rollup" 1610 | }, 1611 | "engines": { 1612 | "node": ">=14.18.0", 1613 | "npm": ">=8.0.0" 1614 | }, 1615 | "optionalDependencies": { 1616 | "fsevents": "~2.3.2" 1617 | } 1618 | }, 1619 | "node_modules/scheduler": { 1620 | "version": "0.23.0", 1621 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 1622 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 1623 | "dependencies": { 1624 | "loose-envify": "^1.1.0" 1625 | } 1626 | }, 1627 | "node_modules/semver": { 1628 | "version": "6.3.1", 1629 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 1630 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 1631 | "dev": true, 1632 | "bin": { 1633 | "semver": "bin/semver.js" 1634 | } 1635 | }, 1636 | "node_modules/source-map-js": { 1637 | "version": "1.0.2", 1638 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 1639 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 1640 | "dev": true, 1641 | "engines": { 1642 | "node": ">=0.10.0" 1643 | } 1644 | }, 1645 | "node_modules/strip-outer": { 1646 | "version": "1.0.1", 1647 | "resolved": "https://registry.npmjs.org/strip-outer/-/strip-outer-1.0.1.tgz", 1648 | "integrity": "sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==", 1649 | "dev": true, 1650 | "dependencies": { 1651 | "escape-string-regexp": "^1.0.2" 1652 | }, 1653 | "engines": { 1654 | "node": ">=0.10.0" 1655 | } 1656 | }, 1657 | "node_modules/supports-color": { 1658 | "version": "5.5.0", 1659 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1660 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1661 | "dev": true, 1662 | "dependencies": { 1663 | "has-flag": "^3.0.0" 1664 | }, 1665 | "engines": { 1666 | "node": ">=4" 1667 | } 1668 | }, 1669 | "node_modules/to-fast-properties": { 1670 | "version": "2.0.0", 1671 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 1672 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 1673 | "dev": true, 1674 | "engines": { 1675 | "node": ">=4" 1676 | } 1677 | }, 1678 | "node_modules/trim-repeated": { 1679 | "version": "1.0.0", 1680 | "resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz", 1681 | "integrity": "sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==", 1682 | "dev": true, 1683 | "dependencies": { 1684 | "escape-string-regexp": "^1.0.2" 1685 | }, 1686 | "engines": { 1687 | "node": ">=0.10.0" 1688 | } 1689 | }, 1690 | "node_modules/universalify": { 1691 | "version": "0.1.2", 1692 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1693 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1694 | "dev": true, 1695 | "engines": { 1696 | "node": ">= 4.0.0" 1697 | } 1698 | }, 1699 | "node_modules/update-browserslist-db": { 1700 | "version": "1.0.11", 1701 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", 1702 | "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", 1703 | "dev": true, 1704 | "funding": [ 1705 | { 1706 | "type": "opencollective", 1707 | "url": "https://opencollective.com/browserslist" 1708 | }, 1709 | { 1710 | "type": "tidelift", 1711 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1712 | }, 1713 | { 1714 | "type": "github", 1715 | "url": "https://github.com/sponsors/ai" 1716 | } 1717 | ], 1718 | "dependencies": { 1719 | "escalade": "^3.1.1", 1720 | "picocolors": "^1.0.0" 1721 | }, 1722 | "bin": { 1723 | "update-browserslist-db": "cli.js" 1724 | }, 1725 | "peerDependencies": { 1726 | "browserslist": ">= 4.21.0" 1727 | } 1728 | }, 1729 | "node_modules/vite": { 1730 | "version": "4.4.7", 1731 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.4.7.tgz", 1732 | "integrity": "sha512-6pYf9QJ1mHylfVh39HpuSfMPojPSKVxZvnclX1K1FyZ1PXDOcLBibdq5t1qxJSnL63ca8Wf4zts6mD8u8oc9Fw==", 1733 | "dev": true, 1734 | "dependencies": { 1735 | "esbuild": "^0.18.10", 1736 | "postcss": "^8.4.26", 1737 | "rollup": "^3.25.2" 1738 | }, 1739 | "bin": { 1740 | "vite": "bin/vite.js" 1741 | }, 1742 | "engines": { 1743 | "node": "^14.18.0 || >=16.0.0" 1744 | }, 1745 | "funding": { 1746 | "url": "https://github.com/vitejs/vite?sponsor=1" 1747 | }, 1748 | "optionalDependencies": { 1749 | "fsevents": "~2.3.2" 1750 | }, 1751 | "peerDependencies": { 1752 | "@types/node": ">= 14", 1753 | "less": "*", 1754 | "lightningcss": "^1.21.0", 1755 | "sass": "*", 1756 | "stylus": "*", 1757 | "sugarss": "*", 1758 | "terser": "^5.4.0" 1759 | }, 1760 | "peerDependenciesMeta": { 1761 | "@types/node": { 1762 | "optional": true 1763 | }, 1764 | "less": { 1765 | "optional": true 1766 | }, 1767 | "lightningcss": { 1768 | "optional": true 1769 | }, 1770 | "sass": { 1771 | "optional": true 1772 | }, 1773 | "stylus": { 1774 | "optional": true 1775 | }, 1776 | "sugarss": { 1777 | "optional": true 1778 | }, 1779 | "terser": { 1780 | "optional": true 1781 | } 1782 | } 1783 | }, 1784 | "node_modules/wrappy": { 1785 | "version": "1.0.2", 1786 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1787 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 1788 | "dev": true 1789 | }, 1790 | "node_modules/yallist": { 1791 | "version": "3.1.1", 1792 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 1793 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 1794 | "dev": true 1795 | } 1796 | } 1797 | } 1798 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-hook-form-tutorial", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "preview": "vite preview", 10 | "deploy": "gh-pages -d dist" 11 | }, 12 | "dependencies": { 13 | "react": "^18.2.0", 14 | "react-dom": "^18.2.0", 15 | "react-hook-form": "^7.45.2" 16 | }, 17 | "devDependencies": { 18 | "@types/react": "^18.0.26", 19 | "@types/react-dom": "^18.0.9", 20 | "@vitejs/plugin-react": "^3.0.0", 21 | "gh-pages": "^5.0.0", 22 | "vite": "^4.0.0" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/fazt/react-hook-form-tutorial/71fb27ee18b43abfbdd979ec45e9d6ee71208c2a/src/App.css -------------------------------------------------------------------------------- /src/App.jsx: -------------------------------------------------------------------------------- 1 | import { useRef } from "react"; 2 | import { useForm } from "react-hook-form"; 3 | 4 | function Formulario() { 5 | const { 6 | register, 7 | handleSubmit, 8 | formState: { errors }, 9 | watch, 10 | setValue, 11 | reset, 12 | } = useForm({ 13 | defaultValues: { 14 | nombre: "", 15 | correo: "", 16 | fechaNacimiento: "", 17 | password: "", 18 | confirmarPassword: "", 19 | pais: "co", 20 | archivo: "", 21 | aceptaTerminos: false, 22 | }, 23 | }); 24 | 25 | const password = useRef(null); 26 | password.current = watch("password", ""); 27 | 28 | const onSubmit = handleSubmit((data) => { 29 | console.log(data); 30 | // reset({ 31 | // nombre: '', 32 | // correo: '', 33 | // fechaNacimiento: '', 34 | // password: '', 35 | // confirmarPassword: '', 36 | // pais: 'ar', 37 | // archivo: '', 38 | // aceptaTerminos: false 39 | // }) 40 | reset(); 41 | }); 42 | 43 | return ( 44 |
45 |
46 | 47 | 59 | {errors.nombre?.type === "required" && Nombre requerido} 60 | {errors.nombre?.type === "maxLength" && ( 61 | Nombre no debe ser mayor a 20 caracteres 62 | )} 63 | {errors.nombre?.type === "minLength" && ( 64 | Nombre debe ser mayor a 2 caracteres 65 | )} 66 |
67 | 68 |
69 | 70 | 84 | {errors.correo && {errors.correo.message}} 85 |
86 | 87 |
88 | 89 | { 98 | const fechaNacimiento = new Date(value); 99 | const fechaActual = new Date(); 100 | const edad = 101 | fechaActual.getFullYear() - fechaNacimiento.getFullYear(); 102 | return edad >= 18 || "Debes ser mayor de edad"; 103 | }, 104 | })} 105 | /> 106 | {errors.fechaNacimiento && ( 107 | {errors.fechaNacimiento.message} 108 | )} 109 |
110 | 111 |
112 | 113 | 127 | {errors.password && {errors.password.message}} 128 |
129 | 130 |
131 | 132 | 145 | value === password.current || "Las contraseñas no coinciden", 146 | })} 147 | /> 148 | {errors.confirmarPassword && ( 149 | {errors.confirmarPassword.message} 150 | )} 151 |
152 | 153 |
154 | 155 | 160 | 161 | {watch("pais") === "ar" && ( 162 | 172 | )} 173 |
174 | 175 |
176 | 177 | { 180 | setValue("archivo", e.target.files[0].name); 181 | }} 182 | /> 183 | {errors.archivo && {errors.archivo.message}} 184 |
185 | 186 |
187 | 197 | 198 | {errors.aceptaTerminos && {errors.aceptaTerminos.message}} 199 |
200 | 201 | 202 | 203 |
{JSON.stringify(watch(), null, 2)}
204 |

Hello {watch("nombre")}

205 |
206 | ); 207 | } 208 | 209 | export default Formulario; 210 | -------------------------------------------------------------------------------- /src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- 1 | body { 2 | background: #101010; 3 | color: white; 4 | display: flex; 5 | justify-content: center; 6 | align-items: center; 7 | min-height: 100vh; 8 | } 9 | 10 | label { 11 | display: block; 12 | } 13 | 14 | span { 15 | display: block; 16 | color: tomato; 17 | font-size: x-small; 18 | } 19 | 20 | input { 21 | margin-bottom: .3rem; 22 | } -------------------------------------------------------------------------------- /src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react' 2 | import ReactDOM from 'react-dom/client' 3 | import App from './App' 4 | import './index.css' 5 | 6 | ReactDOM.createRoot(document.getElementById('root')).render( 7 | 8 | 9 | , 10 | ) 11 | -------------------------------------------------------------------------------- /vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | base: process.env.NODE_ENV !== 'development' ? '/react-hook-form-tutorial/' : '/', 8 | }) 9 | --------------------------------------------------------------------------------