├── Lista-Contactos ├── .gitignore ├── README.md ├── eslint.config.js ├── 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 ├── README.md ├── carrito-compras ├── .gitignore ├── README.md ├── eslint.config.js ├── index.html ├── package-lock.json ├── package.json ├── public │ └── vite.svg ├── src │ ├── App.css │ ├── App.jsx │ ├── assets │ │ ├── img.jpg │ │ └── react.svg │ ├── index.css │ └── main.jsx └── vite.config.js └── img.png /Lista-Contactos/.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 | -------------------------------------------------------------------------------- /Lista-Contactos/README.md: -------------------------------------------------------------------------------- 1 | # Plantilla Base React + Vite + Tailwind CSS v4 🚀 2 | 3 | Usa esta plantilla para arrancar proyectos rápido. Ya viene con: 4 | - React 5 | - Vite 6 | - TailwindCSS v4 7 | - Estructura ordenada 8 | 9 | ## Uso 10 | 11 | ```bash 12 | cp -r plantilla-base mi-nuevo-proyecto 13 | cd mi-nuevo-proyecto 14 | npm install 15 | npm run dev 16 | -------------------------------------------------------------------------------- /Lista-Contactos/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 | 6 | export default [ 7 | { ignores: ['dist'] }, 8 | { 9 | files: ['**/*.{js,jsx}'], 10 | languageOptions: { 11 | ecmaVersion: 2020, 12 | globals: globals.browser, 13 | parserOptions: { 14 | ecmaVersion: 'latest', 15 | ecmaFeatures: { jsx: true }, 16 | sourceType: 'module', 17 | }, 18 | }, 19 | plugins: { 20 | 'react-hooks': reactHooks, 21 | 'react-refresh': reactRefresh, 22 | }, 23 | rules: { 24 | ...js.configs.recommended.rules, 25 | ...reactHooks.configs.recommended.rules, 26 | 'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }], 27 | 'react-refresh/only-export-components': [ 28 | 'warn', 29 | { allowConstantExport: true }, 30 | ], 31 | }, 32 | }, 33 | ] 34 | -------------------------------------------------------------------------------- /Lista-Contactos/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /Lista-Contactos/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "plantilla-base", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "plantilla-base", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "@tailwindcss/vite": "^4.1.3", 12 | "react": "^19.0.0", 13 | "react-dom": "^19.0.0", 14 | "tailwindcss": "^4.1.3" 15 | }, 16 | "devDependencies": { 17 | "@eslint/js": "^9.21.0", 18 | "@types/react": "^19.0.10", 19 | "@types/react-dom": "^19.0.4", 20 | "@vitejs/plugin-react": "^4.3.4", 21 | "eslint": "^9.21.0", 22 | "eslint-plugin-react-hooks": "^5.1.0", 23 | "eslint-plugin-react-refresh": "^0.4.19", 24 | "globals": "^15.15.0", 25 | "vite": "^6.2.0" 26 | } 27 | }, 28 | "node_modules/@ampproject/remapping": { 29 | "version": "2.3.0", 30 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", 31 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", 32 | "dev": true, 33 | "dependencies": { 34 | "@jridgewell/gen-mapping": "^0.3.5", 35 | "@jridgewell/trace-mapping": "^0.3.24" 36 | }, 37 | "engines": { 38 | "node": ">=6.0.0" 39 | } 40 | }, 41 | "node_modules/@babel/code-frame": { 42 | "version": "7.26.2", 43 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz", 44 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==", 45 | "dev": true, 46 | "dependencies": { 47 | "@babel/helper-validator-identifier": "^7.25.9", 48 | "js-tokens": "^4.0.0", 49 | "picocolors": "^1.0.0" 50 | }, 51 | "engines": { 52 | "node": ">=6.9.0" 53 | } 54 | }, 55 | "node_modules/@babel/compat-data": { 56 | "version": "7.26.8", 57 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.26.8.tgz", 58 | "integrity": "sha512-oH5UPLMWR3L2wEFLnFJ1TZXqHufiTKAiLfqw5zkhS4dKXLJ10yVztfil/twG8EDTA4F/tvVNw9nOl4ZMslB8rQ==", 59 | "dev": true, 60 | "engines": { 61 | "node": ">=6.9.0" 62 | } 63 | }, 64 | "node_modules/@babel/core": { 65 | "version": "7.26.10", 66 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.26.10.tgz", 67 | "integrity": "sha512-vMqyb7XCDMPvJFFOaT9kxtiRh42GwlZEg1/uIgtZshS5a/8OaduUfCi7kynKgc3Tw/6Uo2D+db9qBttghhmxwQ==", 68 | "dev": true, 69 | "dependencies": { 70 | "@ampproject/remapping": "^2.2.0", 71 | "@babel/code-frame": "^7.26.2", 72 | "@babel/generator": "^7.26.10", 73 | "@babel/helper-compilation-targets": "^7.26.5", 74 | "@babel/helper-module-transforms": "^7.26.0", 75 | "@babel/helpers": "^7.26.10", 76 | "@babel/parser": "^7.26.10", 77 | "@babel/template": "^7.26.9", 78 | "@babel/traverse": "^7.26.10", 79 | "@babel/types": "^7.26.10", 80 | "convert-source-map": "^2.0.0", 81 | "debug": "^4.1.0", 82 | "gensync": "^1.0.0-beta.2", 83 | "json5": "^2.2.3", 84 | "semver": "^6.3.1" 85 | }, 86 | "engines": { 87 | "node": ">=6.9.0" 88 | }, 89 | "funding": { 90 | "type": "opencollective", 91 | "url": "https://opencollective.com/babel" 92 | } 93 | }, 94 | "node_modules/@babel/generator": { 95 | "version": "7.27.0", 96 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.27.0.tgz", 97 | "integrity": "sha512-VybsKvpiN1gU1sdMZIp7FcqphVVKEwcuj02x73uvcHE0PTihx1nlBcowYWhDwjpoAXRv43+gDzyggGnn1XZhVw==", 98 | "dev": true, 99 | "dependencies": { 100 | "@babel/parser": "^7.27.0", 101 | "@babel/types": "^7.27.0", 102 | "@jridgewell/gen-mapping": "^0.3.5", 103 | "@jridgewell/trace-mapping": "^0.3.25", 104 | "jsesc": "^3.0.2" 105 | }, 106 | "engines": { 107 | "node": ">=6.9.0" 108 | } 109 | }, 110 | "node_modules/@babel/helper-compilation-targets": { 111 | "version": "7.27.0", 112 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.27.0.tgz", 113 | "integrity": "sha512-LVk7fbXml0H2xH34dFzKQ7TDZ2G4/rVTOrq9V+icbbadjbVxxeFeDsNHv2SrZeWoA+6ZiTyWYWtScEIW07EAcA==", 114 | "dev": true, 115 | "dependencies": { 116 | "@babel/compat-data": "^7.26.8", 117 | "@babel/helper-validator-option": "^7.25.9", 118 | "browserslist": "^4.24.0", 119 | "lru-cache": "^5.1.1", 120 | "semver": "^6.3.1" 121 | }, 122 | "engines": { 123 | "node": ">=6.9.0" 124 | } 125 | }, 126 | "node_modules/@babel/helper-module-imports": { 127 | "version": "7.25.9", 128 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz", 129 | "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==", 130 | "dev": true, 131 | "dependencies": { 132 | "@babel/traverse": "^7.25.9", 133 | "@babel/types": "^7.25.9" 134 | }, 135 | "engines": { 136 | "node": ">=6.9.0" 137 | } 138 | }, 139 | "node_modules/@babel/helper-module-transforms": { 140 | "version": "7.26.0", 141 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz", 142 | "integrity": "sha512-xO+xu6B5K2czEnQye6BHA7DolFFmS3LB7stHZFaOLb1pAwO1HWLS8fXA+eh0A2yIvltPVmx3eNNDBJA2SLHXFw==", 143 | "dev": true, 144 | "dependencies": { 145 | "@babel/helper-module-imports": "^7.25.9", 146 | "@babel/helper-validator-identifier": "^7.25.9", 147 | "@babel/traverse": "^7.25.9" 148 | }, 149 | "engines": { 150 | "node": ">=6.9.0" 151 | }, 152 | "peerDependencies": { 153 | "@babel/core": "^7.0.0" 154 | } 155 | }, 156 | "node_modules/@babel/helper-plugin-utils": { 157 | "version": "7.26.5", 158 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.26.5.tgz", 159 | "integrity": "sha512-RS+jZcRdZdRFzMyr+wcsaqOmld1/EqTghfaBGQQd/WnRdzdlvSZ//kF7U8VQTxf1ynZ4cjUcYgjVGx13ewNPMg==", 160 | "dev": true, 161 | "engines": { 162 | "node": ">=6.9.0" 163 | } 164 | }, 165 | "node_modules/@babel/helper-string-parser": { 166 | "version": "7.25.9", 167 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz", 168 | "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==", 169 | "dev": true, 170 | "engines": { 171 | "node": ">=6.9.0" 172 | } 173 | }, 174 | "node_modules/@babel/helper-validator-identifier": { 175 | "version": "7.25.9", 176 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", 177 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", 178 | "dev": true, 179 | "engines": { 180 | "node": ">=6.9.0" 181 | } 182 | }, 183 | "node_modules/@babel/helper-validator-option": { 184 | "version": "7.25.9", 185 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.9.tgz", 186 | "integrity": "sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw==", 187 | "dev": true, 188 | "engines": { 189 | "node": ">=6.9.0" 190 | } 191 | }, 192 | "node_modules/@babel/helpers": { 193 | "version": "7.27.0", 194 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.27.0.tgz", 195 | "integrity": "sha512-U5eyP/CTFPuNE3qk+WZMxFkp/4zUzdceQlfzf7DdGdhp+Fezd7HD+i8Y24ZuTMKX3wQBld449jijbGq6OdGNQg==", 196 | "dev": true, 197 | "dependencies": { 198 | "@babel/template": "^7.27.0", 199 | "@babel/types": "^7.27.0" 200 | }, 201 | "engines": { 202 | "node": ">=6.9.0" 203 | } 204 | }, 205 | "node_modules/@babel/parser": { 206 | "version": "7.27.0", 207 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.27.0.tgz", 208 | "integrity": "sha512-iaepho73/2Pz7w2eMS0Q5f83+0RKI7i4xmiYeBmDzfRVbQtTOG7Ts0S4HzJVsTMGI9keU8rNfuZr8DKfSt7Yyg==", 209 | "dev": true, 210 | "dependencies": { 211 | "@babel/types": "^7.27.0" 212 | }, 213 | "bin": { 214 | "parser": "bin/babel-parser.js" 215 | }, 216 | "engines": { 217 | "node": ">=6.0.0" 218 | } 219 | }, 220 | "node_modules/@babel/plugin-transform-react-jsx-self": { 221 | "version": "7.25.9", 222 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.25.9.tgz", 223 | "integrity": "sha512-y8quW6p0WHkEhmErnfe58r7x0A70uKphQm8Sp8cV7tjNQwK56sNVK0M73LK3WuYmsuyrftut4xAkjjgU0twaMg==", 224 | "dev": true, 225 | "dependencies": { 226 | "@babel/helper-plugin-utils": "^7.25.9" 227 | }, 228 | "engines": { 229 | "node": ">=6.9.0" 230 | }, 231 | "peerDependencies": { 232 | "@babel/core": "^7.0.0-0" 233 | } 234 | }, 235 | "node_modules/@babel/plugin-transform-react-jsx-source": { 236 | "version": "7.25.9", 237 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.25.9.tgz", 238 | "integrity": "sha512-+iqjT8xmXhhYv4/uiYd8FNQsraMFZIfxVSqxxVSZP0WbbSAWvBXAul0m/zu+7Vv4O/3WtApy9pmaTMiumEZgfg==", 239 | "dev": true, 240 | "dependencies": { 241 | "@babel/helper-plugin-utils": "^7.25.9" 242 | }, 243 | "engines": { 244 | "node": ">=6.9.0" 245 | }, 246 | "peerDependencies": { 247 | "@babel/core": "^7.0.0-0" 248 | } 249 | }, 250 | "node_modules/@babel/template": { 251 | "version": "7.27.0", 252 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.27.0.tgz", 253 | "integrity": "sha512-2ncevenBqXI6qRMukPlXwHKHchC7RyMuu4xv5JBXRfOGVcTy1mXCD12qrp7Jsoxll1EV3+9sE4GugBVRjT2jFA==", 254 | "dev": true, 255 | "dependencies": { 256 | "@babel/code-frame": "^7.26.2", 257 | "@babel/parser": "^7.27.0", 258 | "@babel/types": "^7.27.0" 259 | }, 260 | "engines": { 261 | "node": ">=6.9.0" 262 | } 263 | }, 264 | "node_modules/@babel/traverse": { 265 | "version": "7.27.0", 266 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.27.0.tgz", 267 | "integrity": "sha512-19lYZFzYVQkkHkl4Cy4WrAVcqBkgvV2YM2TU3xG6DIwO7O3ecbDPfW3yM3bjAGcqcQHi+CCtjMR3dIEHxsd6bA==", 268 | "dev": true, 269 | "dependencies": { 270 | "@babel/code-frame": "^7.26.2", 271 | "@babel/generator": "^7.27.0", 272 | "@babel/parser": "^7.27.0", 273 | "@babel/template": "^7.27.0", 274 | "@babel/types": "^7.27.0", 275 | "debug": "^4.3.1", 276 | "globals": "^11.1.0" 277 | }, 278 | "engines": { 279 | "node": ">=6.9.0" 280 | } 281 | }, 282 | "node_modules/@babel/traverse/node_modules/globals": { 283 | "version": "11.12.0", 284 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 285 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 286 | "dev": true, 287 | "engines": { 288 | "node": ">=4" 289 | } 290 | }, 291 | "node_modules/@babel/types": { 292 | "version": "7.27.0", 293 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.27.0.tgz", 294 | "integrity": "sha512-H45s8fVLYjbhFH62dIJ3WtmJ6RSPt/3DRO0ZcT2SUiYiQyz3BLVb9ADEnLl91m74aQPS3AzzeajZHYOalWe3bg==", 295 | "dev": true, 296 | "dependencies": { 297 | "@babel/helper-string-parser": "^7.25.9", 298 | "@babel/helper-validator-identifier": "^7.25.9" 299 | }, 300 | "engines": { 301 | "node": ">=6.9.0" 302 | } 303 | }, 304 | "node_modules/@esbuild/aix-ppc64": { 305 | "version": "0.25.2", 306 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.2.tgz", 307 | "integrity": "sha512-wCIboOL2yXZym2cgm6mlA742s9QeJ8DjGVaL39dLN4rRwrOgOyYSnOaFPhKZGLb2ngj4EyfAFjsNJwPXZvseag==", 308 | "cpu": [ 309 | "ppc64" 310 | ], 311 | "optional": true, 312 | "os": [ 313 | "aix" 314 | ], 315 | "engines": { 316 | "node": ">=18" 317 | } 318 | }, 319 | "node_modules/@esbuild/android-arm": { 320 | "version": "0.25.2", 321 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.2.tgz", 322 | "integrity": "sha512-NQhH7jFstVY5x8CKbcfa166GoV0EFkaPkCKBQkdPJFvo5u+nGXLEH/ooniLb3QI8Fk58YAx7nsPLozUWfCBOJA==", 323 | "cpu": [ 324 | "arm" 325 | ], 326 | "optional": true, 327 | "os": [ 328 | "android" 329 | ], 330 | "engines": { 331 | "node": ">=18" 332 | } 333 | }, 334 | "node_modules/@esbuild/android-arm64": { 335 | "version": "0.25.2", 336 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.2.tgz", 337 | "integrity": "sha512-5ZAX5xOmTligeBaeNEPnPaeEuah53Id2tX4c2CVP3JaROTH+j4fnfHCkr1PjXMd78hMst+TlkfKcW/DlTq0i4w==", 338 | "cpu": [ 339 | "arm64" 340 | ], 341 | "optional": true, 342 | "os": [ 343 | "android" 344 | ], 345 | "engines": { 346 | "node": ">=18" 347 | } 348 | }, 349 | "node_modules/@esbuild/android-x64": { 350 | "version": "0.25.2", 351 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.2.tgz", 352 | "integrity": "sha512-Ffcx+nnma8Sge4jzddPHCZVRvIfQ0kMsUsCMcJRHkGJ1cDmhe4SsrYIjLUKn1xpHZybmOqCWwB0zQvsjdEHtkg==", 353 | "cpu": [ 354 | "x64" 355 | ], 356 | "optional": true, 357 | "os": [ 358 | "android" 359 | ], 360 | "engines": { 361 | "node": ">=18" 362 | } 363 | }, 364 | "node_modules/@esbuild/darwin-arm64": { 365 | "version": "0.25.2", 366 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.2.tgz", 367 | "integrity": "sha512-MpM6LUVTXAzOvN4KbjzU/q5smzryuoNjlriAIx+06RpecwCkL9JpenNzpKd2YMzLJFOdPqBpuub6eVRP5IgiSA==", 368 | "cpu": [ 369 | "arm64" 370 | ], 371 | "optional": true, 372 | "os": [ 373 | "darwin" 374 | ], 375 | "engines": { 376 | "node": ">=18" 377 | } 378 | }, 379 | "node_modules/@esbuild/darwin-x64": { 380 | "version": "0.25.2", 381 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.2.tgz", 382 | "integrity": "sha512-5eRPrTX7wFyuWe8FqEFPG2cU0+butQQVNcT4sVipqjLYQjjh8a8+vUTfgBKM88ObB85ahsnTwF7PSIt6PG+QkA==", 383 | "cpu": [ 384 | "x64" 385 | ], 386 | "optional": true, 387 | "os": [ 388 | "darwin" 389 | ], 390 | "engines": { 391 | "node": ">=18" 392 | } 393 | }, 394 | "node_modules/@esbuild/freebsd-arm64": { 395 | "version": "0.25.2", 396 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.2.tgz", 397 | "integrity": "sha512-mLwm4vXKiQ2UTSX4+ImyiPdiHjiZhIaE9QvC7sw0tZ6HoNMjYAqQpGyui5VRIi5sGd+uWq940gdCbY3VLvsO1w==", 398 | "cpu": [ 399 | "arm64" 400 | ], 401 | "optional": true, 402 | "os": [ 403 | "freebsd" 404 | ], 405 | "engines": { 406 | "node": ">=18" 407 | } 408 | }, 409 | "node_modules/@esbuild/freebsd-x64": { 410 | "version": "0.25.2", 411 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.2.tgz", 412 | "integrity": "sha512-6qyyn6TjayJSwGpm8J9QYYGQcRgc90nmfdUb0O7pp1s4lTY+9D0H9O02v5JqGApUyiHOtkz6+1hZNvNtEhbwRQ==", 413 | "cpu": [ 414 | "x64" 415 | ], 416 | "optional": true, 417 | "os": [ 418 | "freebsd" 419 | ], 420 | "engines": { 421 | "node": ">=18" 422 | } 423 | }, 424 | "node_modules/@esbuild/linux-arm": { 425 | "version": "0.25.2", 426 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.2.tgz", 427 | "integrity": "sha512-UHBRgJcmjJv5oeQF8EpTRZs/1knq6loLxTsjc3nxO9eXAPDLcWW55flrMVc97qFPbmZP31ta1AZVUKQzKTzb0g==", 428 | "cpu": [ 429 | "arm" 430 | ], 431 | "optional": true, 432 | "os": [ 433 | "linux" 434 | ], 435 | "engines": { 436 | "node": ">=18" 437 | } 438 | }, 439 | "node_modules/@esbuild/linux-arm64": { 440 | "version": "0.25.2", 441 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.2.tgz", 442 | "integrity": "sha512-gq/sjLsOyMT19I8obBISvhoYiZIAaGF8JpeXu1u8yPv8BE5HlWYobmlsfijFIZ9hIVGYkbdFhEqC0NvM4kNO0g==", 443 | "cpu": [ 444 | "arm64" 445 | ], 446 | "optional": true, 447 | "os": [ 448 | "linux" 449 | ], 450 | "engines": { 451 | "node": ">=18" 452 | } 453 | }, 454 | "node_modules/@esbuild/linux-ia32": { 455 | "version": "0.25.2", 456 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.2.tgz", 457 | "integrity": "sha512-bBYCv9obgW2cBP+2ZWfjYTU+f5cxRoGGQ5SeDbYdFCAZpYWrfjjfYwvUpP8MlKbP0nwZ5gyOU/0aUzZ5HWPuvQ==", 458 | "cpu": [ 459 | "ia32" 460 | ], 461 | "optional": true, 462 | "os": [ 463 | "linux" 464 | ], 465 | "engines": { 466 | "node": ">=18" 467 | } 468 | }, 469 | "node_modules/@esbuild/linux-loong64": { 470 | "version": "0.25.2", 471 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.2.tgz", 472 | "integrity": "sha512-SHNGiKtvnU2dBlM5D8CXRFdd+6etgZ9dXfaPCeJtz+37PIUlixvlIhI23L5khKXs3DIzAn9V8v+qb1TRKrgT5w==", 473 | "cpu": [ 474 | "loong64" 475 | ], 476 | "optional": true, 477 | "os": [ 478 | "linux" 479 | ], 480 | "engines": { 481 | "node": ">=18" 482 | } 483 | }, 484 | "node_modules/@esbuild/linux-mips64el": { 485 | "version": "0.25.2", 486 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.2.tgz", 487 | "integrity": "sha512-hDDRlzE6rPeoj+5fsADqdUZl1OzqDYow4TB4Y/3PlKBD0ph1e6uPHzIQcv2Z65u2K0kpeByIyAjCmjn1hJgG0Q==", 488 | "cpu": [ 489 | "mips64el" 490 | ], 491 | "optional": true, 492 | "os": [ 493 | "linux" 494 | ], 495 | "engines": { 496 | "node": ">=18" 497 | } 498 | }, 499 | "node_modules/@esbuild/linux-ppc64": { 500 | "version": "0.25.2", 501 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.2.tgz", 502 | "integrity": "sha512-tsHu2RRSWzipmUi9UBDEzc0nLc4HtpZEI5Ba+Omms5456x5WaNuiG3u7xh5AO6sipnJ9r4cRWQB2tUjPyIkc6g==", 503 | "cpu": [ 504 | "ppc64" 505 | ], 506 | "optional": true, 507 | "os": [ 508 | "linux" 509 | ], 510 | "engines": { 511 | "node": ">=18" 512 | } 513 | }, 514 | "node_modules/@esbuild/linux-riscv64": { 515 | "version": "0.25.2", 516 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.2.tgz", 517 | "integrity": "sha512-k4LtpgV7NJQOml/10uPU0s4SAXGnowi5qBSjaLWMojNCUICNu7TshqHLAEbkBdAszL5TabfvQ48kK84hyFzjnw==", 518 | "cpu": [ 519 | "riscv64" 520 | ], 521 | "optional": true, 522 | "os": [ 523 | "linux" 524 | ], 525 | "engines": { 526 | "node": ">=18" 527 | } 528 | }, 529 | "node_modules/@esbuild/linux-s390x": { 530 | "version": "0.25.2", 531 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.2.tgz", 532 | "integrity": "sha512-GRa4IshOdvKY7M/rDpRR3gkiTNp34M0eLTaC1a08gNrh4u488aPhuZOCpkF6+2wl3zAN7L7XIpOFBhnaE3/Q8Q==", 533 | "cpu": [ 534 | "s390x" 535 | ], 536 | "optional": true, 537 | "os": [ 538 | "linux" 539 | ], 540 | "engines": { 541 | "node": ">=18" 542 | } 543 | }, 544 | "node_modules/@esbuild/linux-x64": { 545 | "version": "0.25.2", 546 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.2.tgz", 547 | "integrity": "sha512-QInHERlqpTTZ4FRB0fROQWXcYRD64lAoiegezDunLpalZMjcUcld3YzZmVJ2H/Cp0wJRZ8Xtjtj0cEHhYc/uUg==", 548 | "cpu": [ 549 | "x64" 550 | ], 551 | "optional": true, 552 | "os": [ 553 | "linux" 554 | ], 555 | "engines": { 556 | "node": ">=18" 557 | } 558 | }, 559 | "node_modules/@esbuild/netbsd-arm64": { 560 | "version": "0.25.2", 561 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.2.tgz", 562 | "integrity": "sha512-talAIBoY5M8vHc6EeI2WW9d/CkiO9MQJ0IOWX8hrLhxGbro/vBXJvaQXefW2cP0z0nQVTdQ/eNyGFV1GSKrxfw==", 563 | "cpu": [ 564 | "arm64" 565 | ], 566 | "optional": true, 567 | "os": [ 568 | "netbsd" 569 | ], 570 | "engines": { 571 | "node": ">=18" 572 | } 573 | }, 574 | "node_modules/@esbuild/netbsd-x64": { 575 | "version": "0.25.2", 576 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.2.tgz", 577 | "integrity": "sha512-voZT9Z+tpOxrvfKFyfDYPc4DO4rk06qamv1a/fkuzHpiVBMOhpjK+vBmWM8J1eiB3OLSMFYNaOaBNLXGChf5tg==", 578 | "cpu": [ 579 | "x64" 580 | ], 581 | "optional": true, 582 | "os": [ 583 | "netbsd" 584 | ], 585 | "engines": { 586 | "node": ">=18" 587 | } 588 | }, 589 | "node_modules/@esbuild/openbsd-arm64": { 590 | "version": "0.25.2", 591 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.2.tgz", 592 | "integrity": "sha512-dcXYOC6NXOqcykeDlwId9kB6OkPUxOEqU+rkrYVqJbK2hagWOMrsTGsMr8+rW02M+d5Op5NNlgMmjzecaRf7Tg==", 593 | "cpu": [ 594 | "arm64" 595 | ], 596 | "optional": true, 597 | "os": [ 598 | "openbsd" 599 | ], 600 | "engines": { 601 | "node": ">=18" 602 | } 603 | }, 604 | "node_modules/@esbuild/openbsd-x64": { 605 | "version": "0.25.2", 606 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.2.tgz", 607 | "integrity": "sha512-t/TkWwahkH0Tsgoq1Ju7QfgGhArkGLkF1uYz8nQS/PPFlXbP5YgRpqQR3ARRiC2iXoLTWFxc6DJMSK10dVXluw==", 608 | "cpu": [ 609 | "x64" 610 | ], 611 | "optional": true, 612 | "os": [ 613 | "openbsd" 614 | ], 615 | "engines": { 616 | "node": ">=18" 617 | } 618 | }, 619 | "node_modules/@esbuild/sunos-x64": { 620 | "version": "0.25.2", 621 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.2.tgz", 622 | "integrity": "sha512-cfZH1co2+imVdWCjd+D1gf9NjkchVhhdpgb1q5y6Hcv9TP6Zi9ZG/beI3ig8TvwT9lH9dlxLq5MQBBgwuj4xvA==", 623 | "cpu": [ 624 | "x64" 625 | ], 626 | "optional": true, 627 | "os": [ 628 | "sunos" 629 | ], 630 | "engines": { 631 | "node": ">=18" 632 | } 633 | }, 634 | "node_modules/@esbuild/win32-arm64": { 635 | "version": "0.25.2", 636 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.2.tgz", 637 | "integrity": "sha512-7Loyjh+D/Nx/sOTzV8vfbB3GJuHdOQyrOryFdZvPHLf42Tk9ivBU5Aedi7iyX+x6rbn2Mh68T4qq1SDqJBQO5Q==", 638 | "cpu": [ 639 | "arm64" 640 | ], 641 | "optional": true, 642 | "os": [ 643 | "win32" 644 | ], 645 | "engines": { 646 | "node": ">=18" 647 | } 648 | }, 649 | "node_modules/@esbuild/win32-ia32": { 650 | "version": "0.25.2", 651 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.2.tgz", 652 | "integrity": "sha512-WRJgsz9un0nqZJ4MfhabxaD9Ft8KioqU3JMinOTvobbX6MOSUigSBlogP8QB3uxpJDsFS6yN+3FDBdqE5lg9kg==", 653 | "cpu": [ 654 | "ia32" 655 | ], 656 | "optional": true, 657 | "os": [ 658 | "win32" 659 | ], 660 | "engines": { 661 | "node": ">=18" 662 | } 663 | }, 664 | "node_modules/@esbuild/win32-x64": { 665 | "version": "0.25.2", 666 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.2.tgz", 667 | "integrity": "sha512-kM3HKb16VIXZyIeVrM1ygYmZBKybX8N4p754bw390wGO3Tf2j4L2/WYL+4suWujpgf6GBYs3jv7TyUivdd05JA==", 668 | "cpu": [ 669 | "x64" 670 | ], 671 | "optional": true, 672 | "os": [ 673 | "win32" 674 | ], 675 | "engines": { 676 | "node": ">=18" 677 | } 678 | }, 679 | "node_modules/@eslint-community/eslint-utils": { 680 | "version": "4.6.0", 681 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.6.0.tgz", 682 | "integrity": "sha512-WhCn7Z7TauhBtmzhvKpoQs0Wwb/kBcy4CwpuI0/eEIr2Lx2auxmulAzLr91wVZJaz47iUZdkXOK7WlAfxGKCnA==", 683 | "dev": true, 684 | "dependencies": { 685 | "eslint-visitor-keys": "^3.4.3" 686 | }, 687 | "engines": { 688 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 689 | }, 690 | "funding": { 691 | "url": "https://opencollective.com/eslint" 692 | }, 693 | "peerDependencies": { 694 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 695 | } 696 | }, 697 | "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { 698 | "version": "3.4.3", 699 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 700 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 701 | "dev": true, 702 | "engines": { 703 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 704 | }, 705 | "funding": { 706 | "url": "https://opencollective.com/eslint" 707 | } 708 | }, 709 | "node_modules/@eslint-community/regexpp": { 710 | "version": "4.12.1", 711 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", 712 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", 713 | "dev": true, 714 | "engines": { 715 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 716 | } 717 | }, 718 | "node_modules/@eslint/config-array": { 719 | "version": "0.20.0", 720 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.20.0.tgz", 721 | "integrity": "sha512-fxlS1kkIjx8+vy2SjuCB94q3htSNrufYTXubwiBFeaQHbH6Ipi43gFJq2zCMt6PHhImH3Xmr0NksKDvchWlpQQ==", 722 | "dev": true, 723 | "dependencies": { 724 | "@eslint/object-schema": "^2.1.6", 725 | "debug": "^4.3.1", 726 | "minimatch": "^3.1.2" 727 | }, 728 | "engines": { 729 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 730 | } 731 | }, 732 | "node_modules/@eslint/config-helpers": { 733 | "version": "0.2.1", 734 | "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.2.1.tgz", 735 | "integrity": "sha512-RI17tsD2frtDu/3dmI7QRrD4bedNKPM08ziRYaC5AhkGrzIAJelm9kJU1TznK+apx6V+cqRz8tfpEeG3oIyjxw==", 736 | "dev": true, 737 | "engines": { 738 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 739 | } 740 | }, 741 | "node_modules/@eslint/core": { 742 | "version": "0.12.0", 743 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.12.0.tgz", 744 | "integrity": "sha512-cmrR6pytBuSMTaBweKoGMwu3EiHiEC+DoyupPmlZ0HxBJBtIxwe+j/E4XPIKNx+Q74c8lXKPwYawBf5glsTkHg==", 745 | "dev": true, 746 | "dependencies": { 747 | "@types/json-schema": "^7.0.15" 748 | }, 749 | "engines": { 750 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 751 | } 752 | }, 753 | "node_modules/@eslint/eslintrc": { 754 | "version": "3.3.1", 755 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz", 756 | "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==", 757 | "dev": true, 758 | "dependencies": { 759 | "ajv": "^6.12.4", 760 | "debug": "^4.3.2", 761 | "espree": "^10.0.1", 762 | "globals": "^14.0.0", 763 | "ignore": "^5.2.0", 764 | "import-fresh": "^3.2.1", 765 | "js-yaml": "^4.1.0", 766 | "minimatch": "^3.1.2", 767 | "strip-json-comments": "^3.1.1" 768 | }, 769 | "engines": { 770 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 771 | }, 772 | "funding": { 773 | "url": "https://opencollective.com/eslint" 774 | } 775 | }, 776 | "node_modules/@eslint/eslintrc/node_modules/globals": { 777 | "version": "14.0.0", 778 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", 779 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", 780 | "dev": true, 781 | "engines": { 782 | "node": ">=18" 783 | }, 784 | "funding": { 785 | "url": "https://github.com/sponsors/sindresorhus" 786 | } 787 | }, 788 | "node_modules/@eslint/js": { 789 | "version": "9.24.0", 790 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.24.0.tgz", 791 | "integrity": "sha512-uIY/y3z0uvOGX8cp1C2fiC4+ZmBhp6yZWkojtHL1YEMnRt1Y63HB9TM17proGEmeG7HeUY+UP36F0aknKYTpYA==", 792 | "dev": true, 793 | "engines": { 794 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 795 | } 796 | }, 797 | "node_modules/@eslint/object-schema": { 798 | "version": "2.1.6", 799 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz", 800 | "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==", 801 | "dev": true, 802 | "engines": { 803 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 804 | } 805 | }, 806 | "node_modules/@eslint/plugin-kit": { 807 | "version": "0.2.8", 808 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.8.tgz", 809 | "integrity": "sha512-ZAoA40rNMPwSm+AeHpCq8STiNAwzWLJuP8Xv4CHIc9wv/PSuExjMrmjfYNj682vW0OOiZ1HKxzvjQr9XZIisQA==", 810 | "dev": true, 811 | "dependencies": { 812 | "@eslint/core": "^0.13.0", 813 | "levn": "^0.4.1" 814 | }, 815 | "engines": { 816 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 817 | } 818 | }, 819 | "node_modules/@eslint/plugin-kit/node_modules/@eslint/core": { 820 | "version": "0.13.0", 821 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.13.0.tgz", 822 | "integrity": "sha512-yfkgDw1KR66rkT5A8ci4irzDysN7FRpq3ttJolR88OqQikAWqwA8j5VZyas+vjyBNFIJ7MfybJ9plMILI2UrCw==", 823 | "dev": true, 824 | "dependencies": { 825 | "@types/json-schema": "^7.0.15" 826 | }, 827 | "engines": { 828 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 829 | } 830 | }, 831 | "node_modules/@humanfs/core": { 832 | "version": "0.19.1", 833 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz", 834 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==", 835 | "dev": true, 836 | "engines": { 837 | "node": ">=18.18.0" 838 | } 839 | }, 840 | "node_modules/@humanfs/node": { 841 | "version": "0.16.6", 842 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz", 843 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==", 844 | "dev": true, 845 | "dependencies": { 846 | "@humanfs/core": "^0.19.1", 847 | "@humanwhocodes/retry": "^0.3.0" 848 | }, 849 | "engines": { 850 | "node": ">=18.18.0" 851 | } 852 | }, 853 | "node_modules/@humanfs/node/node_modules/@humanwhocodes/retry": { 854 | "version": "0.3.1", 855 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", 856 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", 857 | "dev": true, 858 | "engines": { 859 | "node": ">=18.18" 860 | }, 861 | "funding": { 862 | "type": "github", 863 | "url": "https://github.com/sponsors/nzakas" 864 | } 865 | }, 866 | "node_modules/@humanwhocodes/module-importer": { 867 | "version": "1.0.1", 868 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 869 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 870 | "dev": true, 871 | "engines": { 872 | "node": ">=12.22" 873 | }, 874 | "funding": { 875 | "type": "github", 876 | "url": "https://github.com/sponsors/nzakas" 877 | } 878 | }, 879 | "node_modules/@humanwhocodes/retry": { 880 | "version": "0.4.2", 881 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.2.tgz", 882 | "integrity": "sha512-xeO57FpIu4p1Ri3Jq/EXq4ClRm86dVF2z/+kvFnyqVYRavTZmaFaUBbWCOuuTh0o/g7DSsk6kc2vrS4Vl5oPOQ==", 883 | "dev": true, 884 | "engines": { 885 | "node": ">=18.18" 886 | }, 887 | "funding": { 888 | "type": "github", 889 | "url": "https://github.com/sponsors/nzakas" 890 | } 891 | }, 892 | "node_modules/@jridgewell/gen-mapping": { 893 | "version": "0.3.8", 894 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz", 895 | "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==", 896 | "dev": true, 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 | "dev": true, 911 | "engines": { 912 | "node": ">=6.0.0" 913 | } 914 | }, 915 | "node_modules/@jridgewell/set-array": { 916 | "version": "1.2.1", 917 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 918 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 919 | "dev": true, 920 | "engines": { 921 | "node": ">=6.0.0" 922 | } 923 | }, 924 | "node_modules/@jridgewell/sourcemap-codec": { 925 | "version": "1.5.0", 926 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", 927 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", 928 | "dev": true 929 | }, 930 | "node_modules/@jridgewell/trace-mapping": { 931 | "version": "0.3.25", 932 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 933 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 934 | "dev": true, 935 | "dependencies": { 936 | "@jridgewell/resolve-uri": "^3.1.0", 937 | "@jridgewell/sourcemap-codec": "^1.4.14" 938 | } 939 | }, 940 | "node_modules/@rollup/rollup-android-arm-eabi": { 941 | "version": "4.40.0", 942 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.40.0.tgz", 943 | "integrity": "sha512-+Fbls/diZ0RDerhE8kyC6hjADCXA1K4yVNlH0EYfd2XjyH0UGgzaQ8MlT0pCXAThfxv3QUAczHaL+qSv1E4/Cg==", 944 | "cpu": [ 945 | "arm" 946 | ], 947 | "optional": true, 948 | "os": [ 949 | "android" 950 | ] 951 | }, 952 | "node_modules/@rollup/rollup-android-arm64": { 953 | "version": "4.40.0", 954 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.40.0.tgz", 955 | "integrity": "sha512-PPA6aEEsTPRz+/4xxAmaoWDqh67N7wFbgFUJGMnanCFs0TV99M0M8QhhaSCks+n6EbQoFvLQgYOGXxlMGQe/6w==", 956 | "cpu": [ 957 | "arm64" 958 | ], 959 | "optional": true, 960 | "os": [ 961 | "android" 962 | ] 963 | }, 964 | "node_modules/@rollup/rollup-darwin-arm64": { 965 | "version": "4.40.0", 966 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.40.0.tgz", 967 | "integrity": "sha512-GwYOcOakYHdfnjjKwqpTGgn5a6cUX7+Ra2HeNj/GdXvO2VJOOXCiYYlRFU4CubFM67EhbmzLOmACKEfvp3J1kQ==", 968 | "cpu": [ 969 | "arm64" 970 | ], 971 | "optional": true, 972 | "os": [ 973 | "darwin" 974 | ] 975 | }, 976 | "node_modules/@rollup/rollup-darwin-x64": { 977 | "version": "4.40.0", 978 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.40.0.tgz", 979 | "integrity": "sha512-CoLEGJ+2eheqD9KBSxmma6ld01czS52Iw0e2qMZNpPDlf7Z9mj8xmMemxEucinev4LgHalDPczMyxzbq+Q+EtA==", 980 | "cpu": [ 981 | "x64" 982 | ], 983 | "optional": true, 984 | "os": [ 985 | "darwin" 986 | ] 987 | }, 988 | "node_modules/@rollup/rollup-freebsd-arm64": { 989 | "version": "4.40.0", 990 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.40.0.tgz", 991 | "integrity": "sha512-r7yGiS4HN/kibvESzmrOB/PxKMhPTlz+FcGvoUIKYoTyGd5toHp48g1uZy1o1xQvybwwpqpe010JrcGG2s5nkg==", 992 | "cpu": [ 993 | "arm64" 994 | ], 995 | "optional": true, 996 | "os": [ 997 | "freebsd" 998 | ] 999 | }, 1000 | "node_modules/@rollup/rollup-freebsd-x64": { 1001 | "version": "4.40.0", 1002 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.40.0.tgz", 1003 | "integrity": "sha512-mVDxzlf0oLzV3oZOr0SMJ0lSDd3xC4CmnWJ8Val8isp9jRGl5Dq//LLDSPFrasS7pSm6m5xAcKaw3sHXhBjoRw==", 1004 | "cpu": [ 1005 | "x64" 1006 | ], 1007 | "optional": true, 1008 | "os": [ 1009 | "freebsd" 1010 | ] 1011 | }, 1012 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 1013 | "version": "4.40.0", 1014 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.40.0.tgz", 1015 | "integrity": "sha512-y/qUMOpJxBMy8xCXD++jeu8t7kzjlOCkoxxajL58G62PJGBZVl/Gwpm7JK9+YvlB701rcQTzjUZ1JgUoPTnoQA==", 1016 | "cpu": [ 1017 | "arm" 1018 | ], 1019 | "optional": true, 1020 | "os": [ 1021 | "linux" 1022 | ] 1023 | }, 1024 | "node_modules/@rollup/rollup-linux-arm-musleabihf": { 1025 | "version": "4.40.0", 1026 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.40.0.tgz", 1027 | "integrity": "sha512-GoCsPibtVdJFPv/BOIvBKO/XmwZLwaNWdyD8TKlXuqp0veo2sHE+A/vpMQ5iSArRUz/uaoj4h5S6Pn0+PdhRjg==", 1028 | "cpu": [ 1029 | "arm" 1030 | ], 1031 | "optional": true, 1032 | "os": [ 1033 | "linux" 1034 | ] 1035 | }, 1036 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1037 | "version": "4.40.0", 1038 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.40.0.tgz", 1039 | "integrity": "sha512-L5ZLphTjjAD9leJzSLI7rr8fNqJMlGDKlazW2tX4IUF9P7R5TMQPElpH82Q7eNIDQnQlAyiNVfRPfP2vM5Avvg==", 1040 | "cpu": [ 1041 | "arm64" 1042 | ], 1043 | "optional": true, 1044 | "os": [ 1045 | "linux" 1046 | ] 1047 | }, 1048 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1049 | "version": "4.40.0", 1050 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.40.0.tgz", 1051 | "integrity": "sha512-ATZvCRGCDtv1Y4gpDIXsS+wfFeFuLwVxyUBSLawjgXK2tRE6fnsQEkE4csQQYWlBlsFztRzCnBvWVfcae/1qxQ==", 1052 | "cpu": [ 1053 | "arm64" 1054 | ], 1055 | "optional": true, 1056 | "os": [ 1057 | "linux" 1058 | ] 1059 | }, 1060 | "node_modules/@rollup/rollup-linux-loongarch64-gnu": { 1061 | "version": "4.40.0", 1062 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.40.0.tgz", 1063 | "integrity": "sha512-wG9e2XtIhd++QugU5MD9i7OnpaVb08ji3P1y/hNbxrQ3sYEelKJOq1UJ5dXczeo6Hj2rfDEL5GdtkMSVLa/AOg==", 1064 | "cpu": [ 1065 | "loong64" 1066 | ], 1067 | "optional": true, 1068 | "os": [ 1069 | "linux" 1070 | ] 1071 | }, 1072 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { 1073 | "version": "4.40.0", 1074 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.40.0.tgz", 1075 | "integrity": "sha512-vgXfWmj0f3jAUvC7TZSU/m/cOE558ILWDzS7jBhiCAFpY2WEBn5jqgbqvmzlMjtp8KlLcBlXVD2mkTSEQE6Ixw==", 1076 | "cpu": [ 1077 | "ppc64" 1078 | ], 1079 | "optional": true, 1080 | "os": [ 1081 | "linux" 1082 | ] 1083 | }, 1084 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1085 | "version": "4.40.0", 1086 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.40.0.tgz", 1087 | "integrity": "sha512-uJkYTugqtPZBS3Z136arevt/FsKTF/J9dEMTX/cwR7lsAW4bShzI2R0pJVw+hcBTWF4dxVckYh72Hk3/hWNKvA==", 1088 | "cpu": [ 1089 | "riscv64" 1090 | ], 1091 | "optional": true, 1092 | "os": [ 1093 | "linux" 1094 | ] 1095 | }, 1096 | "node_modules/@rollup/rollup-linux-riscv64-musl": { 1097 | "version": "4.40.0", 1098 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.40.0.tgz", 1099 | "integrity": "sha512-rKmSj6EXQRnhSkE22+WvrqOqRtk733x3p5sWpZilhmjnkHkpeCgWsFFo0dGnUGeA+OZjRl3+VYq+HyCOEuwcxQ==", 1100 | "cpu": [ 1101 | "riscv64" 1102 | ], 1103 | "optional": true, 1104 | "os": [ 1105 | "linux" 1106 | ] 1107 | }, 1108 | "node_modules/@rollup/rollup-linux-s390x-gnu": { 1109 | "version": "4.40.0", 1110 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.40.0.tgz", 1111 | "integrity": "sha512-SpnYlAfKPOoVsQqmTFJ0usx0z84bzGOS9anAC0AZ3rdSo3snecihbhFTlJZ8XMwzqAcodjFU4+/SM311dqE5Sw==", 1112 | "cpu": [ 1113 | "s390x" 1114 | ], 1115 | "optional": true, 1116 | "os": [ 1117 | "linux" 1118 | ] 1119 | }, 1120 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1121 | "version": "4.40.0", 1122 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.40.0.tgz", 1123 | "integrity": "sha512-RcDGMtqF9EFN8i2RYN2W+64CdHruJ5rPqrlYw+cgM3uOVPSsnAQps7cpjXe9be/yDp8UC7VLoCoKC8J3Kn2FkQ==", 1124 | "cpu": [ 1125 | "x64" 1126 | ], 1127 | "optional": true, 1128 | "os": [ 1129 | "linux" 1130 | ] 1131 | }, 1132 | "node_modules/@rollup/rollup-linux-x64-musl": { 1133 | "version": "4.40.0", 1134 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.40.0.tgz", 1135 | "integrity": "sha512-HZvjpiUmSNx5zFgwtQAV1GaGazT2RWvqeDi0hV+AtC8unqqDSsaFjPxfsO6qPtKRRg25SisACWnJ37Yio8ttaw==", 1136 | "cpu": [ 1137 | "x64" 1138 | ], 1139 | "optional": true, 1140 | "os": [ 1141 | "linux" 1142 | ] 1143 | }, 1144 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1145 | "version": "4.40.0", 1146 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.40.0.tgz", 1147 | "integrity": "sha512-UtZQQI5k/b8d7d3i9AZmA/t+Q4tk3hOC0tMOMSq2GlMYOfxbesxG4mJSeDp0EHs30N9bsfwUvs3zF4v/RzOeTQ==", 1148 | "cpu": [ 1149 | "arm64" 1150 | ], 1151 | "optional": true, 1152 | "os": [ 1153 | "win32" 1154 | ] 1155 | }, 1156 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1157 | "version": "4.40.0", 1158 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.40.0.tgz", 1159 | "integrity": "sha512-+m03kvI2f5syIqHXCZLPVYplP8pQch9JHyXKZ3AGMKlg8dCyr2PKHjwRLiW53LTrN/Nc3EqHOKxUxzoSPdKddA==", 1160 | "cpu": [ 1161 | "ia32" 1162 | ], 1163 | "optional": true, 1164 | "os": [ 1165 | "win32" 1166 | ] 1167 | }, 1168 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1169 | "version": "4.40.0", 1170 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.40.0.tgz", 1171 | "integrity": "sha512-lpPE1cLfP5oPzVjKMx10pgBmKELQnFJXHgvtHCtuJWOv8MxqdEIMNtgHgBFf7Ea2/7EuVwa9fodWUfXAlXZLZQ==", 1172 | "cpu": [ 1173 | "x64" 1174 | ], 1175 | "optional": true, 1176 | "os": [ 1177 | "win32" 1178 | ] 1179 | }, 1180 | "node_modules/@tailwindcss/node": { 1181 | "version": "4.1.3", 1182 | "resolved": "https://registry.npmjs.org/@tailwindcss/node/-/node-4.1.3.tgz", 1183 | "integrity": "sha512-H/6r6IPFJkCfBJZ2dKZiPJ7Ueb2wbL592+9bQEl2r73qbX6yGnmQVIfiUvDRB2YI0a3PWDrzUwkvQx1XW1bNkA==", 1184 | "dependencies": { 1185 | "enhanced-resolve": "^5.18.1", 1186 | "jiti": "^2.4.2", 1187 | "lightningcss": "1.29.2", 1188 | "tailwindcss": "4.1.3" 1189 | } 1190 | }, 1191 | "node_modules/@tailwindcss/oxide": { 1192 | "version": "4.1.3", 1193 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide/-/oxide-4.1.3.tgz", 1194 | "integrity": "sha512-t16lpHCU7LBxDe/8dCj9ntyNpXaSTAgxWm1u2XQP5NiIu4KGSyrDJJRlK9hJ4U9yJxx0UKCVI67MJWFNll5mOQ==", 1195 | "engines": { 1196 | "node": ">= 10" 1197 | }, 1198 | "optionalDependencies": { 1199 | "@tailwindcss/oxide-android-arm64": "4.1.3", 1200 | "@tailwindcss/oxide-darwin-arm64": "4.1.3", 1201 | "@tailwindcss/oxide-darwin-x64": "4.1.3", 1202 | "@tailwindcss/oxide-freebsd-x64": "4.1.3", 1203 | "@tailwindcss/oxide-linux-arm-gnueabihf": "4.1.3", 1204 | "@tailwindcss/oxide-linux-arm64-gnu": "4.1.3", 1205 | "@tailwindcss/oxide-linux-arm64-musl": "4.1.3", 1206 | "@tailwindcss/oxide-linux-x64-gnu": "4.1.3", 1207 | "@tailwindcss/oxide-linux-x64-musl": "4.1.3", 1208 | "@tailwindcss/oxide-win32-arm64-msvc": "4.1.3", 1209 | "@tailwindcss/oxide-win32-x64-msvc": "4.1.3" 1210 | } 1211 | }, 1212 | "node_modules/@tailwindcss/oxide-android-arm64": { 1213 | "version": "4.1.3", 1214 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-android-arm64/-/oxide-android-arm64-4.1.3.tgz", 1215 | "integrity": "sha512-cxklKjtNLwFl3mDYw4XpEfBY+G8ssSg9ADL4Wm6//5woi3XGqlxFsnV5Zb6v07dxw1NvEX2uoqsxO/zWQsgR+g==", 1216 | "cpu": [ 1217 | "arm64" 1218 | ], 1219 | "optional": true, 1220 | "os": [ 1221 | "android" 1222 | ], 1223 | "engines": { 1224 | "node": ">= 10" 1225 | } 1226 | }, 1227 | "node_modules/@tailwindcss/oxide-darwin-arm64": { 1228 | "version": "4.1.3", 1229 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-arm64/-/oxide-darwin-arm64-4.1.3.tgz", 1230 | "integrity": "sha512-mqkf2tLR5VCrjBvuRDwzKNShRu99gCAVMkVsaEOFvv6cCjlEKXRecPu9DEnxp6STk5z+Vlbh1M5zY3nQCXMXhw==", 1231 | "cpu": [ 1232 | "arm64" 1233 | ], 1234 | "optional": true, 1235 | "os": [ 1236 | "darwin" 1237 | ], 1238 | "engines": { 1239 | "node": ">= 10" 1240 | } 1241 | }, 1242 | "node_modules/@tailwindcss/oxide-darwin-x64": { 1243 | "version": "4.1.3", 1244 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-x64/-/oxide-darwin-x64-4.1.3.tgz", 1245 | "integrity": "sha512-7sGraGaWzXvCLyxrc7d+CCpUN3fYnkkcso3rCzwUmo/LteAl2ZGCDlGvDD8Y/1D3ngxT8KgDj1DSwOnNewKhmg==", 1246 | "cpu": [ 1247 | "x64" 1248 | ], 1249 | "optional": true, 1250 | "os": [ 1251 | "darwin" 1252 | ], 1253 | "engines": { 1254 | "node": ">= 10" 1255 | } 1256 | }, 1257 | "node_modules/@tailwindcss/oxide-freebsd-x64": { 1258 | "version": "4.1.3", 1259 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-freebsd-x64/-/oxide-freebsd-x64-4.1.3.tgz", 1260 | "integrity": "sha512-E2+PbcbzIReaAYZe997wb9rId246yDkCwAakllAWSGqe6VTg9hHle67hfH6ExjpV2LSK/siRzBUs5wVff3RW9w==", 1261 | "cpu": [ 1262 | "x64" 1263 | ], 1264 | "optional": true, 1265 | "os": [ 1266 | "freebsd" 1267 | ], 1268 | "engines": { 1269 | "node": ">= 10" 1270 | } 1271 | }, 1272 | "node_modules/@tailwindcss/oxide-linux-arm-gnueabihf": { 1273 | "version": "4.1.3", 1274 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm-gnueabihf/-/oxide-linux-arm-gnueabihf-4.1.3.tgz", 1275 | "integrity": "sha512-GvfbJ8wjSSjbLFFE3UYz4Eh8i4L6GiEYqCtA8j2Zd2oXriPuom/Ah/64pg/szWycQpzRnbDiJozoxFU2oJZyfg==", 1276 | "cpu": [ 1277 | "arm" 1278 | ], 1279 | "optional": true, 1280 | "os": [ 1281 | "linux" 1282 | ], 1283 | "engines": { 1284 | "node": ">= 10" 1285 | } 1286 | }, 1287 | "node_modules/@tailwindcss/oxide-linux-arm64-gnu": { 1288 | "version": "4.1.3", 1289 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-gnu/-/oxide-linux-arm64-gnu-4.1.3.tgz", 1290 | "integrity": "sha512-35UkuCWQTeG9BHcBQXndDOrpsnt3Pj9NVIB4CgNiKmpG8GnCNXeMczkUpOoqcOhO6Cc/mM2W7kaQ/MTEENDDXg==", 1291 | "cpu": [ 1292 | "arm64" 1293 | ], 1294 | "optional": true, 1295 | "os": [ 1296 | "linux" 1297 | ], 1298 | "engines": { 1299 | "node": ">= 10" 1300 | } 1301 | }, 1302 | "node_modules/@tailwindcss/oxide-linux-arm64-musl": { 1303 | "version": "4.1.3", 1304 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-musl/-/oxide-linux-arm64-musl-4.1.3.tgz", 1305 | "integrity": "sha512-dm18aQiML5QCj9DQo7wMbt1Z2tl3Giht54uVR87a84X8qRtuXxUqnKQkRDK5B4bCOmcZ580lF9YcoMkbDYTXHQ==", 1306 | "cpu": [ 1307 | "arm64" 1308 | ], 1309 | "optional": true, 1310 | "os": [ 1311 | "linux" 1312 | ], 1313 | "engines": { 1314 | "node": ">= 10" 1315 | } 1316 | }, 1317 | "node_modules/@tailwindcss/oxide-linux-x64-gnu": { 1318 | "version": "4.1.3", 1319 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-gnu/-/oxide-linux-x64-gnu-4.1.3.tgz", 1320 | "integrity": "sha512-LMdTmGe/NPtGOaOfV2HuO7w07jI3cflPrVq5CXl+2O93DCewADK0uW1ORNAcfu2YxDUS035eY2W38TxrsqngxA==", 1321 | "cpu": [ 1322 | "x64" 1323 | ], 1324 | "optional": true, 1325 | "os": [ 1326 | "linux" 1327 | ], 1328 | "engines": { 1329 | "node": ">= 10" 1330 | } 1331 | }, 1332 | "node_modules/@tailwindcss/oxide-linux-x64-musl": { 1333 | "version": "4.1.3", 1334 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-musl/-/oxide-linux-x64-musl-4.1.3.tgz", 1335 | "integrity": "sha512-aalNWwIi54bbFEizwl1/XpmdDrOaCjRFQRgtbv9slWjmNPuJJTIKPHf5/XXDARc9CneW9FkSTqTbyvNecYAEGw==", 1336 | "cpu": [ 1337 | "x64" 1338 | ], 1339 | "optional": true, 1340 | "os": [ 1341 | "linux" 1342 | ], 1343 | "engines": { 1344 | "node": ">= 10" 1345 | } 1346 | }, 1347 | "node_modules/@tailwindcss/oxide-win32-arm64-msvc": { 1348 | "version": "4.1.3", 1349 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-arm64-msvc/-/oxide-win32-arm64-msvc-4.1.3.tgz", 1350 | "integrity": "sha512-PEj7XR4OGTGoboTIAdXicKuWl4EQIjKHKuR+bFy9oYN7CFZo0eu74+70O4XuERX4yjqVZGAkCdglBODlgqcCXg==", 1351 | "cpu": [ 1352 | "arm64" 1353 | ], 1354 | "optional": true, 1355 | "os": [ 1356 | "win32" 1357 | ], 1358 | "engines": { 1359 | "node": ">= 10" 1360 | } 1361 | }, 1362 | "node_modules/@tailwindcss/oxide-win32-x64-msvc": { 1363 | "version": "4.1.3", 1364 | "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-x64-msvc/-/oxide-win32-x64-msvc-4.1.3.tgz", 1365 | "integrity": "sha512-T8gfxECWDBENotpw3HR9SmNiHC9AOJdxs+woasRZ8Q/J4VHN0OMs7F+4yVNZ9EVN26Wv6mZbK0jv7eHYuLJLwA==", 1366 | "cpu": [ 1367 | "x64" 1368 | ], 1369 | "optional": true, 1370 | "os": [ 1371 | "win32" 1372 | ], 1373 | "engines": { 1374 | "node": ">= 10" 1375 | } 1376 | }, 1377 | "node_modules/@tailwindcss/vite": { 1378 | "version": "4.1.3", 1379 | "resolved": "https://registry.npmjs.org/@tailwindcss/vite/-/vite-4.1.3.tgz", 1380 | "integrity": "sha512-lUI/QaDxLtlV52Lho6pu07CG9pSnRYLOPmKGIQjyHdTBagemc6HmgZxyjGAQ/5HMPrNeWBfTVIpQl0/jLXvWHQ==", 1381 | "dependencies": { 1382 | "@tailwindcss/node": "4.1.3", 1383 | "@tailwindcss/oxide": "4.1.3", 1384 | "tailwindcss": "4.1.3" 1385 | }, 1386 | "peerDependencies": { 1387 | "vite": "^5.2.0 || ^6" 1388 | } 1389 | }, 1390 | "node_modules/@types/babel__core": { 1391 | "version": "7.20.5", 1392 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1393 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1394 | "dev": true, 1395 | "dependencies": { 1396 | "@babel/parser": "^7.20.7", 1397 | "@babel/types": "^7.20.7", 1398 | "@types/babel__generator": "*", 1399 | "@types/babel__template": "*", 1400 | "@types/babel__traverse": "*" 1401 | } 1402 | }, 1403 | "node_modules/@types/babel__generator": { 1404 | "version": "7.27.0", 1405 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.27.0.tgz", 1406 | "integrity": "sha512-ufFd2Xi92OAVPYsy+P4n7/U7e68fex0+Ee8gSG9KX7eo084CWiQ4sdxktvdl0bOPupXtVJPY19zk6EwWqUQ8lg==", 1407 | "dev": true, 1408 | "dependencies": { 1409 | "@babel/types": "^7.0.0" 1410 | } 1411 | }, 1412 | "node_modules/@types/babel__template": { 1413 | "version": "7.4.4", 1414 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1415 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1416 | "dev": true, 1417 | "dependencies": { 1418 | "@babel/parser": "^7.1.0", 1419 | "@babel/types": "^7.0.0" 1420 | } 1421 | }, 1422 | "node_modules/@types/babel__traverse": { 1423 | "version": "7.20.7", 1424 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.7.tgz", 1425 | "integrity": "sha512-dkO5fhS7+/oos4ciWxyEyjWe48zmG6wbCheo/G2ZnHx4fs3EU6YC6UM8rk56gAjNJ9P3MTH2jo5jb92/K6wbng==", 1426 | "dev": true, 1427 | "dependencies": { 1428 | "@babel/types": "^7.20.7" 1429 | } 1430 | }, 1431 | "node_modules/@types/estree": { 1432 | "version": "1.0.7", 1433 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.7.tgz", 1434 | "integrity": "sha512-w28IoSUCJpidD/TGviZwwMJckNESJZXFu7NBZ5YJ4mEUnNraUn9Pm8HSZm/jDF1pDWYKspWE7oVphigUPRakIQ==" 1435 | }, 1436 | "node_modules/@types/json-schema": { 1437 | "version": "7.0.15", 1438 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 1439 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 1440 | "dev": true 1441 | }, 1442 | "node_modules/@types/react": { 1443 | "version": "19.1.1", 1444 | "resolved": "https://registry.npmjs.org/@types/react/-/react-19.1.1.tgz", 1445 | "integrity": "sha512-ePapxDL7qrgqSF67s0h9m412d9DbXyC1n59O2st+9rjuuamWsZuD2w55rqY12CbzsZ7uVXb5Nw0gEp9Z8MMutQ==", 1446 | "dev": true, 1447 | "dependencies": { 1448 | "csstype": "^3.0.2" 1449 | } 1450 | }, 1451 | "node_modules/@types/react-dom": { 1452 | "version": "19.1.2", 1453 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.1.2.tgz", 1454 | "integrity": "sha512-XGJkWF41Qq305SKWEILa1O8vzhb3aOo3ogBlSmiqNko/WmRb6QIaweuZCXjKygVDXpzXb5wyxKTSOsmkuqj+Qw==", 1455 | "dev": true, 1456 | "peerDependencies": { 1457 | "@types/react": "^19.0.0" 1458 | } 1459 | }, 1460 | "node_modules/@vitejs/plugin-react": { 1461 | "version": "4.3.4", 1462 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.3.4.tgz", 1463 | "integrity": "sha512-SCCPBJtYLdE8PX/7ZQAs1QAZ8Jqwih+0VBLum1EGqmCCQal+MIUqLCzj3ZUy8ufbC0cAM4LRlSTm7IQJwWT4ug==", 1464 | "dev": true, 1465 | "dependencies": { 1466 | "@babel/core": "^7.26.0", 1467 | "@babel/plugin-transform-react-jsx-self": "^7.25.9", 1468 | "@babel/plugin-transform-react-jsx-source": "^7.25.9", 1469 | "@types/babel__core": "^7.20.5", 1470 | "react-refresh": "^0.14.2" 1471 | }, 1472 | "engines": { 1473 | "node": "^14.18.0 || >=16.0.0" 1474 | }, 1475 | "peerDependencies": { 1476 | "vite": "^4.2.0 || ^5.0.0 || ^6.0.0" 1477 | } 1478 | }, 1479 | "node_modules/acorn": { 1480 | "version": "8.14.1", 1481 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.1.tgz", 1482 | "integrity": "sha512-OvQ/2pUDKmgfCg++xsTX1wGxfTaszcHVcTctW4UJB4hibJx2HXxxO5UmVgyjMa+ZDsiaf5wWLXYpRWMmBI0QHg==", 1483 | "dev": true, 1484 | "bin": { 1485 | "acorn": "bin/acorn" 1486 | }, 1487 | "engines": { 1488 | "node": ">=0.4.0" 1489 | } 1490 | }, 1491 | "node_modules/acorn-jsx": { 1492 | "version": "5.3.2", 1493 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1494 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1495 | "dev": true, 1496 | "peerDependencies": { 1497 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1498 | } 1499 | }, 1500 | "node_modules/ajv": { 1501 | "version": "6.12.6", 1502 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1503 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1504 | "dev": true, 1505 | "dependencies": { 1506 | "fast-deep-equal": "^3.1.1", 1507 | "fast-json-stable-stringify": "^2.0.0", 1508 | "json-schema-traverse": "^0.4.1", 1509 | "uri-js": "^4.2.2" 1510 | }, 1511 | "funding": { 1512 | "type": "github", 1513 | "url": "https://github.com/sponsors/epoberezkin" 1514 | } 1515 | }, 1516 | "node_modules/ansi-styles": { 1517 | "version": "4.3.0", 1518 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1519 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1520 | "dev": true, 1521 | "dependencies": { 1522 | "color-convert": "^2.0.1" 1523 | }, 1524 | "engines": { 1525 | "node": ">=8" 1526 | }, 1527 | "funding": { 1528 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1529 | } 1530 | }, 1531 | "node_modules/argparse": { 1532 | "version": "2.0.1", 1533 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1534 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1535 | "dev": true 1536 | }, 1537 | "node_modules/balanced-match": { 1538 | "version": "1.0.2", 1539 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1540 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1541 | "dev": true 1542 | }, 1543 | "node_modules/brace-expansion": { 1544 | "version": "1.1.11", 1545 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1546 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1547 | "dev": true, 1548 | "dependencies": { 1549 | "balanced-match": "^1.0.0", 1550 | "concat-map": "0.0.1" 1551 | } 1552 | }, 1553 | "node_modules/browserslist": { 1554 | "version": "4.24.4", 1555 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.4.tgz", 1556 | "integrity": "sha512-KDi1Ny1gSePi1vm0q4oxSF8b4DR44GF4BbmS2YdhPLOEqd8pDviZOGH/GsmRwoWJ2+5Lr085X7naowMwKHDG1A==", 1557 | "dev": true, 1558 | "funding": [ 1559 | { 1560 | "type": "opencollective", 1561 | "url": "https://opencollective.com/browserslist" 1562 | }, 1563 | { 1564 | "type": "tidelift", 1565 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1566 | }, 1567 | { 1568 | "type": "github", 1569 | "url": "https://github.com/sponsors/ai" 1570 | } 1571 | ], 1572 | "dependencies": { 1573 | "caniuse-lite": "^1.0.30001688", 1574 | "electron-to-chromium": "^1.5.73", 1575 | "node-releases": "^2.0.19", 1576 | "update-browserslist-db": "^1.1.1" 1577 | }, 1578 | "bin": { 1579 | "browserslist": "cli.js" 1580 | }, 1581 | "engines": { 1582 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1583 | } 1584 | }, 1585 | "node_modules/callsites": { 1586 | "version": "3.1.0", 1587 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1588 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1589 | "dev": true, 1590 | "engines": { 1591 | "node": ">=6" 1592 | } 1593 | }, 1594 | "node_modules/caniuse-lite": { 1595 | "version": "1.0.30001713", 1596 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001713.tgz", 1597 | "integrity": "sha512-wCIWIg+A4Xr7NfhTuHdX+/FKh3+Op3LBbSp2N5Pfx6T/LhdQy3GTyoTg48BReaW/MyMNZAkTadsBtai3ldWK0Q==", 1598 | "dev": true, 1599 | "funding": [ 1600 | { 1601 | "type": "opencollective", 1602 | "url": "https://opencollective.com/browserslist" 1603 | }, 1604 | { 1605 | "type": "tidelift", 1606 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1607 | }, 1608 | { 1609 | "type": "github", 1610 | "url": "https://github.com/sponsors/ai" 1611 | } 1612 | ] 1613 | }, 1614 | "node_modules/chalk": { 1615 | "version": "4.1.2", 1616 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1617 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1618 | "dev": true, 1619 | "dependencies": { 1620 | "ansi-styles": "^4.1.0", 1621 | "supports-color": "^7.1.0" 1622 | }, 1623 | "engines": { 1624 | "node": ">=10" 1625 | }, 1626 | "funding": { 1627 | "url": "https://github.com/chalk/chalk?sponsor=1" 1628 | } 1629 | }, 1630 | "node_modules/color-convert": { 1631 | "version": "2.0.1", 1632 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1633 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1634 | "dev": true, 1635 | "dependencies": { 1636 | "color-name": "~1.1.4" 1637 | }, 1638 | "engines": { 1639 | "node": ">=7.0.0" 1640 | } 1641 | }, 1642 | "node_modules/color-name": { 1643 | "version": "1.1.4", 1644 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1645 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1646 | "dev": true 1647 | }, 1648 | "node_modules/concat-map": { 1649 | "version": "0.0.1", 1650 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1651 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1652 | "dev": true 1653 | }, 1654 | "node_modules/convert-source-map": { 1655 | "version": "2.0.0", 1656 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1657 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1658 | "dev": true 1659 | }, 1660 | "node_modules/cross-spawn": { 1661 | "version": "7.0.6", 1662 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", 1663 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", 1664 | "dev": true, 1665 | "dependencies": { 1666 | "path-key": "^3.1.0", 1667 | "shebang-command": "^2.0.0", 1668 | "which": "^2.0.1" 1669 | }, 1670 | "engines": { 1671 | "node": ">= 8" 1672 | } 1673 | }, 1674 | "node_modules/csstype": { 1675 | "version": "3.1.3", 1676 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 1677 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 1678 | "dev": true 1679 | }, 1680 | "node_modules/debug": { 1681 | "version": "4.4.0", 1682 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", 1683 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", 1684 | "dev": true, 1685 | "dependencies": { 1686 | "ms": "^2.1.3" 1687 | }, 1688 | "engines": { 1689 | "node": ">=6.0" 1690 | }, 1691 | "peerDependenciesMeta": { 1692 | "supports-color": { 1693 | "optional": true 1694 | } 1695 | } 1696 | }, 1697 | "node_modules/deep-is": { 1698 | "version": "0.1.4", 1699 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1700 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1701 | "dev": true 1702 | }, 1703 | "node_modules/detect-libc": { 1704 | "version": "2.0.3", 1705 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.3.tgz", 1706 | "integrity": "sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==", 1707 | "engines": { 1708 | "node": ">=8" 1709 | } 1710 | }, 1711 | "node_modules/electron-to-chromium": { 1712 | "version": "1.5.136", 1713 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.136.tgz", 1714 | "integrity": "sha512-kL4+wUTD7RSA5FHx5YwWtjDnEEkIIikFgWHR4P6fqjw1PPLlqYkxeOb++wAauAssat0YClCy8Y3C5SxgSkjibQ==", 1715 | "dev": true 1716 | }, 1717 | "node_modules/enhanced-resolve": { 1718 | "version": "5.18.1", 1719 | "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.18.1.tgz", 1720 | "integrity": "sha512-ZSW3ma5GkcQBIpwZTSRAI8N71Uuwgs93IezB7mf7R60tC8ZbJideoDNKjHn2O9KIlx6rkGTTEk1xUCK2E1Y2Yg==", 1721 | "dependencies": { 1722 | "graceful-fs": "^4.2.4", 1723 | "tapable": "^2.2.0" 1724 | }, 1725 | "engines": { 1726 | "node": ">=10.13.0" 1727 | } 1728 | }, 1729 | "node_modules/esbuild": { 1730 | "version": "0.25.2", 1731 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.2.tgz", 1732 | "integrity": "sha512-16854zccKPnC+toMywC+uKNeYSv+/eXkevRAfwRD/G9Cleq66m8XFIrigkbvauLLlCfDL45Q2cWegSg53gGBnQ==", 1733 | "hasInstallScript": true, 1734 | "bin": { 1735 | "esbuild": "bin/esbuild" 1736 | }, 1737 | "engines": { 1738 | "node": ">=18" 1739 | }, 1740 | "optionalDependencies": { 1741 | "@esbuild/aix-ppc64": "0.25.2", 1742 | "@esbuild/android-arm": "0.25.2", 1743 | "@esbuild/android-arm64": "0.25.2", 1744 | "@esbuild/android-x64": "0.25.2", 1745 | "@esbuild/darwin-arm64": "0.25.2", 1746 | "@esbuild/darwin-x64": "0.25.2", 1747 | "@esbuild/freebsd-arm64": "0.25.2", 1748 | "@esbuild/freebsd-x64": "0.25.2", 1749 | "@esbuild/linux-arm": "0.25.2", 1750 | "@esbuild/linux-arm64": "0.25.2", 1751 | "@esbuild/linux-ia32": "0.25.2", 1752 | "@esbuild/linux-loong64": "0.25.2", 1753 | "@esbuild/linux-mips64el": "0.25.2", 1754 | "@esbuild/linux-ppc64": "0.25.2", 1755 | "@esbuild/linux-riscv64": "0.25.2", 1756 | "@esbuild/linux-s390x": "0.25.2", 1757 | "@esbuild/linux-x64": "0.25.2", 1758 | "@esbuild/netbsd-arm64": "0.25.2", 1759 | "@esbuild/netbsd-x64": "0.25.2", 1760 | "@esbuild/openbsd-arm64": "0.25.2", 1761 | "@esbuild/openbsd-x64": "0.25.2", 1762 | "@esbuild/sunos-x64": "0.25.2", 1763 | "@esbuild/win32-arm64": "0.25.2", 1764 | "@esbuild/win32-ia32": "0.25.2", 1765 | "@esbuild/win32-x64": "0.25.2" 1766 | } 1767 | }, 1768 | "node_modules/escalade": { 1769 | "version": "3.2.0", 1770 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", 1771 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", 1772 | "dev": true, 1773 | "engines": { 1774 | "node": ">=6" 1775 | } 1776 | }, 1777 | "node_modules/escape-string-regexp": { 1778 | "version": "4.0.0", 1779 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1780 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1781 | "dev": true, 1782 | "engines": { 1783 | "node": ">=10" 1784 | }, 1785 | "funding": { 1786 | "url": "https://github.com/sponsors/sindresorhus" 1787 | } 1788 | }, 1789 | "node_modules/eslint": { 1790 | "version": "9.24.0", 1791 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.24.0.tgz", 1792 | "integrity": "sha512-eh/jxIEJyZrvbWRe4XuVclLPDYSYYYgLy5zXGGxD6j8zjSAxFEzI2fL/8xNq6O2yKqVt+eF2YhV+hxjV6UKXwQ==", 1793 | "dev": true, 1794 | "dependencies": { 1795 | "@eslint-community/eslint-utils": "^4.2.0", 1796 | "@eslint-community/regexpp": "^4.12.1", 1797 | "@eslint/config-array": "^0.20.0", 1798 | "@eslint/config-helpers": "^0.2.0", 1799 | "@eslint/core": "^0.12.0", 1800 | "@eslint/eslintrc": "^3.3.1", 1801 | "@eslint/js": "9.24.0", 1802 | "@eslint/plugin-kit": "^0.2.7", 1803 | "@humanfs/node": "^0.16.6", 1804 | "@humanwhocodes/module-importer": "^1.0.1", 1805 | "@humanwhocodes/retry": "^0.4.2", 1806 | "@types/estree": "^1.0.6", 1807 | "@types/json-schema": "^7.0.15", 1808 | "ajv": "^6.12.4", 1809 | "chalk": "^4.0.0", 1810 | "cross-spawn": "^7.0.6", 1811 | "debug": "^4.3.2", 1812 | "escape-string-regexp": "^4.0.0", 1813 | "eslint-scope": "^8.3.0", 1814 | "eslint-visitor-keys": "^4.2.0", 1815 | "espree": "^10.3.0", 1816 | "esquery": "^1.5.0", 1817 | "esutils": "^2.0.2", 1818 | "fast-deep-equal": "^3.1.3", 1819 | "file-entry-cache": "^8.0.0", 1820 | "find-up": "^5.0.0", 1821 | "glob-parent": "^6.0.2", 1822 | "ignore": "^5.2.0", 1823 | "imurmurhash": "^0.1.4", 1824 | "is-glob": "^4.0.0", 1825 | "json-stable-stringify-without-jsonify": "^1.0.1", 1826 | "lodash.merge": "^4.6.2", 1827 | "minimatch": "^3.1.2", 1828 | "natural-compare": "^1.4.0", 1829 | "optionator": "^0.9.3" 1830 | }, 1831 | "bin": { 1832 | "eslint": "bin/eslint.js" 1833 | }, 1834 | "engines": { 1835 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1836 | }, 1837 | "funding": { 1838 | "url": "https://eslint.org/donate" 1839 | }, 1840 | "peerDependencies": { 1841 | "jiti": "*" 1842 | }, 1843 | "peerDependenciesMeta": { 1844 | "jiti": { 1845 | "optional": true 1846 | } 1847 | } 1848 | }, 1849 | "node_modules/eslint-plugin-react-hooks": { 1850 | "version": "5.2.0", 1851 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.2.0.tgz", 1852 | "integrity": "sha512-+f15FfK64YQwZdJNELETdn5ibXEUQmW1DZL6KXhNnc2heoy/sg9VJJeT7n8TlMWouzWqSWavFkIhHyIbIAEapg==", 1853 | "dev": true, 1854 | "engines": { 1855 | "node": ">=10" 1856 | }, 1857 | "peerDependencies": { 1858 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0" 1859 | } 1860 | }, 1861 | "node_modules/eslint-plugin-react-refresh": { 1862 | "version": "0.4.19", 1863 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.19.tgz", 1864 | "integrity": "sha512-eyy8pcr/YxSYjBoqIFSrlbn9i/xvxUFa8CjzAYo9cFjgGXqq1hyjihcpZvxRLalpaWmueWR81xn7vuKmAFijDQ==", 1865 | "dev": true, 1866 | "peerDependencies": { 1867 | "eslint": ">=8.40" 1868 | } 1869 | }, 1870 | "node_modules/eslint-scope": { 1871 | "version": "8.3.0", 1872 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.3.0.tgz", 1873 | "integrity": "sha512-pUNxi75F8MJ/GdeKtVLSbYg4ZI34J6C0C7sbL4YOp2exGwen7ZsuBqKzUhXd0qMQ362yET3z+uPwKeg/0C2XCQ==", 1874 | "dev": true, 1875 | "dependencies": { 1876 | "esrecurse": "^4.3.0", 1877 | "estraverse": "^5.2.0" 1878 | }, 1879 | "engines": { 1880 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1881 | }, 1882 | "funding": { 1883 | "url": "https://opencollective.com/eslint" 1884 | } 1885 | }, 1886 | "node_modules/eslint-visitor-keys": { 1887 | "version": "4.2.0", 1888 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", 1889 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", 1890 | "dev": true, 1891 | "engines": { 1892 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1893 | }, 1894 | "funding": { 1895 | "url": "https://opencollective.com/eslint" 1896 | } 1897 | }, 1898 | "node_modules/espree": { 1899 | "version": "10.3.0", 1900 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz", 1901 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==", 1902 | "dev": true, 1903 | "dependencies": { 1904 | "acorn": "^8.14.0", 1905 | "acorn-jsx": "^5.3.2", 1906 | "eslint-visitor-keys": "^4.2.0" 1907 | }, 1908 | "engines": { 1909 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 1910 | }, 1911 | "funding": { 1912 | "url": "https://opencollective.com/eslint" 1913 | } 1914 | }, 1915 | "node_modules/esquery": { 1916 | "version": "1.6.0", 1917 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", 1918 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", 1919 | "dev": true, 1920 | "dependencies": { 1921 | "estraverse": "^5.1.0" 1922 | }, 1923 | "engines": { 1924 | "node": ">=0.10" 1925 | } 1926 | }, 1927 | "node_modules/esrecurse": { 1928 | "version": "4.3.0", 1929 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1930 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1931 | "dev": true, 1932 | "dependencies": { 1933 | "estraverse": "^5.2.0" 1934 | }, 1935 | "engines": { 1936 | "node": ">=4.0" 1937 | } 1938 | }, 1939 | "node_modules/estraverse": { 1940 | "version": "5.3.0", 1941 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1942 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1943 | "dev": true, 1944 | "engines": { 1945 | "node": ">=4.0" 1946 | } 1947 | }, 1948 | "node_modules/esutils": { 1949 | "version": "2.0.3", 1950 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1951 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1952 | "dev": true, 1953 | "engines": { 1954 | "node": ">=0.10.0" 1955 | } 1956 | }, 1957 | "node_modules/fast-deep-equal": { 1958 | "version": "3.1.3", 1959 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1960 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1961 | "dev": true 1962 | }, 1963 | "node_modules/fast-json-stable-stringify": { 1964 | "version": "2.1.0", 1965 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1966 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1967 | "dev": true 1968 | }, 1969 | "node_modules/fast-levenshtein": { 1970 | "version": "2.0.6", 1971 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1972 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1973 | "dev": true 1974 | }, 1975 | "node_modules/file-entry-cache": { 1976 | "version": "8.0.0", 1977 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", 1978 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", 1979 | "dev": true, 1980 | "dependencies": { 1981 | "flat-cache": "^4.0.0" 1982 | }, 1983 | "engines": { 1984 | "node": ">=16.0.0" 1985 | } 1986 | }, 1987 | "node_modules/find-up": { 1988 | "version": "5.0.0", 1989 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1990 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1991 | "dev": true, 1992 | "dependencies": { 1993 | "locate-path": "^6.0.0", 1994 | "path-exists": "^4.0.0" 1995 | }, 1996 | "engines": { 1997 | "node": ">=10" 1998 | }, 1999 | "funding": { 2000 | "url": "https://github.com/sponsors/sindresorhus" 2001 | } 2002 | }, 2003 | "node_modules/flat-cache": { 2004 | "version": "4.0.1", 2005 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", 2006 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", 2007 | "dev": true, 2008 | "dependencies": { 2009 | "flatted": "^3.2.9", 2010 | "keyv": "^4.5.4" 2011 | }, 2012 | "engines": { 2013 | "node": ">=16" 2014 | } 2015 | }, 2016 | "node_modules/flatted": { 2017 | "version": "3.3.3", 2018 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.3.tgz", 2019 | "integrity": "sha512-GX+ysw4PBCz0PzosHDepZGANEuFCMLrnRTiEy9McGjmkCQYwRq4A/X786G/fjM/+OjsWSU1ZrY5qyARZmO/uwg==", 2020 | "dev": true 2021 | }, 2022 | "node_modules/fsevents": { 2023 | "version": "2.3.3", 2024 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2025 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2026 | "hasInstallScript": true, 2027 | "optional": true, 2028 | "os": [ 2029 | "darwin" 2030 | ], 2031 | "engines": { 2032 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2033 | } 2034 | }, 2035 | "node_modules/gensync": { 2036 | "version": "1.0.0-beta.2", 2037 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2038 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2039 | "dev": true, 2040 | "engines": { 2041 | "node": ">=6.9.0" 2042 | } 2043 | }, 2044 | "node_modules/glob-parent": { 2045 | "version": "6.0.2", 2046 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2047 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2048 | "dev": true, 2049 | "dependencies": { 2050 | "is-glob": "^4.0.3" 2051 | }, 2052 | "engines": { 2053 | "node": ">=10.13.0" 2054 | } 2055 | }, 2056 | "node_modules/globals": { 2057 | "version": "15.15.0", 2058 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.15.0.tgz", 2059 | "integrity": "sha512-7ACyT3wmyp3I61S4fG682L0VA2RGD9otkqGJIwNUMF1SWUombIIk+af1unuDYgMm082aHYwD+mzJvv9Iu8dsgg==", 2060 | "dev": true, 2061 | "engines": { 2062 | "node": ">=18" 2063 | }, 2064 | "funding": { 2065 | "url": "https://github.com/sponsors/sindresorhus" 2066 | } 2067 | }, 2068 | "node_modules/graceful-fs": { 2069 | "version": "4.2.11", 2070 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 2071 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==" 2072 | }, 2073 | "node_modules/has-flag": { 2074 | "version": "4.0.0", 2075 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2076 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2077 | "dev": true, 2078 | "engines": { 2079 | "node": ">=8" 2080 | } 2081 | }, 2082 | "node_modules/ignore": { 2083 | "version": "5.3.2", 2084 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", 2085 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", 2086 | "dev": true, 2087 | "engines": { 2088 | "node": ">= 4" 2089 | } 2090 | }, 2091 | "node_modules/import-fresh": { 2092 | "version": "3.3.1", 2093 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz", 2094 | "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==", 2095 | "dev": true, 2096 | "dependencies": { 2097 | "parent-module": "^1.0.0", 2098 | "resolve-from": "^4.0.0" 2099 | }, 2100 | "engines": { 2101 | "node": ">=6" 2102 | }, 2103 | "funding": { 2104 | "url": "https://github.com/sponsors/sindresorhus" 2105 | } 2106 | }, 2107 | "node_modules/imurmurhash": { 2108 | "version": "0.1.4", 2109 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2110 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2111 | "dev": true, 2112 | "engines": { 2113 | "node": ">=0.8.19" 2114 | } 2115 | }, 2116 | "node_modules/is-extglob": { 2117 | "version": "2.1.1", 2118 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2119 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2120 | "dev": true, 2121 | "engines": { 2122 | "node": ">=0.10.0" 2123 | } 2124 | }, 2125 | "node_modules/is-glob": { 2126 | "version": "4.0.3", 2127 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2128 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2129 | "dev": true, 2130 | "dependencies": { 2131 | "is-extglob": "^2.1.1" 2132 | }, 2133 | "engines": { 2134 | "node": ">=0.10.0" 2135 | } 2136 | }, 2137 | "node_modules/isexe": { 2138 | "version": "2.0.0", 2139 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2140 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2141 | "dev": true 2142 | }, 2143 | "node_modules/jiti": { 2144 | "version": "2.4.2", 2145 | "resolved": "https://registry.npmjs.org/jiti/-/jiti-2.4.2.tgz", 2146 | "integrity": "sha512-rg9zJN+G4n2nfJl5MW3BMygZX56zKPNVEYYqq7adpmMh4Jn2QNEwhvQlFy6jPVdcod7txZtKHWnyZiA3a0zP7A==", 2147 | "bin": { 2148 | "jiti": "lib/jiti-cli.mjs" 2149 | } 2150 | }, 2151 | "node_modules/js-tokens": { 2152 | "version": "4.0.0", 2153 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2154 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2155 | "dev": true 2156 | }, 2157 | "node_modules/js-yaml": { 2158 | "version": "4.1.0", 2159 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2160 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2161 | "dev": true, 2162 | "dependencies": { 2163 | "argparse": "^2.0.1" 2164 | }, 2165 | "bin": { 2166 | "js-yaml": "bin/js-yaml.js" 2167 | } 2168 | }, 2169 | "node_modules/jsesc": { 2170 | "version": "3.1.0", 2171 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", 2172 | "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", 2173 | "dev": true, 2174 | "bin": { 2175 | "jsesc": "bin/jsesc" 2176 | }, 2177 | "engines": { 2178 | "node": ">=6" 2179 | } 2180 | }, 2181 | "node_modules/json-buffer": { 2182 | "version": "3.0.1", 2183 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2184 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2185 | "dev": true 2186 | }, 2187 | "node_modules/json-schema-traverse": { 2188 | "version": "0.4.1", 2189 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2190 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2191 | "dev": true 2192 | }, 2193 | "node_modules/json-stable-stringify-without-jsonify": { 2194 | "version": "1.0.1", 2195 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2196 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2197 | "dev": true 2198 | }, 2199 | "node_modules/json5": { 2200 | "version": "2.2.3", 2201 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2202 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2203 | "dev": true, 2204 | "bin": { 2205 | "json5": "lib/cli.js" 2206 | }, 2207 | "engines": { 2208 | "node": ">=6" 2209 | } 2210 | }, 2211 | "node_modules/keyv": { 2212 | "version": "4.5.4", 2213 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2214 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2215 | "dev": true, 2216 | "dependencies": { 2217 | "json-buffer": "3.0.1" 2218 | } 2219 | }, 2220 | "node_modules/levn": { 2221 | "version": "0.4.1", 2222 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2223 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2224 | "dev": true, 2225 | "dependencies": { 2226 | "prelude-ls": "^1.2.1", 2227 | "type-check": "~0.4.0" 2228 | }, 2229 | "engines": { 2230 | "node": ">= 0.8.0" 2231 | } 2232 | }, 2233 | "node_modules/lightningcss": { 2234 | "version": "1.29.2", 2235 | "resolved": "https://registry.npmjs.org/lightningcss/-/lightningcss-1.29.2.tgz", 2236 | "integrity": "sha512-6b6gd/RUXKaw5keVdSEtqFVdzWnU5jMxTUjA2bVcMNPLwSQ08Sv/UodBVtETLCn7k4S1Ibxwh7k68IwLZPgKaA==", 2237 | "dependencies": { 2238 | "detect-libc": "^2.0.3" 2239 | }, 2240 | "engines": { 2241 | "node": ">= 12.0.0" 2242 | }, 2243 | "funding": { 2244 | "type": "opencollective", 2245 | "url": "https://opencollective.com/parcel" 2246 | }, 2247 | "optionalDependencies": { 2248 | "lightningcss-darwin-arm64": "1.29.2", 2249 | "lightningcss-darwin-x64": "1.29.2", 2250 | "lightningcss-freebsd-x64": "1.29.2", 2251 | "lightningcss-linux-arm-gnueabihf": "1.29.2", 2252 | "lightningcss-linux-arm64-gnu": "1.29.2", 2253 | "lightningcss-linux-arm64-musl": "1.29.2", 2254 | "lightningcss-linux-x64-gnu": "1.29.2", 2255 | "lightningcss-linux-x64-musl": "1.29.2", 2256 | "lightningcss-win32-arm64-msvc": "1.29.2", 2257 | "lightningcss-win32-x64-msvc": "1.29.2" 2258 | } 2259 | }, 2260 | "node_modules/lightningcss-darwin-arm64": { 2261 | "version": "1.29.2", 2262 | "resolved": "https://registry.npmjs.org/lightningcss-darwin-arm64/-/lightningcss-darwin-arm64-1.29.2.tgz", 2263 | "integrity": "sha512-cK/eMabSViKn/PG8U/a7aCorpeKLMlK0bQeNHmdb7qUnBkNPnL+oV5DjJUo0kqWsJUapZsM4jCfYItbqBDvlcA==", 2264 | "cpu": [ 2265 | "arm64" 2266 | ], 2267 | "optional": true, 2268 | "os": [ 2269 | "darwin" 2270 | ], 2271 | "engines": { 2272 | "node": ">= 12.0.0" 2273 | }, 2274 | "funding": { 2275 | "type": "opencollective", 2276 | "url": "https://opencollective.com/parcel" 2277 | } 2278 | }, 2279 | "node_modules/lightningcss-darwin-x64": { 2280 | "version": "1.29.2", 2281 | "resolved": "https://registry.npmjs.org/lightningcss-darwin-x64/-/lightningcss-darwin-x64-1.29.2.tgz", 2282 | "integrity": "sha512-j5qYxamyQw4kDXX5hnnCKMf3mLlHvG44f24Qyi2965/Ycz829MYqjrVg2H8BidybHBp9kom4D7DR5VqCKDXS0w==", 2283 | "cpu": [ 2284 | "x64" 2285 | ], 2286 | "optional": true, 2287 | "os": [ 2288 | "darwin" 2289 | ], 2290 | "engines": { 2291 | "node": ">= 12.0.0" 2292 | }, 2293 | "funding": { 2294 | "type": "opencollective", 2295 | "url": "https://opencollective.com/parcel" 2296 | } 2297 | }, 2298 | "node_modules/lightningcss-freebsd-x64": { 2299 | "version": "1.29.2", 2300 | "resolved": "https://registry.npmjs.org/lightningcss-freebsd-x64/-/lightningcss-freebsd-x64-1.29.2.tgz", 2301 | "integrity": "sha512-wDk7M2tM78Ii8ek9YjnY8MjV5f5JN2qNVO+/0BAGZRvXKtQrBC4/cn4ssQIpKIPP44YXw6gFdpUF+Ps+RGsCwg==", 2302 | "cpu": [ 2303 | "x64" 2304 | ], 2305 | "optional": true, 2306 | "os": [ 2307 | "freebsd" 2308 | ], 2309 | "engines": { 2310 | "node": ">= 12.0.0" 2311 | }, 2312 | "funding": { 2313 | "type": "opencollective", 2314 | "url": "https://opencollective.com/parcel" 2315 | } 2316 | }, 2317 | "node_modules/lightningcss-linux-arm-gnueabihf": { 2318 | "version": "1.29.2", 2319 | "resolved": "https://registry.npmjs.org/lightningcss-linux-arm-gnueabihf/-/lightningcss-linux-arm-gnueabihf-1.29.2.tgz", 2320 | "integrity": "sha512-IRUrOrAF2Z+KExdExe3Rz7NSTuuJ2HvCGlMKoquK5pjvo2JY4Rybr+NrKnq0U0hZnx5AnGsuFHjGnNT14w26sg==", 2321 | "cpu": [ 2322 | "arm" 2323 | ], 2324 | "optional": true, 2325 | "os": [ 2326 | "linux" 2327 | ], 2328 | "engines": { 2329 | "node": ">= 12.0.0" 2330 | }, 2331 | "funding": { 2332 | "type": "opencollective", 2333 | "url": "https://opencollective.com/parcel" 2334 | } 2335 | }, 2336 | "node_modules/lightningcss-linux-arm64-gnu": { 2337 | "version": "1.29.2", 2338 | "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-gnu/-/lightningcss-linux-arm64-gnu-1.29.2.tgz", 2339 | "integrity": "sha512-KKCpOlmhdjvUTX/mBuaKemp0oeDIBBLFiU5Fnqxh1/DZ4JPZi4evEH7TKoSBFOSOV3J7iEmmBaw/8dpiUvRKlQ==", 2340 | "cpu": [ 2341 | "arm64" 2342 | ], 2343 | "optional": true, 2344 | "os": [ 2345 | "linux" 2346 | ], 2347 | "engines": { 2348 | "node": ">= 12.0.0" 2349 | }, 2350 | "funding": { 2351 | "type": "opencollective", 2352 | "url": "https://opencollective.com/parcel" 2353 | } 2354 | }, 2355 | "node_modules/lightningcss-linux-arm64-musl": { 2356 | "version": "1.29.2", 2357 | "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-musl/-/lightningcss-linux-arm64-musl-1.29.2.tgz", 2358 | "integrity": "sha512-Q64eM1bPlOOUgxFmoPUefqzY1yV3ctFPE6d/Vt7WzLW4rKTv7MyYNky+FWxRpLkNASTnKQUaiMJ87zNODIrrKQ==", 2359 | "cpu": [ 2360 | "arm64" 2361 | ], 2362 | "optional": true, 2363 | "os": [ 2364 | "linux" 2365 | ], 2366 | "engines": { 2367 | "node": ">= 12.0.0" 2368 | }, 2369 | "funding": { 2370 | "type": "opencollective", 2371 | "url": "https://opencollective.com/parcel" 2372 | } 2373 | }, 2374 | "node_modules/lightningcss-linux-x64-gnu": { 2375 | "version": "1.29.2", 2376 | "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-gnu/-/lightningcss-linux-x64-gnu-1.29.2.tgz", 2377 | "integrity": "sha512-0v6idDCPG6epLXtBH/RPkHvYx74CVziHo6TMYga8O2EiQApnUPZsbR9nFNrg2cgBzk1AYqEd95TlrsL7nYABQg==", 2378 | "cpu": [ 2379 | "x64" 2380 | ], 2381 | "optional": true, 2382 | "os": [ 2383 | "linux" 2384 | ], 2385 | "engines": { 2386 | "node": ">= 12.0.0" 2387 | }, 2388 | "funding": { 2389 | "type": "opencollective", 2390 | "url": "https://opencollective.com/parcel" 2391 | } 2392 | }, 2393 | "node_modules/lightningcss-linux-x64-musl": { 2394 | "version": "1.29.2", 2395 | "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-musl/-/lightningcss-linux-x64-musl-1.29.2.tgz", 2396 | "integrity": "sha512-rMpz2yawkgGT8RULc5S4WiZopVMOFWjiItBT7aSfDX4NQav6M44rhn5hjtkKzB+wMTRlLLqxkeYEtQ3dd9696w==", 2397 | "cpu": [ 2398 | "x64" 2399 | ], 2400 | "optional": true, 2401 | "os": [ 2402 | "linux" 2403 | ], 2404 | "engines": { 2405 | "node": ">= 12.0.0" 2406 | }, 2407 | "funding": { 2408 | "type": "opencollective", 2409 | "url": "https://opencollective.com/parcel" 2410 | } 2411 | }, 2412 | "node_modules/lightningcss-win32-arm64-msvc": { 2413 | "version": "1.29.2", 2414 | "resolved": "https://registry.npmjs.org/lightningcss-win32-arm64-msvc/-/lightningcss-win32-arm64-msvc-1.29.2.tgz", 2415 | "integrity": "sha512-nL7zRW6evGQqYVu/bKGK+zShyz8OVzsCotFgc7judbt6wnB2KbiKKJwBE4SGoDBQ1O94RjW4asrCjQL4i8Fhbw==", 2416 | "cpu": [ 2417 | "arm64" 2418 | ], 2419 | "optional": true, 2420 | "os": [ 2421 | "win32" 2422 | ], 2423 | "engines": { 2424 | "node": ">= 12.0.0" 2425 | }, 2426 | "funding": { 2427 | "type": "opencollective", 2428 | "url": "https://opencollective.com/parcel" 2429 | } 2430 | }, 2431 | "node_modules/lightningcss-win32-x64-msvc": { 2432 | "version": "1.29.2", 2433 | "resolved": "https://registry.npmjs.org/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.29.2.tgz", 2434 | "integrity": "sha512-EdIUW3B2vLuHmv7urfzMI/h2fmlnOQBk1xlsDxkN1tCWKjNFjfLhGxYk8C8mzpSfr+A6jFFIi8fU6LbQGsRWjA==", 2435 | "cpu": [ 2436 | "x64" 2437 | ], 2438 | "optional": true, 2439 | "os": [ 2440 | "win32" 2441 | ], 2442 | "engines": { 2443 | "node": ">= 12.0.0" 2444 | }, 2445 | "funding": { 2446 | "type": "opencollective", 2447 | "url": "https://opencollective.com/parcel" 2448 | } 2449 | }, 2450 | "node_modules/locate-path": { 2451 | "version": "6.0.0", 2452 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2453 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2454 | "dev": true, 2455 | "dependencies": { 2456 | "p-locate": "^5.0.0" 2457 | }, 2458 | "engines": { 2459 | "node": ">=10" 2460 | }, 2461 | "funding": { 2462 | "url": "https://github.com/sponsors/sindresorhus" 2463 | } 2464 | }, 2465 | "node_modules/lodash.merge": { 2466 | "version": "4.6.2", 2467 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2468 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2469 | "dev": true 2470 | }, 2471 | "node_modules/lru-cache": { 2472 | "version": "5.1.1", 2473 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2474 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2475 | "dev": true, 2476 | "dependencies": { 2477 | "yallist": "^3.0.2" 2478 | } 2479 | }, 2480 | "node_modules/minimatch": { 2481 | "version": "3.1.2", 2482 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2483 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2484 | "dev": true, 2485 | "dependencies": { 2486 | "brace-expansion": "^1.1.7" 2487 | }, 2488 | "engines": { 2489 | "node": "*" 2490 | } 2491 | }, 2492 | "node_modules/ms": { 2493 | "version": "2.1.3", 2494 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 2495 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", 2496 | "dev": true 2497 | }, 2498 | "node_modules/nanoid": { 2499 | "version": "3.3.11", 2500 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.11.tgz", 2501 | "integrity": "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==", 2502 | "funding": [ 2503 | { 2504 | "type": "github", 2505 | "url": "https://github.com/sponsors/ai" 2506 | } 2507 | ], 2508 | "bin": { 2509 | "nanoid": "bin/nanoid.cjs" 2510 | }, 2511 | "engines": { 2512 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2513 | } 2514 | }, 2515 | "node_modules/natural-compare": { 2516 | "version": "1.4.0", 2517 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2518 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2519 | "dev": true 2520 | }, 2521 | "node_modules/node-releases": { 2522 | "version": "2.0.19", 2523 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.19.tgz", 2524 | "integrity": "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==", 2525 | "dev": true 2526 | }, 2527 | "node_modules/optionator": { 2528 | "version": "0.9.4", 2529 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 2530 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 2531 | "dev": true, 2532 | "dependencies": { 2533 | "deep-is": "^0.1.3", 2534 | "fast-levenshtein": "^2.0.6", 2535 | "levn": "^0.4.1", 2536 | "prelude-ls": "^1.2.1", 2537 | "type-check": "^0.4.0", 2538 | "word-wrap": "^1.2.5" 2539 | }, 2540 | "engines": { 2541 | "node": ">= 0.8.0" 2542 | } 2543 | }, 2544 | "node_modules/p-limit": { 2545 | "version": "3.1.0", 2546 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2547 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2548 | "dev": true, 2549 | "dependencies": { 2550 | "yocto-queue": "^0.1.0" 2551 | }, 2552 | "engines": { 2553 | "node": ">=10" 2554 | }, 2555 | "funding": { 2556 | "url": "https://github.com/sponsors/sindresorhus" 2557 | } 2558 | }, 2559 | "node_modules/p-locate": { 2560 | "version": "5.0.0", 2561 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2562 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2563 | "dev": true, 2564 | "dependencies": { 2565 | "p-limit": "^3.0.2" 2566 | }, 2567 | "engines": { 2568 | "node": ">=10" 2569 | }, 2570 | "funding": { 2571 | "url": "https://github.com/sponsors/sindresorhus" 2572 | } 2573 | }, 2574 | "node_modules/parent-module": { 2575 | "version": "1.0.1", 2576 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2577 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2578 | "dev": true, 2579 | "dependencies": { 2580 | "callsites": "^3.0.0" 2581 | }, 2582 | "engines": { 2583 | "node": ">=6" 2584 | } 2585 | }, 2586 | "node_modules/path-exists": { 2587 | "version": "4.0.0", 2588 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2589 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2590 | "dev": true, 2591 | "engines": { 2592 | "node": ">=8" 2593 | } 2594 | }, 2595 | "node_modules/path-key": { 2596 | "version": "3.1.1", 2597 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2598 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2599 | "dev": true, 2600 | "engines": { 2601 | "node": ">=8" 2602 | } 2603 | }, 2604 | "node_modules/picocolors": { 2605 | "version": "1.1.1", 2606 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", 2607 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==" 2608 | }, 2609 | "node_modules/postcss": { 2610 | "version": "8.5.3", 2611 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.3.tgz", 2612 | "integrity": "sha512-dle9A3yYxlBSrt8Fu+IpjGT8SY8hN0mlaA6GY8t0P5PjIOZemULz/E2Bnm/2dcUOena75OTNkHI76uZBNUUq3A==", 2613 | "funding": [ 2614 | { 2615 | "type": "opencollective", 2616 | "url": "https://opencollective.com/postcss/" 2617 | }, 2618 | { 2619 | "type": "tidelift", 2620 | "url": "https://tidelift.com/funding/github/npm/postcss" 2621 | }, 2622 | { 2623 | "type": "github", 2624 | "url": "https://github.com/sponsors/ai" 2625 | } 2626 | ], 2627 | "dependencies": { 2628 | "nanoid": "^3.3.8", 2629 | "picocolors": "^1.1.1", 2630 | "source-map-js": "^1.2.1" 2631 | }, 2632 | "engines": { 2633 | "node": "^10 || ^12 || >=14" 2634 | } 2635 | }, 2636 | "node_modules/prelude-ls": { 2637 | "version": "1.2.1", 2638 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2639 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2640 | "dev": true, 2641 | "engines": { 2642 | "node": ">= 0.8.0" 2643 | } 2644 | }, 2645 | "node_modules/punycode": { 2646 | "version": "2.3.1", 2647 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2648 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2649 | "dev": true, 2650 | "engines": { 2651 | "node": ">=6" 2652 | } 2653 | }, 2654 | "node_modules/react": { 2655 | "version": "19.1.0", 2656 | "resolved": "https://registry.npmjs.org/react/-/react-19.1.0.tgz", 2657 | "integrity": "sha512-FS+XFBNvn3GTAWq26joslQgWNoFu08F4kl0J4CgdNKADkdSGXQyTCnKteIAJy96Br6YbpEU1LSzV5dYtjMkMDg==", 2658 | "engines": { 2659 | "node": ">=0.10.0" 2660 | } 2661 | }, 2662 | "node_modules/react-dom": { 2663 | "version": "19.1.0", 2664 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.1.0.tgz", 2665 | "integrity": "sha512-Xs1hdnE+DyKgeHJeJznQmYMIBG3TKIHJJT95Q58nHLSrElKlGQqDTR2HQ9fx5CN/Gk6Vh/kupBTDLU11/nDk/g==", 2666 | "dependencies": { 2667 | "scheduler": "^0.26.0" 2668 | }, 2669 | "peerDependencies": { 2670 | "react": "^19.1.0" 2671 | } 2672 | }, 2673 | "node_modules/react-refresh": { 2674 | "version": "0.14.2", 2675 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.2.tgz", 2676 | "integrity": "sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==", 2677 | "dev": true, 2678 | "engines": { 2679 | "node": ">=0.10.0" 2680 | } 2681 | }, 2682 | "node_modules/resolve-from": { 2683 | "version": "4.0.0", 2684 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2685 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2686 | "dev": true, 2687 | "engines": { 2688 | "node": ">=4" 2689 | } 2690 | }, 2691 | "node_modules/rollup": { 2692 | "version": "4.40.0", 2693 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.40.0.tgz", 2694 | "integrity": "sha512-Noe455xmA96nnqH5piFtLobsGbCij7Tu+tb3c1vYjNbTkfzGqXqQXG3wJaYXkRZuQ0vEYN4bhwg7QnIrqB5B+w==", 2695 | "dependencies": { 2696 | "@types/estree": "1.0.7" 2697 | }, 2698 | "bin": { 2699 | "rollup": "dist/bin/rollup" 2700 | }, 2701 | "engines": { 2702 | "node": ">=18.0.0", 2703 | "npm": ">=8.0.0" 2704 | }, 2705 | "optionalDependencies": { 2706 | "@rollup/rollup-android-arm-eabi": "4.40.0", 2707 | "@rollup/rollup-android-arm64": "4.40.0", 2708 | "@rollup/rollup-darwin-arm64": "4.40.0", 2709 | "@rollup/rollup-darwin-x64": "4.40.0", 2710 | "@rollup/rollup-freebsd-arm64": "4.40.0", 2711 | "@rollup/rollup-freebsd-x64": "4.40.0", 2712 | "@rollup/rollup-linux-arm-gnueabihf": "4.40.0", 2713 | "@rollup/rollup-linux-arm-musleabihf": "4.40.0", 2714 | "@rollup/rollup-linux-arm64-gnu": "4.40.0", 2715 | "@rollup/rollup-linux-arm64-musl": "4.40.0", 2716 | "@rollup/rollup-linux-loongarch64-gnu": "4.40.0", 2717 | "@rollup/rollup-linux-powerpc64le-gnu": "4.40.0", 2718 | "@rollup/rollup-linux-riscv64-gnu": "4.40.0", 2719 | "@rollup/rollup-linux-riscv64-musl": "4.40.0", 2720 | "@rollup/rollup-linux-s390x-gnu": "4.40.0", 2721 | "@rollup/rollup-linux-x64-gnu": "4.40.0", 2722 | "@rollup/rollup-linux-x64-musl": "4.40.0", 2723 | "@rollup/rollup-win32-arm64-msvc": "4.40.0", 2724 | "@rollup/rollup-win32-ia32-msvc": "4.40.0", 2725 | "@rollup/rollup-win32-x64-msvc": "4.40.0", 2726 | "fsevents": "~2.3.2" 2727 | } 2728 | }, 2729 | "node_modules/scheduler": { 2730 | "version": "0.26.0", 2731 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.26.0.tgz", 2732 | "integrity": "sha512-NlHwttCI/l5gCPR3D1nNXtWABUmBwvZpEQiD4IXSbIDq8BzLIK/7Ir5gTFSGZDUu37K5cMNp0hFtzO38sC7gWA==" 2733 | }, 2734 | "node_modules/semver": { 2735 | "version": "6.3.1", 2736 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 2737 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 2738 | "dev": true, 2739 | "bin": { 2740 | "semver": "bin/semver.js" 2741 | } 2742 | }, 2743 | "node_modules/shebang-command": { 2744 | "version": "2.0.0", 2745 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2746 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2747 | "dev": true, 2748 | "dependencies": { 2749 | "shebang-regex": "^3.0.0" 2750 | }, 2751 | "engines": { 2752 | "node": ">=8" 2753 | } 2754 | }, 2755 | "node_modules/shebang-regex": { 2756 | "version": "3.0.0", 2757 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2758 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2759 | "dev": true, 2760 | "engines": { 2761 | "node": ">=8" 2762 | } 2763 | }, 2764 | "node_modules/source-map-js": { 2765 | "version": "1.2.1", 2766 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", 2767 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", 2768 | "engines": { 2769 | "node": ">=0.10.0" 2770 | } 2771 | }, 2772 | "node_modules/strip-json-comments": { 2773 | "version": "3.1.1", 2774 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2775 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2776 | "dev": true, 2777 | "engines": { 2778 | "node": ">=8" 2779 | }, 2780 | "funding": { 2781 | "url": "https://github.com/sponsors/sindresorhus" 2782 | } 2783 | }, 2784 | "node_modules/supports-color": { 2785 | "version": "7.2.0", 2786 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2787 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2788 | "dev": true, 2789 | "dependencies": { 2790 | "has-flag": "^4.0.0" 2791 | }, 2792 | "engines": { 2793 | "node": ">=8" 2794 | } 2795 | }, 2796 | "node_modules/tailwindcss": { 2797 | "version": "4.1.3", 2798 | "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.1.3.tgz", 2799 | "integrity": "sha512-2Q+rw9vy1WFXu5cIxlvsabCwhU2qUwodGq03ODhLJ0jW4ek5BUtoCsnLB0qG+m8AHgEsSJcJGDSDe06FXlP74g==" 2800 | }, 2801 | "node_modules/tapable": { 2802 | "version": "2.2.1", 2803 | "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", 2804 | "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", 2805 | "engines": { 2806 | "node": ">=6" 2807 | } 2808 | }, 2809 | "node_modules/type-check": { 2810 | "version": "0.4.0", 2811 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2812 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2813 | "dev": true, 2814 | "dependencies": { 2815 | "prelude-ls": "^1.2.1" 2816 | }, 2817 | "engines": { 2818 | "node": ">= 0.8.0" 2819 | } 2820 | }, 2821 | "node_modules/update-browserslist-db": { 2822 | "version": "1.1.3", 2823 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz", 2824 | "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==", 2825 | "dev": true, 2826 | "funding": [ 2827 | { 2828 | "type": "opencollective", 2829 | "url": "https://opencollective.com/browserslist" 2830 | }, 2831 | { 2832 | "type": "tidelift", 2833 | "url": "https://tidelift.com/funding/github/npm/browserslist" 2834 | }, 2835 | { 2836 | "type": "github", 2837 | "url": "https://github.com/sponsors/ai" 2838 | } 2839 | ], 2840 | "dependencies": { 2841 | "escalade": "^3.2.0", 2842 | "picocolors": "^1.1.1" 2843 | }, 2844 | "bin": { 2845 | "update-browserslist-db": "cli.js" 2846 | }, 2847 | "peerDependencies": { 2848 | "browserslist": ">= 4.21.0" 2849 | } 2850 | }, 2851 | "node_modules/uri-js": { 2852 | "version": "4.4.1", 2853 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2854 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2855 | "dev": true, 2856 | "dependencies": { 2857 | "punycode": "^2.1.0" 2858 | } 2859 | }, 2860 | "node_modules/vite": { 2861 | "version": "6.2.6", 2862 | "resolved": "https://registry.npmjs.org/vite/-/vite-6.2.6.tgz", 2863 | "integrity": "sha512-9xpjNl3kR4rVDZgPNdTL0/c6ao4km69a/2ihNQbcANz8RuCOK3hQBmLSJf3bRKVQjVMda+YvizNE8AwvogcPbw==", 2864 | "dependencies": { 2865 | "esbuild": "^0.25.0", 2866 | "postcss": "^8.5.3", 2867 | "rollup": "^4.30.1" 2868 | }, 2869 | "bin": { 2870 | "vite": "bin/vite.js" 2871 | }, 2872 | "engines": { 2873 | "node": "^18.0.0 || ^20.0.0 || >=22.0.0" 2874 | }, 2875 | "funding": { 2876 | "url": "https://github.com/vitejs/vite?sponsor=1" 2877 | }, 2878 | "optionalDependencies": { 2879 | "fsevents": "~2.3.3" 2880 | }, 2881 | "peerDependencies": { 2882 | "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0", 2883 | "jiti": ">=1.21.0", 2884 | "less": "*", 2885 | "lightningcss": "^1.21.0", 2886 | "sass": "*", 2887 | "sass-embedded": "*", 2888 | "stylus": "*", 2889 | "sugarss": "*", 2890 | "terser": "^5.16.0", 2891 | "tsx": "^4.8.1", 2892 | "yaml": "^2.4.2" 2893 | }, 2894 | "peerDependenciesMeta": { 2895 | "@types/node": { 2896 | "optional": true 2897 | }, 2898 | "jiti": { 2899 | "optional": true 2900 | }, 2901 | "less": { 2902 | "optional": true 2903 | }, 2904 | "lightningcss": { 2905 | "optional": true 2906 | }, 2907 | "sass": { 2908 | "optional": true 2909 | }, 2910 | "sass-embedded": { 2911 | "optional": true 2912 | }, 2913 | "stylus": { 2914 | "optional": true 2915 | }, 2916 | "sugarss": { 2917 | "optional": true 2918 | }, 2919 | "terser": { 2920 | "optional": true 2921 | }, 2922 | "tsx": { 2923 | "optional": true 2924 | }, 2925 | "yaml": { 2926 | "optional": true 2927 | } 2928 | } 2929 | }, 2930 | "node_modules/which": { 2931 | "version": "2.0.2", 2932 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2933 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2934 | "dev": true, 2935 | "dependencies": { 2936 | "isexe": "^2.0.0" 2937 | }, 2938 | "bin": { 2939 | "node-which": "bin/node-which" 2940 | }, 2941 | "engines": { 2942 | "node": ">= 8" 2943 | } 2944 | }, 2945 | "node_modules/word-wrap": { 2946 | "version": "1.2.5", 2947 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 2948 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 2949 | "dev": true, 2950 | "engines": { 2951 | "node": ">=0.10.0" 2952 | } 2953 | }, 2954 | "node_modules/yallist": { 2955 | "version": "3.1.1", 2956 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2957 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 2958 | "dev": true 2959 | }, 2960 | "node_modules/yocto-queue": { 2961 | "version": "0.1.0", 2962 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2963 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2964 | "dev": true, 2965 | "engines": { 2966 | "node": ">=10" 2967 | }, 2968 | "funding": { 2969 | "url": "https://github.com/sponsors/sindresorhus" 2970 | } 2971 | } 2972 | } 2973 | } 2974 | -------------------------------------------------------------------------------- /Lista-Contactos/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "plantilla-base", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "lint": "eslint .", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "@tailwindcss/vite": "^4.1.3", 14 | "react": "^19.0.0", 15 | "react-dom": "^19.0.0", 16 | "tailwindcss": "^4.1.3" 17 | }, 18 | "devDependencies": { 19 | "@eslint/js": "^9.21.0", 20 | "@types/react": "^19.0.10", 21 | "@types/react-dom": "^19.0.4", 22 | "@vitejs/plugin-react": "^4.3.4", 23 | "eslint": "^9.21.0", 24 | "eslint-plugin-react-hooks": "^5.1.0", 25 | "eslint-plugin-react-refresh": "^0.4.19", 26 | "globals": "^15.15.0", 27 | "vite": "^6.2.0" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /Lista-Contactos/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /Lista-Contactos/src/App.css: -------------------------------------------------------------------------------- 1 | #root { 2 | max-width: 1280px; 3 | margin: 0 auto; 4 | padding: 2rem; 5 | text-align: center; 6 | } 7 | 8 | .logo { 9 | height: 6em; 10 | padding: 1.5em; 11 | will-change: filter; 12 | transition: filter 300ms; 13 | } 14 | .logo:hover { 15 | filter: drop-shadow(0 0 2em #646cffaa); 16 | } 17 | .logo.react:hover { 18 | filter: drop-shadow(0 0 2em #61dafbaa); 19 | } 20 | 21 | @keyframes logo-spin { 22 | from { 23 | transform: rotate(0deg); 24 | } 25 | to { 26 | transform: rotate(360deg); 27 | } 28 | } 29 | 30 | @media (prefers-reduced-motion: no-preference) { 31 | a:nth-of-type(2) .logo { 32 | animation: logo-spin infinite 20s linear; 33 | } 34 | } 35 | 36 | .card { 37 | padding: 2em; 38 | } 39 | 40 | .read-the-docs { 41 | color: #888; 42 | } 43 | -------------------------------------------------------------------------------- /Lista-Contactos/src/App.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from 'react'; 2 | 3 | function App() { 4 | const [usuario, setUsuario] = useState({ nombre: "", edad: "", correo: "", cedula: "" }) 5 | const [listaUsuarios, setListaUsuarios] = useState([]) 6 | const [indiceEditar, setIndiceEditar] = useState(null); 7 | 8 | const iniciarEdicion = (indice) => { 9 | setUsuario(listaUsuarios[indice]); 10 | setIndiceEditar(indice); 11 | }; 12 | 13 | 14 | const agregarUsuario = (e) => { 15 | e.preventDefault(); 16 | 17 | if (usuario.nombre && usuario.edad && usuario.correo && usuario.cedula) { 18 | if (indiceEditar !== null) { 19 | const nuevaLista = [...listaUsuarios]; 20 | nuevaLista[indiceEditar] = usuario; 21 | setListaUsuarios(nuevaLista); 22 | setIndiceEditar(null); 23 | alert("Usuario editado exitosamente"); 24 | } else { 25 | setListaUsuarios([...listaUsuarios, usuario]); 26 | alert("Usuario agregado exitosamente"); 27 | } 28 | 29 | setUsuario({ nombre: "", edad: "", correo: "", cedula: "" }); 30 | } else { 31 | alert("Debes completar todos los campos"); 32 | } 33 | }; 34 | 35 | 36 | 37 | const eliminarUsuario = (indice) => { 38 | const nuevaLista = listaUsuarios.filter((usuario, i) => i !== indice); 39 | setListaUsuarios(nuevaLista); 40 | }; 41 | 42 | const mostrarUsuarios = () => { 43 | if (listaUsuarios.length === 0) { 44 | return

