diff options
| author | A Farzat <a@farzat.xyz> | 2025-10-06 14:29:43 +0300 | 
|---|---|---|
| committer | A Farzat <a@farzat.xyz> | 2025-10-06 14:29:43 +0300 | 
| commit | cbed467589d74022c4a1b49167d237d85663ab96 (patch) | |
| tree | 1bb33cb7314c416f68cd3726530f61192bfeb2ff /front-end | |
| parent | c9205f0fc12a357a45b9ade1dd4077d4c37acd01 (diff) | |
| download | csca5028-cbed467589d74022c4a1b49167d237d85663ab96.tar.gz csca5028-cbed467589d74022c4a1b49167d237d85663ab96.zip | |
Add the front-end component
Diffstat (limited to 'front-end')
| -rw-r--r-- | front-end/.gitignore | 24 | ||||
| -rw-r--r-- | front-end/README.md | 12 | ||||
| -rw-r--r-- | front-end/eslint.config.js | 29 | ||||
| -rw-r--r-- | front-end/index.html | 13 | ||||
| -rw-r--r-- | front-end/package-lock.json | 3079 | ||||
| -rw-r--r-- | front-end/package.json | 28 | ||||
| -rw-r--r-- | front-end/public/vite.svg | 1 | ||||
| -rw-r--r-- | front-end/src/App.css | 322 | ||||
| -rw-r--r-- | front-end/src/App.jsx | 298 | ||||
| -rw-r--r-- | front-end/src/assets/react.svg | 1 | ||||
| -rw-r--r-- | front-end/src/main.jsx | 9 | ||||
| -rw-r--r-- | front-end/vite.config.js | 7 | 
12 files changed, 3823 insertions, 0 deletions
| diff --git a/front-end/.gitignore b/front-end/.gitignore new file mode 100644 index 0000000..a547bf3 --- /dev/null +++ b/front-end/.gitignore @@ -0,0 +1,24 @@ +# Logs +logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* +lerna-debug.log* + +node_modules +dist +dist-ssr +*.local + +# Editor directories and files +.vscode/* +!.vscode/extensions.json +.idea +.DS_Store +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? diff --git a/front-end/README.md b/front-end/README.md new file mode 100644 index 0000000..7059a96 --- /dev/null +++ b/front-end/README.md @@ -0,0 +1,12 @@ +# React + Vite + +This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. + +Currently, two official plugins are available: + +- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react) uses [Babel](https://babeljs.io/) for Fast Refresh +- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh + +## Expanding the ESLint configuration + +If you are developing a production application, we recommend using TypeScript with type-aware lint rules enabled. Check out the [TS template](https://github.com/vitejs/vite/tree/main/packages/create-vite/template-react-ts) for information on how to integrate TypeScript and [`typescript-eslint`](https://typescript-eslint.io) in your project. diff --git a/front-end/eslint.config.js b/front-end/eslint.config.js new file mode 100644 index 0000000..cee1e2c --- /dev/null +++ b/front-end/eslint.config.js @@ -0,0 +1,29 @@ +import js from '@eslint/js' +import globals from 'globals' +import reactHooks from 'eslint-plugin-react-hooks' +import reactRefresh from 'eslint-plugin-react-refresh' +import { defineConfig, globalIgnores } from 'eslint/config' + +export default defineConfig([ +  globalIgnores(['dist']), +  { +    files: ['**/*.{js,jsx}'], +    extends: [ +      js.configs.recommended, +      reactHooks.configs['recommended-latest'], +      reactRefresh.configs.vite, +    ], +    languageOptions: { +      ecmaVersion: 2020, +      globals: globals.browser, +      parserOptions: { +        ecmaVersion: 'latest', +        ecmaFeatures: { jsx: true }, +        sourceType: 'module', +      }, +    }, +    rules: { +      'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }], +    }, +  }, +]) diff --git a/front-end/index.html b/front-end/index.html new file mode 100644 index 0000000..167f9ea --- /dev/null +++ b/front-end/index.html @@ -0,0 +1,13 @@ +<!doctype html> +<html lang="en"> +  <head> +    <meta charset="UTF-8" /> +    <link rel="icon" type="image/svg+xml" href="/react.svg" /> +    <meta name="viewport" content="width=device-width, initial-scale=1.0" /> +    <title>YouTube Subscriber</title> +  </head> +  <body> +    <div id="root"></div> +    <script type="module" src="/src/main.jsx"></script> +  </body> +</html> diff --git a/front-end/package-lock.json b/front-end/package-lock.json new file mode 100644 index 0000000..63227b9 --- /dev/null +++ b/front-end/package-lock.json @@ -0,0 +1,3079 @@ +{ +  "name": "front-end", +  "version": "0.0.0", +  "lockfileVersion": 3, +  "requires": true, +  "packages": { +    "": { +      "name": "front-end", +      "version": "0.0.0", +      "dependencies": { +        "axios": "^1.11.0", +        "react": "^19.1.1", +        "react-dom": "^19.1.1" +      }, +      "devDependencies": { +        "@eslint/js": "^9.33.0", +        "@types/react": "^19.1.10", +        "@types/react-dom": "^19.1.7", +        "@vitejs/plugin-react": "^5.0.0", +        "eslint": "^9.33.0", +        "eslint-plugin-react-hooks": "^5.2.0", +        "eslint-plugin-react-refresh": "^0.4.20", +        "globals": "^16.3.0", +        "vite": "^7.1.2" +      } +    }, +    "node_modules/@ampproject/remapping": { +      "version": "2.3.0", +      "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", +      "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", +      "dev": true, +      "license": "Apache-2.0", +      "dependencies": { +        "@jridgewell/gen-mapping": "^0.3.5", +        "@jridgewell/trace-mapping": "^0.3.24" +      }, +      "engines": { +        "node": ">=6.0.0" +      } +    }, +    "node_modules/@babel/code-frame": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.27.1.tgz", +      "integrity": "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/helper-validator-identifier": "^7.27.1", +        "js-tokens": "^4.0.0", +        "picocolors": "^1.1.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/compat-data": { +      "version": "7.28.0", +      "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.28.0.tgz", +      "integrity": "sha512-60X7qkglvrap8mn1lh2ebxXdZYtUcpd7gsmy9kLaBJ4i/WdY8PqTSdxyA8qraikqKQK5C1KRBKXqznrVapyNaw==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/core": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.28.3.tgz", +      "integrity": "sha512-yDBHV9kQNcr2/sUr9jghVyz9C3Y5G2zUM2H2lo+9mKv4sFgbA8s8Z9t8D1jiTkGoO/NoIfKMyKWr4s6CN23ZwQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@ampproject/remapping": "^2.2.0", +        "@babel/code-frame": "^7.27.1", +        "@babel/generator": "^7.28.3", +        "@babel/helper-compilation-targets": "^7.27.2", +        "@babel/helper-module-transforms": "^7.28.3", +        "@babel/helpers": "^7.28.3", +        "@babel/parser": "^7.28.3", +        "@babel/template": "^7.27.2", +        "@babel/traverse": "^7.28.3", +        "@babel/types": "^7.28.2", +        "convert-source-map": "^2.0.0", +        "debug": "^4.1.0", +        "gensync": "^1.0.0-beta.2", +        "json5": "^2.2.3", +        "semver": "^6.3.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      }, +      "funding": { +        "type": "opencollective", +        "url": "https://opencollective.com/babel" +      } +    }, +    "node_modules/@babel/generator": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.28.3.tgz", +      "integrity": "sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/parser": "^7.28.3", +        "@babel/types": "^7.28.2", +        "@jridgewell/gen-mapping": "^0.3.12", +        "@jridgewell/trace-mapping": "^0.3.28", +        "jsesc": "^3.0.2" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-compilation-targets": { +      "version": "7.27.2", +      "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.27.2.tgz", +      "integrity": "sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/compat-data": "^7.27.2", +        "@babel/helper-validator-option": "^7.27.1", +        "browserslist": "^4.24.0", +        "lru-cache": "^5.1.1", +        "semver": "^6.3.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-globals": { +      "version": "7.28.0", +      "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz", +      "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-module-imports": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.27.1.tgz", +      "integrity": "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/traverse": "^7.27.1", +        "@babel/types": "^7.27.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-module-transforms": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.3.tgz", +      "integrity": "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/helper-module-imports": "^7.27.1", +        "@babel/helper-validator-identifier": "^7.27.1", +        "@babel/traverse": "^7.28.3" +      }, +      "engines": { +        "node": ">=6.9.0" +      }, +      "peerDependencies": { +        "@babel/core": "^7.0.0" +      } +    }, +    "node_modules/@babel/helper-plugin-utils": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.27.1.tgz", +      "integrity": "sha512-1gn1Up5YXka3YYAHGKpbideQ5Yjf1tDa9qYcgysz+cNCXukyLl6DjPXhD3VRwSb8c0J9tA4b2+rHEZtc6R0tlw==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-string-parser": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz", +      "integrity": "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-validator-identifier": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.27.1.tgz", +      "integrity": "sha512-D2hP9eA+Sqx1kBZgzxZh0y1trbuU+JoDkiEwqhQ36nodYqJwyEIhPSdMNd7lOm/4io72luTPWH20Yda0xOuUow==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helper-validator-option": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz", +      "integrity": "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/helpers": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.28.3.tgz", +      "integrity": "sha512-PTNtvUQihsAsDHMOP5pfobP8C6CM4JWXmP8DrEIt46c3r2bf87Ua1zoqevsMo9g+tWDwgWrFP5EIxuBx5RudAw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/template": "^7.27.2", +        "@babel/types": "^7.28.2" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/parser": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.28.3.tgz", +      "integrity": "sha512-7+Ey1mAgYqFAx2h0RuoxcQT5+MlG3GTV0TQrgr7/ZliKsm/MNDxVVutlWaziMq7wJNAz8MTqz55XLpWvva6StA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/types": "^7.28.2" +      }, +      "bin": { +        "parser": "bin/babel-parser.js" +      }, +      "engines": { +        "node": ">=6.0.0" +      } +    }, +    "node_modules/@babel/plugin-transform-react-jsx-self": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.27.1.tgz", +      "integrity": "sha512-6UzkCs+ejGdZ5mFFC/OCUrv028ab2fp1znZmCZjAOBKiBK2jXD1O+BPSfX8X2qjJ75fZBMSnQn3Rq2mrBJK2mw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/helper-plugin-utils": "^7.27.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      }, +      "peerDependencies": { +        "@babel/core": "^7.0.0-0" +      } +    }, +    "node_modules/@babel/plugin-transform-react-jsx-source": { +      "version": "7.27.1", +      "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.27.1.tgz", +      "integrity": "sha512-zbwoTsBruTeKB9hSq73ha66iFeJHuaFkUbwvqElnygoNbj/jHRsSeokowZFN3CZ64IvEqcmmkVe89OPXc7ldAw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/helper-plugin-utils": "^7.27.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      }, +      "peerDependencies": { +        "@babel/core": "^7.0.0-0" +      } +    }, +    "node_modules/@babel/template": { +      "version": "7.27.2", +      "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.27.2.tgz", +      "integrity": "sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/code-frame": "^7.27.1", +        "@babel/parser": "^7.27.2", +        "@babel/types": "^7.27.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/traverse": { +      "version": "7.28.3", +      "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.28.3.tgz", +      "integrity": "sha512-7w4kZYHneL3A6NP2nxzHvT3HCZ7puDZZjFMqDpBPECub79sTtSO5CGXDkKrTQq8ksAwfD/XI2MRFX23njdDaIQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/code-frame": "^7.27.1", +        "@babel/generator": "^7.28.3", +        "@babel/helper-globals": "^7.28.0", +        "@babel/parser": "^7.28.3", +        "@babel/template": "^7.27.2", +        "@babel/types": "^7.28.2", +        "debug": "^4.3.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@babel/types": { +      "version": "7.28.2", +      "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.28.2.tgz", +      "integrity": "sha512-ruv7Ae4J5dUYULmeXw1gmb7rYRz57OWCPM57pHojnLq/3Z1CK2lNSLTCVjxVk1F/TZHwOZZrOWi0ur95BbLxNQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/helper-string-parser": "^7.27.1", +        "@babel/helper-validator-identifier": "^7.27.1" +      }, +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/@esbuild/aix-ppc64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.9.tgz", +      "integrity": "sha512-OaGtL73Jck6pBKjNIe24BnFE6agGl+6KxDtTfHhy1HmhthfKouEcOhqpSL64K4/0WCtbKFLOdzD/44cJ4k9opA==", +      "cpu": [ +        "ppc64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "aix" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/android-arm": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.9.tgz", +      "integrity": "sha512-5WNI1DaMtxQ7t7B6xa572XMXpHAaI/9Hnhk8lcxF4zVN4xstUgTlvuGDorBguKEnZO70qwEcLpfifMLoxiPqHQ==", +      "cpu": [ +        "arm" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "android" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/android-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.9.tgz", +      "integrity": "sha512-IDrddSmpSv51ftWslJMvl3Q2ZT98fUSL2/rlUXuVqRXHCs5EUF1/f+jbjF5+NG9UffUDMCiTyh8iec7u8RlTLg==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "android" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/android-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.9.tgz", +      "integrity": "sha512-I853iMZ1hWZdNllhVZKm34f4wErd4lMyeV7BLzEExGEIZYsOzqDWDf+y082izYUE8gtJnYHdeDpN/6tUdwvfiw==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "android" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/darwin-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.9.tgz", +      "integrity": "sha512-XIpIDMAjOELi/9PB30vEbVMs3GV1v2zkkPnuyRRURbhqjyzIINwj+nbQATh4H9GxUgH1kFsEyQMxwiLFKUS6Rg==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "darwin" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/darwin-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.9.tgz", +      "integrity": "sha512-jhHfBzjYTA1IQu8VyrjCX4ApJDnH+ez+IYVEoJHeqJm9VhG9Dh2BYaJritkYK3vMaXrf7Ogr/0MQ8/MeIefsPQ==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "darwin" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/freebsd-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.9.tgz", +      "integrity": "sha512-z93DmbnY6fX9+KdD4Ue/H6sYs+bhFQJNCPZsi4XWJoYblUqT06MQUdBCpcSfuiN72AbqeBFu5LVQTjfXDE2A6Q==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "freebsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/freebsd-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.9.tgz", +      "integrity": "sha512-mrKX6H/vOyo5v71YfXWJxLVxgy1kyt1MQaD8wZJgJfG4gq4DpQGpgTB74e5yBeQdyMTbgxp0YtNj7NuHN0PoZg==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "freebsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-arm": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.9.tgz", +      "integrity": "sha512-HBU2Xv78SMgaydBmdor38lg8YDnFKSARg1Q6AT0/y2ezUAKiZvc211RDFHlEZRFNRVhcMamiToo7bDx3VEOYQw==", +      "cpu": [ +        "arm" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.9.tgz", +      "integrity": "sha512-BlB7bIcLT3G26urh5Dmse7fiLmLXnRlopw4s8DalgZ8ef79Jj4aUcYbk90g8iCa2467HX8SAIidbL7gsqXHdRw==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-ia32": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.9.tgz", +      "integrity": "sha512-e7S3MOJPZGp2QW6AK6+Ly81rC7oOSerQ+P8L0ta4FhVi+/j/v2yZzx5CqqDaWjtPFfYz21Vi1S0auHrap3Ma3A==", +      "cpu": [ +        "ia32" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-loong64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.9.tgz", +      "integrity": "sha512-Sbe10Bnn0oUAB2AalYztvGcK+o6YFFA/9829PhOCUS9vkJElXGdphz0A3DbMdP8gmKkqPmPcMJmJOrI3VYB1JQ==", +      "cpu": [ +        "loong64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-mips64el": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.9.tgz", +      "integrity": "sha512-YcM5br0mVyZw2jcQeLIkhWtKPeVfAerES5PvOzaDxVtIyZ2NUBZKNLjC5z3/fUlDgT6w89VsxP2qzNipOaaDyA==", +      "cpu": [ +        "mips64el" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-ppc64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.9.tgz", +      "integrity": "sha512-++0HQvasdo20JytyDpFvQtNrEsAgNG2CY1CLMwGXfFTKGBGQT3bOeLSYE2l1fYdvML5KUuwn9Z8L1EWe2tzs1w==", +      "cpu": [ +        "ppc64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-riscv64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.9.tgz", +      "integrity": "sha512-uNIBa279Y3fkjV+2cUjx36xkx7eSjb8IvnL01eXUKXez/CBHNRw5ekCGMPM0BcmqBxBcdgUWuUXmVWwm4CH9kg==", +      "cpu": [ +        "riscv64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-s390x": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.9.tgz", +      "integrity": "sha512-Mfiphvp3MjC/lctb+7D287Xw1DGzqJPb/J2aHHcHxflUo+8tmN/6d4k6I2yFR7BVo5/g7x2Monq4+Yew0EHRIA==", +      "cpu": [ +        "s390x" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/linux-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.9.tgz", +      "integrity": "sha512-iSwByxzRe48YVkmpbgoxVzn76BXjlYFXC7NvLYq+b+kDjyyk30J0JY47DIn8z1MO3K0oSl9fZoRmZPQI4Hklzg==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/netbsd-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.9.tgz", +      "integrity": "sha512-9jNJl6FqaUG+COdQMjSCGW4QiMHH88xWbvZ+kRVblZsWrkXlABuGdFJ1E9L7HK+T0Yqd4akKNa/lO0+jDxQD4Q==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "netbsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/netbsd-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.9.tgz", +      "integrity": "sha512-RLLdkflmqRG8KanPGOU7Rpg829ZHu8nFy5Pqdi9U01VYtG9Y0zOG6Vr2z4/S+/3zIyOxiK6cCeYNWOFR9QP87g==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "netbsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/openbsd-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.9.tgz", +      "integrity": "sha512-YaFBlPGeDasft5IIM+CQAhJAqS3St3nJzDEgsgFixcfZeyGPCd6eJBWzke5piZuZ7CtL656eOSYKk4Ls2C0FRQ==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "openbsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/openbsd-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.9.tgz", +      "integrity": "sha512-1MkgTCuvMGWuqVtAvkpkXFmtL8XhWy+j4jaSO2wxfJtilVCi0ZE37b8uOdMItIHz4I6z1bWWtEX4CJwcKYLcuA==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "openbsd" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/openharmony-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/openharmony-arm64/-/openharmony-arm64-0.25.9.tgz", +      "integrity": "sha512-4Xd0xNiMVXKh6Fa7HEJQbrpP3m3DDn43jKxMjxLLRjWnRsfxjORYJlXPO4JNcXtOyfajXorRKY9NkOpTHptErg==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "openharmony" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/sunos-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.9.tgz", +      "integrity": "sha512-WjH4s6hzo00nNezhp3wFIAfmGZ8U7KtrJNlFMRKxiI9mxEK1scOMAaa9i4crUtu+tBr+0IN6JCuAcSBJZfnphw==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "sunos" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/win32-arm64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.9.tgz", +      "integrity": "sha512-mGFrVJHmZiRqmP8xFOc6b84/7xa5y5YvR1x8djzXpJBSv/UsNK6aqec+6JDjConTgvvQefdGhFDAs2DLAds6gQ==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/win32-ia32": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.9.tgz", +      "integrity": "sha512-b33gLVU2k11nVx1OhX3C8QQP6UHQK4ZtN56oFWvVXvz2VkDoe6fbG8TOgHFxEvqeqohmRnIHe5A1+HADk4OQww==", +      "cpu": [ +        "ia32" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@esbuild/win32-x64": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.9.tgz", +      "integrity": "sha512-PPOl1mi6lpLNQxnGoyAfschAodRFYXJ+9fs6WHXz7CSWKbOqiMZsubC+BQsVKuul+3vKLuwTHsS2c2y9EoKwxQ==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ], +      "engines": { +        "node": ">=18" +      } +    }, +    "node_modules/@eslint-community/eslint-utils": { +      "version": "4.7.0", +      "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.7.0.tgz", +      "integrity": "sha512-dyybb3AcajC7uha6CvhdVRJqaKyn7w2YKqKyAN37NKYgZT36w+iRb0Dymmc5qEJ549c/S31cMMSFd75bteCpCw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "eslint-visitor-keys": "^3.4.3" +      }, +      "engines": { +        "node": "^12.22.0 || ^14.17.0 || >=16.0.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      }, +      "peerDependencies": { +        "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" +      } +    }, +    "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { +      "version": "3.4.3", +      "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", +      "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": "^12.22.0 || ^14.17.0 || >=16.0.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      } +    }, +    "node_modules/@eslint-community/regexpp": { +      "version": "4.12.1", +      "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", +      "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": "^12.0.0 || ^14.0.0 || >=16.0.0" +      } +    }, +    "node_modules/@eslint/config-array": { +      "version": "0.21.0", +      "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.0.tgz", +      "integrity": "sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ==", +      "dev": true, +      "license": "Apache-2.0", +      "dependencies": { +        "@eslint/object-schema": "^2.1.6", +        "debug": "^4.3.1", +        "minimatch": "^3.1.2" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      } +    }, +    "node_modules/@eslint/config-helpers": { +      "version": "0.3.1", +      "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.3.1.tgz", +      "integrity": "sha512-xR93k9WhrDYpXHORXpxVL5oHj3Era7wo6k/Wd8/IsQNnZUTzkGS29lyn3nAT05v6ltUuTFVCCYDEGfy2Or/sPA==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      } +    }, +    "node_modules/@eslint/core": { +      "version": "0.15.2", +      "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.15.2.tgz", +      "integrity": "sha512-78Md3/Rrxh83gCxoUc0EiciuOHsIITzLy53m3d9UyiW8y9Dj2D29FeETqyKA+BRK76tnTp6RXWb3pCay8Oyomg==", +      "dev": true, +      "license": "Apache-2.0", +      "dependencies": { +        "@types/json-schema": "^7.0.15" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      } +    }, +    "node_modules/@eslint/eslintrc": { +      "version": "3.3.1", +      "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz", +      "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "ajv": "^6.12.4", +        "debug": "^4.3.2", +        "espree": "^10.0.1", +        "globals": "^14.0.0", +        "ignore": "^5.2.0", +        "import-fresh": "^3.2.1", +        "js-yaml": "^4.1.0", +        "minimatch": "^3.1.2", +        "strip-json-comments": "^3.1.1" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      } +    }, +    "node_modules/@eslint/eslintrc/node_modules/globals": { +      "version": "14.0.0", +      "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", +      "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=18" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/@eslint/js": { +      "version": "9.33.0", +      "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.33.0.tgz", +      "integrity": "sha512-5K1/mKhWaMfreBGJTwval43JJmkip0RmM+3+IuqupeSKNC/Th2Kc7ucaq5ovTSra/OOKB9c58CGSz3QMVbWt0A==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://eslint.org/donate" +      } +    }, +    "node_modules/@eslint/object-schema": { +      "version": "2.1.6", +      "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz", +      "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      } +    }, +    "node_modules/@eslint/plugin-kit": { +      "version": "0.3.5", +      "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.5.tgz", +      "integrity": "sha512-Z5kJ+wU3oA7MMIqVR9tyZRtjYPr4OC004Q4Rw7pgOKUOKkJfZ3O24nz3WYfGRpMDNmcOi3TwQOmgm7B7Tpii0w==", +      "dev": true, +      "license": "Apache-2.0", +      "dependencies": { +        "@eslint/core": "^0.15.2", +        "levn": "^0.4.1" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      } +    }, +    "node_modules/@humanfs/core": { +      "version": "0.19.1", +      "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz", +      "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": ">=18.18.0" +      } +    }, +    "node_modules/@humanfs/node": { +      "version": "0.16.6", +      "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz", +      "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==", +      "dev": true, +      "license": "Apache-2.0", +      "dependencies": { +        "@humanfs/core": "^0.19.1", +        "@humanwhocodes/retry": "^0.3.0" +      }, +      "engines": { +        "node": ">=18.18.0" +      } +    }, +    "node_modules/@humanfs/node/node_modules/@humanwhocodes/retry": { +      "version": "0.3.1", +      "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", +      "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": ">=18.18" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/nzakas" +      } +    }, +    "node_modules/@humanwhocodes/module-importer": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", +      "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": ">=12.22" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/nzakas" +      } +    }, +    "node_modules/@humanwhocodes/retry": { +      "version": "0.4.3", +      "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz", +      "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": ">=18.18" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/nzakas" +      } +    }, +    "node_modules/@jridgewell/gen-mapping": { +      "version": "0.3.13", +      "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz", +      "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@jridgewell/sourcemap-codec": "^1.5.0", +        "@jridgewell/trace-mapping": "^0.3.24" +      } +    }, +    "node_modules/@jridgewell/resolve-uri": { +      "version": "3.1.2", +      "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", +      "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.0.0" +      } +    }, +    "node_modules/@jridgewell/sourcemap-codec": { +      "version": "1.5.5", +      "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz", +      "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/@jridgewell/trace-mapping": { +      "version": "0.3.30", +      "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.30.tgz", +      "integrity": "sha512-GQ7Nw5G2lTu/BtHTKfXhKHok2WGetd4XYcVKGx00SjAk8GMwgJM3zr6zORiPGuOE+/vkc90KtTosSSvaCjKb2Q==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@jridgewell/resolve-uri": "^3.1.0", +        "@jridgewell/sourcemap-codec": "^1.4.14" +      } +    }, +    "node_modules/@rolldown/pluginutils": { +      "version": "1.0.0-beta.32", +      "resolved": "https://registry.npmjs.org/@rolldown/pluginutils/-/pluginutils-1.0.0-beta.32.tgz", +      "integrity": "sha512-QReCdvxiUZAPkvp1xpAg62IeNzykOFA6syH2CnClif4YmALN1XKpB39XneL80008UbtMShthSVDKmrx05N1q/g==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/@rollup/rollup-android-arm-eabi": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.47.1.tgz", +      "integrity": "sha512-lTahKRJip0knffA/GTNFJMrToD+CM+JJ+Qt5kjzBK/sFQ0EWqfKW3AYQSlZXN98tX0lx66083U9JYIMioMMK7g==", +      "cpu": [ +        "arm" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "android" +      ] +    }, +    "node_modules/@rollup/rollup-android-arm64": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.47.1.tgz", +      "integrity": "sha512-uqxkb3RJLzlBbh/bbNQ4r7YpSZnjgMgyoEOY7Fy6GCbelkDSAzeiogxMG9TfLsBbqmGsdDObo3mzGqa8hps4MA==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "android" +      ] +    }, +    "node_modules/@rollup/rollup-darwin-arm64": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.47.1.tgz", +      "integrity": "sha512-tV6reObmxBDS4DDyLzTDIpymthNlxrLBGAoQx6m2a7eifSNEZdkXQl1PE4ZjCkEDPVgNXSzND/k9AQ3mC4IOEQ==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "darwin" +      ] +    }, +    "node_modules/@rollup/rollup-darwin-x64": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.47.1.tgz", +      "integrity": "sha512-XuJRPTnMk1lwsSnS3vYyVMu4x/+WIw1MMSiqj5C4j3QOWsMzbJEK90zG+SWV1h0B1ABGCQ0UZUjti+TQK35uHQ==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "darwin" +      ] +    }, +    "node_modules/@rollup/rollup-freebsd-arm64": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.47.1.tgz", +      "integrity": "sha512-79BAm8Ag/tmJ5asCqgOXsb3WY28Rdd5Lxj8ONiQzWzy9LvWORd5qVuOnjlqiWWZJw+dWewEktZb5yiM1DLLaHw==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "freebsd" +      ] +    }, +    "node_modules/@rollup/rollup-freebsd-x64": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.47.1.tgz", +      "integrity": "sha512-OQ2/ZDGzdOOlyfqBiip0ZX/jVFekzYrGtUsqAfLDbWy0jh1PUU18+jYp8UMpqhly5ltEqotc2miLngf9FPSWIA==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "freebsd" +      ] +    }, +    "node_modules/@rollup/rollup-linux-arm-gnueabihf": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.47.1.tgz", +      "integrity": "sha512-HZZBXJL1udxlCVvoVadstgiU26seKkHbbAMLg7680gAcMnRNP9SAwTMVet02ANA94kXEI2VhBnXs4e5nf7KG2A==", +      "cpu": [ +        "arm" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-arm-musleabihf": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.47.1.tgz", +      "integrity": "sha512-sZ5p2I9UA7T950JmuZ3pgdKA6+RTBr+0FpK427ExW0t7n+QwYOcmDTK/aRlzoBrWyTpJNlS3kacgSlSTUg6P/Q==", +      "cpu": [ +        "arm" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-arm64-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.47.1.tgz", +      "integrity": "sha512-3hBFoqPyU89Dyf1mQRXCdpc6qC6At3LV6jbbIOZd72jcx7xNk3aAp+EjzAtN6sDlmHFzsDJN5yeUySvorWeRXA==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-arm64-musl": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.47.1.tgz", +      "integrity": "sha512-49J4FnMHfGodJWPw73Ve+/hsPjZgcXQGkmqBGZFvltzBKRS+cvMiWNLadOMXKGnYRhs1ToTGM0sItKISoSGUNA==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-loongarch64-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.47.1.tgz", +      "integrity": "sha512-4yYU8p7AneEpQkRX03pbpLmE21z5JNys16F1BZBZg5fP9rIlb0TkeQjn5du5w4agConCCEoYIG57sNxjryHEGg==", +      "cpu": [ +        "loong64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-ppc64-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.47.1.tgz", +      "integrity": "sha512-fAiq+J28l2YMWgC39jz/zPi2jqc0y3GSRo1yyxlBHt6UN0yYgnegHSRPa3pnHS5amT/efXQrm0ug5+aNEu9UuQ==", +      "cpu": [ +        "ppc64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-riscv64-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.47.1.tgz", +      "integrity": "sha512-daoT0PMENNdjVYYU9xec30Y2prb1AbEIbb64sqkcQcSaR0zYuKkoPuhIztfxuqN82KYCKKrj+tQe4Gi7OSm1ow==", +      "cpu": [ +        "riscv64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-riscv64-musl": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.47.1.tgz", +      "integrity": "sha512-JNyXaAhWtdzfXu5pUcHAuNwGQKevR+6z/poYQKVW+pLaYOj9G1meYc57/1Xv2u4uTxfu9qEWmNTjv/H/EpAisw==", +      "cpu": [ +        "riscv64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-s390x-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.47.1.tgz", +      "integrity": "sha512-U/CHbqKSwEQyZXjCpY43/GLYcTVKEXeRHw0rMBJP7fP3x6WpYG4LTJWR3ic6TeYKX6ZK7mrhltP4ppolyVhLVQ==", +      "cpu": [ +        "s390x" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-x64-gnu": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.47.1.tgz", +      "integrity": "sha512-uTLEakjxOTElfeZIGWkC34u2auLHB1AYS6wBjPGI00bWdxdLcCzK5awjs25YXpqB9lS8S0vbO0t9ZcBeNibA7g==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-linux-x64-musl": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.47.1.tgz", +      "integrity": "sha512-Ft+d/9DXs30BK7CHCTX11FtQGHUdpNDLJW0HHLign4lgMgBcPFN3NkdIXhC5r9iwsMwYreBBc4Rho5ieOmKNVQ==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "linux" +      ] +    }, +    "node_modules/@rollup/rollup-win32-arm64-msvc": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.47.1.tgz", +      "integrity": "sha512-N9X5WqGYzZnjGAFsKSfYFtAShYjwOmFJoWbLg3dYixZOZqU7hdMq+/xyS14zKLhFhZDhP9VfkzQnsdk0ZDS9IA==", +      "cpu": [ +        "arm64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ] +    }, +    "node_modules/@rollup/rollup-win32-ia32-msvc": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.47.1.tgz", +      "integrity": "sha512-O+KcfeCORZADEY8oQJk4HK8wtEOCRE4MdOkb8qGZQNun3jzmj2nmhV/B/ZaaZOkPmJyvm/gW9n0gsB4eRa1eiQ==", +      "cpu": [ +        "ia32" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ] +    }, +    "node_modules/@rollup/rollup-win32-x64-msvc": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.47.1.tgz", +      "integrity": "sha512-CpKnYa8eHthJa3c+C38v/E+/KZyF1Jdh2Cz3DyKZqEWYgrM1IHFArXNWvBLPQCKUEsAqqKX27tTqVEFbDNUcOA==", +      "cpu": [ +        "x64" +      ], +      "dev": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "win32" +      ] +    }, +    "node_modules/@types/babel__core": { +      "version": "7.20.5", +      "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", +      "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/parser": "^7.20.7", +        "@babel/types": "^7.20.7", +        "@types/babel__generator": "*", +        "@types/babel__template": "*", +        "@types/babel__traverse": "*" +      } +    }, +    "node_modules/@types/babel__generator": { +      "version": "7.27.0", +      "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.27.0.tgz", +      "integrity": "sha512-ufFd2Xi92OAVPYsy+P4n7/U7e68fex0+Ee8gSG9KX7eo084CWiQ4sdxktvdl0bOPupXtVJPY19zk6EwWqUQ8lg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/types": "^7.0.0" +      } +    }, +    "node_modules/@types/babel__template": { +      "version": "7.4.4", +      "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", +      "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/parser": "^7.1.0", +        "@babel/types": "^7.0.0" +      } +    }, +    "node_modules/@types/babel__traverse": { +      "version": "7.28.0", +      "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.28.0.tgz", +      "integrity": "sha512-8PvcXf70gTDZBgt9ptxJ8elBeBjcLOAcOtoO/mPJjtji1+CdGbHgm77om1GrsPxsiE+uXIpNSK64UYaIwQXd4Q==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/types": "^7.28.2" +      } +    }, +    "node_modules/@types/estree": { +      "version": "1.0.8", +      "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz", +      "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/@types/json-schema": { +      "version": "7.0.15", +      "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", +      "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/@types/react": { +      "version": "19.1.10", +      "resolved": "https://registry.npmjs.org/@types/react/-/react-19.1.10.tgz", +      "integrity": "sha512-EhBeSYX0Y6ye8pNebpKrwFJq7BoQ8J5SO6NlvNwwHjSj6adXJViPQrKlsyPw7hLBLvckEMO1yxeGdR82YBBlDg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "csstype": "^3.0.2" +      } +    }, +    "node_modules/@types/react-dom": { +      "version": "19.1.7", +      "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.1.7.tgz", +      "integrity": "sha512-i5ZzwYpqjmrKenzkoLM2Ibzt6mAsM7pxB6BCIouEVVmgiqaMj1TjaK7hnA36hbW5aZv20kx7Lw6hWzPWg0Rurw==", +      "dev": true, +      "license": "MIT", +      "peerDependencies": { +        "@types/react": "^19.0.0" +      } +    }, +    "node_modules/@vitejs/plugin-react": { +      "version": "5.0.1", +      "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-5.0.1.tgz", +      "integrity": "sha512-DE4UNaBXwtVoDJ0ccBdLVjFTWL70NRuWNCxEieTI3lrq9ORB9aOCQEKstwDXBl87NvFdbqh/p7eINGyj0BthJA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@babel/core": "^7.28.3", +        "@babel/plugin-transform-react-jsx-self": "^7.27.1", +        "@babel/plugin-transform-react-jsx-source": "^7.27.1", +        "@rolldown/pluginutils": "1.0.0-beta.32", +        "@types/babel__core": "^7.20.5", +        "react-refresh": "^0.17.0" +      }, +      "engines": { +        "node": "^20.19.0 || >=22.12.0" +      }, +      "peerDependencies": { +        "vite": "^4.2.0 || ^5.0.0 || ^6.0.0 || ^7.0.0" +      } +    }, +    "node_modules/acorn": { +      "version": "8.15.0", +      "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", +      "integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==", +      "dev": true, +      "license": "MIT", +      "bin": { +        "acorn": "bin/acorn" +      }, +      "engines": { +        "node": ">=0.4.0" +      } +    }, +    "node_modules/acorn-jsx": { +      "version": "5.3.2", +      "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", +      "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", +      "dev": true, +      "license": "MIT", +      "peerDependencies": { +        "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" +      } +    }, +    "node_modules/ajv": { +      "version": "6.12.6", +      "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", +      "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "fast-deep-equal": "^3.1.1", +        "fast-json-stable-stringify": "^2.0.0", +        "json-schema-traverse": "^0.4.1", +        "uri-js": "^4.2.2" +      }, +      "funding": { +        "type": "github", +        "url": "https://github.com/sponsors/epoberezkin" +      } +    }, +    "node_modules/ansi-styles": { +      "version": "4.3.0", +      "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", +      "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "color-convert": "^2.0.1" +      }, +      "engines": { +        "node": ">=8" +      }, +      "funding": { +        "url": "https://github.com/chalk/ansi-styles?sponsor=1" +      } +    }, +    "node_modules/argparse": { +      "version": "2.0.1", +      "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", +      "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", +      "dev": true, +      "license": "Python-2.0" +    }, +    "node_modules/asynckit": { +      "version": "0.4.0", +      "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", +      "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", +      "license": "MIT" +    }, +    "node_modules/axios": { +      "version": "1.11.0", +      "resolved": "https://registry.npmjs.org/axios/-/axios-1.11.0.tgz", +      "integrity": "sha512-1Lx3WLFQWm3ooKDYZD1eXmoGO9fxYQjrycfHFC8P0sCfQVXyROp0p9PFWBehewBOdCwHc+f/b8I0fMto5eSfwA==", +      "license": "MIT", +      "dependencies": { +        "follow-redirects": "^1.15.6", +        "form-data": "^4.0.4", +        "proxy-from-env": "^1.1.0" +      } +    }, +    "node_modules/balanced-match": { +      "version": "1.0.2", +      "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", +      "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/brace-expansion": { +      "version": "1.1.12", +      "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz", +      "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "balanced-match": "^1.0.0", +        "concat-map": "0.0.1" +      } +    }, +    "node_modules/browserslist": { +      "version": "4.25.3", +      "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.25.3.tgz", +      "integrity": "sha512-cDGv1kkDI4/0e5yON9yM5G/0A5u8sf5TnmdX5C9qHzI9PPu++sQ9zjm1k9NiOrf3riY4OkK0zSGqfvJyJsgCBQ==", +      "dev": true, +      "funding": [ +        { +          "type": "opencollective", +          "url": "https://opencollective.com/browserslist" +        }, +        { +          "type": "tidelift", +          "url": "https://tidelift.com/funding/github/npm/browserslist" +        }, +        { +          "type": "github", +          "url": "https://github.com/sponsors/ai" +        } +      ], +      "license": "MIT", +      "dependencies": { +        "caniuse-lite": "^1.0.30001735", +        "electron-to-chromium": "^1.5.204", +        "node-releases": "^2.0.19", +        "update-browserslist-db": "^1.1.3" +      }, +      "bin": { +        "browserslist": "cli.js" +      }, +      "engines": { +        "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" +      } +    }, +    "node_modules/call-bind-apply-helpers": { +      "version": "1.0.2", +      "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", +      "integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==", +      "license": "MIT", +      "dependencies": { +        "es-errors": "^1.3.0", +        "function-bind": "^1.1.2" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/callsites": { +      "version": "3.1.0", +      "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", +      "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/caniuse-lite": { +      "version": "1.0.30001737", +      "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001737.tgz", +      "integrity": "sha512-BiloLiXtQNrY5UyF0+1nSJLXUENuhka2pzy2Fx5pGxqavdrxSCW4U6Pn/PoG3Efspi2frRbHpBV2XsrPE6EDlw==", +      "dev": true, +      "funding": [ +        { +          "type": "opencollective", +          "url": "https://opencollective.com/browserslist" +        }, +        { +          "type": "tidelift", +          "url": "https://tidelift.com/funding/github/npm/caniuse-lite" +        }, +        { +          "type": "github", +          "url": "https://github.com/sponsors/ai" +        } +      ], +      "license": "CC-BY-4.0" +    }, +    "node_modules/chalk": { +      "version": "4.1.2", +      "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", +      "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "ansi-styles": "^4.1.0", +        "supports-color": "^7.1.0" +      }, +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/chalk/chalk?sponsor=1" +      } +    }, +    "node_modules/color-convert": { +      "version": "2.0.1", +      "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", +      "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "color-name": "~1.1.4" +      }, +      "engines": { +        "node": ">=7.0.0" +      } +    }, +    "node_modules/color-name": { +      "version": "1.1.4", +      "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", +      "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/combined-stream": { +      "version": "1.0.8", +      "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", +      "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", +      "license": "MIT", +      "dependencies": { +        "delayed-stream": "~1.0.0" +      }, +      "engines": { +        "node": ">= 0.8" +      } +    }, +    "node_modules/concat-map": { +      "version": "0.0.1", +      "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", +      "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/convert-source-map": { +      "version": "2.0.0", +      "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", +      "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/cross-spawn": { +      "version": "7.0.6", +      "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", +      "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "path-key": "^3.1.0", +        "shebang-command": "^2.0.0", +        "which": "^2.0.1" +      }, +      "engines": { +        "node": ">= 8" +      } +    }, +    "node_modules/csstype": { +      "version": "3.1.3", +      "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", +      "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/debug": { +      "version": "4.4.1", +      "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz", +      "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "ms": "^2.1.3" +      }, +      "engines": { +        "node": ">=6.0" +      }, +      "peerDependenciesMeta": { +        "supports-color": { +          "optional": true +        } +      } +    }, +    "node_modules/deep-is": { +      "version": "0.1.4", +      "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", +      "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/delayed-stream": { +      "version": "1.0.0", +      "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", +      "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", +      "license": "MIT", +      "engines": { +        "node": ">=0.4.0" +      } +    }, +    "node_modules/dunder-proto": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/dunder-proto/-/dunder-proto-1.0.1.tgz", +      "integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==", +      "license": "MIT", +      "dependencies": { +        "call-bind-apply-helpers": "^1.0.1", +        "es-errors": "^1.3.0", +        "gopd": "^1.2.0" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/electron-to-chromium": { +      "version": "1.5.208", +      "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.208.tgz", +      "integrity": "sha512-ozZyibehoe7tOhNaf16lKmljVf+3npZcJIEbJRVftVsmAg5TeA1mGS9dVCZzOwr2xT7xK15V0p7+GZqSPgkuPg==", +      "dev": true, +      "license": "ISC" +    }, +    "node_modules/es-define-property": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz", +      "integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/es-errors": { +      "version": "1.3.0", +      "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", +      "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/es-object-atoms": { +      "version": "1.1.1", +      "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.1.1.tgz", +      "integrity": "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==", +      "license": "MIT", +      "dependencies": { +        "es-errors": "^1.3.0" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/es-set-tostringtag": { +      "version": "2.1.0", +      "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.1.0.tgz", +      "integrity": "sha512-j6vWzfrGVfyXxge+O0x5sh6cvxAog0a/4Rdd2K36zCMV5eJ+/+tOAngRO8cODMNWbVRdVlmGZQL2YS3yR8bIUA==", +      "license": "MIT", +      "dependencies": { +        "es-errors": "^1.3.0", +        "get-intrinsic": "^1.2.6", +        "has-tostringtag": "^1.0.2", +        "hasown": "^2.0.2" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/esbuild": { +      "version": "0.25.9", +      "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.9.tgz", +      "integrity": "sha512-CRbODhYyQx3qp7ZEwzxOk4JBqmD/seJrzPa/cGjY1VtIn5E09Oi9/dB4JwctnfZ8Q8iT7rioVv5k/FNT/uf54g==", +      "dev": true, +      "hasInstallScript": true, +      "license": "MIT", +      "bin": { +        "esbuild": "bin/esbuild" +      }, +      "engines": { +        "node": ">=18" +      }, +      "optionalDependencies": { +        "@esbuild/aix-ppc64": "0.25.9", +        "@esbuild/android-arm": "0.25.9", +        "@esbuild/android-arm64": "0.25.9", +        "@esbuild/android-x64": "0.25.9", +        "@esbuild/darwin-arm64": "0.25.9", +        "@esbuild/darwin-x64": "0.25.9", +        "@esbuild/freebsd-arm64": "0.25.9", +        "@esbuild/freebsd-x64": "0.25.9", +        "@esbuild/linux-arm": "0.25.9", +        "@esbuild/linux-arm64": "0.25.9", +        "@esbuild/linux-ia32": "0.25.9", +        "@esbuild/linux-loong64": "0.25.9", +        "@esbuild/linux-mips64el": "0.25.9", +        "@esbuild/linux-ppc64": "0.25.9", +        "@esbuild/linux-riscv64": "0.25.9", +        "@esbuild/linux-s390x": "0.25.9", +        "@esbuild/linux-x64": "0.25.9", +        "@esbuild/netbsd-arm64": "0.25.9", +        "@esbuild/netbsd-x64": "0.25.9", +        "@esbuild/openbsd-arm64": "0.25.9", +        "@esbuild/openbsd-x64": "0.25.9", +        "@esbuild/openharmony-arm64": "0.25.9", +        "@esbuild/sunos-x64": "0.25.9", +        "@esbuild/win32-arm64": "0.25.9", +        "@esbuild/win32-ia32": "0.25.9", +        "@esbuild/win32-x64": "0.25.9" +      } +    }, +    "node_modules/escalade": { +      "version": "3.2.0", +      "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", +      "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/escape-string-regexp": { +      "version": "4.0.0", +      "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", +      "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/eslint": { +      "version": "9.33.0", +      "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.33.0.tgz", +      "integrity": "sha512-TS9bTNIryDzStCpJN93aC5VRSW3uTx9sClUn4B87pwiCaJh220otoI0X8mJKr+VcPtniMdN8GKjlwgWGUv5ZKA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@eslint-community/eslint-utils": "^4.2.0", +        "@eslint-community/regexpp": "^4.12.1", +        "@eslint/config-array": "^0.21.0", +        "@eslint/config-helpers": "^0.3.1", +        "@eslint/core": "^0.15.2", +        "@eslint/eslintrc": "^3.3.1", +        "@eslint/js": "9.33.0", +        "@eslint/plugin-kit": "^0.3.5", +        "@humanfs/node": "^0.16.6", +        "@humanwhocodes/module-importer": "^1.0.1", +        "@humanwhocodes/retry": "^0.4.2", +        "@types/estree": "^1.0.6", +        "@types/json-schema": "^7.0.15", +        "ajv": "^6.12.4", +        "chalk": "^4.0.0", +        "cross-spawn": "^7.0.6", +        "debug": "^4.3.2", +        "escape-string-regexp": "^4.0.0", +        "eslint-scope": "^8.4.0", +        "eslint-visitor-keys": "^4.2.1", +        "espree": "^10.4.0", +        "esquery": "^1.5.0", +        "esutils": "^2.0.2", +        "fast-deep-equal": "^3.1.3", +        "file-entry-cache": "^8.0.0", +        "find-up": "^5.0.0", +        "glob-parent": "^6.0.2", +        "ignore": "^5.2.0", +        "imurmurhash": "^0.1.4", +        "is-glob": "^4.0.0", +        "json-stable-stringify-without-jsonify": "^1.0.1", +        "lodash.merge": "^4.6.2", +        "minimatch": "^3.1.2", +        "natural-compare": "^1.4.0", +        "optionator": "^0.9.3" +      }, +      "bin": { +        "eslint": "bin/eslint.js" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://eslint.org/donate" +      }, +      "peerDependencies": { +        "jiti": "*" +      }, +      "peerDependenciesMeta": { +        "jiti": { +          "optional": true +        } +      } +    }, +    "node_modules/eslint-plugin-react-hooks": { +      "version": "5.2.0", +      "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.2.0.tgz", +      "integrity": "sha512-+f15FfK64YQwZdJNELETdn5ibXEUQmW1DZL6KXhNnc2heoy/sg9VJJeT7n8TlMWouzWqSWavFkIhHyIbIAEapg==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=10" +      }, +      "peerDependencies": { +        "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0" +      } +    }, +    "node_modules/eslint-plugin-react-refresh": { +      "version": "0.4.20", +      "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.20.tgz", +      "integrity": "sha512-XpbHQ2q5gUF8BGOX4dHe+71qoirYMhApEPZ7sfhF/dNnOF1UXnCMGZf79SFTBO7Bz5YEIT4TMieSlJBWhP9WBA==", +      "dev": true, +      "license": "MIT", +      "peerDependencies": { +        "eslint": ">=8.40" +      } +    }, +    "node_modules/eslint-scope": { +      "version": "8.4.0", +      "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.4.0.tgz", +      "integrity": "sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg==", +      "dev": true, +      "license": "BSD-2-Clause", +      "dependencies": { +        "esrecurse": "^4.3.0", +        "estraverse": "^5.2.0" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      } +    }, +    "node_modules/eslint-visitor-keys": { +      "version": "4.2.1", +      "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.1.tgz", +      "integrity": "sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==", +      "dev": true, +      "license": "Apache-2.0", +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      } +    }, +    "node_modules/espree": { +      "version": "10.4.0", +      "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz", +      "integrity": "sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==", +      "dev": true, +      "license": "BSD-2-Clause", +      "dependencies": { +        "acorn": "^8.15.0", +        "acorn-jsx": "^5.3.2", +        "eslint-visitor-keys": "^4.2.1" +      }, +      "engines": { +        "node": "^18.18.0 || ^20.9.0 || >=21.1.0" +      }, +      "funding": { +        "url": "https://opencollective.com/eslint" +      } +    }, +    "node_modules/esquery": { +      "version": "1.6.0", +      "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", +      "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", +      "dev": true, +      "license": "BSD-3-Clause", +      "dependencies": { +        "estraverse": "^5.1.0" +      }, +      "engines": { +        "node": ">=0.10" +      } +    }, +    "node_modules/esrecurse": { +      "version": "4.3.0", +      "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", +      "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", +      "dev": true, +      "license": "BSD-2-Clause", +      "dependencies": { +        "estraverse": "^5.2.0" +      }, +      "engines": { +        "node": ">=4.0" +      } +    }, +    "node_modules/estraverse": { +      "version": "5.3.0", +      "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", +      "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", +      "dev": true, +      "license": "BSD-2-Clause", +      "engines": { +        "node": ">=4.0" +      } +    }, +    "node_modules/esutils": { +      "version": "2.0.3", +      "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", +      "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", +      "dev": true, +      "license": "BSD-2-Clause", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/fast-deep-equal": { +      "version": "3.1.3", +      "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", +      "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/fast-json-stable-stringify": { +      "version": "2.1.0", +      "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", +      "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/fast-levenshtein": { +      "version": "2.0.6", +      "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", +      "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/fdir": { +      "version": "6.5.0", +      "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.5.0.tgz", +      "integrity": "sha512-tIbYtZbucOs0BRGqPJkshJUYdL+SDH7dVM8gjy+ERp3WAUjLEFJE+02kanyHtwjWOnwrKYBiwAmM0p4kLJAnXg==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=12.0.0" +      }, +      "peerDependencies": { +        "picomatch": "^3 || ^4" +      }, +      "peerDependenciesMeta": { +        "picomatch": { +          "optional": true +        } +      } +    }, +    "node_modules/file-entry-cache": { +      "version": "8.0.0", +      "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", +      "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "flat-cache": "^4.0.0" +      }, +      "engines": { +        "node": ">=16.0.0" +      } +    }, +    "node_modules/find-up": { +      "version": "5.0.0", +      "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", +      "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "locate-path": "^6.0.0", +        "path-exists": "^4.0.0" +      }, +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/flat-cache": { +      "version": "4.0.1", +      "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", +      "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "flatted": "^3.2.9", +        "keyv": "^4.5.4" +      }, +      "engines": { +        "node": ">=16" +      } +    }, +    "node_modules/flatted": { +      "version": "3.3.3", +      "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.3.tgz", +      "integrity": "sha512-GX+ysw4PBCz0PzosHDepZGANEuFCMLrnRTiEy9McGjmkCQYwRq4A/X786G/fjM/+OjsWSU1ZrY5qyARZmO/uwg==", +      "dev": true, +      "license": "ISC" +    }, +    "node_modules/follow-redirects": { +      "version": "1.15.11", +      "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.11.tgz", +      "integrity": "sha512-deG2P0JfjrTxl50XGCDyfI97ZGVCxIpfKYmfyrQ54n5FO/0gfIES8C/Psl6kWVDolizcaaxZJnTS0QSMxvnsBQ==", +      "funding": [ +        { +          "type": "individual", +          "url": "https://github.com/sponsors/RubenVerborgh" +        } +      ], +      "license": "MIT", +      "engines": { +        "node": ">=4.0" +      }, +      "peerDependenciesMeta": { +        "debug": { +          "optional": true +        } +      } +    }, +    "node_modules/form-data": { +      "version": "4.0.4", +      "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz", +      "integrity": "sha512-KrGhL9Q4zjj0kiUt5OO4Mr/A/jlI2jDYs5eHBpYHPcBEVSiipAvn2Ko2HnPe20rmcuuvMHNdZFp+4IlGTMF0Ow==", +      "license": "MIT", +      "dependencies": { +        "asynckit": "^0.4.0", +        "combined-stream": "^1.0.8", +        "es-set-tostringtag": "^2.1.0", +        "hasown": "^2.0.2", +        "mime-types": "^2.1.12" +      }, +      "engines": { +        "node": ">= 6" +      } +    }, +    "node_modules/fsevents": { +      "version": "2.3.3", +      "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", +      "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", +      "dev": true, +      "hasInstallScript": true, +      "license": "MIT", +      "optional": true, +      "os": [ +        "darwin" +      ], +      "engines": { +        "node": "^8.16.0 || ^10.6.0 || >=11.0.0" +      } +    }, +    "node_modules/function-bind": { +      "version": "1.1.2", +      "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", +      "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", +      "license": "MIT", +      "funding": { +        "url": "https://github.com/sponsors/ljharb" +      } +    }, +    "node_modules/gensync": { +      "version": "1.0.0-beta.2", +      "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", +      "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6.9.0" +      } +    }, +    "node_modules/get-intrinsic": { +      "version": "1.3.0", +      "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.3.0.tgz", +      "integrity": "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==", +      "license": "MIT", +      "dependencies": { +        "call-bind-apply-helpers": "^1.0.2", +        "es-define-property": "^1.0.1", +        "es-errors": "^1.3.0", +        "es-object-atoms": "^1.1.1", +        "function-bind": "^1.1.2", +        "get-proto": "^1.0.1", +        "gopd": "^1.2.0", +        "has-symbols": "^1.1.0", +        "hasown": "^2.0.2", +        "math-intrinsics": "^1.1.0" +      }, +      "engines": { +        "node": ">= 0.4" +      }, +      "funding": { +        "url": "https://github.com/sponsors/ljharb" +      } +    }, +    "node_modules/get-proto": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz", +      "integrity": "sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==", +      "license": "MIT", +      "dependencies": { +        "dunder-proto": "^1.0.1", +        "es-object-atoms": "^1.0.0" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/glob-parent": { +      "version": "6.0.2", +      "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", +      "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", +      "dev": true, +      "license": "ISC", +      "dependencies": { +        "is-glob": "^4.0.3" +      }, +      "engines": { +        "node": ">=10.13.0" +      } +    }, +    "node_modules/globals": { +      "version": "16.3.0", +      "resolved": "https://registry.npmjs.org/globals/-/globals-16.3.0.tgz", +      "integrity": "sha512-bqWEnJ1Nt3neqx2q5SFfGS8r/ahumIakg3HcwtNlrVlwXIeNumWn/c7Pn/wKzGhf6SaW6H6uWXLqC30STCMchQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=18" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/gopd": { +      "version": "1.2.0", +      "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz", +      "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.4" +      }, +      "funding": { +        "url": "https://github.com/sponsors/ljharb" +      } +    }, +    "node_modules/has-flag": { +      "version": "4.0.0", +      "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", +      "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/has-symbols": { +      "version": "1.1.0", +      "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz", +      "integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.4" +      }, +      "funding": { +        "url": "https://github.com/sponsors/ljharb" +      } +    }, +    "node_modules/has-tostringtag": { +      "version": "1.0.2", +      "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", +      "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", +      "license": "MIT", +      "dependencies": { +        "has-symbols": "^1.0.3" +      }, +      "engines": { +        "node": ">= 0.4" +      }, +      "funding": { +        "url": "https://github.com/sponsors/ljharb" +      } +    }, +    "node_modules/hasown": { +      "version": "2.0.2", +      "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", +      "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", +      "license": "MIT", +      "dependencies": { +        "function-bind": "^1.1.2" +      }, +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/ignore": { +      "version": "5.3.2", +      "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", +      "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">= 4" +      } +    }, +    "node_modules/import-fresh": { +      "version": "3.3.1", +      "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz", +      "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "parent-module": "^1.0.0", +        "resolve-from": "^4.0.0" +      }, +      "engines": { +        "node": ">=6" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/imurmurhash": { +      "version": "0.1.4", +      "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", +      "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=0.8.19" +      } +    }, +    "node_modules/is-extglob": { +      "version": "2.1.1", +      "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", +      "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/is-glob": { +      "version": "4.0.3", +      "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", +      "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "is-extglob": "^2.1.1" +      }, +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/isexe": { +      "version": "2.0.0", +      "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", +      "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", +      "dev": true, +      "license": "ISC" +    }, +    "node_modules/js-tokens": { +      "version": "4.0.0", +      "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", +      "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/js-yaml": { +      "version": "4.1.0", +      "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", +      "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "argparse": "^2.0.1" +      }, +      "bin": { +        "js-yaml": "bin/js-yaml.js" +      } +    }, +    "node_modules/jsesc": { +      "version": "3.1.0", +      "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", +      "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", +      "dev": true, +      "license": "MIT", +      "bin": { +        "jsesc": "bin/jsesc" +      }, +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/json-buffer": { +      "version": "3.0.1", +      "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", +      "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/json-schema-traverse": { +      "version": "0.4.1", +      "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", +      "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/json-stable-stringify-without-jsonify": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", +      "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/json5": { +      "version": "2.2.3", +      "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", +      "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", +      "dev": true, +      "license": "MIT", +      "bin": { +        "json5": "lib/cli.js" +      }, +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/keyv": { +      "version": "4.5.4", +      "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", +      "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "json-buffer": "3.0.1" +      } +    }, +    "node_modules/levn": { +      "version": "0.4.1", +      "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", +      "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "prelude-ls": "^1.2.1", +        "type-check": "~0.4.0" +      }, +      "engines": { +        "node": ">= 0.8.0" +      } +    }, +    "node_modules/locate-path": { +      "version": "6.0.0", +      "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", +      "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "p-locate": "^5.0.0" +      }, +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/lodash.merge": { +      "version": "4.6.2", +      "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", +      "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/lru-cache": { +      "version": "5.1.1", +      "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", +      "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", +      "dev": true, +      "license": "ISC", +      "dependencies": { +        "yallist": "^3.0.2" +      } +    }, +    "node_modules/math-intrinsics": { +      "version": "1.1.0", +      "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", +      "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.4" +      } +    }, +    "node_modules/mime-db": { +      "version": "1.52.0", +      "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", +      "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", +      "license": "MIT", +      "engines": { +        "node": ">= 0.6" +      } +    }, +    "node_modules/mime-types": { +      "version": "2.1.35", +      "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", +      "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", +      "license": "MIT", +      "dependencies": { +        "mime-db": "1.52.0" +      }, +      "engines": { +        "node": ">= 0.6" +      } +    }, +    "node_modules/minimatch": { +      "version": "3.1.2", +      "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", +      "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", +      "dev": true, +      "license": "ISC", +      "dependencies": { +        "brace-expansion": "^1.1.7" +      }, +      "engines": { +        "node": "*" +      } +    }, +    "node_modules/ms": { +      "version": "2.1.3", +      "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", +      "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/nanoid": { +      "version": "3.3.11", +      "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.11.tgz", +      "integrity": "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==", +      "dev": true, +      "funding": [ +        { +          "type": "github", +          "url": "https://github.com/sponsors/ai" +        } +      ], +      "license": "MIT", +      "bin": { +        "nanoid": "bin/nanoid.cjs" +      }, +      "engines": { +        "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" +      } +    }, +    "node_modules/natural-compare": { +      "version": "1.4.0", +      "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", +      "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/node-releases": { +      "version": "2.0.19", +      "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.19.tgz", +      "integrity": "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==", +      "dev": true, +      "license": "MIT" +    }, +    "node_modules/optionator": { +      "version": "0.9.4", +      "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", +      "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "deep-is": "^0.1.3", +        "fast-levenshtein": "^2.0.6", +        "levn": "^0.4.1", +        "prelude-ls": "^1.2.1", +        "type-check": "^0.4.0", +        "word-wrap": "^1.2.5" +      }, +      "engines": { +        "node": ">= 0.8.0" +      } +    }, +    "node_modules/p-limit": { +      "version": "3.1.0", +      "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", +      "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "yocto-queue": "^0.1.0" +      }, +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/p-locate": { +      "version": "5.0.0", +      "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", +      "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "p-limit": "^3.0.2" +      }, +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/parent-module": { +      "version": "1.0.1", +      "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", +      "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "callsites": "^3.0.0" +      }, +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/path-exists": { +      "version": "4.0.0", +      "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", +      "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/path-key": { +      "version": "3.1.1", +      "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", +      "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/picocolors": { +      "version": "1.1.1", +      "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", +      "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", +      "dev": true, +      "license": "ISC" +    }, +    "node_modules/picomatch": { +      "version": "4.0.3", +      "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", +      "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=12" +      }, +      "funding": { +        "url": "https://github.com/sponsors/jonschlinkert" +      } +    }, +    "node_modules/postcss": { +      "version": "8.5.6", +      "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.6.tgz", +      "integrity": "sha512-3Ybi1tAuwAP9s0r1UQ2J4n5Y0G05bJkpUIO0/bI9MhwmD70S5aTWbXGBwxHrelT+XM1k6dM0pk+SwNkpTRN7Pg==", +      "dev": true, +      "funding": [ +        { +          "type": "opencollective", +          "url": "https://opencollective.com/postcss/" +        }, +        { +          "type": "tidelift", +          "url": "https://tidelift.com/funding/github/npm/postcss" +        }, +        { +          "type": "github", +          "url": "https://github.com/sponsors/ai" +        } +      ], +      "license": "MIT", +      "dependencies": { +        "nanoid": "^3.3.11", +        "picocolors": "^1.1.1", +        "source-map-js": "^1.2.1" +      }, +      "engines": { +        "node": "^10 || ^12 || >=14" +      } +    }, +    "node_modules/prelude-ls": { +      "version": "1.2.1", +      "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", +      "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">= 0.8.0" +      } +    }, +    "node_modules/proxy-from-env": { +      "version": "1.1.0", +      "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", +      "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", +      "license": "MIT" +    }, +    "node_modules/punycode": { +      "version": "2.3.1", +      "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", +      "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=6" +      } +    }, +    "node_modules/react": { +      "version": "19.1.1", +      "resolved": "https://registry.npmjs.org/react/-/react-19.1.1.tgz", +      "integrity": "sha512-w8nqGImo45dmMIfljjMwOGtbmC/mk4CMYhWIicdSflH91J9TyCyczcPFXJzrZ/ZXcgGRFeP6BU0BEJTw6tZdfQ==", +      "license": "MIT", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/react-dom": { +      "version": "19.1.1", +      "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.1.1.tgz", +      "integrity": "sha512-Dlq/5LAZgF0Gaz6yiqZCf6VCcZs1ghAJyrsu84Q/GT0gV+mCxbfmKNoGRKBYMJ8IEdGPqu49YWXD02GCknEDkw==", +      "license": "MIT", +      "dependencies": { +        "scheduler": "^0.26.0" +      }, +      "peerDependencies": { +        "react": "^19.1.1" +      } +    }, +    "node_modules/react-refresh": { +      "version": "0.17.0", +      "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.17.0.tgz", +      "integrity": "sha512-z6F7K9bV85EfseRCp2bzrpyQ0Gkw1uLoCel9XBVWPg/TjRj94SkJzUTGfOa4bs7iJvBWtQG0Wq7wnI0syw3EBQ==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/resolve-from": { +      "version": "4.0.0", +      "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", +      "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=4" +      } +    }, +    "node_modules/rollup": { +      "version": "4.47.1", +      "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.47.1.tgz", +      "integrity": "sha512-iasGAQoZ5dWDzULEUX3jiW0oB1qyFOepSyDyoU6S/OhVlDIwj5knI5QBa5RRQ0sK7OE0v+8VIi2JuV+G+3tfNg==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "@types/estree": "1.0.8" +      }, +      "bin": { +        "rollup": "dist/bin/rollup" +      }, +      "engines": { +        "node": ">=18.0.0", +        "npm": ">=8.0.0" +      }, +      "optionalDependencies": { +        "@rollup/rollup-android-arm-eabi": "4.47.1", +        "@rollup/rollup-android-arm64": "4.47.1", +        "@rollup/rollup-darwin-arm64": "4.47.1", +        "@rollup/rollup-darwin-x64": "4.47.1", +        "@rollup/rollup-freebsd-arm64": "4.47.1", +        "@rollup/rollup-freebsd-x64": "4.47.1", +        "@rollup/rollup-linux-arm-gnueabihf": "4.47.1", +        "@rollup/rollup-linux-arm-musleabihf": "4.47.1", +        "@rollup/rollup-linux-arm64-gnu": "4.47.1", +        "@rollup/rollup-linux-arm64-musl": "4.47.1", +        "@rollup/rollup-linux-loongarch64-gnu": "4.47.1", +        "@rollup/rollup-linux-ppc64-gnu": "4.47.1", +        "@rollup/rollup-linux-riscv64-gnu": "4.47.1", +        "@rollup/rollup-linux-riscv64-musl": "4.47.1", +        "@rollup/rollup-linux-s390x-gnu": "4.47.1", +        "@rollup/rollup-linux-x64-gnu": "4.47.1", +        "@rollup/rollup-linux-x64-musl": "4.47.1", +        "@rollup/rollup-win32-arm64-msvc": "4.47.1", +        "@rollup/rollup-win32-ia32-msvc": "4.47.1", +        "@rollup/rollup-win32-x64-msvc": "4.47.1", +        "fsevents": "~2.3.2" +      } +    }, +    "node_modules/scheduler": { +      "version": "0.26.0", +      "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.26.0.tgz", +      "integrity": "sha512-NlHwttCI/l5gCPR3D1nNXtWABUmBwvZpEQiD4IXSbIDq8BzLIK/7Ir5gTFSGZDUu37K5cMNp0hFtzO38sC7gWA==", +      "license": "MIT" +    }, +    "node_modules/semver": { +      "version": "6.3.1", +      "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", +      "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", +      "dev": true, +      "license": "ISC", +      "bin": { +        "semver": "bin/semver.js" +      } +    }, +    "node_modules/shebang-command": { +      "version": "2.0.0", +      "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", +      "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "shebang-regex": "^3.0.0" +      }, +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/shebang-regex": { +      "version": "3.0.0", +      "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", +      "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/source-map-js": { +      "version": "1.2.1", +      "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", +      "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", +      "dev": true, +      "license": "BSD-3-Clause", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/strip-json-comments": { +      "version": "3.1.1", +      "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", +      "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=8" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    }, +    "node_modules/supports-color": { +      "version": "7.2.0", +      "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", +      "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "has-flag": "^4.0.0" +      }, +      "engines": { +        "node": ">=8" +      } +    }, +    "node_modules/tinyglobby": { +      "version": "0.2.14", +      "resolved": "https://registry.npmjs.org/tinyglobby/-/tinyglobby-0.2.14.tgz", +      "integrity": "sha512-tX5e7OM1HnYr2+a2C/4V0htOcSQcoSTH9KgJnVvNm5zm/cyEWKJ7j7YutsH9CxMdtOkkLFy2AHrMci9IM8IPZQ==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "fdir": "^6.4.4", +        "picomatch": "^4.0.2" +      }, +      "engines": { +        "node": ">=12.0.0" +      }, +      "funding": { +        "url": "https://github.com/sponsors/SuperchupuDev" +      } +    }, +    "node_modules/type-check": { +      "version": "0.4.0", +      "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", +      "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "prelude-ls": "^1.2.1" +      }, +      "engines": { +        "node": ">= 0.8.0" +      } +    }, +    "node_modules/update-browserslist-db": { +      "version": "1.1.3", +      "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz", +      "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==", +      "dev": true, +      "funding": [ +        { +          "type": "opencollective", +          "url": "https://opencollective.com/browserslist" +        }, +        { +          "type": "tidelift", +          "url": "https://tidelift.com/funding/github/npm/browserslist" +        }, +        { +          "type": "github", +          "url": "https://github.com/sponsors/ai" +        } +      ], +      "license": "MIT", +      "dependencies": { +        "escalade": "^3.2.0", +        "picocolors": "^1.1.1" +      }, +      "bin": { +        "update-browserslist-db": "cli.js" +      }, +      "peerDependencies": { +        "browserslist": ">= 4.21.0" +      } +    }, +    "node_modules/uri-js": { +      "version": "4.4.1", +      "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", +      "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", +      "dev": true, +      "license": "BSD-2-Clause", +      "dependencies": { +        "punycode": "^2.1.0" +      } +    }, +    "node_modules/vite": { +      "version": "7.1.3", +      "resolved": "https://registry.npmjs.org/vite/-/vite-7.1.3.tgz", +      "integrity": "sha512-OOUi5zjkDxYrKhTV3V7iKsoS37VUM7v40+HuwEmcrsf11Cdx9y3DIr2Px6liIcZFwt3XSRpQvFpL3WVy7ApkGw==", +      "dev": true, +      "license": "MIT", +      "dependencies": { +        "esbuild": "^0.25.0", +        "fdir": "^6.5.0", +        "picomatch": "^4.0.3", +        "postcss": "^8.5.6", +        "rollup": "^4.43.0", +        "tinyglobby": "^0.2.14" +      }, +      "bin": { +        "vite": "bin/vite.js" +      }, +      "engines": { +        "node": "^20.19.0 || >=22.12.0" +      }, +      "funding": { +        "url": "https://github.com/vitejs/vite?sponsor=1" +      }, +      "optionalDependencies": { +        "fsevents": "~2.3.3" +      }, +      "peerDependencies": { +        "@types/node": "^20.19.0 || >=22.12.0", +        "jiti": ">=1.21.0", +        "less": "^4.0.0", +        "lightningcss": "^1.21.0", +        "sass": "^1.70.0", +        "sass-embedded": "^1.70.0", +        "stylus": ">=0.54.8", +        "sugarss": "^5.0.0", +        "terser": "^5.16.0", +        "tsx": "^4.8.1", +        "yaml": "^2.4.2" +      }, +      "peerDependenciesMeta": { +        "@types/node": { +          "optional": true +        }, +        "jiti": { +          "optional": true +        }, +        "less": { +          "optional": true +        }, +        "lightningcss": { +          "optional": true +        }, +        "sass": { +          "optional": true +        }, +        "sass-embedded": { +          "optional": true +        }, +        "stylus": { +          "optional": true +        }, +        "sugarss": { +          "optional": true +        }, +        "terser": { +          "optional": true +        }, +        "tsx": { +          "optional": true +        }, +        "yaml": { +          "optional": true +        } +      } +    }, +    "node_modules/which": { +      "version": "2.0.2", +      "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", +      "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", +      "dev": true, +      "license": "ISC", +      "dependencies": { +        "isexe": "^2.0.0" +      }, +      "bin": { +        "node-which": "bin/node-which" +      }, +      "engines": { +        "node": ">= 8" +      } +    }, +    "node_modules/word-wrap": { +      "version": "1.2.5", +      "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", +      "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=0.10.0" +      } +    }, +    "node_modules/yallist": { +      "version": "3.1.1", +      "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", +      "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", +      "dev": true, +      "license": "ISC" +    }, +    "node_modules/yocto-queue": { +      "version": "0.1.0", +      "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", +      "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", +      "dev": true, +      "license": "MIT", +      "engines": { +        "node": ">=10" +      }, +      "funding": { +        "url": "https://github.com/sponsors/sindresorhus" +      } +    } +  } +} diff --git a/front-end/package.json b/front-end/package.json new file mode 100644 index 0000000..640f523 --- /dev/null +++ b/front-end/package.json @@ -0,0 +1,28 @@ +{ +  "name": "front-end", +  "private": true, +  "version": "0.0.0", +  "type": "module", +  "scripts": { +    "dev": "vite", +    "build": "vite build", +    "lint": "eslint .", +    "preview": "vite preview" +  }, +  "dependencies": { +    "axios": "^1.11.0", +    "react": "^19.1.1", +    "react-dom": "^19.1.1" +  }, +  "devDependencies": { +    "@eslint/js": "^9.33.0", +    "@types/react": "^19.1.10", +    "@types/react-dom": "^19.1.7", +    "@vitejs/plugin-react": "^5.0.0", +    "eslint": "^9.33.0", +    "eslint-plugin-react-hooks": "^5.2.0", +    "eslint-plugin-react-refresh": "^0.4.20", +    "globals": "^16.3.0", +    "vite": "^7.1.2" +  } +} diff --git a/front-end/public/vite.svg b/front-end/public/vite.svg new file mode 100644 index 0000000..e7b8dfb --- /dev/null +++ b/front-end/public/vite.svg @@ -0,0 +1 @@ +<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg>
\ No newline at end of file diff --git a/front-end/src/App.css b/front-end/src/App.css new file mode 100644 index 0000000..1548a0d --- /dev/null +++ b/front-end/src/App.css @@ -0,0 +1,322 @@ +/* src/App.css */ +body { +  margin: 0; +  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', +    'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', +    sans-serif; +  -webkit-font-smoothing: antialiased; +  -moz-osx-font-smoothing: grayscale; +} + +.App { +  text-align: center; +  min-height: 100vh; +  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); +} + +.App-header { +  background: rgba(255, 255, 255, 0.1); +  padding: 2rem; +  backdrop-filter: blur(10px); +  border-bottom: 1px solid rgba(255, 255, 255, 0.2); +} + +.App-header h1 { +  color: white; +  margin-bottom: 1.5rem; +  font-size: 2.5rem; +  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3); +} + +.channel-selector { +  max-width: 600px; +  margin: 0 auto; +} + +.selector-header { +  display: flex; +  justify-content: space-between; +  align-items: center; +  margin-bottom: 0.5rem; +} + +.selector-header label { +  color: white; +  font-size: 1.1rem; +  font-weight: bold; +} + +.refresh-button { +  padding: 0.4rem 0.8rem; +  border: none; +  border-radius: 15px; +  background: rgba(255, 255, 255, 0.2); +  color: white; +  cursor: pointer; +  font-size: 0.9rem; +  transition: all 0.3s ease; +} + +.refresh-button:hover:not(:disabled) { +  background: rgba(255, 255, 255, 0.3); +  transform: rotate(45deg); +} + +.refresh-button:disabled { +  opacity: 0.6; +  cursor: not-allowed; +} + +.channel-select { +  width: 100%; +  padding: 0.8rem 1.2rem; +  border: none; +  border-radius: 25px; +  font-size: 1rem; +  background: rgba(255, 255, 255, 0.9); +  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1); +  margin-bottom: 1rem; +} + +.channel-select:focus { +  outline: none; +  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2); +} + +.channel-info { +  color: rgba(255, 255, 255, 0.9); +  font-size: 0.9rem; +} + +.channel-info strong { +  color: #74b9ff; +} + +.main-content { +  padding: 2rem; +  max-width: 1200px; +  margin: 0 auto; +} + +.loading, .error, .no-channels, .no-videos, .no-selection { +  color: white; +  font-size: 1.2rem; +  padding: 2rem; +  background: rgba(255, 255, 255, 0.1); +  border-radius: 15px; +  backdrop-filter: blur(10px); +  margin: 1rem 0; +} + +.error { +  color: #ff6b6b; +} + +.no-channels, .no-selection { +  color: #ffd93d; +} + +.no-videos { +  color: #ffd93d; +} + +.retry-button { +  margin-top: 1rem; +  padding: 0.5rem 1rem; +  border: none; +  border-radius: 20px; +  background: rgba(255, 255, 255, 0.2); +  color: white; +  cursor: pointer; +  transition: all 0.3s ease; +} + +.retry-button:hover { +  background: rgba(255, 255, 255, 0.3); +} + +.videos-container h2 { +  color: white; +  margin-bottom: 2rem; +  font-size: 2rem; +  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3); +} + +.videos-grid { +  display: grid; +  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); +  gap: 2rem; +  margin-top: 2rem; +} + +.video-card { +  background: rgba(255, 255, 255, 0.1); +  border-radius: 15px; +  overflow: hidden; +  backdrop-filter: blur(10px); +  border: 1px solid rgba(255, 255, 255, 0.2); +  transition: all 0.3s ease; +  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); +} + +.video-card:hover { +  transform: translateY(-5px); +  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2); +  border-color: rgba(255, 255, 255, 0.3); +} + +.video-thumbnail { +  position: relative; +  height: 180px; +  overflow: hidden; +} + +.thumbnail-image { +  width: 100%; +  height: 100%; +  object-fit: cover; +  transition: transform 0.3s ease; +} + +.video-card:hover .thumbnail-image { +  transform: scale(1.05); +} + +.play-button { +  position: absolute; +  top: 50%; +  left: 50%; +  transform: translate(-50%, -50%); +  font-size: 3rem; +  color: white; +  text-shadow: 2px 2px 8px rgba(0, 0, 0, 0.7); +  opacity: 0.9; +  transition: all 0.3s ease; +} + +.video-card:hover .play-button { +  opacity: 1; +  transform: translate(-50%, -50%) scale(1.1); +} + +.video-info { +  padding: 1.5rem; +  text-align: left; +} + +.video-title { +  color: white; +  font-size: 1.1rem; +  font-weight: bold; +  margin-bottom: 0.8rem; +  line-height: 1.4; +  display: -webkit-box; +  -webkit-line-clamp: 2; +  -webkit-box-orient: vertical; +  overflow: hidden; +  position: relative; +  cursor: help; +} + +.video-author, .video-date { +  color: rgba(255, 255, 255, 0.8); +  font-size: 0.9rem; +  margin-bottom: 0.5rem; +} + +.channel-link { +  color: #74b9ff; +  text-decoration: none; +} + +.channel-link:hover { +  text-decoration: underline; +} + +.video-summary { +  margin: 1rem 0; +  padding: 0.8rem; +  background: rgba(255, 255, 255, 0.1); +  border-radius: 8px; +  border-left: 3px solid #74b9ff; +} + +.video-summary p { +  color: rgba(255, 255, 255, 0.9); +  font-size: 0.85rem; +  line-height: 1.4; +  margin: 0; +  transition: all 0.3s ease; +} + +.video-summary p.collapsed { +  display: -webkit-box; +  -webkit-line-clamp: 3; +  -webkit-box-orient: vertical; +  overflow: hidden; +} + +.video-summary p.expanded { +  display: block; +  overflow: visible; +} + +.expand-button { +  background: rgba(255, 255, 255, 0.15); +  border: 1px solid rgba(255, 255, 255, 0.3); +  color: #74b9ff; +  padding: 0.3rem 0.8rem; +  border-radius: 12px; +  font-size: 0.75rem; +  cursor: pointer; +  margin-top: 0.5rem; +  transition: all 0.3s ease; +} + +.expand-button:hover { +  background: rgba(255, 255, 255, 0.25); +  transform: translateY(-1px); +} + +.video-actions { +  margin-top: 1rem; +} + +.watch-button { +  display: inline-block; +  padding: 0.6rem 1.2rem; +  background: #ff4757; +  color: white; +  text-decoration: none; +  border-radius: 20px; +  font-weight: bold; +  transition: all 0.3s ease; +  font-size: 0.9rem; +} + +.watch-button:hover { +  background: #ff6b81; +  transform: translateY(-2px); +  box-shadow: 0 4px 15px rgba(255, 71, 87, 0.3); +} + +/* Responsive design */ +@media (max-width: 768px) { +  .selector-header { +    flex-direction: column; +    gap: 0.5rem; +    align-items: flex-start; +  } + +  .videos-grid { +    grid-template-columns: 1fr; +  } + +  .App-header h1 { +    font-size: 2rem; +  } + +  .video-info { +    padding: 1rem; +  } +} diff --git a/front-end/src/App.jsx b/front-end/src/App.jsx new file mode 100644 index 0000000..a540e47 --- /dev/null +++ b/front-end/src/App.jsx @@ -0,0 +1,298 @@ +// src/App.js +import React, { useState, useEffect } from 'react'; +import axios from 'axios'; +import './App.css'; + +const API_BASE_URL = import.meta.env.VITE_API_BASE_URL || 'http://127.0.0.1:4000'; + +function App() { +  const [videos, setVideos] = useState([]); +  const [channels, setChannels] = useState([]); +  const [loading, setLoading] = useState(true); +  const [channelsLoading, setChannelsLoading] = useState(true); +  const [error, setError] = useState(null); +  const [selectedChannelId, setSelectedChannelId] = useState(''); +  const [expandedDescriptions, setExpandedDescriptions] = useState({}); + +  const fetchChannels = async () => { +    try { +      setChannelsLoading(true); +      const response = await axios.get(`${API_BASE_URL}/subs-info`); + +      if (response.data && Array.isArray(response.data)) { +        const formattedChannels = response.data.map(channel => { +          // Extract the channel ID from the _id field +          const channelId = channel._id.replace('yt:channel:', ''); +          return { +            id: channelId, +            _id: channel._id, +            last_video_update: channel.last_video_update, +            new_vids: channel.new_vids, +            time_between_fetches: channel.time_between_fetches, +            videos: channel.videos +          }; +        }); +        setChannels(formattedChannels); +      } +    } catch (err) { +      console.error('Error fetching channels:', err); +      setError('Failed to fetch available channels.'); +    } finally { +      setChannelsLoading(false); +    } +  }; + +  const fetchVideos = async (channelId) => { +    try { +      setLoading(true); +      setError(null); +      setExpandedDescriptions({}); // Reset expanded states when fetching new videos + +      const apiUrl = `${API_BASE_URL}/vid-from-link/yt:channel:${channelId}`; +      const response = await axios.get(apiUrl); + +      if (response.data && Array.isArray(response.data)) { +        setVideos(response.data); +      } else { +        throw new Error('Invalid response format'); +      } +    } catch (err) { +      setError('Failed to fetch videos. Please check the channel and ensure the API is running.'); +      console.error('Error fetching videos:', err); +    } finally { +      setLoading(false); +    } +  }; + +  useEffect(() => { +    fetchChannels(); +  }, []); + +  useEffect(() => { +    if (selectedChannelId) { +      fetchVideos(selectedChannelId); +    } +  }, [selectedChannelId]); + +  const handleChannelChange = (e) => { +    setSelectedChannelId(e.target.value); +  }; + +  const handleRefreshChannels = () => { +    fetchChannels(); +  }; + +  const toggleDescription = (videoId) => { +    setExpandedDescriptions(prev => ({ +      ...prev, +      [videoId]: !prev[videoId] +    })); +  }; + +  const formatDate = (dateString) => { +    try { +      return new Date(dateString).toLocaleDateString('en-US', { +        year: 'numeric', +        month: 'short', +        day: 'numeric', +        hour: '2-digit', +        minute: '2-digit' +      }); +    } catch { +      return dateString; +    } +  }; + +  const formatRelativeTime = (dateString) => { +    try { +      const date = new Date(dateString); +      const now = new Date(); +      const diffInHours = Math.floor((now - date) / (1000 * 60 * 60)); + +      if (diffInHours < 1) { +        return 'Just now'; +      } else if (diffInHours < 24) { +        return `${diffInHours}h ago`; +      } else { +        const diffInDays = Math.floor(diffInHours / 24); +        return `${diffInDays}d ago`; +      } +    } catch { +      return dateString; +    } +  }; + +  return ( +    <div className="App"> +      <header className="App-header"> +        <h1>YouTube Channel Videos</h1> + +        <div className="channel-selector"> +          <div className="selector-header"> +            <label htmlFor="channel-select">Select Channel:</label> +            <button +              onClick={handleRefreshChannels} +              className="refresh-button" +              disabled={channelsLoading} +            > +              {channelsLoading ? 'Refreshing...' : '↻ Refresh'} +            </button> +          </div> + +          <select +            id="channel-select" +            value={selectedChannelId} +            onChange={handleChannelChange} +            className="channel-select" +            disabled={channelsLoading || channels.length === 0} +          > +            {channelsLoading ? ( +              <option value="">Loading channels...</option> +            ) : channels.length === 0 ? ( +              <option value="">No channels available</option> +            ) : ( +              <> +                <option value="">Choose a channel...</option> +                {channels.map((channel) => ( +                  <option key={channel.id} value={channel.id}> +                    {channel.id} ({channel.videos} videos, {channel.new_vids} new) +                  </option> +                ))} +              </> +            )} +          </select> + +          {selectedChannelId && channels.length > 0 && ( +            <div className="channel-info"> +              <p> +                Selected: <strong>{selectedChannelId}</strong> +                {channels.find(ch => ch.id === selectedChannelId)?.last_video_update && ( +                  <span> • Last updated: {formatRelativeTime(channels.find(ch => ch.id === selectedChannelId).last_video_update)}</span> +                )} +              </p> +            </div> +          )} +        </div> +      </header> + +      <main className="main-content"> +        {channelsLoading && <div className="loading">Loading channels...</div>} + +        {error && ( +          <div className="error"> +            {error} +            <button onClick={() => selectedChannelId && fetchVideos(selectedChannelId)} className="retry-button"> +              Try Again +            </button> +          </div> +        )} + +        {!channelsLoading && channels.length === 0 && !error && ( +          <div className="no-channels"> +            <h3>No channels available</h3> +            <p>No YouTube channels found in the subscription list.</p> +            <button onClick={handleRefreshChannels} className="retry-button"> +              Refresh Channels +            </button> +          </div> +        )} + +        {loading && selectedChannelId && ( +          <div className="loading">Loading videos for {selectedChannelId}...</div> +        )} + +        {!loading && !error && selectedChannelId && ( +          <div className="videos-container"> +            <h2> +              Latest Videos from {selectedChannelId} +              {videos.length > 0 && ` (${videos.length})`} +            </h2> +            <div className="videos-grid"> +              {videos.sort((a, b) => new Date(b.published) - new Date(a.published)).map((video) => ( +                <div key={video.id} className="video-card"> +                  <div className="video-thumbnail"> +                    <img +                      src={video.thumbnail} +                      alt={video.title} +                      className="thumbnail-image" +                      onError={(e) => { +                        e.target.src = 'https://via.placeholder.com/300x180/333/fff?text=No+Thumbnail'; +                      }} +                    /> +                    <div className="play-button">▶</div> +                  </div> + +                  <div className="video-info"> +                    <h3 +                      className="video-title" +                      title={video.title} +                    > +                      {video.title} +                    </h3> +                    <p className="video-author"> +                      By: <a +                        href={video.author_channel} +                        target="_blank" +                        rel="noopener noreferrer" +                        className="channel-link" +                      > +                        {video.author} +                      </a> +                    </p> +                    <p className="video-date">Published: {formatDate(video.published)}</p> +                    {video.updated && ( +                      <p className="video-date">Updated: {formatDate(video.updated)}</p> +                    )} + +                    {video.summary && ( +                      <div className="video-summary"> +                        <p className={expandedDescriptions[video.id] ? 'expanded' : 'collapsed'}> +                          {video.summary} +                        </p> +                        {video.summary.length > 100 && ( +                          <button +                            className="expand-button" +                            onClick={() => toggleDescription(video.id)} +                          > +                            {expandedDescriptions[video.id] ? 'Show Less' : 'Show More'} +                          </button> +                        )} +                      </div> +                    )} + +                    <div className="video-actions"> +                      <a +                        href={video.link} +                        target="_blank" +                        rel="noopener noreferrer" +                        className="watch-button" +                      > +                        Watch on YouTube +                      </a> +                    </div> +                  </div> +                </div> +              ))} +            </div> +          </div> +        )} + +        {!loading && !error && selectedChannelId && videos.length === 0 && ( +          <div className="no-videos"> +            <h3>No videos found for this channel</h3> +            <p>The channel might not have any videos or there was an issue loading them.</p> +          </div> +        )} + +        {!channelsLoading && !selectedChannelId && channels.length > 0 && ( +          <div className="no-selection"> +            <h3>Please select a channel to view videos</h3> +            <p>Choose a channel from the dropdown above to see its latest videos.</p> +          </div> +        )} +      </main> +    </div> +  ); +} + +export default App; diff --git a/front-end/src/assets/react.svg b/front-end/src/assets/react.svg new file mode 100644 index 0000000..6c87de9 --- /dev/null +++ b/front-end/src/assets/react.svg @@ -0,0 +1 @@ +<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="35.93" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 228"><path fill="#00D8FF" d="M210.483 73.824a171.49 171.49 0 0 0-8.24-2.597c.465-1.9.893-3.777 1.273-5.621c6.238-30.281 2.16-54.676-11.769-62.708c-13.355-7.7-35.196.329-57.254 19.526a171.23 171.23 0 0 0-6.375 5.848a155.866 155.866 0 0 0-4.241-3.917C100.759 3.829 77.587-4.822 63.673 3.233C50.33 10.957 46.379 33.89 51.995 62.588a170.974 170.974 0 0 0 1.892 8.48c-3.28.932-6.445 1.924-9.474 2.98C17.309 83.498 0 98.307 0 113.668c0 15.865 18.582 31.778 46.812 41.427a145.52 145.52 0 0 0 6.921 2.165a167.467 167.467 0 0 0-2.01 9.138c-5.354 28.2-1.173 50.591 12.134 58.266c13.744 7.926 36.812-.22 59.273-19.855a145.567 145.567 0 0 0 5.342-4.923a168.064 168.064 0 0 0 6.92 6.314c21.758 18.722 43.246 26.282 56.54 18.586c13.731-7.949 18.194-32.003 12.4-61.268a145.016 145.016 0 0 0-1.535-6.842c1.62-.48 3.21-.974 4.76-1.488c29.348-9.723 48.443-25.443 48.443-41.52c0-15.417-17.868-30.326-45.517-39.844Zm-6.365 70.984c-1.4.463-2.836.91-4.3 1.345c-3.24-10.257-7.612-21.163-12.963-32.432c5.106-11 9.31-21.767 12.459-31.957c2.619.758 5.16 1.557 7.61 2.4c23.69 8.156 38.14 20.213 38.14 29.504c0 9.896-15.606 22.743-40.946 31.14Zm-10.514 20.834c2.562 12.94 2.927 24.64 1.23 33.787c-1.524 8.219-4.59 13.698-8.382 15.893c-8.067 4.67-25.32-1.4-43.927-17.412a156.726 156.726 0 0 1-6.437-5.87c7.214-7.889 14.423-17.06 21.459-27.246c12.376-1.098 24.068-2.894 34.671-5.345a134.17 134.17 0 0 1 1.386 6.193ZM87.276 214.515c-7.882 2.783-14.16 2.863-17.955.675c-8.075-4.657-11.432-22.636-6.853-46.752a156.923 156.923 0 0 1 1.869-8.499c10.486 2.32 22.093 3.988 34.498 4.994c7.084 9.967 14.501 19.128 21.976 27.15a134.668 134.668 0 0 1-4.877 4.492c-9.933 8.682-19.886 14.842-28.658 17.94ZM50.35 144.747c-12.483-4.267-22.792-9.812-29.858-15.863c-6.35-5.437-9.555-10.836-9.555-15.216c0-9.322 13.897-21.212 37.076-29.293c2.813-.98 5.757-1.905 8.812-2.773c3.204 10.42 7.406 21.315 12.477 32.332c-5.137 11.18-9.399 22.249-12.634 32.792a134.718 134.718 0 0 1-6.318-1.979Zm12.378-84.26c-4.811-24.587-1.616-43.134 6.425-47.789c8.564-4.958 27.502 2.111 47.463 19.835a144.318 144.318 0 0 1 3.841 3.545c-7.438 7.987-14.787 17.08-21.808 26.988c-12.04 1.116-23.565 2.908-34.161 5.309a160.342 160.342 0 0 1-1.76-7.887Zm110.427 27.268a347.8 347.8 0 0 0-7.785-12.803c8.168 1.033 15.994 2.404 23.343 4.08c-2.206 7.072-4.956 14.465-8.193 22.045a381.151 381.151 0 0 0-7.365-13.322Zm-45.032-43.861c5.044 5.465 10.096 11.566 15.065 18.186a322.04 322.04 0 0 0-30.257-.006c4.974-6.559 10.069-12.652 15.192-18.18ZM82.802 87.83a323.167 323.167 0 0 0-7.227 13.238c-3.184-7.553-5.909-14.98-8.134-22.152c7.304-1.634 15.093-2.97 23.209-3.984a321.524 321.524 0 0 0-7.848 12.897Zm8.081 65.352c-8.385-.936-16.291-2.203-23.593-3.793c2.26-7.3 5.045-14.885 8.298-22.6a321.187 321.187 0 0 0 7.257 13.246c2.594 4.48 5.28 8.868 8.038 13.147Zm37.542 31.03c-5.184-5.592-10.354-11.779-15.403-18.433c4.902.192 9.899.29 14.978.29c5.218 0 10.376-.117 15.453-.343c-4.985 6.774-10.018 12.97-15.028 18.486Zm52.198-57.817c3.422 7.8 6.306 15.345 8.596 22.52c-7.422 1.694-15.436 3.058-23.88 4.071a382.417 382.417 0 0 0 7.859-13.026a347.403 347.403 0 0 0 7.425-13.565Zm-16.898 8.101a358.557 358.557 0 0 1-12.281 19.815a329.4 329.4 0 0 1-23.444.823c-7.967 0-15.716-.248-23.178-.732a310.202 310.202 0 0 1-12.513-19.846h.001a307.41 307.41 0 0 1-10.923-20.627a310.278 310.278 0 0 1 10.89-20.637l-.001.001a307.318 307.318 0 0 1 12.413-19.761c7.613-.576 15.42-.876 23.31-.876H128c7.926 0 15.743.303 23.354.883a329.357 329.357 0 0 1 12.335 19.695a358.489 358.489 0 0 1 11.036 20.54a329.472 329.472 0 0 1-11 20.722Zm22.56-122.124c8.572 4.944 11.906 24.881 6.52 51.026c-.344 1.668-.73 3.367-1.15 5.09c-10.622-2.452-22.155-4.275-34.23-5.408c-7.034-10.017-14.323-19.124-21.64-27.008a160.789 160.789 0 0 1 5.888-5.4c18.9-16.447 36.564-22.941 44.612-18.3ZM128 90.808c12.625 0 22.86 10.235 22.86 22.86s-10.235 22.86-22.86 22.86s-22.86-10.235-22.86-22.86s10.235-22.86 22.86-22.86Z"></path></svg>
\ No newline at end of file diff --git a/front-end/src/main.jsx b/front-end/src/main.jsx new file mode 100644 index 0000000..3d9da8a --- /dev/null +++ b/front-end/src/main.jsx @@ -0,0 +1,9 @@ +import { StrictMode } from 'react' +import { createRoot } from 'react-dom/client' +import App from './App.jsx' + +createRoot(document.getElementById('root')).render( +  <StrictMode> +    <App /> +  </StrictMode>, +) diff --git a/front-end/vite.config.js b/front-end/vite.config.js new file mode 100644 index 0000000..8b0f57b --- /dev/null +++ b/front-end/vite.config.js @@ -0,0 +1,7 @@ +import { defineConfig } from 'vite' +import react from '@vitejs/plugin-react' + +// https://vite.dev/config/ +export default defineConfig({ +  plugins: [react()], +}) | 