No tienes contactos mi friend

45 | } 46 | return
47 | {listaUsuarios.map((usuario, indice) => ( 48 |
49 |
50 |

Contacto #{indice + 1}

51 | Cédula: {usuario.cedula} 52 |
53 |
54 |

Nombre: {usuario.nombre}

55 |

Edad: {usuario.edad}

56 |

Correo: {usuario.correo}

57 |
58 |
59 | 65 |
71 |
72 | ))} 73 |
74 | 75 | 76 | 77 | } 78 | 79 | 80 | return ( 81 |
82 |
83 |

Tus contactos

84 | {mostrarUsuarios()} 85 |
86 |
87 |
88 |

Agregar contacto

89 |
90 |
91 | Datos del contacto 92 | 93 |
94 |
95 | 96 | setUsuario({...usuario, nombre:e.target.value})} 100 | value={usuario.nombre} 101 | className="border border-gray-300 rounded px-3 py-2 focus:outline-none focus:ring-2 focus:ring-sky-500" 102 | /> 103 |
104 | 105 |
106 | 107 | setUsuario({...usuario, edad: e.target.value})} 112 | className="border border-gray-300 rounded px-3 py-2 focus:outline-none focus:ring-2 focus:ring-sky-500" 113 | /> 114 |
115 | 116 |
117 | 118 | setUsuario ({...usuario, correo: e.target.value})} 123 | className="border border-gray-300 rounded px-3 py-2 focus:outline-none focus:ring-2 focus:ring-sky-500" 124 | /> 125 |
126 | 127 |
128 | 129 | setUsuario ({...usuario, cedula: e.target.value})} 134 | className="border border-gray-300 rounded px-3 py-2 focus:outline-none focus:ring-2 focus:ring-sky-500" 135 | /> 136 |
137 |
138 | 144 |
145 |
146 |
147 |
148 | 149 |
150 | ); 151 | } 152 | 153 | export default App; 154 | -------------------------------------------------------------------------------- /Lista-Contactos/src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /Lista-Contactos/src/index.css: -------------------------------------------------------------------------------- 1 | 2 | 3 | @import "tailwindcss"; 4 | 5 | :root { 6 | font-family: system-ui, Avenir, Helvetica, Arial, sans-serif; 7 | line-height: 1.5; 8 | font-weight: 400; 9 | 10 | color-scheme: light dark; 11 | color: rgba(255, 255, 255, 0.87); 12 | background-color: #242424; 13 | 14 | font-synthesis: none; 15 | text-rendering: optimizeLegibility; 16 | -webkit-font-smoothing: antialiased; 17 | -moz-osx-font-smoothing: grayscale; 18 | } 19 | 20 | a { 21 | font-weight: 500; 22 | color: #646cff; 23 | text-decoration: inherit; 24 | } 25 | a:hover { 26 | color: #535bf2; 27 | } 28 | 29 | body { 30 | margin: 0; 31 | display: flex; 32 | place-items: center; 33 | min-width: 320px; 34 | min-height: 100vh; 35 | } 36 | 37 | h1 { 38 | font-size: 3.2em; 39 | line-height: 1.1; 40 | } 41 | 42 | 43 | -------------------------------------------------------------------------------- /Lista-Contactos/src/main.jsx: -------------------------------------------------------------------------------- 1 | import { StrictMode } from 'react' 2 | import { createRoot } from 'react-dom/client' 3 | import './index.css' 4 | import App from './App.jsx' 5 | 6 | createRoot(document.getElementById('root')).render( 7 | 8 | 9 | , 10 | ) 11 | -------------------------------------------------------------------------------- /Lista-Contactos/vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import react from '@vitejs/plugin-react'; 3 | import tailwindcss from '@tailwindcss/vite'; 4 | 5 | export default defineConfig({ 6 | plugins: [react(), tailwindcss()], 7 | }); 8 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |
2 | Proyectos React 3 |
4 | 5 | --- 6 | 7 | # 📦 Monorepo de Proyectos React 8 | 9 | > 🎯 Una colección creativa de **20 proyectos React** de nivel intermedio, desarrollados con **Vite** y **Tailwind CSS** para practicar, mejorar y compartir. 10 | > 💡 Ideal para estudiantes, autodidactas y devs que quieren construir cosas reales con `useState`. 11 | 12 | --- 13 | 14 | ## 🧩 Estructura del monorepo 15 | 16 | Cada carpeta es un proyecto independiente con su propio código, dependencias y estilos. 17 | Puedes clonarlo, estudiarlo, mejorarlo o usarlo como base para tus propios retos. 18 | 19 | --- 20 | 21 | ## 🚀 Proyectos incluidos (nivel intermedio) 22 | 23 | | # | Proyecto | Estado | Descripción breve | 24 | |----|-----------------------------------|--------------|----------------------------------------------| 25 | | 01 | TodoApp | ⬜ Hecho | Crear, marcar,editar y eliminar tareas | 26 | | 02 | Carrito de compras | ⬜ Hecho | Productos con cantidad y subtotal | 27 | | 03 | Lista de contactos | ⬜ Hecho | Nombre, email, y acciones básicas | 28 | | 04 | Calculadora de propinas | ⬜ Por hacer | Divide cuenta entre personas | 29 | | 05 | Biblioteca de libros | ⬜ Por hacer | Marcar libros como leídos | 30 | | 06 | Rutina de ejercicios | ⬜ Por hacer | Planifica ejercicios semanales | 31 | | 07 | Gestor de gastos | ⬜ Por hacer | Añadir, editar, ver totales | 32 | | 08 | Paleta de colores | ⬜ Por hacer | Selecciona y guarda colores favoritos | 33 | | 09 | Checklist inteligente | ⬜ Por hacer | Marcado por secciones y progreso | 34 | | 10 | Sistema de puntos gamificado | ⬜ Por hacer | Recompensas por acciones | 35 | | 11 | Inventario | ⬜ Por hacer | Control de stock y productos | 36 | | 12 | Flashcards | ⬜ Por hacer | Estudiar con tarjetas de memoria | 37 | | 13 | Ahorro mensual | ⬜ Por hacer | Calcula cuánto ahorrar | 38 | | 14 | Posts tipo blog | ⬜ Por hacer | Crear, listar y eliminar posts | 39 | | 15 | Tracker de metas | ⬜ Por hacer | Seguimiento con barra de avance | 40 | | 16 | Juego clic rápido | ⬜ Por hacer | Mide tiempo de reacción | 41 | | 17 | Adivina el país | ⬜ Por hacer | Juego de preguntas | 42 | | 18 | Conversor de unidades | ⬜ Por hacer | °C↔°F, km↔mi, etc. | 43 | | 19 | Generador de tareas aleatorias | ⬜ Por hacer | Ideas random para tareas | 44 | | 20 | Calendario visual | ⬜ Por hacer | Marca días en calendario básico | 45 | 46 | --- 47 | 48 | ## 🛠 Tecnologías usadas 49 | 50 | - ⚛️ React 51 | - ⚡ Vite 52 | - 🎨 Tailwind CSS 53 | - 💾 `useState` 54 | - 🧩 Componentes reutilizables 55 | - 📱 Responsive design 56 | 57 | --- 58 | 59 | ## 📌 Cómo ejecutar un proyecto 60 | 61 | ```bash 62 | cd nombre-del-proyecto 63 | npm install 64 | npm run dev 65 | 66 | 67 | 🧑‍💻 Autor 68 | Johan Bohorquez – Desarrollador frontend 69 | 📍 Colombia | 💻 En constante aprendizaje 70 | 📫 Sigueme en LinkedIn (https://www.linkedin.com/in/johanbodev/) 71 | 72 | 73 | 74 | ⭐ Contribuye 75 | Si quieres sugerir un proyecto, corregir algo o compartir tu versión mejorada, ¡abre un issue o un PR! 76 | 77 | 🧠 Inspira. Aprende. Comparte. 78 | "La mejor forma de aprender a programar, es programando proyectos que te reten cada día." 79 | -------------------------------------------------------------------------------- /carrito-compras/.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 | -------------------------------------------------------------------------------- /carrito-compras/README.md: -------------------------------------------------------------------------------- 1 | # Plantilla Base React + Vite + Tailwind CSS v4 🚀 2 | 3 | Usa esta plantilla para arrancar proyectos rápido. Ya viene con: 4 | - React 5 | - Vite 6 | - TailwindCSS v4 7 | - Estructura ordenada 8 | 9 | ## Uso 10 | 11 | ```bash 12 | cp -r plantilla-base mi-nuevo-proyecto 13 | cd mi-nuevo-proyecto 14 | npm install 15 | npm run dev 16 | -------------------------------------------------------------------------------- /carrito-compras/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 | 6 | export default [ 7 | { ignores: ['dist'] }, 8 | { 9 | files: ['**/*.{js,jsx}'], 10 | languageOptions: { 11 | ecmaVersion: 2020, 12 | globals: globals.browser, 13 | parserOptions: { 14 | ecmaVersion: 'latest', 15 | ecmaFeatures: { jsx: true }, 16 | sourceType: 'module', 17 | }, 18 | }, 19 | plugins: { 20 | 'react-hooks': reactHooks, 21 | 'react-refresh': reactRefresh, 22 | }, 23 | rules: { 24 | ...js.configs.recommended.rules, 25 | ...reactHooks.configs.recommended.rules, 26 | 'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }], 27 | 'react-refresh/only-export-components': [ 28 | 'warn', 29 | { allowConstantExport: true }, 30 | ], 31 | }, 32 | }, 33 | ] 34 | -------------------------------------------------------------------------------- /carrito-compras/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 11 | Vite + React 12 | 13 | 14 |
15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /carrito-compras/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "plantilla-base", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "lint": "eslint .", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "@tailwindcss/vite": "^4.1.3", 14 | "react": "^19.0.0", 15 | "react-dom": "^19.0.0", 16 | "tailwindcss": "^4.1.3" 17 | }, 18 | "devDependencies": { 19 | "@eslint/js": "^9.21.0", 20 | "@types/react": "^19.0.10", 21 | "@types/react-dom": "^19.0.4", 22 | "@vitejs/plugin-react": "^4.3.4", 23 | "eslint": "^9.21.0", 24 | "eslint-plugin-react-hooks": "^5.1.0", 25 | "eslint-plugin-react-refresh": "^0.4.19", 26 | "globals": "^15.15.0", 27 | "vite": "^6.2.0" 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /carrito-compras/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /carrito-compras/src/App.css: -------------------------------------------------------------------------------- 1 | #root { 2 | max-width: 1280px; 3 | margin: 0 auto; 4 | padding: 2rem; 5 | text-align: center; 6 | } 7 | 8 | .logo { 9 | height: 6em; 10 | padding: 1.5em; 11 | will-change: filter; 12 | transition: filter 300ms; 13 | } 14 | .logo:hover { 15 | filter: drop-shadow(0 0 2em #646cffaa); 16 | } 17 | .logo.react:hover { 18 | filter: drop-shadow(0 0 2em #61dafbaa); 19 | } 20 | 21 | @keyframes logo-spin { 22 | from { 23 | transform: rotate(0deg); 24 | } 25 | to { 26 | transform: rotate(360deg); 27 | } 28 | } 29 | 30 | @media (prefers-reduced-motion: no-preference) { 31 | a:nth-of-type(2) .logo { 32 | animation: logo-spin infinite 20s linear; 33 | } 34 | } 35 | 36 | .card { 37 | padding: 2em; 38 | } 39 | 40 | .read-the-docs { 41 | color: #888; 42 | } 43 | -------------------------------------------------------------------------------- /carrito-compras/src/App.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import img from './assets/img.jpg' 3 | 4 | function App() { 5 | const productosDisponibles = [ 6 | { 7 | id: 1, 8 | nombre: "Balon", 9 | precio: 20000, 10 | imagen: img 11 | }, 12 | { 13 | id: 2, 14 | nombre: "Celular", 15 | precio: 2520000, 16 | imagen: img 17 | }, 18 | { 19 | id: 3, 20 | nombre: "Forro de celular", 21 | precio: 18000, 22 | imagen: img 23 | }, 24 | { 25 | id: 4, 26 | nombre: "Perfume", 27 | precio: 230000, 28 | imagen: img 29 | }, 30 | { 31 | id: 5, 32 | nombre: "Reloj", 33 | precio: 65000, 34 | imagen: img 35 | }, 36 | { 37 | id: 6, 38 | nombre: "Cargador", 39 | precio: 10000, 40 | imagen: img 41 | }, 42 | { 43 | id: 7, 44 | nombre: "Libro", 45 | precio: 50000, 46 | imagen: img 47 | }, 48 | { 49 | id: 8, 50 | nombre: "Alcancia", 51 | precio: 2700, 52 | imagen: img 53 | }, 54 | { 55 | id: 9, 56 | nombre: "Laptop Asus", 57 | precio: 2300000, 58 | imagen: img 59 | }, 60 | { 61 | id: 10, 62 | nombre: "Desodorante", 63 | precio: 6000, 64 | imagen: img 65 | }, 66 | ] 67 | 68 | const [carrito, setCarrito] = useState([]) 69 | const [mostrarCarrito, setmostrarCarrito] = useState(false) 70 | 71 | const agregarCarrito = (id) => { 72 | // Busca el producto que coincide con el id 73 | const productoEncontrado = productosDisponibles.find(producto => producto.id === id); 74 | 75 | // Si lo encuentra, lo agrega al carrito 76 | if (productoEncontrado) { 77 | setCarrito([...carrito, productoEncontrado]); 78 | console.log(`Producto agregado: ${productoEncontrado.nombre}`); 79 | } 80 | }; 81 | 82 | const elimianarProductoCarrito = (index) => { 83 | const nuevoCarrito = carrito.filter((producto, i) => i !== index); 84 | setCarrito(nuevoCarrito) 85 | } 86 | 87 | const vaciarCarrito = () => { 88 | setCarrito([]) 89 | } 90 | 91 | const total = carrito.reduce((acc, producto) => acc + producto.precio, 0) / 1 92 | 93 | 94 | return ( 95 |
96 |
97 | 98 |
99 |

Productos disponibles 100 |

101 | 102 | 103 | 117 |
118 | {mostrarCarrito && ( 119 |
120 |
121 |

Tu carrito

122 | 128 | 129 | { 130 | carrito.length > 0 ? ( 131 | <>
132 | {carrito.map((producto, indice) => ( 133 |
  • 134 |
    135 | {`Imagen 136 |
    137 |

    {producto.nombre}

    138 | {producto.precio} 139 |
    140 |
    141 | 147 | 148 |
  • 149 | ))} 150 |
    151 |
    152 | 153 |

    154 | Total: ${total} 155 |

    156 |
    157 | 158 | 159 | 160 | 161 | 162 | ) : ( 163 |
    164 |

    Carrito

    165 |

    No tienes productos

    166 |
    167 | ) 168 | } 169 | 170 |
    171 |
    172 | 173 | )} 174 | 175 |
    176 | ); 177 | } 178 | 179 | export default App; 180 | -------------------------------------------------------------------------------- /carrito-compras/src/assets/img.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/JohanBoDev/react-proyectos/a374ecd4882c15562d382fb7f36229115a8ce214/carrito-compras/src/assets/img.jpg -------------------------------------------------------------------------------- /carrito-compras/src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /carrito-compras/src/index.css: -------------------------------------------------------------------------------- 1 | 2 | 3 | @import "tailwindcss"; 4 | 5 | -------------------------------------------------------------------------------- /carrito-compras/src/main.jsx: -------------------------------------------------------------------------------- 1 | import { StrictMode } from 'react' 2 | import { createRoot } from 'react-dom/client' 3 | import './index.css' 4 | import App from './App.jsx' 5 | 6 | createRoot(document.getElementById('root')).render( 7 | 8 | 9 | , 10 | ) 11 | -------------------------------------------------------------------------------- /carrito-compras/vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import react from '@vitejs/plugin-react'; 3 | import tailwindcss from '@tailwindcss/vite'; 4 | 5 | export default defineConfig({ 6 | plugins: [react(), tailwindcss()], 7 | }); 8 | -------------------------------------------------------------------------------- /img.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/JohanBoDev/react-proyectos/a374ecd4882c15562d382fb7f36229115a8ce214/img.png --------------------------------------------------------------------------------