├── .eslintrc.cjs ├── .gitignore ├── README.md ├── index.html ├── package-lock.json ├── package.json ├── postcss.config.js ├── public └── vite.svg ├── src ├── App.tsx ├── components │ ├── AudioPlayer.tsx │ ├── Controls.tsx │ ├── PlayList.tsx │ ├── ProgressBar.tsx │ ├── TrackInfo.tsx │ └── VolumeControl.tsx ├── context │ └── audio-player-context.tsx ├── data │ ├── We_Are_The_World.mp3 │ ├── a_beautiful_day.mp3 │ ├── cinematic-time-lapse-115672.mp3 │ ├── dbang-world.mp3 │ ├── dbanj.png │ ├── forest-lullaby-110624.mp3 │ ├── jackson.jpeg │ ├── lexin.jpeg │ ├── react.svg │ ├── the-podcast-intro-111863.mp3 │ ├── tracks.ts │ └── trinix.jpeg ├── main.tsx ├── styles │ ├── customize-progress-bar.css │ └── index.css └── vite-env.d.ts ├── tailwind.config.js ├── tsconfig.app.json ├── tsconfig.json ├── tsconfig.node.json └── vite.config.ts /.eslintrc.cjs: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | env: { browser: true, es2020: true }, 4 | extends: [ 5 | 'eslint:recommended', 6 | 'plugin:@typescript-eslint/recommended', 7 | 'plugin:react-hooks/recommended', 8 | ], 9 | ignorePatterns: ['dist', '.eslintrc.cjs'], 10 | parser: '@typescript-eslint/parser', 11 | plugins: ['react-refresh'], 12 | rules: { 13 | 'react-refresh/only-export-components': [ 14 | 'warn', 15 | { allowConstantExport: true }, 16 | ], 17 | }, 18 | } 19 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # React + TypeScript + Vite 2 | 3 | This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. 4 | 5 | Currently, two official plugins are available: 6 | 7 | - [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh 8 | - [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh 9 | 10 | ## Expanding the ESLint configuration 11 | 12 | If you are developing a production application, we recommend updating the configuration to enable type aware lint rules: 13 | 14 | - Configure the top-level `parserOptions` property like this: 15 | 16 | ```js 17 | export default { 18 | // other rules... 19 | parserOptions: { 20 | ecmaVersion: 'latest', 21 | sourceType: 'module', 22 | project: ['./tsconfig.json', './tsconfig.node.json', './tsconfig.app.json'], 23 | tsconfigRootDir: __dirname, 24 | }, 25 | } 26 | ``` 27 | 28 | - Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked` 29 | - Optionally add `plugin:@typescript-eslint/stylistic-type-checked` 30 | - Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` & `plugin:react/jsx-runtime` to the `extends` list 31 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 10 | Audio player in React 11 | 12 | 13 |
14 | 15 | 16 | 17 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "audio-player-react-v2", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "audio-player-react-v2", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "react": "^18.3.1", 12 | "react-dom": "^18.3.1", 13 | "react-icons": "^5.2.1" 14 | }, 15 | "devDependencies": { 16 | "@types/react": "^18.3.3", 17 | "@types/react-dom": "^18.3.0", 18 | "@typescript-eslint/eslint-plugin": "^7.15.0", 19 | "@typescript-eslint/parser": "^7.15.0", 20 | "@vitejs/plugin-react": "^4.3.1", 21 | "autoprefixer": "^10.4.20", 22 | "eslint": "^8.57.0", 23 | "eslint-plugin-react-hooks": "^4.6.2", 24 | "eslint-plugin-react-refresh": "^0.4.7", 25 | "postcss": "^8.4.40", 26 | "tailwindcss": "^3.4.7", 27 | "typescript": "^5.2.2", 28 | "vite": "^5.3.4" 29 | } 30 | }, 31 | "node_modules/@alloc/quick-lru": { 32 | "version": "5.2.0", 33 | "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", 34 | "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", 35 | "dev": true, 36 | "engines": { 37 | "node": ">=10" 38 | }, 39 | "funding": { 40 | "url": "https://github.com/sponsors/sindresorhus" 41 | } 42 | }, 43 | "node_modules/@ampproject/remapping": { 44 | "version": "2.3.0", 45 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", 46 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", 47 | "dev": true, 48 | "dependencies": { 49 | "@jridgewell/gen-mapping": "^0.3.5", 50 | "@jridgewell/trace-mapping": "^0.3.24" 51 | }, 52 | "engines": { 53 | "node": ">=6.0.0" 54 | } 55 | }, 56 | "node_modules/@babel/code-frame": { 57 | "version": "7.24.7", 58 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", 59 | "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", 60 | "dev": true, 61 | "dependencies": { 62 | "@babel/highlight": "^7.24.7", 63 | "picocolors": "^1.0.0" 64 | }, 65 | "engines": { 66 | "node": ">=6.9.0" 67 | } 68 | }, 69 | "node_modules/@babel/compat-data": { 70 | "version": "7.25.2", 71 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.2.tgz", 72 | "integrity": "sha512-bYcppcpKBvX4znYaPEeFau03bp89ShqNMLs+rmdptMw+heSZh9+z84d2YG+K7cYLbWwzdjtDoW/uqZmPjulClQ==", 73 | "dev": true, 74 | "engines": { 75 | "node": ">=6.9.0" 76 | } 77 | }, 78 | "node_modules/@babel/core": { 79 | "version": "7.25.2", 80 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.2.tgz", 81 | "integrity": "sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==", 82 | "dev": true, 83 | "dependencies": { 84 | "@ampproject/remapping": "^2.2.0", 85 | "@babel/code-frame": "^7.24.7", 86 | "@babel/generator": "^7.25.0", 87 | "@babel/helper-compilation-targets": "^7.25.2", 88 | "@babel/helper-module-transforms": "^7.25.2", 89 | "@babel/helpers": "^7.25.0", 90 | "@babel/parser": "^7.25.0", 91 | "@babel/template": "^7.25.0", 92 | "@babel/traverse": "^7.25.2", 93 | "@babel/types": "^7.25.2", 94 | "convert-source-map": "^2.0.0", 95 | "debug": "^4.1.0", 96 | "gensync": "^1.0.0-beta.2", 97 | "json5": "^2.2.3", 98 | "semver": "^6.3.1" 99 | }, 100 | "engines": { 101 | "node": ">=6.9.0" 102 | }, 103 | "funding": { 104 | "type": "opencollective", 105 | "url": "https://opencollective.com/babel" 106 | } 107 | }, 108 | "node_modules/@babel/core/node_modules/semver": { 109 | "version": "6.3.1", 110 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 111 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 112 | "dev": true, 113 | "bin": { 114 | "semver": "bin/semver.js" 115 | } 116 | }, 117 | "node_modules/@babel/generator": { 118 | "version": "7.25.0", 119 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.0.tgz", 120 | "integrity": "sha512-3LEEcj3PVW8pW2R1SR1M89g/qrYk/m/mB/tLqn7dn4sbBUQyTqnlod+II2U4dqiGtUmkcnAmkMDralTFZttRiw==", 121 | "dev": true, 122 | "dependencies": { 123 | "@babel/types": "^7.25.0", 124 | "@jridgewell/gen-mapping": "^0.3.5", 125 | "@jridgewell/trace-mapping": "^0.3.25", 126 | "jsesc": "^2.5.1" 127 | }, 128 | "engines": { 129 | "node": ">=6.9.0" 130 | } 131 | }, 132 | "node_modules/@babel/helper-compilation-targets": { 133 | "version": "7.25.2", 134 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.2.tgz", 135 | "integrity": "sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==", 136 | "dev": true, 137 | "dependencies": { 138 | "@babel/compat-data": "^7.25.2", 139 | "@babel/helper-validator-option": "^7.24.8", 140 | "browserslist": "^4.23.1", 141 | "lru-cache": "^5.1.1", 142 | "semver": "^6.3.1" 143 | }, 144 | "engines": { 145 | "node": ">=6.9.0" 146 | } 147 | }, 148 | "node_modules/@babel/helper-compilation-targets/node_modules/semver": { 149 | "version": "6.3.1", 150 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 151 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 152 | "dev": true, 153 | "bin": { 154 | "semver": "bin/semver.js" 155 | } 156 | }, 157 | "node_modules/@babel/helper-module-imports": { 158 | "version": "7.24.7", 159 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", 160 | "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", 161 | "dev": true, 162 | "dependencies": { 163 | "@babel/traverse": "^7.24.7", 164 | "@babel/types": "^7.24.7" 165 | }, 166 | "engines": { 167 | "node": ">=6.9.0" 168 | } 169 | }, 170 | "node_modules/@babel/helper-module-transforms": { 171 | "version": "7.25.2", 172 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz", 173 | "integrity": "sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ==", 174 | "dev": true, 175 | "dependencies": { 176 | "@babel/helper-module-imports": "^7.24.7", 177 | "@babel/helper-simple-access": "^7.24.7", 178 | "@babel/helper-validator-identifier": "^7.24.7", 179 | "@babel/traverse": "^7.25.2" 180 | }, 181 | "engines": { 182 | "node": ">=6.9.0" 183 | }, 184 | "peerDependencies": { 185 | "@babel/core": "^7.0.0" 186 | } 187 | }, 188 | "node_modules/@babel/helper-plugin-utils": { 189 | "version": "7.24.8", 190 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz", 191 | "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==", 192 | "dev": true, 193 | "engines": { 194 | "node": ">=6.9.0" 195 | } 196 | }, 197 | "node_modules/@babel/helper-simple-access": { 198 | "version": "7.24.7", 199 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", 200 | "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", 201 | "dev": true, 202 | "dependencies": { 203 | "@babel/traverse": "^7.24.7", 204 | "@babel/types": "^7.24.7" 205 | }, 206 | "engines": { 207 | "node": ">=6.9.0" 208 | } 209 | }, 210 | "node_modules/@babel/helper-string-parser": { 211 | "version": "7.24.8", 212 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz", 213 | "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==", 214 | "dev": true, 215 | "engines": { 216 | "node": ">=6.9.0" 217 | } 218 | }, 219 | "node_modules/@babel/helper-validator-identifier": { 220 | "version": "7.24.7", 221 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", 222 | "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", 223 | "dev": true, 224 | "engines": { 225 | "node": ">=6.9.0" 226 | } 227 | }, 228 | "node_modules/@babel/helper-validator-option": { 229 | "version": "7.24.8", 230 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz", 231 | "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==", 232 | "dev": true, 233 | "engines": { 234 | "node": ">=6.9.0" 235 | } 236 | }, 237 | "node_modules/@babel/helpers": { 238 | "version": "7.25.0", 239 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.0.tgz", 240 | "integrity": "sha512-MjgLZ42aCm0oGjJj8CtSM3DB8NOOf8h2l7DCTePJs29u+v7yO/RBX9nShlKMgFnRks/Q4tBAe7Hxnov9VkGwLw==", 241 | "dev": true, 242 | "dependencies": { 243 | "@babel/template": "^7.25.0", 244 | "@babel/types": "^7.25.0" 245 | }, 246 | "engines": { 247 | "node": ">=6.9.0" 248 | } 249 | }, 250 | "node_modules/@babel/highlight": { 251 | "version": "7.24.7", 252 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", 253 | "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", 254 | "dev": true, 255 | "dependencies": { 256 | "@babel/helper-validator-identifier": "^7.24.7", 257 | "chalk": "^2.4.2", 258 | "js-tokens": "^4.0.0", 259 | "picocolors": "^1.0.0" 260 | }, 261 | "engines": { 262 | "node": ">=6.9.0" 263 | } 264 | }, 265 | "node_modules/@babel/parser": { 266 | "version": "7.25.3", 267 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.3.tgz", 268 | "integrity": "sha512-iLTJKDbJ4hMvFPgQwwsVoxtHyWpKKPBrxkANrSYewDPaPpT5py5yeVkgPIJ7XYXhndxJpaA3PyALSXQ7u8e/Dw==", 269 | "dev": true, 270 | "dependencies": { 271 | "@babel/types": "^7.25.2" 272 | }, 273 | "bin": { 274 | "parser": "bin/babel-parser.js" 275 | }, 276 | "engines": { 277 | "node": ">=6.0.0" 278 | } 279 | }, 280 | "node_modules/@babel/plugin-transform-react-jsx-self": { 281 | "version": "7.24.7", 282 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.24.7.tgz", 283 | "integrity": "sha512-fOPQYbGSgH0HUp4UJO4sMBFjY6DuWq+2i8rixyUMb3CdGixs/gccURvYOAhajBdKDoGajFr3mUq5rH3phtkGzw==", 284 | "dev": true, 285 | "dependencies": { 286 | "@babel/helper-plugin-utils": "^7.24.7" 287 | }, 288 | "engines": { 289 | "node": ">=6.9.0" 290 | }, 291 | "peerDependencies": { 292 | "@babel/core": "^7.0.0-0" 293 | } 294 | }, 295 | "node_modules/@babel/plugin-transform-react-jsx-source": { 296 | "version": "7.24.7", 297 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.24.7.tgz", 298 | "integrity": "sha512-J2z+MWzZHVOemyLweMqngXrgGC42jQ//R0KdxqkIz/OrbVIIlhFI3WigZ5fO+nwFvBlncr4MGapd8vTyc7RPNQ==", 299 | "dev": true, 300 | "dependencies": { 301 | "@babel/helper-plugin-utils": "^7.24.7" 302 | }, 303 | "engines": { 304 | "node": ">=6.9.0" 305 | }, 306 | "peerDependencies": { 307 | "@babel/core": "^7.0.0-0" 308 | } 309 | }, 310 | "node_modules/@babel/template": { 311 | "version": "7.25.0", 312 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz", 313 | "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==", 314 | "dev": true, 315 | "dependencies": { 316 | "@babel/code-frame": "^7.24.7", 317 | "@babel/parser": "^7.25.0", 318 | "@babel/types": "^7.25.0" 319 | }, 320 | "engines": { 321 | "node": ">=6.9.0" 322 | } 323 | }, 324 | "node_modules/@babel/traverse": { 325 | "version": "7.25.3", 326 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.3.tgz", 327 | "integrity": "sha512-HefgyP1x754oGCsKmV5reSmtV7IXj/kpaE1XYY+D9G5PvKKoFfSbiS4M77MdjuwlZKDIKFCffq9rPU+H/s3ZdQ==", 328 | "dev": true, 329 | "dependencies": { 330 | "@babel/code-frame": "^7.24.7", 331 | "@babel/generator": "^7.25.0", 332 | "@babel/parser": "^7.25.3", 333 | "@babel/template": "^7.25.0", 334 | "@babel/types": "^7.25.2", 335 | "debug": "^4.3.1", 336 | "globals": "^11.1.0" 337 | }, 338 | "engines": { 339 | "node": ">=6.9.0" 340 | } 341 | }, 342 | "node_modules/@babel/types": { 343 | "version": "7.25.2", 344 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.2.tgz", 345 | "integrity": "sha512-YTnYtra7W9e6/oAZEHj0bJehPRUlLH9/fbpT5LfB0NhQXyALCRkRs3zH9v07IYhkgpqX6Z78FnuccZr/l4Fs4Q==", 346 | "dev": true, 347 | "dependencies": { 348 | "@babel/helper-string-parser": "^7.24.8", 349 | "@babel/helper-validator-identifier": "^7.24.7", 350 | "to-fast-properties": "^2.0.0" 351 | }, 352 | "engines": { 353 | "node": ">=6.9.0" 354 | } 355 | }, 356 | "node_modules/@esbuild/aix-ppc64": { 357 | "version": "0.21.5", 358 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", 359 | "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", 360 | "cpu": [ 361 | "ppc64" 362 | ], 363 | "dev": true, 364 | "optional": true, 365 | "os": [ 366 | "aix" 367 | ], 368 | "engines": { 369 | "node": ">=12" 370 | } 371 | }, 372 | "node_modules/@esbuild/android-arm": { 373 | "version": "0.21.5", 374 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", 375 | "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", 376 | "cpu": [ 377 | "arm" 378 | ], 379 | "dev": true, 380 | "optional": true, 381 | "os": [ 382 | "android" 383 | ], 384 | "engines": { 385 | "node": ">=12" 386 | } 387 | }, 388 | "node_modules/@esbuild/android-arm64": { 389 | "version": "0.21.5", 390 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", 391 | "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", 392 | "cpu": [ 393 | "arm64" 394 | ], 395 | "dev": true, 396 | "optional": true, 397 | "os": [ 398 | "android" 399 | ], 400 | "engines": { 401 | "node": ">=12" 402 | } 403 | }, 404 | "node_modules/@esbuild/android-x64": { 405 | "version": "0.21.5", 406 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", 407 | "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", 408 | "cpu": [ 409 | "x64" 410 | ], 411 | "dev": true, 412 | "optional": true, 413 | "os": [ 414 | "android" 415 | ], 416 | "engines": { 417 | "node": ">=12" 418 | } 419 | }, 420 | "node_modules/@esbuild/darwin-arm64": { 421 | "version": "0.21.5", 422 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", 423 | "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", 424 | "cpu": [ 425 | "arm64" 426 | ], 427 | "dev": true, 428 | "optional": true, 429 | "os": [ 430 | "darwin" 431 | ], 432 | "engines": { 433 | "node": ">=12" 434 | } 435 | }, 436 | "node_modules/@esbuild/darwin-x64": { 437 | "version": "0.21.5", 438 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", 439 | "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", 440 | "cpu": [ 441 | "x64" 442 | ], 443 | "dev": true, 444 | "optional": true, 445 | "os": [ 446 | "darwin" 447 | ], 448 | "engines": { 449 | "node": ">=12" 450 | } 451 | }, 452 | "node_modules/@esbuild/freebsd-arm64": { 453 | "version": "0.21.5", 454 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", 455 | "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", 456 | "cpu": [ 457 | "arm64" 458 | ], 459 | "dev": true, 460 | "optional": true, 461 | "os": [ 462 | "freebsd" 463 | ], 464 | "engines": { 465 | "node": ">=12" 466 | } 467 | }, 468 | "node_modules/@esbuild/freebsd-x64": { 469 | "version": "0.21.5", 470 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", 471 | "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", 472 | "cpu": [ 473 | "x64" 474 | ], 475 | "dev": true, 476 | "optional": true, 477 | "os": [ 478 | "freebsd" 479 | ], 480 | "engines": { 481 | "node": ">=12" 482 | } 483 | }, 484 | "node_modules/@esbuild/linux-arm": { 485 | "version": "0.21.5", 486 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", 487 | "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", 488 | "cpu": [ 489 | "arm" 490 | ], 491 | "dev": true, 492 | "optional": true, 493 | "os": [ 494 | "linux" 495 | ], 496 | "engines": { 497 | "node": ">=12" 498 | } 499 | }, 500 | "node_modules/@esbuild/linux-arm64": { 501 | "version": "0.21.5", 502 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", 503 | "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", 504 | "cpu": [ 505 | "arm64" 506 | ], 507 | "dev": true, 508 | "optional": true, 509 | "os": [ 510 | "linux" 511 | ], 512 | "engines": { 513 | "node": ">=12" 514 | } 515 | }, 516 | "node_modules/@esbuild/linux-ia32": { 517 | "version": "0.21.5", 518 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", 519 | "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", 520 | "cpu": [ 521 | "ia32" 522 | ], 523 | "dev": true, 524 | "optional": true, 525 | "os": [ 526 | "linux" 527 | ], 528 | "engines": { 529 | "node": ">=12" 530 | } 531 | }, 532 | "node_modules/@esbuild/linux-loong64": { 533 | "version": "0.21.5", 534 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", 535 | "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", 536 | "cpu": [ 537 | "loong64" 538 | ], 539 | "dev": true, 540 | "optional": true, 541 | "os": [ 542 | "linux" 543 | ], 544 | "engines": { 545 | "node": ">=12" 546 | } 547 | }, 548 | "node_modules/@esbuild/linux-mips64el": { 549 | "version": "0.21.5", 550 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", 551 | "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", 552 | "cpu": [ 553 | "mips64el" 554 | ], 555 | "dev": true, 556 | "optional": true, 557 | "os": [ 558 | "linux" 559 | ], 560 | "engines": { 561 | "node": ">=12" 562 | } 563 | }, 564 | "node_modules/@esbuild/linux-ppc64": { 565 | "version": "0.21.5", 566 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", 567 | "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", 568 | "cpu": [ 569 | "ppc64" 570 | ], 571 | "dev": true, 572 | "optional": true, 573 | "os": [ 574 | "linux" 575 | ], 576 | "engines": { 577 | "node": ">=12" 578 | } 579 | }, 580 | "node_modules/@esbuild/linux-riscv64": { 581 | "version": "0.21.5", 582 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", 583 | "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", 584 | "cpu": [ 585 | "riscv64" 586 | ], 587 | "dev": true, 588 | "optional": true, 589 | "os": [ 590 | "linux" 591 | ], 592 | "engines": { 593 | "node": ">=12" 594 | } 595 | }, 596 | "node_modules/@esbuild/linux-s390x": { 597 | "version": "0.21.5", 598 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", 599 | "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", 600 | "cpu": [ 601 | "s390x" 602 | ], 603 | "dev": true, 604 | "optional": true, 605 | "os": [ 606 | "linux" 607 | ], 608 | "engines": { 609 | "node": ">=12" 610 | } 611 | }, 612 | "node_modules/@esbuild/linux-x64": { 613 | "version": "0.21.5", 614 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", 615 | "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", 616 | "cpu": [ 617 | "x64" 618 | ], 619 | "dev": true, 620 | "optional": true, 621 | "os": [ 622 | "linux" 623 | ], 624 | "engines": { 625 | "node": ">=12" 626 | } 627 | }, 628 | "node_modules/@esbuild/netbsd-x64": { 629 | "version": "0.21.5", 630 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", 631 | "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", 632 | "cpu": [ 633 | "x64" 634 | ], 635 | "dev": true, 636 | "optional": true, 637 | "os": [ 638 | "netbsd" 639 | ], 640 | "engines": { 641 | "node": ">=12" 642 | } 643 | }, 644 | "node_modules/@esbuild/openbsd-x64": { 645 | "version": "0.21.5", 646 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", 647 | "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", 648 | "cpu": [ 649 | "x64" 650 | ], 651 | "dev": true, 652 | "optional": true, 653 | "os": [ 654 | "openbsd" 655 | ], 656 | "engines": { 657 | "node": ">=12" 658 | } 659 | }, 660 | "node_modules/@esbuild/sunos-x64": { 661 | "version": "0.21.5", 662 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", 663 | "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", 664 | "cpu": [ 665 | "x64" 666 | ], 667 | "dev": true, 668 | "optional": true, 669 | "os": [ 670 | "sunos" 671 | ], 672 | "engines": { 673 | "node": ">=12" 674 | } 675 | }, 676 | "node_modules/@esbuild/win32-arm64": { 677 | "version": "0.21.5", 678 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", 679 | "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", 680 | "cpu": [ 681 | "arm64" 682 | ], 683 | "dev": true, 684 | "optional": true, 685 | "os": [ 686 | "win32" 687 | ], 688 | "engines": { 689 | "node": ">=12" 690 | } 691 | }, 692 | "node_modules/@esbuild/win32-ia32": { 693 | "version": "0.21.5", 694 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", 695 | "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", 696 | "cpu": [ 697 | "ia32" 698 | ], 699 | "dev": true, 700 | "optional": true, 701 | "os": [ 702 | "win32" 703 | ], 704 | "engines": { 705 | "node": ">=12" 706 | } 707 | }, 708 | "node_modules/@esbuild/win32-x64": { 709 | "version": "0.21.5", 710 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", 711 | "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", 712 | "cpu": [ 713 | "x64" 714 | ], 715 | "dev": true, 716 | "optional": true, 717 | "os": [ 718 | "win32" 719 | ], 720 | "engines": { 721 | "node": ">=12" 722 | } 723 | }, 724 | "node_modules/@eslint-community/eslint-utils": { 725 | "version": "4.4.0", 726 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 727 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 728 | "dev": true, 729 | "dependencies": { 730 | "eslint-visitor-keys": "^3.3.0" 731 | }, 732 | "engines": { 733 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 734 | }, 735 | "peerDependencies": { 736 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 737 | } 738 | }, 739 | "node_modules/@eslint-community/regexpp": { 740 | "version": "4.11.0", 741 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.0.tgz", 742 | "integrity": "sha512-G/M/tIiMrTAxEWRfLfQJMmGNX28IxBg4PBz8XqQhqUHLFI6TL2htpIB1iQCj144V5ee/JaKyT9/WZ0MGZWfA7A==", 743 | "dev": true, 744 | "engines": { 745 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 746 | } 747 | }, 748 | "node_modules/@eslint/eslintrc": { 749 | "version": "2.1.4", 750 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 751 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 752 | "dev": true, 753 | "dependencies": { 754 | "ajv": "^6.12.4", 755 | "debug": "^4.3.2", 756 | "espree": "^9.6.0", 757 | "globals": "^13.19.0", 758 | "ignore": "^5.2.0", 759 | "import-fresh": "^3.2.1", 760 | "js-yaml": "^4.1.0", 761 | "minimatch": "^3.1.2", 762 | "strip-json-comments": "^3.1.1" 763 | }, 764 | "engines": { 765 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 766 | }, 767 | "funding": { 768 | "url": "https://opencollective.com/eslint" 769 | } 770 | }, 771 | "node_modules/@eslint/eslintrc/node_modules/brace-expansion": { 772 | "version": "1.1.11", 773 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 774 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 775 | "dev": true, 776 | "dependencies": { 777 | "balanced-match": "^1.0.0", 778 | "concat-map": "0.0.1" 779 | } 780 | }, 781 | "node_modules/@eslint/eslintrc/node_modules/globals": { 782 | "version": "13.24.0", 783 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 784 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 785 | "dev": true, 786 | "dependencies": { 787 | "type-fest": "^0.20.2" 788 | }, 789 | "engines": { 790 | "node": ">=8" 791 | }, 792 | "funding": { 793 | "url": "https://github.com/sponsors/sindresorhus" 794 | } 795 | }, 796 | "node_modules/@eslint/eslintrc/node_modules/minimatch": { 797 | "version": "3.1.2", 798 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 799 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 800 | "dev": true, 801 | "dependencies": { 802 | "brace-expansion": "^1.1.7" 803 | }, 804 | "engines": { 805 | "node": "*" 806 | } 807 | }, 808 | "node_modules/@eslint/js": { 809 | "version": "8.57.0", 810 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 811 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 812 | "dev": true, 813 | "engines": { 814 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 815 | } 816 | }, 817 | "node_modules/@humanwhocodes/config-array": { 818 | "version": "0.11.14", 819 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 820 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 821 | "deprecated": "Use @eslint/config-array instead", 822 | "dev": true, 823 | "dependencies": { 824 | "@humanwhocodes/object-schema": "^2.0.2", 825 | "debug": "^4.3.1", 826 | "minimatch": "^3.0.5" 827 | }, 828 | "engines": { 829 | "node": ">=10.10.0" 830 | } 831 | }, 832 | "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": { 833 | "version": "1.1.11", 834 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 835 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 836 | "dev": true, 837 | "dependencies": { 838 | "balanced-match": "^1.0.0", 839 | "concat-map": "0.0.1" 840 | } 841 | }, 842 | "node_modules/@humanwhocodes/config-array/node_modules/minimatch": { 843 | "version": "3.1.2", 844 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 845 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 846 | "dev": true, 847 | "dependencies": { 848 | "brace-expansion": "^1.1.7" 849 | }, 850 | "engines": { 851 | "node": "*" 852 | } 853 | }, 854 | "node_modules/@humanwhocodes/module-importer": { 855 | "version": "1.0.1", 856 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 857 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 858 | "dev": true, 859 | "engines": { 860 | "node": ">=12.22" 861 | }, 862 | "funding": { 863 | "type": "github", 864 | "url": "https://github.com/sponsors/nzakas" 865 | } 866 | }, 867 | "node_modules/@humanwhocodes/object-schema": { 868 | "version": "2.0.3", 869 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", 870 | "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", 871 | "deprecated": "Use @eslint/object-schema instead", 872 | "dev": true 873 | }, 874 | "node_modules/@isaacs/cliui": { 875 | "version": "8.0.2", 876 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", 877 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", 878 | "dev": true, 879 | "dependencies": { 880 | "string-width": "^5.1.2", 881 | "string-width-cjs": "npm:string-width@^4.2.0", 882 | "strip-ansi": "^7.0.1", 883 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", 884 | "wrap-ansi": "^8.1.0", 885 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" 886 | }, 887 | "engines": { 888 | "node": ">=12" 889 | } 890 | }, 891 | "node_modules/@isaacs/cliui/node_modules/ansi-regex": { 892 | "version": "6.0.1", 893 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 894 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 895 | "dev": true, 896 | "engines": { 897 | "node": ">=12" 898 | }, 899 | "funding": { 900 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 901 | } 902 | }, 903 | "node_modules/@isaacs/cliui/node_modules/strip-ansi": { 904 | "version": "7.1.0", 905 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 906 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 907 | "dev": true, 908 | "dependencies": { 909 | "ansi-regex": "^6.0.1" 910 | }, 911 | "engines": { 912 | "node": ">=12" 913 | }, 914 | "funding": { 915 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 916 | } 917 | }, 918 | "node_modules/@jridgewell/gen-mapping": { 919 | "version": "0.3.5", 920 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 921 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 922 | "dev": true, 923 | "dependencies": { 924 | "@jridgewell/set-array": "^1.2.1", 925 | "@jridgewell/sourcemap-codec": "^1.4.10", 926 | "@jridgewell/trace-mapping": "^0.3.24" 927 | }, 928 | "engines": { 929 | "node": ">=6.0.0" 930 | } 931 | }, 932 | "node_modules/@jridgewell/resolve-uri": { 933 | "version": "3.1.2", 934 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 935 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 936 | "dev": true, 937 | "engines": { 938 | "node": ">=6.0.0" 939 | } 940 | }, 941 | "node_modules/@jridgewell/set-array": { 942 | "version": "1.2.1", 943 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 944 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 945 | "dev": true, 946 | "engines": { 947 | "node": ">=6.0.0" 948 | } 949 | }, 950 | "node_modules/@jridgewell/sourcemap-codec": { 951 | "version": "1.5.0", 952 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", 953 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", 954 | "dev": true 955 | }, 956 | "node_modules/@jridgewell/trace-mapping": { 957 | "version": "0.3.25", 958 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 959 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 960 | "dev": true, 961 | "dependencies": { 962 | "@jridgewell/resolve-uri": "^3.1.0", 963 | "@jridgewell/sourcemap-codec": "^1.4.14" 964 | } 965 | }, 966 | "node_modules/@nodelib/fs.scandir": { 967 | "version": "2.1.5", 968 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 969 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 970 | "dev": true, 971 | "dependencies": { 972 | "@nodelib/fs.stat": "2.0.5", 973 | "run-parallel": "^1.1.9" 974 | }, 975 | "engines": { 976 | "node": ">= 8" 977 | } 978 | }, 979 | "node_modules/@nodelib/fs.stat": { 980 | "version": "2.0.5", 981 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 982 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 983 | "dev": true, 984 | "engines": { 985 | "node": ">= 8" 986 | } 987 | }, 988 | "node_modules/@nodelib/fs.walk": { 989 | "version": "1.2.8", 990 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 991 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 992 | "dev": true, 993 | "dependencies": { 994 | "@nodelib/fs.scandir": "2.1.5", 995 | "fastq": "^1.6.0" 996 | }, 997 | "engines": { 998 | "node": ">= 8" 999 | } 1000 | }, 1001 | "node_modules/@pkgjs/parseargs": { 1002 | "version": "0.11.0", 1003 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", 1004 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", 1005 | "dev": true, 1006 | "optional": true, 1007 | "engines": { 1008 | "node": ">=14" 1009 | } 1010 | }, 1011 | "node_modules/@rollup/rollup-android-arm-eabi": { 1012 | "version": "4.20.0", 1013 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.20.0.tgz", 1014 | "integrity": "sha512-TSpWzflCc4VGAUJZlPpgAJE1+V60MePDQnBd7PPkpuEmOy8i87aL6tinFGKBFKuEDikYpig72QzdT3QPYIi+oA==", 1015 | "cpu": [ 1016 | "arm" 1017 | ], 1018 | "dev": true, 1019 | "optional": true, 1020 | "os": [ 1021 | "android" 1022 | ] 1023 | }, 1024 | "node_modules/@rollup/rollup-android-arm64": { 1025 | "version": "4.20.0", 1026 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.20.0.tgz", 1027 | "integrity": "sha512-u00Ro/nok7oGzVuh/FMYfNoGqxU5CPWz1mxV85S2w9LxHR8OoMQBuSk+3BKVIDYgkpeOET5yXkx90OYFc+ytpQ==", 1028 | "cpu": [ 1029 | "arm64" 1030 | ], 1031 | "dev": true, 1032 | "optional": true, 1033 | "os": [ 1034 | "android" 1035 | ] 1036 | }, 1037 | "node_modules/@rollup/rollup-darwin-arm64": { 1038 | "version": "4.20.0", 1039 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.20.0.tgz", 1040 | "integrity": "sha512-uFVfvzvsdGtlSLuL0ZlvPJvl6ZmrH4CBwLGEFPe7hUmf7htGAN+aXo43R/V6LATyxlKVC/m6UsLb7jbG+LG39Q==", 1041 | "cpu": [ 1042 | "arm64" 1043 | ], 1044 | "dev": true, 1045 | "optional": true, 1046 | "os": [ 1047 | "darwin" 1048 | ] 1049 | }, 1050 | "node_modules/@rollup/rollup-darwin-x64": { 1051 | "version": "4.20.0", 1052 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.20.0.tgz", 1053 | "integrity": "sha512-xbrMDdlev53vNXexEa6l0LffojxhqDTBeL+VUxuuIXys4x6xyvbKq5XqTXBCEUA8ty8iEJblHvFaWRJTk/icAQ==", 1054 | "cpu": [ 1055 | "x64" 1056 | ], 1057 | "dev": true, 1058 | "optional": true, 1059 | "os": [ 1060 | "darwin" 1061 | ] 1062 | }, 1063 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 1064 | "version": "4.20.0", 1065 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.20.0.tgz", 1066 | "integrity": "sha512-jMYvxZwGmoHFBTbr12Xc6wOdc2xA5tF5F2q6t7Rcfab68TT0n+r7dgawD4qhPEvasDsVpQi+MgDzj2faOLsZjA==", 1067 | "cpu": [ 1068 | "arm" 1069 | ], 1070 | "dev": true, 1071 | "optional": true, 1072 | "os": [ 1073 | "linux" 1074 | ] 1075 | }, 1076 | "node_modules/@rollup/rollup-linux-arm-musleabihf": { 1077 | "version": "4.20.0", 1078 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.20.0.tgz", 1079 | "integrity": "sha512-1asSTl4HKuIHIB1GcdFHNNZhxAYEdqML/MW4QmPS4G0ivbEcBr1JKlFLKsIRqjSwOBkdItn3/ZDlyvZ/N6KPlw==", 1080 | "cpu": [ 1081 | "arm" 1082 | ], 1083 | "dev": true, 1084 | "optional": true, 1085 | "os": [ 1086 | "linux" 1087 | ] 1088 | }, 1089 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1090 | "version": "4.20.0", 1091 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.20.0.tgz", 1092 | "integrity": "sha512-COBb8Bkx56KldOYJfMf6wKeYJrtJ9vEgBRAOkfw6Ens0tnmzPqvlpjZiLgkhg6cA3DGzCmLmmd319pmHvKWWlQ==", 1093 | "cpu": [ 1094 | "arm64" 1095 | ], 1096 | "dev": true, 1097 | "optional": true, 1098 | "os": [ 1099 | "linux" 1100 | ] 1101 | }, 1102 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1103 | "version": "4.20.0", 1104 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.20.0.tgz", 1105 | "integrity": "sha512-+it+mBSyMslVQa8wSPvBx53fYuZK/oLTu5RJoXogjk6x7Q7sz1GNRsXWjn6SwyJm8E/oMjNVwPhmNdIjwP135Q==", 1106 | "cpu": [ 1107 | "arm64" 1108 | ], 1109 | "dev": true, 1110 | "optional": true, 1111 | "os": [ 1112 | "linux" 1113 | ] 1114 | }, 1115 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { 1116 | "version": "4.20.0", 1117 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.20.0.tgz", 1118 | "integrity": "sha512-yAMvqhPfGKsAxHN8I4+jE0CpLWD8cv4z7CK7BMmhjDuz606Q2tFKkWRY8bHR9JQXYcoLfopo5TTqzxgPUjUMfw==", 1119 | "cpu": [ 1120 | "ppc64" 1121 | ], 1122 | "dev": true, 1123 | "optional": true, 1124 | "os": [ 1125 | "linux" 1126 | ] 1127 | }, 1128 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1129 | "version": "4.20.0", 1130 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.20.0.tgz", 1131 | "integrity": "sha512-qmuxFpfmi/2SUkAw95TtNq/w/I7Gpjurx609OOOV7U4vhvUhBcftcmXwl3rqAek+ADBwSjIC4IVNLiszoj3dPA==", 1132 | "cpu": [ 1133 | "riscv64" 1134 | ], 1135 | "dev": true, 1136 | "optional": true, 1137 | "os": [ 1138 | "linux" 1139 | ] 1140 | }, 1141 | "node_modules/@rollup/rollup-linux-s390x-gnu": { 1142 | "version": "4.20.0", 1143 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.20.0.tgz", 1144 | "integrity": "sha512-I0BtGXddHSHjV1mqTNkgUZLnS3WtsqebAXv11D5BZE/gfw5KoyXSAXVqyJximQXNvNzUo4GKlCK/dIwXlz+jlg==", 1145 | "cpu": [ 1146 | "s390x" 1147 | ], 1148 | "dev": true, 1149 | "optional": true, 1150 | "os": [ 1151 | "linux" 1152 | ] 1153 | }, 1154 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1155 | "version": "4.20.0", 1156 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.20.0.tgz", 1157 | "integrity": "sha512-y+eoL2I3iphUg9tN9GB6ku1FA8kOfmF4oUEWhztDJ4KXJy1agk/9+pejOuZkNFhRwHAOxMsBPLbXPd6mJiCwew==", 1158 | "cpu": [ 1159 | "x64" 1160 | ], 1161 | "dev": true, 1162 | "optional": true, 1163 | "os": [ 1164 | "linux" 1165 | ] 1166 | }, 1167 | "node_modules/@rollup/rollup-linux-x64-musl": { 1168 | "version": "4.20.0", 1169 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.20.0.tgz", 1170 | "integrity": "sha512-hM3nhW40kBNYUkZb/r9k2FKK+/MnKglX7UYd4ZUy5DJs8/sMsIbqWK2piZtVGE3kcXVNj3B2IrUYROJMMCikNg==", 1171 | "cpu": [ 1172 | "x64" 1173 | ], 1174 | "dev": true, 1175 | "optional": true, 1176 | "os": [ 1177 | "linux" 1178 | ] 1179 | }, 1180 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1181 | "version": "4.20.0", 1182 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.20.0.tgz", 1183 | "integrity": "sha512-psegMvP+Ik/Bg7QRJbv8w8PAytPA7Uo8fpFjXyCRHWm6Nt42L+JtoqH8eDQ5hRP7/XW2UiIriy1Z46jf0Oa1kA==", 1184 | "cpu": [ 1185 | "arm64" 1186 | ], 1187 | "dev": true, 1188 | "optional": true, 1189 | "os": [ 1190 | "win32" 1191 | ] 1192 | }, 1193 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1194 | "version": "4.20.0", 1195 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.20.0.tgz", 1196 | "integrity": "sha512-GabekH3w4lgAJpVxkk7hUzUf2hICSQO0a/BLFA11/RMxQT92MabKAqyubzDZmMOC/hcJNlc+rrypzNzYl4Dx7A==", 1197 | "cpu": [ 1198 | "ia32" 1199 | ], 1200 | "dev": true, 1201 | "optional": true, 1202 | "os": [ 1203 | "win32" 1204 | ] 1205 | }, 1206 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1207 | "version": "4.20.0", 1208 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.20.0.tgz", 1209 | "integrity": "sha512-aJ1EJSuTdGnM6qbVC4B5DSmozPTqIag9fSzXRNNo+humQLG89XpPgdt16Ia56ORD7s+H8Pmyx44uczDQ0yDzpg==", 1210 | "cpu": [ 1211 | "x64" 1212 | ], 1213 | "dev": true, 1214 | "optional": true, 1215 | "os": [ 1216 | "win32" 1217 | ] 1218 | }, 1219 | "node_modules/@types/babel__core": { 1220 | "version": "7.20.5", 1221 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1222 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1223 | "dev": true, 1224 | "dependencies": { 1225 | "@babel/parser": "^7.20.7", 1226 | "@babel/types": "^7.20.7", 1227 | "@types/babel__generator": "*", 1228 | "@types/babel__template": "*", 1229 | "@types/babel__traverse": "*" 1230 | } 1231 | }, 1232 | "node_modules/@types/babel__generator": { 1233 | "version": "7.6.8", 1234 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 1235 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 1236 | "dev": true, 1237 | "dependencies": { 1238 | "@babel/types": "^7.0.0" 1239 | } 1240 | }, 1241 | "node_modules/@types/babel__template": { 1242 | "version": "7.4.4", 1243 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1244 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1245 | "dev": true, 1246 | "dependencies": { 1247 | "@babel/parser": "^7.1.0", 1248 | "@babel/types": "^7.0.0" 1249 | } 1250 | }, 1251 | "node_modules/@types/babel__traverse": { 1252 | "version": "7.20.6", 1253 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz", 1254 | "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==", 1255 | "dev": true, 1256 | "dependencies": { 1257 | "@babel/types": "^7.20.7" 1258 | } 1259 | }, 1260 | "node_modules/@types/estree": { 1261 | "version": "1.0.5", 1262 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1263 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1264 | "dev": true 1265 | }, 1266 | "node_modules/@types/prop-types": { 1267 | "version": "15.7.12", 1268 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.12.tgz", 1269 | "integrity": "sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==", 1270 | "dev": true 1271 | }, 1272 | "node_modules/@types/react": { 1273 | "version": "18.3.3", 1274 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.3.tgz", 1275 | "integrity": "sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw==", 1276 | "dev": true, 1277 | "dependencies": { 1278 | "@types/prop-types": "*", 1279 | "csstype": "^3.0.2" 1280 | } 1281 | }, 1282 | "node_modules/@types/react-dom": { 1283 | "version": "18.3.0", 1284 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.0.tgz", 1285 | "integrity": "sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==", 1286 | "dev": true, 1287 | "dependencies": { 1288 | "@types/react": "*" 1289 | } 1290 | }, 1291 | "node_modules/@typescript-eslint/eslint-plugin": { 1292 | "version": "7.18.0", 1293 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.18.0.tgz", 1294 | "integrity": "sha512-94EQTWZ40mzBc42ATNIBimBEDltSJ9RQHCC8vc/PDbxi4k8dVwUAv4o98dk50M1zB+JGFxp43FP7f8+FP8R6Sw==", 1295 | "dev": true, 1296 | "dependencies": { 1297 | "@eslint-community/regexpp": "^4.10.0", 1298 | "@typescript-eslint/scope-manager": "7.18.0", 1299 | "@typescript-eslint/type-utils": "7.18.0", 1300 | "@typescript-eslint/utils": "7.18.0", 1301 | "@typescript-eslint/visitor-keys": "7.18.0", 1302 | "graphemer": "^1.4.0", 1303 | "ignore": "^5.3.1", 1304 | "natural-compare": "^1.4.0", 1305 | "ts-api-utils": "^1.3.0" 1306 | }, 1307 | "engines": { 1308 | "node": "^18.18.0 || >=20.0.0" 1309 | }, 1310 | "funding": { 1311 | "type": "opencollective", 1312 | "url": "https://opencollective.com/typescript-eslint" 1313 | }, 1314 | "peerDependencies": { 1315 | "@typescript-eslint/parser": "^7.0.0", 1316 | "eslint": "^8.56.0" 1317 | }, 1318 | "peerDependenciesMeta": { 1319 | "typescript": { 1320 | "optional": true 1321 | } 1322 | } 1323 | }, 1324 | "node_modules/@typescript-eslint/parser": { 1325 | "version": "7.18.0", 1326 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.18.0.tgz", 1327 | "integrity": "sha512-4Z+L8I2OqhZV8qA132M4wNL30ypZGYOQVBfMgxDH/K5UX0PNqTu1c6za9ST5r9+tavvHiTWmBnKzpCJ/GlVFtg==", 1328 | "dev": true, 1329 | "dependencies": { 1330 | "@typescript-eslint/scope-manager": "7.18.0", 1331 | "@typescript-eslint/types": "7.18.0", 1332 | "@typescript-eslint/typescript-estree": "7.18.0", 1333 | "@typescript-eslint/visitor-keys": "7.18.0", 1334 | "debug": "^4.3.4" 1335 | }, 1336 | "engines": { 1337 | "node": "^18.18.0 || >=20.0.0" 1338 | }, 1339 | "funding": { 1340 | "type": "opencollective", 1341 | "url": "https://opencollective.com/typescript-eslint" 1342 | }, 1343 | "peerDependencies": { 1344 | "eslint": "^8.56.0" 1345 | }, 1346 | "peerDependenciesMeta": { 1347 | "typescript": { 1348 | "optional": true 1349 | } 1350 | } 1351 | }, 1352 | "node_modules/@typescript-eslint/scope-manager": { 1353 | "version": "7.18.0", 1354 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.18.0.tgz", 1355 | "integrity": "sha512-jjhdIE/FPF2B7Z1uzc6i3oWKbGcHb87Qw7AWj6jmEqNOfDFbJWtjt/XfwCpvNkpGWlcJaog5vTR+VV8+w9JflA==", 1356 | "dev": true, 1357 | "dependencies": { 1358 | "@typescript-eslint/types": "7.18.0", 1359 | "@typescript-eslint/visitor-keys": "7.18.0" 1360 | }, 1361 | "engines": { 1362 | "node": "^18.18.0 || >=20.0.0" 1363 | }, 1364 | "funding": { 1365 | "type": "opencollective", 1366 | "url": "https://opencollective.com/typescript-eslint" 1367 | } 1368 | }, 1369 | "node_modules/@typescript-eslint/type-utils": { 1370 | "version": "7.18.0", 1371 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.18.0.tgz", 1372 | "integrity": "sha512-XL0FJXuCLaDuX2sYqZUUSOJ2sG5/i1AAze+axqmLnSkNEVMVYLF+cbwlB2w8D1tinFuSikHmFta+P+HOofrLeA==", 1373 | "dev": true, 1374 | "dependencies": { 1375 | "@typescript-eslint/typescript-estree": "7.18.0", 1376 | "@typescript-eslint/utils": "7.18.0", 1377 | "debug": "^4.3.4", 1378 | "ts-api-utils": "^1.3.0" 1379 | }, 1380 | "engines": { 1381 | "node": "^18.18.0 || >=20.0.0" 1382 | }, 1383 | "funding": { 1384 | "type": "opencollective", 1385 | "url": "https://opencollective.com/typescript-eslint" 1386 | }, 1387 | "peerDependencies": { 1388 | "eslint": "^8.56.0" 1389 | }, 1390 | "peerDependenciesMeta": { 1391 | "typescript": { 1392 | "optional": true 1393 | } 1394 | } 1395 | }, 1396 | "node_modules/@typescript-eslint/types": { 1397 | "version": "7.18.0", 1398 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.18.0.tgz", 1399 | "integrity": "sha512-iZqi+Ds1y4EDYUtlOOC+aUmxnE9xS/yCigkjA7XpTKV6nCBd3Hp/PRGGmdwnfkV2ThMyYldP1wRpm/id99spTQ==", 1400 | "dev": true, 1401 | "engines": { 1402 | "node": "^18.18.0 || >=20.0.0" 1403 | }, 1404 | "funding": { 1405 | "type": "opencollective", 1406 | "url": "https://opencollective.com/typescript-eslint" 1407 | } 1408 | }, 1409 | "node_modules/@typescript-eslint/typescript-estree": { 1410 | "version": "7.18.0", 1411 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.18.0.tgz", 1412 | "integrity": "sha512-aP1v/BSPnnyhMHts8cf1qQ6Q1IFwwRvAQGRvBFkWlo3/lH29OXA3Pts+c10nxRxIBrDnoMqzhgdwVe5f2D6OzA==", 1413 | "dev": true, 1414 | "dependencies": { 1415 | "@typescript-eslint/types": "7.18.0", 1416 | "@typescript-eslint/visitor-keys": "7.18.0", 1417 | "debug": "^4.3.4", 1418 | "globby": "^11.1.0", 1419 | "is-glob": "^4.0.3", 1420 | "minimatch": "^9.0.4", 1421 | "semver": "^7.6.0", 1422 | "ts-api-utils": "^1.3.0" 1423 | }, 1424 | "engines": { 1425 | "node": "^18.18.0 || >=20.0.0" 1426 | }, 1427 | "funding": { 1428 | "type": "opencollective", 1429 | "url": "https://opencollective.com/typescript-eslint" 1430 | }, 1431 | "peerDependenciesMeta": { 1432 | "typescript": { 1433 | "optional": true 1434 | } 1435 | } 1436 | }, 1437 | "node_modules/@typescript-eslint/utils": { 1438 | "version": "7.18.0", 1439 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.18.0.tgz", 1440 | "integrity": "sha512-kK0/rNa2j74XuHVcoCZxdFBMF+aq/vH83CXAOHieC+2Gis4mF8jJXT5eAfyD3K0sAxtPuwxaIOIOvhwzVDt/kw==", 1441 | "dev": true, 1442 | "dependencies": { 1443 | "@eslint-community/eslint-utils": "^4.4.0", 1444 | "@typescript-eslint/scope-manager": "7.18.0", 1445 | "@typescript-eslint/types": "7.18.0", 1446 | "@typescript-eslint/typescript-estree": "7.18.0" 1447 | }, 1448 | "engines": { 1449 | "node": "^18.18.0 || >=20.0.0" 1450 | }, 1451 | "funding": { 1452 | "type": "opencollective", 1453 | "url": "https://opencollective.com/typescript-eslint" 1454 | }, 1455 | "peerDependencies": { 1456 | "eslint": "^8.56.0" 1457 | } 1458 | }, 1459 | "node_modules/@typescript-eslint/visitor-keys": { 1460 | "version": "7.18.0", 1461 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.18.0.tgz", 1462 | "integrity": "sha512-cDF0/Gf81QpY3xYyJKDV14Zwdmid5+uuENhjH2EqFaF0ni+yAyq/LzMaIJdhNJXZI7uLzwIlA+V7oWoyn6Curg==", 1463 | "dev": true, 1464 | "dependencies": { 1465 | "@typescript-eslint/types": "7.18.0", 1466 | "eslint-visitor-keys": "^3.4.3" 1467 | }, 1468 | "engines": { 1469 | "node": "^18.18.0 || >=20.0.0" 1470 | }, 1471 | "funding": { 1472 | "type": "opencollective", 1473 | "url": "https://opencollective.com/typescript-eslint" 1474 | } 1475 | }, 1476 | "node_modules/@ungap/structured-clone": { 1477 | "version": "1.2.0", 1478 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 1479 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 1480 | "dev": true 1481 | }, 1482 | "node_modules/@vitejs/plugin-react": { 1483 | "version": "4.3.1", 1484 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.3.1.tgz", 1485 | "integrity": "sha512-m/V2syj5CuVnaxcUJOQRel/Wr31FFXRFlnOoq1TVtkCxsY5veGMTEmpWHndrhB2U8ScHtCQB1e+4hWYExQc6Lg==", 1486 | "dev": true, 1487 | "dependencies": { 1488 | "@babel/core": "^7.24.5", 1489 | "@babel/plugin-transform-react-jsx-self": "^7.24.5", 1490 | "@babel/plugin-transform-react-jsx-source": "^7.24.1", 1491 | "@types/babel__core": "^7.20.5", 1492 | "react-refresh": "^0.14.2" 1493 | }, 1494 | "engines": { 1495 | "node": "^14.18.0 || >=16.0.0" 1496 | }, 1497 | "peerDependencies": { 1498 | "vite": "^4.2.0 || ^5.0.0" 1499 | } 1500 | }, 1501 | "node_modules/acorn": { 1502 | "version": "8.12.1", 1503 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", 1504 | "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", 1505 | "dev": true, 1506 | "bin": { 1507 | "acorn": "bin/acorn" 1508 | }, 1509 | "engines": { 1510 | "node": ">=0.4.0" 1511 | } 1512 | }, 1513 | "node_modules/acorn-jsx": { 1514 | "version": "5.3.2", 1515 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1516 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1517 | "dev": true, 1518 | "peerDependencies": { 1519 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1520 | } 1521 | }, 1522 | "node_modules/ajv": { 1523 | "version": "6.12.6", 1524 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1525 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1526 | "dev": true, 1527 | "dependencies": { 1528 | "fast-deep-equal": "^3.1.1", 1529 | "fast-json-stable-stringify": "^2.0.0", 1530 | "json-schema-traverse": "^0.4.1", 1531 | "uri-js": "^4.2.2" 1532 | }, 1533 | "funding": { 1534 | "type": "github", 1535 | "url": "https://github.com/sponsors/epoberezkin" 1536 | } 1537 | }, 1538 | "node_modules/ansi-regex": { 1539 | "version": "5.0.1", 1540 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1541 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1542 | "dev": true, 1543 | "engines": { 1544 | "node": ">=8" 1545 | } 1546 | }, 1547 | "node_modules/ansi-styles": { 1548 | "version": "3.2.1", 1549 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1550 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1551 | "dev": true, 1552 | "dependencies": { 1553 | "color-convert": "^1.9.0" 1554 | }, 1555 | "engines": { 1556 | "node": ">=4" 1557 | } 1558 | }, 1559 | "node_modules/any-promise": { 1560 | "version": "1.3.0", 1561 | "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", 1562 | "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==", 1563 | "dev": true 1564 | }, 1565 | "node_modules/anymatch": { 1566 | "version": "3.1.3", 1567 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", 1568 | "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", 1569 | "dev": true, 1570 | "dependencies": { 1571 | "normalize-path": "^3.0.0", 1572 | "picomatch": "^2.0.4" 1573 | }, 1574 | "engines": { 1575 | "node": ">= 8" 1576 | } 1577 | }, 1578 | "node_modules/arg": { 1579 | "version": "5.0.2", 1580 | "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", 1581 | "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==", 1582 | "dev": true 1583 | }, 1584 | "node_modules/argparse": { 1585 | "version": "2.0.1", 1586 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1587 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1588 | "dev": true 1589 | }, 1590 | "node_modules/array-union": { 1591 | "version": "2.1.0", 1592 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 1593 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 1594 | "dev": true, 1595 | "engines": { 1596 | "node": ">=8" 1597 | } 1598 | }, 1599 | "node_modules/autoprefixer": { 1600 | "version": "10.4.20", 1601 | "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.20.tgz", 1602 | "integrity": "sha512-XY25y5xSv/wEoqzDyXXME4AFfkZI0P23z6Fs3YgymDnKJkCGOnkL0iTxCa85UTqaSgfcqyf3UA6+c7wUvx/16g==", 1603 | "dev": true, 1604 | "funding": [ 1605 | { 1606 | "type": "opencollective", 1607 | "url": "https://opencollective.com/postcss/" 1608 | }, 1609 | { 1610 | "type": "tidelift", 1611 | "url": "https://tidelift.com/funding/github/npm/autoprefixer" 1612 | }, 1613 | { 1614 | "type": "github", 1615 | "url": "https://github.com/sponsors/ai" 1616 | } 1617 | ], 1618 | "dependencies": { 1619 | "browserslist": "^4.23.3", 1620 | "caniuse-lite": "^1.0.30001646", 1621 | "fraction.js": "^4.3.7", 1622 | "normalize-range": "^0.1.2", 1623 | "picocolors": "^1.0.1", 1624 | "postcss-value-parser": "^4.2.0" 1625 | }, 1626 | "bin": { 1627 | "autoprefixer": "bin/autoprefixer" 1628 | }, 1629 | "engines": { 1630 | "node": "^10 || ^12 || >=14" 1631 | }, 1632 | "peerDependencies": { 1633 | "postcss": "^8.1.0" 1634 | } 1635 | }, 1636 | "node_modules/balanced-match": { 1637 | "version": "1.0.2", 1638 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1639 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1640 | "dev": true 1641 | }, 1642 | "node_modules/binary-extensions": { 1643 | "version": "2.3.0", 1644 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", 1645 | "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", 1646 | "dev": true, 1647 | "engines": { 1648 | "node": ">=8" 1649 | }, 1650 | "funding": { 1651 | "url": "https://github.com/sponsors/sindresorhus" 1652 | } 1653 | }, 1654 | "node_modules/brace-expansion": { 1655 | "version": "2.0.1", 1656 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1657 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1658 | "dev": true, 1659 | "dependencies": { 1660 | "balanced-match": "^1.0.0" 1661 | } 1662 | }, 1663 | "node_modules/braces": { 1664 | "version": "3.0.3", 1665 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 1666 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 1667 | "dev": true, 1668 | "dependencies": { 1669 | "fill-range": "^7.1.1" 1670 | }, 1671 | "engines": { 1672 | "node": ">=8" 1673 | } 1674 | }, 1675 | "node_modules/browserslist": { 1676 | "version": "4.23.3", 1677 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.3.tgz", 1678 | "integrity": "sha512-btwCFJVjI4YWDNfau8RhZ+B1Q/VLoUITrm3RlP6y1tYGWIOa+InuYiRGXUBXo8nA1qKmHMyLB/iVQg5TT4eFoA==", 1679 | "dev": true, 1680 | "funding": [ 1681 | { 1682 | "type": "opencollective", 1683 | "url": "https://opencollective.com/browserslist" 1684 | }, 1685 | { 1686 | "type": "tidelift", 1687 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1688 | }, 1689 | { 1690 | "type": "github", 1691 | "url": "https://github.com/sponsors/ai" 1692 | } 1693 | ], 1694 | "dependencies": { 1695 | "caniuse-lite": "^1.0.30001646", 1696 | "electron-to-chromium": "^1.5.4", 1697 | "node-releases": "^2.0.18", 1698 | "update-browserslist-db": "^1.1.0" 1699 | }, 1700 | "bin": { 1701 | "browserslist": "cli.js" 1702 | }, 1703 | "engines": { 1704 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1705 | } 1706 | }, 1707 | "node_modules/callsites": { 1708 | "version": "3.1.0", 1709 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1710 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1711 | "dev": true, 1712 | "engines": { 1713 | "node": ">=6" 1714 | } 1715 | }, 1716 | "node_modules/camelcase-css": { 1717 | "version": "2.0.1", 1718 | "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", 1719 | "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", 1720 | "dev": true, 1721 | "engines": { 1722 | "node": ">= 6" 1723 | } 1724 | }, 1725 | "node_modules/caniuse-lite": { 1726 | "version": "1.0.30001649", 1727 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001649.tgz", 1728 | "integrity": "sha512-fJegqZZ0ZX8HOWr6rcafGr72+xcgJKI9oWfDW5DrD7ExUtgZC7a7R7ZYmZqplh7XDocFdGeIFn7roAxhOeYrPQ==", 1729 | "dev": true, 1730 | "funding": [ 1731 | { 1732 | "type": "opencollective", 1733 | "url": "https://opencollective.com/browserslist" 1734 | }, 1735 | { 1736 | "type": "tidelift", 1737 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1738 | }, 1739 | { 1740 | "type": "github", 1741 | "url": "https://github.com/sponsors/ai" 1742 | } 1743 | ] 1744 | }, 1745 | "node_modules/chalk": { 1746 | "version": "2.4.2", 1747 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1748 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1749 | "dev": true, 1750 | "dependencies": { 1751 | "ansi-styles": "^3.2.1", 1752 | "escape-string-regexp": "^1.0.5", 1753 | "supports-color": "^5.3.0" 1754 | }, 1755 | "engines": { 1756 | "node": ">=4" 1757 | } 1758 | }, 1759 | "node_modules/chokidar": { 1760 | "version": "3.6.0", 1761 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", 1762 | "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", 1763 | "dev": true, 1764 | "dependencies": { 1765 | "anymatch": "~3.1.2", 1766 | "braces": "~3.0.2", 1767 | "glob-parent": "~5.1.2", 1768 | "is-binary-path": "~2.1.0", 1769 | "is-glob": "~4.0.1", 1770 | "normalize-path": "~3.0.0", 1771 | "readdirp": "~3.6.0" 1772 | }, 1773 | "engines": { 1774 | "node": ">= 8.10.0" 1775 | }, 1776 | "funding": { 1777 | "url": "https://paulmillr.com/funding/" 1778 | }, 1779 | "optionalDependencies": { 1780 | "fsevents": "~2.3.2" 1781 | } 1782 | }, 1783 | "node_modules/chokidar/node_modules/glob-parent": { 1784 | "version": "5.1.2", 1785 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1786 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1787 | "dev": true, 1788 | "dependencies": { 1789 | "is-glob": "^4.0.1" 1790 | }, 1791 | "engines": { 1792 | "node": ">= 6" 1793 | } 1794 | }, 1795 | "node_modules/color-convert": { 1796 | "version": "1.9.3", 1797 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1798 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1799 | "dev": true, 1800 | "dependencies": { 1801 | "color-name": "1.1.3" 1802 | } 1803 | }, 1804 | "node_modules/color-name": { 1805 | "version": "1.1.3", 1806 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1807 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1808 | "dev": true 1809 | }, 1810 | "node_modules/commander": { 1811 | "version": "4.1.1", 1812 | "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", 1813 | "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", 1814 | "dev": true, 1815 | "engines": { 1816 | "node": ">= 6" 1817 | } 1818 | }, 1819 | "node_modules/concat-map": { 1820 | "version": "0.0.1", 1821 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1822 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1823 | "dev": true 1824 | }, 1825 | "node_modules/convert-source-map": { 1826 | "version": "2.0.0", 1827 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1828 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1829 | "dev": true 1830 | }, 1831 | "node_modules/cross-spawn": { 1832 | "version": "7.0.3", 1833 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1834 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1835 | "dev": true, 1836 | "dependencies": { 1837 | "path-key": "^3.1.0", 1838 | "shebang-command": "^2.0.0", 1839 | "which": "^2.0.1" 1840 | }, 1841 | "engines": { 1842 | "node": ">= 8" 1843 | } 1844 | }, 1845 | "node_modules/cssesc": { 1846 | "version": "3.0.0", 1847 | "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", 1848 | "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", 1849 | "dev": true, 1850 | "bin": { 1851 | "cssesc": "bin/cssesc" 1852 | }, 1853 | "engines": { 1854 | "node": ">=4" 1855 | } 1856 | }, 1857 | "node_modules/csstype": { 1858 | "version": "3.1.3", 1859 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 1860 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 1861 | "dev": true 1862 | }, 1863 | "node_modules/debug": { 1864 | "version": "4.3.6", 1865 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.6.tgz", 1866 | "integrity": "sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==", 1867 | "dev": true, 1868 | "dependencies": { 1869 | "ms": "2.1.2" 1870 | }, 1871 | "engines": { 1872 | "node": ">=6.0" 1873 | }, 1874 | "peerDependenciesMeta": { 1875 | "supports-color": { 1876 | "optional": true 1877 | } 1878 | } 1879 | }, 1880 | "node_modules/deep-is": { 1881 | "version": "0.1.4", 1882 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1883 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1884 | "dev": true 1885 | }, 1886 | "node_modules/didyoumean": { 1887 | "version": "1.2.2", 1888 | "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", 1889 | "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==", 1890 | "dev": true 1891 | }, 1892 | "node_modules/dir-glob": { 1893 | "version": "3.0.1", 1894 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1895 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1896 | "dev": true, 1897 | "dependencies": { 1898 | "path-type": "^4.0.0" 1899 | }, 1900 | "engines": { 1901 | "node": ">=8" 1902 | } 1903 | }, 1904 | "node_modules/dlv": { 1905 | "version": "1.1.3", 1906 | "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", 1907 | "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", 1908 | "dev": true 1909 | }, 1910 | "node_modules/doctrine": { 1911 | "version": "3.0.0", 1912 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1913 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1914 | "dev": true, 1915 | "dependencies": { 1916 | "esutils": "^2.0.2" 1917 | }, 1918 | "engines": { 1919 | "node": ">=6.0.0" 1920 | } 1921 | }, 1922 | "node_modules/eastasianwidth": { 1923 | "version": "0.2.0", 1924 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 1925 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 1926 | "dev": true 1927 | }, 1928 | "node_modules/electron-to-chromium": { 1929 | "version": "1.5.4", 1930 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.4.tgz", 1931 | "integrity": "sha512-orzA81VqLyIGUEA77YkVA1D+N+nNfl2isJVjjmOyrlxuooZ19ynb+dOlaDTqd/idKRS9lDCSBmtzM+kyCsMnkA==", 1932 | "dev": true 1933 | }, 1934 | "node_modules/emoji-regex": { 1935 | "version": "9.2.2", 1936 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 1937 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 1938 | "dev": true 1939 | }, 1940 | "node_modules/esbuild": { 1941 | "version": "0.21.5", 1942 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", 1943 | "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", 1944 | "dev": true, 1945 | "hasInstallScript": true, 1946 | "bin": { 1947 | "esbuild": "bin/esbuild" 1948 | }, 1949 | "engines": { 1950 | "node": ">=12" 1951 | }, 1952 | "optionalDependencies": { 1953 | "@esbuild/aix-ppc64": "0.21.5", 1954 | "@esbuild/android-arm": "0.21.5", 1955 | "@esbuild/android-arm64": "0.21.5", 1956 | "@esbuild/android-x64": "0.21.5", 1957 | "@esbuild/darwin-arm64": "0.21.5", 1958 | "@esbuild/darwin-x64": "0.21.5", 1959 | "@esbuild/freebsd-arm64": "0.21.5", 1960 | "@esbuild/freebsd-x64": "0.21.5", 1961 | "@esbuild/linux-arm": "0.21.5", 1962 | "@esbuild/linux-arm64": "0.21.5", 1963 | "@esbuild/linux-ia32": "0.21.5", 1964 | "@esbuild/linux-loong64": "0.21.5", 1965 | "@esbuild/linux-mips64el": "0.21.5", 1966 | "@esbuild/linux-ppc64": "0.21.5", 1967 | "@esbuild/linux-riscv64": "0.21.5", 1968 | "@esbuild/linux-s390x": "0.21.5", 1969 | "@esbuild/linux-x64": "0.21.5", 1970 | "@esbuild/netbsd-x64": "0.21.5", 1971 | "@esbuild/openbsd-x64": "0.21.5", 1972 | "@esbuild/sunos-x64": "0.21.5", 1973 | "@esbuild/win32-arm64": "0.21.5", 1974 | "@esbuild/win32-ia32": "0.21.5", 1975 | "@esbuild/win32-x64": "0.21.5" 1976 | } 1977 | }, 1978 | "node_modules/escalade": { 1979 | "version": "3.1.2", 1980 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", 1981 | "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", 1982 | "dev": true, 1983 | "engines": { 1984 | "node": ">=6" 1985 | } 1986 | }, 1987 | "node_modules/escape-string-regexp": { 1988 | "version": "1.0.5", 1989 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1990 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1991 | "dev": true, 1992 | "engines": { 1993 | "node": ">=0.8.0" 1994 | } 1995 | }, 1996 | "node_modules/eslint": { 1997 | "version": "8.57.0", 1998 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 1999 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 2000 | "dev": true, 2001 | "dependencies": { 2002 | "@eslint-community/eslint-utils": "^4.2.0", 2003 | "@eslint-community/regexpp": "^4.6.1", 2004 | "@eslint/eslintrc": "^2.1.4", 2005 | "@eslint/js": "8.57.0", 2006 | "@humanwhocodes/config-array": "^0.11.14", 2007 | "@humanwhocodes/module-importer": "^1.0.1", 2008 | "@nodelib/fs.walk": "^1.2.8", 2009 | "@ungap/structured-clone": "^1.2.0", 2010 | "ajv": "^6.12.4", 2011 | "chalk": "^4.0.0", 2012 | "cross-spawn": "^7.0.2", 2013 | "debug": "^4.3.2", 2014 | "doctrine": "^3.0.0", 2015 | "escape-string-regexp": "^4.0.0", 2016 | "eslint-scope": "^7.2.2", 2017 | "eslint-visitor-keys": "^3.4.3", 2018 | "espree": "^9.6.1", 2019 | "esquery": "^1.4.2", 2020 | "esutils": "^2.0.2", 2021 | "fast-deep-equal": "^3.1.3", 2022 | "file-entry-cache": "^6.0.1", 2023 | "find-up": "^5.0.0", 2024 | "glob-parent": "^6.0.2", 2025 | "globals": "^13.19.0", 2026 | "graphemer": "^1.4.0", 2027 | "ignore": "^5.2.0", 2028 | "imurmurhash": "^0.1.4", 2029 | "is-glob": "^4.0.0", 2030 | "is-path-inside": "^3.0.3", 2031 | "js-yaml": "^4.1.0", 2032 | "json-stable-stringify-without-jsonify": "^1.0.1", 2033 | "levn": "^0.4.1", 2034 | "lodash.merge": "^4.6.2", 2035 | "minimatch": "^3.1.2", 2036 | "natural-compare": "^1.4.0", 2037 | "optionator": "^0.9.3", 2038 | "strip-ansi": "^6.0.1", 2039 | "text-table": "^0.2.0" 2040 | }, 2041 | "bin": { 2042 | "eslint": "bin/eslint.js" 2043 | }, 2044 | "engines": { 2045 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2046 | }, 2047 | "funding": { 2048 | "url": "https://opencollective.com/eslint" 2049 | } 2050 | }, 2051 | "node_modules/eslint-plugin-react-hooks": { 2052 | "version": "4.6.2", 2053 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.2.tgz", 2054 | "integrity": "sha512-QzliNJq4GinDBcD8gPB5v0wh6g8q3SUi6EFF0x8N/BL9PoVs0atuGc47ozMRyOWAKdwaZ5OnbOEa3WR+dSGKuQ==", 2055 | "dev": true, 2056 | "engines": { 2057 | "node": ">=10" 2058 | }, 2059 | "peerDependencies": { 2060 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 2061 | } 2062 | }, 2063 | "node_modules/eslint-plugin-react-refresh": { 2064 | "version": "0.4.9", 2065 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.9.tgz", 2066 | "integrity": "sha512-QK49YrBAo5CLNLseZ7sZgvgTy21E6NEw22eZqc4teZfH8pxV3yXc9XXOYfUI6JNpw7mfHNkAeWtBxrTyykB6HA==", 2067 | "dev": true, 2068 | "peerDependencies": { 2069 | "eslint": ">=7" 2070 | } 2071 | }, 2072 | "node_modules/eslint-scope": { 2073 | "version": "7.2.2", 2074 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 2075 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 2076 | "dev": true, 2077 | "dependencies": { 2078 | "esrecurse": "^4.3.0", 2079 | "estraverse": "^5.2.0" 2080 | }, 2081 | "engines": { 2082 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2083 | }, 2084 | "funding": { 2085 | "url": "https://opencollective.com/eslint" 2086 | } 2087 | }, 2088 | "node_modules/eslint-visitor-keys": { 2089 | "version": "3.4.3", 2090 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 2091 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 2092 | "dev": true, 2093 | "engines": { 2094 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2095 | }, 2096 | "funding": { 2097 | "url": "https://opencollective.com/eslint" 2098 | } 2099 | }, 2100 | "node_modules/eslint/node_modules/ansi-styles": { 2101 | "version": "4.3.0", 2102 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2103 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2104 | "dev": true, 2105 | "dependencies": { 2106 | "color-convert": "^2.0.1" 2107 | }, 2108 | "engines": { 2109 | "node": ">=8" 2110 | }, 2111 | "funding": { 2112 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2113 | } 2114 | }, 2115 | "node_modules/eslint/node_modules/brace-expansion": { 2116 | "version": "1.1.11", 2117 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2118 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2119 | "dev": true, 2120 | "dependencies": { 2121 | "balanced-match": "^1.0.0", 2122 | "concat-map": "0.0.1" 2123 | } 2124 | }, 2125 | "node_modules/eslint/node_modules/chalk": { 2126 | "version": "4.1.2", 2127 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2128 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2129 | "dev": true, 2130 | "dependencies": { 2131 | "ansi-styles": "^4.1.0", 2132 | "supports-color": "^7.1.0" 2133 | }, 2134 | "engines": { 2135 | "node": ">=10" 2136 | }, 2137 | "funding": { 2138 | "url": "https://github.com/chalk/chalk?sponsor=1" 2139 | } 2140 | }, 2141 | "node_modules/eslint/node_modules/color-convert": { 2142 | "version": "2.0.1", 2143 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2144 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2145 | "dev": true, 2146 | "dependencies": { 2147 | "color-name": "~1.1.4" 2148 | }, 2149 | "engines": { 2150 | "node": ">=7.0.0" 2151 | } 2152 | }, 2153 | "node_modules/eslint/node_modules/color-name": { 2154 | "version": "1.1.4", 2155 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2156 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2157 | "dev": true 2158 | }, 2159 | "node_modules/eslint/node_modules/escape-string-regexp": { 2160 | "version": "4.0.0", 2161 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2162 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2163 | "dev": true, 2164 | "engines": { 2165 | "node": ">=10" 2166 | }, 2167 | "funding": { 2168 | "url": "https://github.com/sponsors/sindresorhus" 2169 | } 2170 | }, 2171 | "node_modules/eslint/node_modules/globals": { 2172 | "version": "13.24.0", 2173 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 2174 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 2175 | "dev": true, 2176 | "dependencies": { 2177 | "type-fest": "^0.20.2" 2178 | }, 2179 | "engines": { 2180 | "node": ">=8" 2181 | }, 2182 | "funding": { 2183 | "url": "https://github.com/sponsors/sindresorhus" 2184 | } 2185 | }, 2186 | "node_modules/eslint/node_modules/has-flag": { 2187 | "version": "4.0.0", 2188 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2189 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2190 | "dev": true, 2191 | "engines": { 2192 | "node": ">=8" 2193 | } 2194 | }, 2195 | "node_modules/eslint/node_modules/minimatch": { 2196 | "version": "3.1.2", 2197 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2198 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2199 | "dev": true, 2200 | "dependencies": { 2201 | "brace-expansion": "^1.1.7" 2202 | }, 2203 | "engines": { 2204 | "node": "*" 2205 | } 2206 | }, 2207 | "node_modules/eslint/node_modules/supports-color": { 2208 | "version": "7.2.0", 2209 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2210 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2211 | "dev": true, 2212 | "dependencies": { 2213 | "has-flag": "^4.0.0" 2214 | }, 2215 | "engines": { 2216 | "node": ">=8" 2217 | } 2218 | }, 2219 | "node_modules/espree": { 2220 | "version": "9.6.1", 2221 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2222 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2223 | "dev": true, 2224 | "dependencies": { 2225 | "acorn": "^8.9.0", 2226 | "acorn-jsx": "^5.3.2", 2227 | "eslint-visitor-keys": "^3.4.1" 2228 | }, 2229 | "engines": { 2230 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2231 | }, 2232 | "funding": { 2233 | "url": "https://opencollective.com/eslint" 2234 | } 2235 | }, 2236 | "node_modules/esquery": { 2237 | "version": "1.6.0", 2238 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", 2239 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", 2240 | "dev": true, 2241 | "dependencies": { 2242 | "estraverse": "^5.1.0" 2243 | }, 2244 | "engines": { 2245 | "node": ">=0.10" 2246 | } 2247 | }, 2248 | "node_modules/esrecurse": { 2249 | "version": "4.3.0", 2250 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2251 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2252 | "dev": true, 2253 | "dependencies": { 2254 | "estraverse": "^5.2.0" 2255 | }, 2256 | "engines": { 2257 | "node": ">=4.0" 2258 | } 2259 | }, 2260 | "node_modules/estraverse": { 2261 | "version": "5.3.0", 2262 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2263 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2264 | "dev": true, 2265 | "engines": { 2266 | "node": ">=4.0" 2267 | } 2268 | }, 2269 | "node_modules/esutils": { 2270 | "version": "2.0.3", 2271 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2272 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2273 | "dev": true, 2274 | "engines": { 2275 | "node": ">=0.10.0" 2276 | } 2277 | }, 2278 | "node_modules/fast-deep-equal": { 2279 | "version": "3.1.3", 2280 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2281 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2282 | "dev": true 2283 | }, 2284 | "node_modules/fast-glob": { 2285 | "version": "3.3.2", 2286 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 2287 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 2288 | "dev": true, 2289 | "dependencies": { 2290 | "@nodelib/fs.stat": "^2.0.2", 2291 | "@nodelib/fs.walk": "^1.2.3", 2292 | "glob-parent": "^5.1.2", 2293 | "merge2": "^1.3.0", 2294 | "micromatch": "^4.0.4" 2295 | }, 2296 | "engines": { 2297 | "node": ">=8.6.0" 2298 | } 2299 | }, 2300 | "node_modules/fast-glob/node_modules/glob-parent": { 2301 | "version": "5.1.2", 2302 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2303 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2304 | "dev": true, 2305 | "dependencies": { 2306 | "is-glob": "^4.0.1" 2307 | }, 2308 | "engines": { 2309 | "node": ">= 6" 2310 | } 2311 | }, 2312 | "node_modules/fast-json-stable-stringify": { 2313 | "version": "2.1.0", 2314 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2315 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2316 | "dev": true 2317 | }, 2318 | "node_modules/fast-levenshtein": { 2319 | "version": "2.0.6", 2320 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2321 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2322 | "dev": true 2323 | }, 2324 | "node_modules/fastq": { 2325 | "version": "1.17.1", 2326 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 2327 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 2328 | "dev": true, 2329 | "dependencies": { 2330 | "reusify": "^1.0.4" 2331 | } 2332 | }, 2333 | "node_modules/file-entry-cache": { 2334 | "version": "6.0.1", 2335 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2336 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2337 | "dev": true, 2338 | "dependencies": { 2339 | "flat-cache": "^3.0.4" 2340 | }, 2341 | "engines": { 2342 | "node": "^10.12.0 || >=12.0.0" 2343 | } 2344 | }, 2345 | "node_modules/fill-range": { 2346 | "version": "7.1.1", 2347 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 2348 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 2349 | "dev": true, 2350 | "dependencies": { 2351 | "to-regex-range": "^5.0.1" 2352 | }, 2353 | "engines": { 2354 | "node": ">=8" 2355 | } 2356 | }, 2357 | "node_modules/find-up": { 2358 | "version": "5.0.0", 2359 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2360 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2361 | "dev": true, 2362 | "dependencies": { 2363 | "locate-path": "^6.0.0", 2364 | "path-exists": "^4.0.0" 2365 | }, 2366 | "engines": { 2367 | "node": ">=10" 2368 | }, 2369 | "funding": { 2370 | "url": "https://github.com/sponsors/sindresorhus" 2371 | } 2372 | }, 2373 | "node_modules/flat-cache": { 2374 | "version": "3.2.0", 2375 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2376 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2377 | "dev": true, 2378 | "dependencies": { 2379 | "flatted": "^3.2.9", 2380 | "keyv": "^4.5.3", 2381 | "rimraf": "^3.0.2" 2382 | }, 2383 | "engines": { 2384 | "node": "^10.12.0 || >=12.0.0" 2385 | } 2386 | }, 2387 | "node_modules/flatted": { 2388 | "version": "3.3.1", 2389 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 2390 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 2391 | "dev": true 2392 | }, 2393 | "node_modules/foreground-child": { 2394 | "version": "3.2.1", 2395 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", 2396 | "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", 2397 | "dev": true, 2398 | "dependencies": { 2399 | "cross-spawn": "^7.0.0", 2400 | "signal-exit": "^4.0.1" 2401 | }, 2402 | "engines": { 2403 | "node": ">=14" 2404 | }, 2405 | "funding": { 2406 | "url": "https://github.com/sponsors/isaacs" 2407 | } 2408 | }, 2409 | "node_modules/fraction.js": { 2410 | "version": "4.3.7", 2411 | "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", 2412 | "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", 2413 | "dev": true, 2414 | "engines": { 2415 | "node": "*" 2416 | }, 2417 | "funding": { 2418 | "type": "patreon", 2419 | "url": "https://github.com/sponsors/rawify" 2420 | } 2421 | }, 2422 | "node_modules/fs.realpath": { 2423 | "version": "1.0.0", 2424 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2425 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2426 | "dev": true 2427 | }, 2428 | "node_modules/fsevents": { 2429 | "version": "2.3.3", 2430 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2431 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2432 | "dev": true, 2433 | "hasInstallScript": true, 2434 | "optional": true, 2435 | "os": [ 2436 | "darwin" 2437 | ], 2438 | "engines": { 2439 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2440 | } 2441 | }, 2442 | "node_modules/function-bind": { 2443 | "version": "1.1.2", 2444 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 2445 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 2446 | "dev": true, 2447 | "funding": { 2448 | "url": "https://github.com/sponsors/ljharb" 2449 | } 2450 | }, 2451 | "node_modules/gensync": { 2452 | "version": "1.0.0-beta.2", 2453 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2454 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2455 | "dev": true, 2456 | "engines": { 2457 | "node": ">=6.9.0" 2458 | } 2459 | }, 2460 | "node_modules/glob": { 2461 | "version": "7.2.3", 2462 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2463 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2464 | "deprecated": "Glob versions prior to v9 are no longer supported", 2465 | "dev": true, 2466 | "dependencies": { 2467 | "fs.realpath": "^1.0.0", 2468 | "inflight": "^1.0.4", 2469 | "inherits": "2", 2470 | "minimatch": "^3.1.1", 2471 | "once": "^1.3.0", 2472 | "path-is-absolute": "^1.0.0" 2473 | }, 2474 | "engines": { 2475 | "node": "*" 2476 | }, 2477 | "funding": { 2478 | "url": "https://github.com/sponsors/isaacs" 2479 | } 2480 | }, 2481 | "node_modules/glob-parent": { 2482 | "version": "6.0.2", 2483 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2484 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2485 | "dev": true, 2486 | "dependencies": { 2487 | "is-glob": "^4.0.3" 2488 | }, 2489 | "engines": { 2490 | "node": ">=10.13.0" 2491 | } 2492 | }, 2493 | "node_modules/glob/node_modules/brace-expansion": { 2494 | "version": "1.1.11", 2495 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2496 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2497 | "dev": true, 2498 | "dependencies": { 2499 | "balanced-match": "^1.0.0", 2500 | "concat-map": "0.0.1" 2501 | } 2502 | }, 2503 | "node_modules/glob/node_modules/minimatch": { 2504 | "version": "3.1.2", 2505 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2506 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2507 | "dev": true, 2508 | "dependencies": { 2509 | "brace-expansion": "^1.1.7" 2510 | }, 2511 | "engines": { 2512 | "node": "*" 2513 | } 2514 | }, 2515 | "node_modules/globals": { 2516 | "version": "11.12.0", 2517 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2518 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2519 | "dev": true, 2520 | "engines": { 2521 | "node": ">=4" 2522 | } 2523 | }, 2524 | "node_modules/globby": { 2525 | "version": "11.1.0", 2526 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2527 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2528 | "dev": true, 2529 | "dependencies": { 2530 | "array-union": "^2.1.0", 2531 | "dir-glob": "^3.0.1", 2532 | "fast-glob": "^3.2.9", 2533 | "ignore": "^5.2.0", 2534 | "merge2": "^1.4.1", 2535 | "slash": "^3.0.0" 2536 | }, 2537 | "engines": { 2538 | "node": ">=10" 2539 | }, 2540 | "funding": { 2541 | "url": "https://github.com/sponsors/sindresorhus" 2542 | } 2543 | }, 2544 | "node_modules/graphemer": { 2545 | "version": "1.4.0", 2546 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2547 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2548 | "dev": true 2549 | }, 2550 | "node_modules/has-flag": { 2551 | "version": "3.0.0", 2552 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2553 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2554 | "dev": true, 2555 | "engines": { 2556 | "node": ">=4" 2557 | } 2558 | }, 2559 | "node_modules/hasown": { 2560 | "version": "2.0.2", 2561 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", 2562 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", 2563 | "dev": true, 2564 | "dependencies": { 2565 | "function-bind": "^1.1.2" 2566 | }, 2567 | "engines": { 2568 | "node": ">= 0.4" 2569 | } 2570 | }, 2571 | "node_modules/ignore": { 2572 | "version": "5.3.1", 2573 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 2574 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 2575 | "dev": true, 2576 | "engines": { 2577 | "node": ">= 4" 2578 | } 2579 | }, 2580 | "node_modules/import-fresh": { 2581 | "version": "3.3.0", 2582 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2583 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2584 | "dev": true, 2585 | "dependencies": { 2586 | "parent-module": "^1.0.0", 2587 | "resolve-from": "^4.0.0" 2588 | }, 2589 | "engines": { 2590 | "node": ">=6" 2591 | }, 2592 | "funding": { 2593 | "url": "https://github.com/sponsors/sindresorhus" 2594 | } 2595 | }, 2596 | "node_modules/imurmurhash": { 2597 | "version": "0.1.4", 2598 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2599 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2600 | "dev": true, 2601 | "engines": { 2602 | "node": ">=0.8.19" 2603 | } 2604 | }, 2605 | "node_modules/inflight": { 2606 | "version": "1.0.6", 2607 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2608 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2609 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 2610 | "dev": true, 2611 | "dependencies": { 2612 | "once": "^1.3.0", 2613 | "wrappy": "1" 2614 | } 2615 | }, 2616 | "node_modules/inherits": { 2617 | "version": "2.0.4", 2618 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2619 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2620 | "dev": true 2621 | }, 2622 | "node_modules/is-binary-path": { 2623 | "version": "2.1.0", 2624 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 2625 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 2626 | "dev": true, 2627 | "dependencies": { 2628 | "binary-extensions": "^2.0.0" 2629 | }, 2630 | "engines": { 2631 | "node": ">=8" 2632 | } 2633 | }, 2634 | "node_modules/is-core-module": { 2635 | "version": "2.15.0", 2636 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.0.tgz", 2637 | "integrity": "sha512-Dd+Lb2/zvk9SKy1TGCt1wFJFo/MWBPMX5x7KcvLajWTGuomczdQX61PvY5yK6SVACwpoexWo81IfFyoKY2QnTA==", 2638 | "dev": true, 2639 | "dependencies": { 2640 | "hasown": "^2.0.2" 2641 | }, 2642 | "engines": { 2643 | "node": ">= 0.4" 2644 | }, 2645 | "funding": { 2646 | "url": "https://github.com/sponsors/ljharb" 2647 | } 2648 | }, 2649 | "node_modules/is-extglob": { 2650 | "version": "2.1.1", 2651 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2652 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2653 | "dev": true, 2654 | "engines": { 2655 | "node": ">=0.10.0" 2656 | } 2657 | }, 2658 | "node_modules/is-fullwidth-code-point": { 2659 | "version": "3.0.0", 2660 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2661 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2662 | "dev": true, 2663 | "engines": { 2664 | "node": ">=8" 2665 | } 2666 | }, 2667 | "node_modules/is-glob": { 2668 | "version": "4.0.3", 2669 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2670 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2671 | "dev": true, 2672 | "dependencies": { 2673 | "is-extglob": "^2.1.1" 2674 | }, 2675 | "engines": { 2676 | "node": ">=0.10.0" 2677 | } 2678 | }, 2679 | "node_modules/is-number": { 2680 | "version": "7.0.0", 2681 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2682 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2683 | "dev": true, 2684 | "engines": { 2685 | "node": ">=0.12.0" 2686 | } 2687 | }, 2688 | "node_modules/is-path-inside": { 2689 | "version": "3.0.3", 2690 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2691 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2692 | "dev": true, 2693 | "engines": { 2694 | "node": ">=8" 2695 | } 2696 | }, 2697 | "node_modules/isexe": { 2698 | "version": "2.0.0", 2699 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2700 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2701 | "dev": true 2702 | }, 2703 | "node_modules/jackspeak": { 2704 | "version": "3.4.3", 2705 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz", 2706 | "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==", 2707 | "dev": true, 2708 | "dependencies": { 2709 | "@isaacs/cliui": "^8.0.2" 2710 | }, 2711 | "funding": { 2712 | "url": "https://github.com/sponsors/isaacs" 2713 | }, 2714 | "optionalDependencies": { 2715 | "@pkgjs/parseargs": "^0.11.0" 2716 | } 2717 | }, 2718 | "node_modules/jiti": { 2719 | "version": "1.21.6", 2720 | "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", 2721 | "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", 2722 | "dev": true, 2723 | "bin": { 2724 | "jiti": "bin/jiti.js" 2725 | } 2726 | }, 2727 | "node_modules/js-tokens": { 2728 | "version": "4.0.0", 2729 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2730 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2731 | }, 2732 | "node_modules/js-yaml": { 2733 | "version": "4.1.0", 2734 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2735 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2736 | "dev": true, 2737 | "dependencies": { 2738 | "argparse": "^2.0.1" 2739 | }, 2740 | "bin": { 2741 | "js-yaml": "bin/js-yaml.js" 2742 | } 2743 | }, 2744 | "node_modules/jsesc": { 2745 | "version": "2.5.2", 2746 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2747 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2748 | "dev": true, 2749 | "bin": { 2750 | "jsesc": "bin/jsesc" 2751 | }, 2752 | "engines": { 2753 | "node": ">=4" 2754 | } 2755 | }, 2756 | "node_modules/json-buffer": { 2757 | "version": "3.0.1", 2758 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2759 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2760 | "dev": true 2761 | }, 2762 | "node_modules/json-schema-traverse": { 2763 | "version": "0.4.1", 2764 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2765 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2766 | "dev": true 2767 | }, 2768 | "node_modules/json-stable-stringify-without-jsonify": { 2769 | "version": "1.0.1", 2770 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2771 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2772 | "dev": true 2773 | }, 2774 | "node_modules/json5": { 2775 | "version": "2.2.3", 2776 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2777 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2778 | "dev": true, 2779 | "bin": { 2780 | "json5": "lib/cli.js" 2781 | }, 2782 | "engines": { 2783 | "node": ">=6" 2784 | } 2785 | }, 2786 | "node_modules/keyv": { 2787 | "version": "4.5.4", 2788 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2789 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2790 | "dev": true, 2791 | "dependencies": { 2792 | "json-buffer": "3.0.1" 2793 | } 2794 | }, 2795 | "node_modules/levn": { 2796 | "version": "0.4.1", 2797 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2798 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2799 | "dev": true, 2800 | "dependencies": { 2801 | "prelude-ls": "^1.2.1", 2802 | "type-check": "~0.4.0" 2803 | }, 2804 | "engines": { 2805 | "node": ">= 0.8.0" 2806 | } 2807 | }, 2808 | "node_modules/lilconfig": { 2809 | "version": "2.1.0", 2810 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", 2811 | "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", 2812 | "dev": true, 2813 | "engines": { 2814 | "node": ">=10" 2815 | } 2816 | }, 2817 | "node_modules/lines-and-columns": { 2818 | "version": "1.2.4", 2819 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2820 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", 2821 | "dev": true 2822 | }, 2823 | "node_modules/locate-path": { 2824 | "version": "6.0.0", 2825 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2826 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2827 | "dev": true, 2828 | "dependencies": { 2829 | "p-locate": "^5.0.0" 2830 | }, 2831 | "engines": { 2832 | "node": ">=10" 2833 | }, 2834 | "funding": { 2835 | "url": "https://github.com/sponsors/sindresorhus" 2836 | } 2837 | }, 2838 | "node_modules/lodash.merge": { 2839 | "version": "4.6.2", 2840 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2841 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2842 | "dev": true 2843 | }, 2844 | "node_modules/loose-envify": { 2845 | "version": "1.4.0", 2846 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2847 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2848 | "dependencies": { 2849 | "js-tokens": "^3.0.0 || ^4.0.0" 2850 | }, 2851 | "bin": { 2852 | "loose-envify": "cli.js" 2853 | } 2854 | }, 2855 | "node_modules/lru-cache": { 2856 | "version": "5.1.1", 2857 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2858 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2859 | "dev": true, 2860 | "dependencies": { 2861 | "yallist": "^3.0.2" 2862 | } 2863 | }, 2864 | "node_modules/merge2": { 2865 | "version": "1.4.1", 2866 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2867 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2868 | "dev": true, 2869 | "engines": { 2870 | "node": ">= 8" 2871 | } 2872 | }, 2873 | "node_modules/micromatch": { 2874 | "version": "4.0.7", 2875 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", 2876 | "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", 2877 | "dev": true, 2878 | "dependencies": { 2879 | "braces": "^3.0.3", 2880 | "picomatch": "^2.3.1" 2881 | }, 2882 | "engines": { 2883 | "node": ">=8.6" 2884 | } 2885 | }, 2886 | "node_modules/minimatch": { 2887 | "version": "9.0.5", 2888 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", 2889 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", 2890 | "dev": true, 2891 | "dependencies": { 2892 | "brace-expansion": "^2.0.1" 2893 | }, 2894 | "engines": { 2895 | "node": ">=16 || 14 >=14.17" 2896 | }, 2897 | "funding": { 2898 | "url": "https://github.com/sponsors/isaacs" 2899 | } 2900 | }, 2901 | "node_modules/minipass": { 2902 | "version": "7.1.2", 2903 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", 2904 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", 2905 | "dev": true, 2906 | "engines": { 2907 | "node": ">=16 || 14 >=14.17" 2908 | } 2909 | }, 2910 | "node_modules/ms": { 2911 | "version": "2.1.2", 2912 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2913 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2914 | "dev": true 2915 | }, 2916 | "node_modules/mz": { 2917 | "version": "2.7.0", 2918 | "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", 2919 | "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", 2920 | "dev": true, 2921 | "dependencies": { 2922 | "any-promise": "^1.0.0", 2923 | "object-assign": "^4.0.1", 2924 | "thenify-all": "^1.0.0" 2925 | } 2926 | }, 2927 | "node_modules/nanoid": { 2928 | "version": "3.3.7", 2929 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 2930 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 2931 | "dev": true, 2932 | "funding": [ 2933 | { 2934 | "type": "github", 2935 | "url": "https://github.com/sponsors/ai" 2936 | } 2937 | ], 2938 | "bin": { 2939 | "nanoid": "bin/nanoid.cjs" 2940 | }, 2941 | "engines": { 2942 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2943 | } 2944 | }, 2945 | "node_modules/natural-compare": { 2946 | "version": "1.4.0", 2947 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2948 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2949 | "dev": true 2950 | }, 2951 | "node_modules/node-releases": { 2952 | "version": "2.0.18", 2953 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz", 2954 | "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==", 2955 | "dev": true 2956 | }, 2957 | "node_modules/normalize-path": { 2958 | "version": "3.0.0", 2959 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2960 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2961 | "dev": true, 2962 | "engines": { 2963 | "node": ">=0.10.0" 2964 | } 2965 | }, 2966 | "node_modules/normalize-range": { 2967 | "version": "0.1.2", 2968 | "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", 2969 | "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", 2970 | "dev": true, 2971 | "engines": { 2972 | "node": ">=0.10.0" 2973 | } 2974 | }, 2975 | "node_modules/object-assign": { 2976 | "version": "4.1.1", 2977 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2978 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 2979 | "dev": true, 2980 | "engines": { 2981 | "node": ">=0.10.0" 2982 | } 2983 | }, 2984 | "node_modules/object-hash": { 2985 | "version": "3.0.0", 2986 | "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", 2987 | "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", 2988 | "dev": true, 2989 | "engines": { 2990 | "node": ">= 6" 2991 | } 2992 | }, 2993 | "node_modules/once": { 2994 | "version": "1.4.0", 2995 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2996 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2997 | "dev": true, 2998 | "dependencies": { 2999 | "wrappy": "1" 3000 | } 3001 | }, 3002 | "node_modules/optionator": { 3003 | "version": "0.9.4", 3004 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 3005 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 3006 | "dev": true, 3007 | "dependencies": { 3008 | "deep-is": "^0.1.3", 3009 | "fast-levenshtein": "^2.0.6", 3010 | "levn": "^0.4.1", 3011 | "prelude-ls": "^1.2.1", 3012 | "type-check": "^0.4.0", 3013 | "word-wrap": "^1.2.5" 3014 | }, 3015 | "engines": { 3016 | "node": ">= 0.8.0" 3017 | } 3018 | }, 3019 | "node_modules/p-limit": { 3020 | "version": "3.1.0", 3021 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3022 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3023 | "dev": true, 3024 | "dependencies": { 3025 | "yocto-queue": "^0.1.0" 3026 | }, 3027 | "engines": { 3028 | "node": ">=10" 3029 | }, 3030 | "funding": { 3031 | "url": "https://github.com/sponsors/sindresorhus" 3032 | } 3033 | }, 3034 | "node_modules/p-locate": { 3035 | "version": "5.0.0", 3036 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3037 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3038 | "dev": true, 3039 | "dependencies": { 3040 | "p-limit": "^3.0.2" 3041 | }, 3042 | "engines": { 3043 | "node": ">=10" 3044 | }, 3045 | "funding": { 3046 | "url": "https://github.com/sponsors/sindresorhus" 3047 | } 3048 | }, 3049 | "node_modules/package-json-from-dist": { 3050 | "version": "1.0.0", 3051 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.0.tgz", 3052 | "integrity": "sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==", 3053 | "dev": true 3054 | }, 3055 | "node_modules/parent-module": { 3056 | "version": "1.0.1", 3057 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3058 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3059 | "dev": true, 3060 | "dependencies": { 3061 | "callsites": "^3.0.0" 3062 | }, 3063 | "engines": { 3064 | "node": ">=6" 3065 | } 3066 | }, 3067 | "node_modules/path-exists": { 3068 | "version": "4.0.0", 3069 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3070 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3071 | "dev": true, 3072 | "engines": { 3073 | "node": ">=8" 3074 | } 3075 | }, 3076 | "node_modules/path-is-absolute": { 3077 | "version": "1.0.1", 3078 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3079 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3080 | "dev": true, 3081 | "engines": { 3082 | "node": ">=0.10.0" 3083 | } 3084 | }, 3085 | "node_modules/path-key": { 3086 | "version": "3.1.1", 3087 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3088 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3089 | "dev": true, 3090 | "engines": { 3091 | "node": ">=8" 3092 | } 3093 | }, 3094 | "node_modules/path-parse": { 3095 | "version": "1.0.7", 3096 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3097 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3098 | "dev": true 3099 | }, 3100 | "node_modules/path-scurry": { 3101 | "version": "1.11.1", 3102 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", 3103 | "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", 3104 | "dev": true, 3105 | "dependencies": { 3106 | "lru-cache": "^10.2.0", 3107 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" 3108 | }, 3109 | "engines": { 3110 | "node": ">=16 || 14 >=14.18" 3111 | }, 3112 | "funding": { 3113 | "url": "https://github.com/sponsors/isaacs" 3114 | } 3115 | }, 3116 | "node_modules/path-scurry/node_modules/lru-cache": { 3117 | "version": "10.4.3", 3118 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz", 3119 | "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==", 3120 | "dev": true 3121 | }, 3122 | "node_modules/path-type": { 3123 | "version": "4.0.0", 3124 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 3125 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 3126 | "dev": true, 3127 | "engines": { 3128 | "node": ">=8" 3129 | } 3130 | }, 3131 | "node_modules/picocolors": { 3132 | "version": "1.0.1", 3133 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", 3134 | "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", 3135 | "dev": true 3136 | }, 3137 | "node_modules/picomatch": { 3138 | "version": "2.3.1", 3139 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3140 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3141 | "dev": true, 3142 | "engines": { 3143 | "node": ">=8.6" 3144 | }, 3145 | "funding": { 3146 | "url": "https://github.com/sponsors/jonschlinkert" 3147 | } 3148 | }, 3149 | "node_modules/pify": { 3150 | "version": "2.3.0", 3151 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 3152 | "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", 3153 | "dev": true, 3154 | "engines": { 3155 | "node": ">=0.10.0" 3156 | } 3157 | }, 3158 | "node_modules/pirates": { 3159 | "version": "4.0.6", 3160 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", 3161 | "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", 3162 | "dev": true, 3163 | "engines": { 3164 | "node": ">= 6" 3165 | } 3166 | }, 3167 | "node_modules/postcss": { 3168 | "version": "8.4.40", 3169 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.40.tgz", 3170 | "integrity": "sha512-YF2kKIUzAofPMpfH6hOi2cGnv/HrUlfucspc7pDyvv7kGdqXrfj8SCl/t8owkEgKEuu8ZcRjSOxFxVLqwChZ2Q==", 3171 | "dev": true, 3172 | "funding": [ 3173 | { 3174 | "type": "opencollective", 3175 | "url": "https://opencollective.com/postcss/" 3176 | }, 3177 | { 3178 | "type": "tidelift", 3179 | "url": "https://tidelift.com/funding/github/npm/postcss" 3180 | }, 3181 | { 3182 | "type": "github", 3183 | "url": "https://github.com/sponsors/ai" 3184 | } 3185 | ], 3186 | "dependencies": { 3187 | "nanoid": "^3.3.7", 3188 | "picocolors": "^1.0.1", 3189 | "source-map-js": "^1.2.0" 3190 | }, 3191 | "engines": { 3192 | "node": "^10 || ^12 || >=14" 3193 | } 3194 | }, 3195 | "node_modules/postcss-import": { 3196 | "version": "15.1.0", 3197 | "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", 3198 | "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", 3199 | "dev": true, 3200 | "dependencies": { 3201 | "postcss-value-parser": "^4.0.0", 3202 | "read-cache": "^1.0.0", 3203 | "resolve": "^1.1.7" 3204 | }, 3205 | "engines": { 3206 | "node": ">=14.0.0" 3207 | }, 3208 | "peerDependencies": { 3209 | "postcss": "^8.0.0" 3210 | } 3211 | }, 3212 | "node_modules/postcss-js": { 3213 | "version": "4.0.1", 3214 | "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", 3215 | "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", 3216 | "dev": true, 3217 | "dependencies": { 3218 | "camelcase-css": "^2.0.1" 3219 | }, 3220 | "engines": { 3221 | "node": "^12 || ^14 || >= 16" 3222 | }, 3223 | "funding": { 3224 | "type": "opencollective", 3225 | "url": "https://opencollective.com/postcss/" 3226 | }, 3227 | "peerDependencies": { 3228 | "postcss": "^8.4.21" 3229 | } 3230 | }, 3231 | "node_modules/postcss-load-config": { 3232 | "version": "4.0.2", 3233 | "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", 3234 | "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", 3235 | "dev": true, 3236 | "funding": [ 3237 | { 3238 | "type": "opencollective", 3239 | "url": "https://opencollective.com/postcss/" 3240 | }, 3241 | { 3242 | "type": "github", 3243 | "url": "https://github.com/sponsors/ai" 3244 | } 3245 | ], 3246 | "dependencies": { 3247 | "lilconfig": "^3.0.0", 3248 | "yaml": "^2.3.4" 3249 | }, 3250 | "engines": { 3251 | "node": ">= 14" 3252 | }, 3253 | "peerDependencies": { 3254 | "postcss": ">=8.0.9", 3255 | "ts-node": ">=9.0.0" 3256 | }, 3257 | "peerDependenciesMeta": { 3258 | "postcss": { 3259 | "optional": true 3260 | }, 3261 | "ts-node": { 3262 | "optional": true 3263 | } 3264 | } 3265 | }, 3266 | "node_modules/postcss-load-config/node_modules/lilconfig": { 3267 | "version": "3.1.2", 3268 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.2.tgz", 3269 | "integrity": "sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==", 3270 | "dev": true, 3271 | "engines": { 3272 | "node": ">=14" 3273 | }, 3274 | "funding": { 3275 | "url": "https://github.com/sponsors/antonk52" 3276 | } 3277 | }, 3278 | "node_modules/postcss-nested": { 3279 | "version": "6.2.0", 3280 | "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.2.0.tgz", 3281 | "integrity": "sha512-HQbt28KulC5AJzG+cZtj9kvKB93CFCdLvog1WFLf1D+xmMvPGlBstkpTEZfK5+AN9hfJocyBFCNiqyS48bpgzQ==", 3282 | "dev": true, 3283 | "funding": [ 3284 | { 3285 | "type": "opencollective", 3286 | "url": "https://opencollective.com/postcss/" 3287 | }, 3288 | { 3289 | "type": "github", 3290 | "url": "https://github.com/sponsors/ai" 3291 | } 3292 | ], 3293 | "dependencies": { 3294 | "postcss-selector-parser": "^6.1.1" 3295 | }, 3296 | "engines": { 3297 | "node": ">=12.0" 3298 | }, 3299 | "peerDependencies": { 3300 | "postcss": "^8.2.14" 3301 | } 3302 | }, 3303 | "node_modules/postcss-selector-parser": { 3304 | "version": "6.1.1", 3305 | "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.1.tgz", 3306 | "integrity": "sha512-b4dlw/9V8A71rLIDsSwVmak9z2DuBUB7CA1/wSdelNEzqsjoSPeADTWNO09lpH49Diy3/JIZ2bSPB1dI3LJCHg==", 3307 | "dev": true, 3308 | "dependencies": { 3309 | "cssesc": "^3.0.0", 3310 | "util-deprecate": "^1.0.2" 3311 | }, 3312 | "engines": { 3313 | "node": ">=4" 3314 | } 3315 | }, 3316 | "node_modules/postcss-value-parser": { 3317 | "version": "4.2.0", 3318 | "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", 3319 | "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", 3320 | "dev": true 3321 | }, 3322 | "node_modules/prelude-ls": { 3323 | "version": "1.2.1", 3324 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3325 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3326 | "dev": true, 3327 | "engines": { 3328 | "node": ">= 0.8.0" 3329 | } 3330 | }, 3331 | "node_modules/punycode": { 3332 | "version": "2.3.1", 3333 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 3334 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 3335 | "dev": true, 3336 | "engines": { 3337 | "node": ">=6" 3338 | } 3339 | }, 3340 | "node_modules/queue-microtask": { 3341 | "version": "1.2.3", 3342 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3343 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3344 | "dev": true, 3345 | "funding": [ 3346 | { 3347 | "type": "github", 3348 | "url": "https://github.com/sponsors/feross" 3349 | }, 3350 | { 3351 | "type": "patreon", 3352 | "url": "https://www.patreon.com/feross" 3353 | }, 3354 | { 3355 | "type": "consulting", 3356 | "url": "https://feross.org/support" 3357 | } 3358 | ] 3359 | }, 3360 | "node_modules/react": { 3361 | "version": "18.3.1", 3362 | "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", 3363 | "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", 3364 | "dependencies": { 3365 | "loose-envify": "^1.1.0" 3366 | }, 3367 | "engines": { 3368 | "node": ">=0.10.0" 3369 | } 3370 | }, 3371 | "node_modules/react-dom": { 3372 | "version": "18.3.1", 3373 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", 3374 | "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", 3375 | "dependencies": { 3376 | "loose-envify": "^1.1.0", 3377 | "scheduler": "^0.23.2" 3378 | }, 3379 | "peerDependencies": { 3380 | "react": "^18.3.1" 3381 | } 3382 | }, 3383 | "node_modules/react-icons": { 3384 | "version": "5.2.1", 3385 | "resolved": "https://registry.npmjs.org/react-icons/-/react-icons-5.2.1.tgz", 3386 | "integrity": "sha512-zdbW5GstTzXaVKvGSyTaBalt7HSfuK5ovrzlpyiWHAFXndXTdd/1hdDHI4xBM1Mn7YriT6aqESucFl9kEXzrdw==", 3387 | "peerDependencies": { 3388 | "react": "*" 3389 | } 3390 | }, 3391 | "node_modules/react-refresh": { 3392 | "version": "0.14.2", 3393 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.2.tgz", 3394 | "integrity": "sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==", 3395 | "dev": true, 3396 | "engines": { 3397 | "node": ">=0.10.0" 3398 | } 3399 | }, 3400 | "node_modules/read-cache": { 3401 | "version": "1.0.0", 3402 | "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", 3403 | "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", 3404 | "dev": true, 3405 | "dependencies": { 3406 | "pify": "^2.3.0" 3407 | } 3408 | }, 3409 | "node_modules/readdirp": { 3410 | "version": "3.6.0", 3411 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", 3412 | "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", 3413 | "dev": true, 3414 | "dependencies": { 3415 | "picomatch": "^2.2.1" 3416 | }, 3417 | "engines": { 3418 | "node": ">=8.10.0" 3419 | } 3420 | }, 3421 | "node_modules/resolve": { 3422 | "version": "1.22.8", 3423 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", 3424 | "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", 3425 | "dev": true, 3426 | "dependencies": { 3427 | "is-core-module": "^2.13.0", 3428 | "path-parse": "^1.0.7", 3429 | "supports-preserve-symlinks-flag": "^1.0.0" 3430 | }, 3431 | "bin": { 3432 | "resolve": "bin/resolve" 3433 | }, 3434 | "funding": { 3435 | "url": "https://github.com/sponsors/ljharb" 3436 | } 3437 | }, 3438 | "node_modules/resolve-from": { 3439 | "version": "4.0.0", 3440 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3441 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3442 | "dev": true, 3443 | "engines": { 3444 | "node": ">=4" 3445 | } 3446 | }, 3447 | "node_modules/reusify": { 3448 | "version": "1.0.4", 3449 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3450 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3451 | "dev": true, 3452 | "engines": { 3453 | "iojs": ">=1.0.0", 3454 | "node": ">=0.10.0" 3455 | } 3456 | }, 3457 | "node_modules/rimraf": { 3458 | "version": "3.0.2", 3459 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3460 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3461 | "deprecated": "Rimraf versions prior to v4 are no longer supported", 3462 | "dev": true, 3463 | "dependencies": { 3464 | "glob": "^7.1.3" 3465 | }, 3466 | "bin": { 3467 | "rimraf": "bin.js" 3468 | }, 3469 | "funding": { 3470 | "url": "https://github.com/sponsors/isaacs" 3471 | } 3472 | }, 3473 | "node_modules/rollup": { 3474 | "version": "4.20.0", 3475 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.20.0.tgz", 3476 | "integrity": "sha512-6rbWBChcnSGzIlXeIdNIZTopKYad8ZG8ajhl78lGRLsI2rX8IkaotQhVas2Ma+GPxJav19wrSzvRvuiv0YKzWw==", 3477 | "dev": true, 3478 | "dependencies": { 3479 | "@types/estree": "1.0.5" 3480 | }, 3481 | "bin": { 3482 | "rollup": "dist/bin/rollup" 3483 | }, 3484 | "engines": { 3485 | "node": ">=18.0.0", 3486 | "npm": ">=8.0.0" 3487 | }, 3488 | "optionalDependencies": { 3489 | "@rollup/rollup-android-arm-eabi": "4.20.0", 3490 | "@rollup/rollup-android-arm64": "4.20.0", 3491 | "@rollup/rollup-darwin-arm64": "4.20.0", 3492 | "@rollup/rollup-darwin-x64": "4.20.0", 3493 | "@rollup/rollup-linux-arm-gnueabihf": "4.20.0", 3494 | "@rollup/rollup-linux-arm-musleabihf": "4.20.0", 3495 | "@rollup/rollup-linux-arm64-gnu": "4.20.0", 3496 | "@rollup/rollup-linux-arm64-musl": "4.20.0", 3497 | "@rollup/rollup-linux-powerpc64le-gnu": "4.20.0", 3498 | "@rollup/rollup-linux-riscv64-gnu": "4.20.0", 3499 | "@rollup/rollup-linux-s390x-gnu": "4.20.0", 3500 | "@rollup/rollup-linux-x64-gnu": "4.20.0", 3501 | "@rollup/rollup-linux-x64-musl": "4.20.0", 3502 | "@rollup/rollup-win32-arm64-msvc": "4.20.0", 3503 | "@rollup/rollup-win32-ia32-msvc": "4.20.0", 3504 | "@rollup/rollup-win32-x64-msvc": "4.20.0", 3505 | "fsevents": "~2.3.2" 3506 | } 3507 | }, 3508 | "node_modules/run-parallel": { 3509 | "version": "1.2.0", 3510 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3511 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3512 | "dev": true, 3513 | "funding": [ 3514 | { 3515 | "type": "github", 3516 | "url": "https://github.com/sponsors/feross" 3517 | }, 3518 | { 3519 | "type": "patreon", 3520 | "url": "https://www.patreon.com/feross" 3521 | }, 3522 | { 3523 | "type": "consulting", 3524 | "url": "https://feross.org/support" 3525 | } 3526 | ], 3527 | "dependencies": { 3528 | "queue-microtask": "^1.2.2" 3529 | } 3530 | }, 3531 | "node_modules/scheduler": { 3532 | "version": "0.23.2", 3533 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", 3534 | "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", 3535 | "dependencies": { 3536 | "loose-envify": "^1.1.0" 3537 | } 3538 | }, 3539 | "node_modules/semver": { 3540 | "version": "7.6.3", 3541 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", 3542 | "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", 3543 | "dev": true, 3544 | "bin": { 3545 | "semver": "bin/semver.js" 3546 | }, 3547 | "engines": { 3548 | "node": ">=10" 3549 | } 3550 | }, 3551 | "node_modules/shebang-command": { 3552 | "version": "2.0.0", 3553 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3554 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3555 | "dev": true, 3556 | "dependencies": { 3557 | "shebang-regex": "^3.0.0" 3558 | }, 3559 | "engines": { 3560 | "node": ">=8" 3561 | } 3562 | }, 3563 | "node_modules/shebang-regex": { 3564 | "version": "3.0.0", 3565 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3566 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3567 | "dev": true, 3568 | "engines": { 3569 | "node": ">=8" 3570 | } 3571 | }, 3572 | "node_modules/signal-exit": { 3573 | "version": "4.1.0", 3574 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 3575 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 3576 | "dev": true, 3577 | "engines": { 3578 | "node": ">=14" 3579 | }, 3580 | "funding": { 3581 | "url": "https://github.com/sponsors/isaacs" 3582 | } 3583 | }, 3584 | "node_modules/slash": { 3585 | "version": "3.0.0", 3586 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3587 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3588 | "dev": true, 3589 | "engines": { 3590 | "node": ">=8" 3591 | } 3592 | }, 3593 | "node_modules/source-map-js": { 3594 | "version": "1.2.0", 3595 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", 3596 | "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", 3597 | "dev": true, 3598 | "engines": { 3599 | "node": ">=0.10.0" 3600 | } 3601 | }, 3602 | "node_modules/string-width": { 3603 | "version": "5.1.2", 3604 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", 3605 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", 3606 | "dev": true, 3607 | "dependencies": { 3608 | "eastasianwidth": "^0.2.0", 3609 | "emoji-regex": "^9.2.2", 3610 | "strip-ansi": "^7.0.1" 3611 | }, 3612 | "engines": { 3613 | "node": ">=12" 3614 | }, 3615 | "funding": { 3616 | "url": "https://github.com/sponsors/sindresorhus" 3617 | } 3618 | }, 3619 | "node_modules/string-width-cjs": { 3620 | "name": "string-width", 3621 | "version": "4.2.3", 3622 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3623 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3624 | "dev": true, 3625 | "dependencies": { 3626 | "emoji-regex": "^8.0.0", 3627 | "is-fullwidth-code-point": "^3.0.0", 3628 | "strip-ansi": "^6.0.1" 3629 | }, 3630 | "engines": { 3631 | "node": ">=8" 3632 | } 3633 | }, 3634 | "node_modules/string-width-cjs/node_modules/emoji-regex": { 3635 | "version": "8.0.0", 3636 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3637 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3638 | "dev": true 3639 | }, 3640 | "node_modules/string-width/node_modules/ansi-regex": { 3641 | "version": "6.0.1", 3642 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 3643 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 3644 | "dev": true, 3645 | "engines": { 3646 | "node": ">=12" 3647 | }, 3648 | "funding": { 3649 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 3650 | } 3651 | }, 3652 | "node_modules/string-width/node_modules/strip-ansi": { 3653 | "version": "7.1.0", 3654 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 3655 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 3656 | "dev": true, 3657 | "dependencies": { 3658 | "ansi-regex": "^6.0.1" 3659 | }, 3660 | "engines": { 3661 | "node": ">=12" 3662 | }, 3663 | "funding": { 3664 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 3665 | } 3666 | }, 3667 | "node_modules/strip-ansi": { 3668 | "version": "6.0.1", 3669 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3670 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3671 | "dev": true, 3672 | "dependencies": { 3673 | "ansi-regex": "^5.0.1" 3674 | }, 3675 | "engines": { 3676 | "node": ">=8" 3677 | } 3678 | }, 3679 | "node_modules/strip-ansi-cjs": { 3680 | "name": "strip-ansi", 3681 | "version": "6.0.1", 3682 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3683 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3684 | "dev": true, 3685 | "dependencies": { 3686 | "ansi-regex": "^5.0.1" 3687 | }, 3688 | "engines": { 3689 | "node": ">=8" 3690 | } 3691 | }, 3692 | "node_modules/strip-json-comments": { 3693 | "version": "3.1.1", 3694 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3695 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3696 | "dev": true, 3697 | "engines": { 3698 | "node": ">=8" 3699 | }, 3700 | "funding": { 3701 | "url": "https://github.com/sponsors/sindresorhus" 3702 | } 3703 | }, 3704 | "node_modules/sucrase": { 3705 | "version": "3.35.0", 3706 | "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", 3707 | "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", 3708 | "dev": true, 3709 | "dependencies": { 3710 | "@jridgewell/gen-mapping": "^0.3.2", 3711 | "commander": "^4.0.0", 3712 | "glob": "^10.3.10", 3713 | "lines-and-columns": "^1.1.6", 3714 | "mz": "^2.7.0", 3715 | "pirates": "^4.0.1", 3716 | "ts-interface-checker": "^0.1.9" 3717 | }, 3718 | "bin": { 3719 | "sucrase": "bin/sucrase", 3720 | "sucrase-node": "bin/sucrase-node" 3721 | }, 3722 | "engines": { 3723 | "node": ">=16 || 14 >=14.17" 3724 | } 3725 | }, 3726 | "node_modules/sucrase/node_modules/glob": { 3727 | "version": "10.4.5", 3728 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz", 3729 | "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==", 3730 | "dev": true, 3731 | "dependencies": { 3732 | "foreground-child": "^3.1.0", 3733 | "jackspeak": "^3.1.2", 3734 | "minimatch": "^9.0.4", 3735 | "minipass": "^7.1.2", 3736 | "package-json-from-dist": "^1.0.0", 3737 | "path-scurry": "^1.11.1" 3738 | }, 3739 | "bin": { 3740 | "glob": "dist/esm/bin.mjs" 3741 | }, 3742 | "funding": { 3743 | "url": "https://github.com/sponsors/isaacs" 3744 | } 3745 | }, 3746 | "node_modules/supports-color": { 3747 | "version": "5.5.0", 3748 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3749 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3750 | "dev": true, 3751 | "dependencies": { 3752 | "has-flag": "^3.0.0" 3753 | }, 3754 | "engines": { 3755 | "node": ">=4" 3756 | } 3757 | }, 3758 | "node_modules/supports-preserve-symlinks-flag": { 3759 | "version": "1.0.0", 3760 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3761 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3762 | "dev": true, 3763 | "engines": { 3764 | "node": ">= 0.4" 3765 | }, 3766 | "funding": { 3767 | "url": "https://github.com/sponsors/ljharb" 3768 | } 3769 | }, 3770 | "node_modules/tailwindcss": { 3771 | "version": "3.4.7", 3772 | "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.7.tgz", 3773 | "integrity": "sha512-rxWZbe87YJb4OcSopb7up2Ba4U82BoiSGUdoDr3Ydrg9ckxFS/YWsvhN323GMcddgU65QRy7JndC7ahhInhvlQ==", 3774 | "dev": true, 3775 | "dependencies": { 3776 | "@alloc/quick-lru": "^5.2.0", 3777 | "arg": "^5.0.2", 3778 | "chokidar": "^3.5.3", 3779 | "didyoumean": "^1.2.2", 3780 | "dlv": "^1.1.3", 3781 | "fast-glob": "^3.3.0", 3782 | "glob-parent": "^6.0.2", 3783 | "is-glob": "^4.0.3", 3784 | "jiti": "^1.21.0", 3785 | "lilconfig": "^2.1.0", 3786 | "micromatch": "^4.0.5", 3787 | "normalize-path": "^3.0.0", 3788 | "object-hash": "^3.0.0", 3789 | "picocolors": "^1.0.0", 3790 | "postcss": "^8.4.23", 3791 | "postcss-import": "^15.1.0", 3792 | "postcss-js": "^4.0.1", 3793 | "postcss-load-config": "^4.0.1", 3794 | "postcss-nested": "^6.0.1", 3795 | "postcss-selector-parser": "^6.0.11", 3796 | "resolve": "^1.22.2", 3797 | "sucrase": "^3.32.0" 3798 | }, 3799 | "bin": { 3800 | "tailwind": "lib/cli.js", 3801 | "tailwindcss": "lib/cli.js" 3802 | }, 3803 | "engines": { 3804 | "node": ">=14.0.0" 3805 | } 3806 | }, 3807 | "node_modules/text-table": { 3808 | "version": "0.2.0", 3809 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3810 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3811 | "dev": true 3812 | }, 3813 | "node_modules/thenify": { 3814 | "version": "3.3.1", 3815 | "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", 3816 | "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", 3817 | "dev": true, 3818 | "dependencies": { 3819 | "any-promise": "^1.0.0" 3820 | } 3821 | }, 3822 | "node_modules/thenify-all": { 3823 | "version": "1.6.0", 3824 | "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", 3825 | "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", 3826 | "dev": true, 3827 | "dependencies": { 3828 | "thenify": ">= 3.1.0 < 4" 3829 | }, 3830 | "engines": { 3831 | "node": ">=0.8" 3832 | } 3833 | }, 3834 | "node_modules/to-fast-properties": { 3835 | "version": "2.0.0", 3836 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3837 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 3838 | "dev": true, 3839 | "engines": { 3840 | "node": ">=4" 3841 | } 3842 | }, 3843 | "node_modules/to-regex-range": { 3844 | "version": "5.0.1", 3845 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3846 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3847 | "dev": true, 3848 | "dependencies": { 3849 | "is-number": "^7.0.0" 3850 | }, 3851 | "engines": { 3852 | "node": ">=8.0" 3853 | } 3854 | }, 3855 | "node_modules/ts-api-utils": { 3856 | "version": "1.3.0", 3857 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz", 3858 | "integrity": "sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ==", 3859 | "dev": true, 3860 | "engines": { 3861 | "node": ">=16" 3862 | }, 3863 | "peerDependencies": { 3864 | "typescript": ">=4.2.0" 3865 | } 3866 | }, 3867 | "node_modules/ts-interface-checker": { 3868 | "version": "0.1.13", 3869 | "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", 3870 | "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==", 3871 | "dev": true 3872 | }, 3873 | "node_modules/type-check": { 3874 | "version": "0.4.0", 3875 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3876 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3877 | "dev": true, 3878 | "dependencies": { 3879 | "prelude-ls": "^1.2.1" 3880 | }, 3881 | "engines": { 3882 | "node": ">= 0.8.0" 3883 | } 3884 | }, 3885 | "node_modules/type-fest": { 3886 | "version": "0.20.2", 3887 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3888 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3889 | "dev": true, 3890 | "engines": { 3891 | "node": ">=10" 3892 | }, 3893 | "funding": { 3894 | "url": "https://github.com/sponsors/sindresorhus" 3895 | } 3896 | }, 3897 | "node_modules/typescript": { 3898 | "version": "5.5.4", 3899 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.4.tgz", 3900 | "integrity": "sha512-Mtq29sKDAEYP7aljRgtPOpTvOfbwRWlS6dPRzwjdE+C0R4brX/GUyhHSecbHMFLNBLcJIPt9nl9yG5TZ1weH+Q==", 3901 | "dev": true, 3902 | "bin": { 3903 | "tsc": "bin/tsc", 3904 | "tsserver": "bin/tsserver" 3905 | }, 3906 | "engines": { 3907 | "node": ">=14.17" 3908 | } 3909 | }, 3910 | "node_modules/update-browserslist-db": { 3911 | "version": "1.1.0", 3912 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", 3913 | "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", 3914 | "dev": true, 3915 | "funding": [ 3916 | { 3917 | "type": "opencollective", 3918 | "url": "https://opencollective.com/browserslist" 3919 | }, 3920 | { 3921 | "type": "tidelift", 3922 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3923 | }, 3924 | { 3925 | "type": "github", 3926 | "url": "https://github.com/sponsors/ai" 3927 | } 3928 | ], 3929 | "dependencies": { 3930 | "escalade": "^3.1.2", 3931 | "picocolors": "^1.0.1" 3932 | }, 3933 | "bin": { 3934 | "update-browserslist-db": "cli.js" 3935 | }, 3936 | "peerDependencies": { 3937 | "browserslist": ">= 4.21.0" 3938 | } 3939 | }, 3940 | "node_modules/uri-js": { 3941 | "version": "4.4.1", 3942 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3943 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3944 | "dev": true, 3945 | "dependencies": { 3946 | "punycode": "^2.1.0" 3947 | } 3948 | }, 3949 | "node_modules/util-deprecate": { 3950 | "version": "1.0.2", 3951 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3952 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", 3953 | "dev": true 3954 | }, 3955 | "node_modules/vite": { 3956 | "version": "5.3.5", 3957 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.3.5.tgz", 3958 | "integrity": "sha512-MdjglKR6AQXQb9JGiS7Rc2wC6uMjcm7Go/NHNO63EwiJXfuk9PgqiP/n5IDJCziMkfw9n4Ubp7lttNwz+8ZVKA==", 3959 | "dev": true, 3960 | "dependencies": { 3961 | "esbuild": "^0.21.3", 3962 | "postcss": "^8.4.39", 3963 | "rollup": "^4.13.0" 3964 | }, 3965 | "bin": { 3966 | "vite": "bin/vite.js" 3967 | }, 3968 | "engines": { 3969 | "node": "^18.0.0 || >=20.0.0" 3970 | }, 3971 | "funding": { 3972 | "url": "https://github.com/vitejs/vite?sponsor=1" 3973 | }, 3974 | "optionalDependencies": { 3975 | "fsevents": "~2.3.3" 3976 | }, 3977 | "peerDependencies": { 3978 | "@types/node": "^18.0.0 || >=20.0.0", 3979 | "less": "*", 3980 | "lightningcss": "^1.21.0", 3981 | "sass": "*", 3982 | "stylus": "*", 3983 | "sugarss": "*", 3984 | "terser": "^5.4.0" 3985 | }, 3986 | "peerDependenciesMeta": { 3987 | "@types/node": { 3988 | "optional": true 3989 | }, 3990 | "less": { 3991 | "optional": true 3992 | }, 3993 | "lightningcss": { 3994 | "optional": true 3995 | }, 3996 | "sass": { 3997 | "optional": true 3998 | }, 3999 | "stylus": { 4000 | "optional": true 4001 | }, 4002 | "sugarss": { 4003 | "optional": true 4004 | }, 4005 | "terser": { 4006 | "optional": true 4007 | } 4008 | } 4009 | }, 4010 | "node_modules/which": { 4011 | "version": "2.0.2", 4012 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 4013 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 4014 | "dev": true, 4015 | "dependencies": { 4016 | "isexe": "^2.0.0" 4017 | }, 4018 | "bin": { 4019 | "node-which": "bin/node-which" 4020 | }, 4021 | "engines": { 4022 | "node": ">= 8" 4023 | } 4024 | }, 4025 | "node_modules/word-wrap": { 4026 | "version": "1.2.5", 4027 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 4028 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 4029 | "dev": true, 4030 | "engines": { 4031 | "node": ">=0.10.0" 4032 | } 4033 | }, 4034 | "node_modules/wrap-ansi": { 4035 | "version": "8.1.0", 4036 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", 4037 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", 4038 | "dev": true, 4039 | "dependencies": { 4040 | "ansi-styles": "^6.1.0", 4041 | "string-width": "^5.0.1", 4042 | "strip-ansi": "^7.0.1" 4043 | }, 4044 | "engines": { 4045 | "node": ">=12" 4046 | }, 4047 | "funding": { 4048 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 4049 | } 4050 | }, 4051 | "node_modules/wrap-ansi-cjs": { 4052 | "name": "wrap-ansi", 4053 | "version": "7.0.0", 4054 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 4055 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 4056 | "dev": true, 4057 | "dependencies": { 4058 | "ansi-styles": "^4.0.0", 4059 | "string-width": "^4.1.0", 4060 | "strip-ansi": "^6.0.0" 4061 | }, 4062 | "engines": { 4063 | "node": ">=10" 4064 | }, 4065 | "funding": { 4066 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 4067 | } 4068 | }, 4069 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": { 4070 | "version": "4.3.0", 4071 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 4072 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 4073 | "dev": true, 4074 | "dependencies": { 4075 | "color-convert": "^2.0.1" 4076 | }, 4077 | "engines": { 4078 | "node": ">=8" 4079 | }, 4080 | "funding": { 4081 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 4082 | } 4083 | }, 4084 | "node_modules/wrap-ansi-cjs/node_modules/color-convert": { 4085 | "version": "2.0.1", 4086 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 4087 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 4088 | "dev": true, 4089 | "dependencies": { 4090 | "color-name": "~1.1.4" 4091 | }, 4092 | "engines": { 4093 | "node": ">=7.0.0" 4094 | } 4095 | }, 4096 | "node_modules/wrap-ansi-cjs/node_modules/color-name": { 4097 | "version": "1.1.4", 4098 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 4099 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 4100 | "dev": true 4101 | }, 4102 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { 4103 | "version": "8.0.0", 4104 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 4105 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 4106 | "dev": true 4107 | }, 4108 | "node_modules/wrap-ansi-cjs/node_modules/string-width": { 4109 | "version": "4.2.3", 4110 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 4111 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 4112 | "dev": true, 4113 | "dependencies": { 4114 | "emoji-regex": "^8.0.0", 4115 | "is-fullwidth-code-point": "^3.0.0", 4116 | "strip-ansi": "^6.0.1" 4117 | }, 4118 | "engines": { 4119 | "node": ">=8" 4120 | } 4121 | }, 4122 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 4123 | "version": "6.0.1", 4124 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 4125 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 4126 | "dev": true, 4127 | "engines": { 4128 | "node": ">=12" 4129 | }, 4130 | "funding": { 4131 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 4132 | } 4133 | }, 4134 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 4135 | "version": "6.2.1", 4136 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", 4137 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", 4138 | "dev": true, 4139 | "engines": { 4140 | "node": ">=12" 4141 | }, 4142 | "funding": { 4143 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 4144 | } 4145 | }, 4146 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 4147 | "version": "7.1.0", 4148 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", 4149 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", 4150 | "dev": true, 4151 | "dependencies": { 4152 | "ansi-regex": "^6.0.1" 4153 | }, 4154 | "engines": { 4155 | "node": ">=12" 4156 | }, 4157 | "funding": { 4158 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 4159 | } 4160 | }, 4161 | "node_modules/wrappy": { 4162 | "version": "1.0.2", 4163 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4164 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 4165 | "dev": true 4166 | }, 4167 | "node_modules/yallist": { 4168 | "version": "3.1.1", 4169 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 4170 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 4171 | "dev": true 4172 | }, 4173 | "node_modules/yaml": { 4174 | "version": "2.5.0", 4175 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.5.0.tgz", 4176 | "integrity": "sha512-2wWLbGbYDiSqqIKoPjar3MPgB94ErzCtrNE1FdqGuaO0pi2JGjmE8aW8TDZwzU7vuxcGRdL/4gPQwQ7hD5AMSw==", 4177 | "dev": true, 4178 | "bin": { 4179 | "yaml": "bin.mjs" 4180 | }, 4181 | "engines": { 4182 | "node": ">= 14" 4183 | } 4184 | }, 4185 | "node_modules/yocto-queue": { 4186 | "version": "0.1.0", 4187 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4188 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4189 | "dev": true, 4190 | "engines": { 4191 | "node": ">=10" 4192 | }, 4193 | "funding": { 4194 | "url": "https://github.com/sponsors/sindresorhus" 4195 | } 4196 | } 4197 | } 4198 | } 4199 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "audio-player-react-v2", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc -b && vite build", 9 | "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "react": "^18.3.1", 14 | "react-dom": "^18.3.1", 15 | "react-icons": "^5.2.1" 16 | }, 17 | "devDependencies": { 18 | "@types/react": "^18.3.3", 19 | "@types/react-dom": "^18.3.0", 20 | "@typescript-eslint/eslint-plugin": "^7.15.0", 21 | "@typescript-eslint/parser": "^7.15.0", 22 | "@vitejs/plugin-react": "^4.3.1", 23 | "autoprefixer": "^10.4.20", 24 | "eslint": "^8.57.0", 25 | "eslint-plugin-react-hooks": "^4.6.2", 26 | "eslint-plugin-react-refresh": "^0.4.7", 27 | "postcss": "^8.4.40", 28 | "tailwindcss": "^3.4.7", 29 | "typescript": "^5.2.2", 30 | "vite": "^5.3.4" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /postcss.config.js: -------------------------------------------------------------------------------- 1 | export default { 2 | plugins: { 3 | tailwindcss: {}, 4 | autoprefixer: {}, 5 | }, 6 | } 7 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.tsx: -------------------------------------------------------------------------------- 1 | import { AudioPlayer } from './components/AudioPlayer'; 2 | 3 | function App() { 4 | return ( 5 |
6 |

7 | Audio player in React 8 |

9 | 10 |
11 | ); 12 | } 13 | 14 | export default App; 15 | -------------------------------------------------------------------------------- /src/components/AudioPlayer.tsx: -------------------------------------------------------------------------------- 1 | import { useState } from 'react'; 2 | import { RiMenuAddLine } from 'react-icons/ri'; 3 | 4 | import { TrackInfo } from './TrackInfo'; 5 | import { Controls } from './Controls'; 6 | import { ProgressBar } from './ProgressBar'; 7 | import { VolumeControl } from './VolumeControl'; 8 | import { PlayList } from './PlayList'; 9 | 10 | export const AudioPlayer = () => { 11 | const [openDrawer, setOpenDrawer] = useState(false); 12 | 13 | return ( 14 |
15 |
16 | 17 |
18 | 19 | 20 |
21 |
22 | 23 | 26 |
27 |
28 | 29 |
34 |
35 | 36 |
37 |
38 |
39 | ); 40 | }; 41 | -------------------------------------------------------------------------------- /src/components/Controls.tsx: -------------------------------------------------------------------------------- 1 | import { useCallback, useEffect, useRef, useState } from 'react'; 2 | import { 3 | BsFillFastForwardFill, 4 | BsFillPauseFill, 5 | BsFillPlayFill, 6 | BsFillRewindFill, 7 | BsSkipEndFill, 8 | BsSkipStartFill, 9 | BsShuffle, 10 | BsRepeat, 11 | } from 'react-icons/bs'; 12 | 13 | import { useAudioPlayerContext } from '../context/audio-player-context'; 14 | import { tracks } from '../data/tracks'; 15 | 16 | export const Controls = () => { 17 | const { 18 | currentTrack, 19 | audioRef, 20 | setDuration, 21 | duration, 22 | setTimeProgress, 23 | progressBarRef, 24 | setTrackIndex, 25 | setCurrentTrack, 26 | isPlaying, 27 | setIsPlaying, 28 | } = useAudioPlayerContext(); 29 | 30 | const [isShuffle, setIsShuffle] = useState(false); 31 | const [isRepeat, setIsRepeat] = useState(false); 32 | // const [isPlaying, setIsPlaying] = useState(false); 33 | 34 | const playAnimationRef = useRef(null); 35 | 36 | const updateProgress = useCallback(() => { 37 | if (audioRef.current && progressBarRef.current && duration) { 38 | const currentTime = audioRef.current.currentTime; 39 | setTimeProgress(currentTime); 40 | 41 | progressBarRef.current.value = currentTime.toString(); 42 | progressBarRef.current.style.setProperty( 43 | '--range-progress', 44 | `${(currentTime / duration) * 100}%` 45 | ); 46 | } 47 | }, [duration, setTimeProgress, audioRef, progressBarRef]); 48 | 49 | const startAnimation = useCallback(() => { 50 | if (audioRef.current && progressBarRef.current && duration) { 51 | const animate = () => { 52 | updateProgress(); 53 | playAnimationRef.current = requestAnimationFrame(animate); 54 | }; 55 | playAnimationRef.current = requestAnimationFrame(animate); 56 | } 57 | }, [updateProgress, duration, audioRef, progressBarRef]); 58 | 59 | useEffect(() => { 60 | if (isPlaying) { 61 | audioRef.current?.play(); 62 | startAnimation(); 63 | } else { 64 | audioRef.current?.pause(); 65 | if (playAnimationRef.current !== null) { 66 | cancelAnimationFrame(playAnimationRef.current); 67 | playAnimationRef.current = null; 68 | } 69 | updateProgress(); // Ensure progress is updated immediately when paused 70 | } 71 | 72 | return () => { 73 | if (playAnimationRef.current !== null) { 74 | cancelAnimationFrame(playAnimationRef.current); 75 | } 76 | }; 77 | }, [isPlaying, startAnimation, updateProgress, audioRef]); 78 | 79 | const onLoadedMetadata = () => { 80 | const seconds = audioRef.current?.duration; 81 | if (seconds !== undefined) { 82 | setDuration(seconds); 83 | if (progressBarRef.current) { 84 | progressBarRef.current.max = seconds.toString(); 85 | } 86 | } 87 | }; 88 | 89 | const skipForward = () => { 90 | if (audioRef.current) { 91 | audioRef.current.currentTime += 15; 92 | updateProgress(); 93 | } 94 | }; 95 | 96 | const skipBackward = () => { 97 | if (audioRef.current) { 98 | audioRef.current.currentTime -= 15; 99 | updateProgress(); 100 | } 101 | }; 102 | 103 | const handlePrevious = useCallback(() => { 104 | setTrackIndex((prev) => { 105 | const newIndex = isShuffle 106 | ? Math.floor(Math.random() * tracks.length) 107 | : prev === 0 108 | ? tracks.length - 1 109 | : prev - 1; 110 | setCurrentTrack(tracks[newIndex]); 111 | return newIndex; 112 | }); 113 | }, [isShuffle, setCurrentTrack, setTrackIndex]); 114 | 115 | const handleNext = useCallback(() => { 116 | setTrackIndex((prev) => { 117 | const newIndex = isShuffle 118 | ? Math.floor(Math.random() * tracks.length) 119 | : prev >= tracks.length - 1 120 | ? 0 121 | : prev + 1; 122 | setCurrentTrack(tracks[newIndex]); 123 | return newIndex; 124 | }); 125 | }, [isShuffle, setCurrentTrack, setTrackIndex]); 126 | 127 | useEffect(() => { 128 | const currentAudioRef = audioRef.current; 129 | 130 | if (currentAudioRef) { 131 | currentAudioRef.onended = () => { 132 | if (isRepeat) { 133 | currentAudioRef.play(); 134 | } else { 135 | handleNext(); // This function should handle both shuffle and non-shuffle scenarios 136 | } 137 | }; 138 | } 139 | 140 | return () => { 141 | if (currentAudioRef) { 142 | currentAudioRef.onended = null; 143 | } 144 | }; 145 | }, [isRepeat, handleNext, audioRef]); 146 | 147 | return ( 148 |
149 |
186 | ); 187 | }; 188 | -------------------------------------------------------------------------------- /src/components/PlayList.tsx: -------------------------------------------------------------------------------- 1 | import { BsMusicNoteBeamed } from 'react-icons/bs'; 2 | 3 | import { 4 | Track, 5 | useAudioPlayerContext, 6 | } from '../context/audio-player-context'; 7 | import { tracks } from '../data/tracks'; 8 | 9 | export const PlayList = () => { 10 | const { currentTrack, setIsPlaying, setCurrentTrack } = 11 | useAudioPlayerContext(); 12 | 13 | const handleClick = (track: Track) => { 14 | setCurrentTrack(track); 15 | setIsPlaying(true); 16 | }; 17 | 18 | return ( 19 |
    20 | {tracks.map((track, index) => ( 21 |
  • { 28 | if (e.key === 'Enter' || e.key === ' ') { 29 | handleClick(track); 30 | } 31 | }} 32 | onClick={() => handleClick(track)} 33 | > 34 |
    35 | {track.thumbnail ? ( 36 | audio avatar 41 | ) : ( 42 |
    43 | 44 | 45 | 46 |
    47 | )} 48 |
    49 |
    50 |

    {track.title}

    51 |

    {track.author}

    52 |
    53 |
  • 54 | ))} 55 |
56 | ); 57 | }; 58 | -------------------------------------------------------------------------------- /src/components/ProgressBar.tsx: -------------------------------------------------------------------------------- 1 | import { useAudioPlayerContext } from '../context/audio-player-context'; 2 | 3 | export const ProgressBar = () => { 4 | const { 5 | progressBarRef, 6 | audioRef, 7 | timeProgress, 8 | duration, 9 | setTimeProgress, 10 | } = useAudioPlayerContext(); 11 | 12 | const handleProgressChange = () => { 13 | if (audioRef.current && progressBarRef.current) { 14 | const newTime = Number(progressBarRef.current.value); 15 | audioRef.current.currentTime = newTime; 16 | 17 | setTimeProgress(newTime); 18 | 19 | // if progress bar changes while audio is on pause 20 | progressBarRef.current.style.setProperty( 21 | '--range-progress', 22 | `${(newTime / duration) * 100}%` 23 | ); 24 | } 25 | }; 26 | 27 | const formatTime = (time: number | undefined): string => { 28 | if (typeof time === 'number' && !isNaN(time)) { 29 | const minutes = Math.floor(time / 60); 30 | const seconds = Math.floor(time % 60); 31 | 32 | // Convert to string and pad with leading zeros if necessary 33 | const formatMinutes = minutes.toString().padStart(2, '0'); 34 | const formatSeconds = seconds.toString().padStart(2, '0'); 35 | 36 | return `${formatMinutes}:${formatSeconds}`; 37 | } 38 | return '00:00'; 39 | }; 40 | 41 | return ( 42 |
43 | {formatTime(timeProgress)} 44 | 51 | {formatTime(duration)} 52 |
53 | ); 54 | }; 55 | -------------------------------------------------------------------------------- /src/components/TrackInfo.tsx: -------------------------------------------------------------------------------- 1 | import { BsMusicNoteBeamed } from 'react-icons/bs'; 2 | 3 | import { useAudioPlayerContext } from '../context/audio-player-context'; 4 | 5 | export const TrackInfo = () => { 6 | const { currentTrack } = useAudioPlayerContext(); 7 | 8 | return ( 9 |
10 |
11 | {currentTrack.thumbnail ? ( 12 | audio avatar 17 | ) : ( 18 |
19 | 20 | 21 | 22 |
23 | )} 24 |
25 |
26 |

27 | {currentTrack.title} 28 |

29 |

{currentTrack.author}

30 |
31 |
32 | ); 33 | }; 34 | -------------------------------------------------------------------------------- /src/components/VolumeControl.tsx: -------------------------------------------------------------------------------- 1 | import { ChangeEvent, useEffect, useState } from 'react'; 2 | 3 | import { 4 | IoMdVolumeHigh, 5 | IoMdVolumeOff, 6 | IoMdVolumeLow, 7 | } from 'react-icons/io'; 8 | import { useAudioPlayerContext } from '../context/audio-player-context'; 9 | 10 | export const VolumeControl = () => { 11 | const [volume, setVolume] = useState(60); 12 | const [muteVolume, setMuteVolume] = useState(false); 13 | const { audioRef } = useAudioPlayerContext(); 14 | 15 | useEffect(() => { 16 | if (audioRef.current) { 17 | audioRef.current.volume = volume / 100; 18 | audioRef.current.muted = muteVolume; 19 | } 20 | }, [volume, audioRef, muteVolume]); 21 | 22 | const handleVolumeChange = (e: ChangeEvent) => { 23 | setVolume(Number(e.target.value)); 24 | }; 25 | 26 | return ( 27 |
28 |
29 | 38 | 49 |
50 |
51 | ); 52 | }; 53 | -------------------------------------------------------------------------------- /src/context/audio-player-context.tsx: -------------------------------------------------------------------------------- 1 | import { 2 | createContext, 3 | useContext, 4 | useState, 5 | ReactNode, 6 | Dispatch, 7 | SetStateAction, 8 | RefObject, 9 | useRef, 10 | } from 'react'; 11 | 12 | import { tracks } from '../data/tracks'; 13 | 14 | export interface Track { 15 | title: string; 16 | src: string; 17 | author: string; 18 | thumbnail?: string; 19 | } 20 | 21 | interface AudioPlayerContextType { 22 | currentTrack: Track; 23 | setCurrentTrack: Dispatch>; 24 | timeProgress: number; 25 | setTimeProgress: Dispatch>; 26 | duration: number; 27 | setDuration: Dispatch>; 28 | setTrackIndex: Dispatch>; 29 | audioRef: RefObject; 30 | progressBarRef: RefObject; 31 | isPlaying: boolean; 32 | setIsPlaying: Dispatch>; 33 | } 34 | 35 | const AudioPlayerContext = createContext< 36 | AudioPlayerContextType | undefined 37 | >(undefined); 38 | 39 | export const AudioPlayerProvider = ({ 40 | children, 41 | }: { 42 | children: ReactNode; 43 | }) => { 44 | const [trackIndex, setTrackIndex] = useState(0); 45 | 46 | const [currentTrack, setCurrentTrack] = useState( 47 | tracks[trackIndex] 48 | ); 49 | const [timeProgress, setTimeProgress] = useState(0); 50 | const [duration, setDuration] = useState(0); 51 | const [isPlaying, setIsPlaying] = useState(false); 52 | 53 | const audioRef = useRef(null); 54 | const progressBarRef = useRef(null); 55 | 56 | const contextValue = { 57 | currentTrack, 58 | setCurrentTrack, 59 | audioRef, 60 | progressBarRef, 61 | timeProgress, 62 | setTimeProgress, 63 | duration, 64 | setDuration, 65 | setTrackIndex, 66 | isPlaying, 67 | setIsPlaying, 68 | }; 69 | 70 | return ( 71 | 72 | {children} 73 | 74 | ); 75 | }; 76 | 77 | export const useAudioPlayerContext = (): AudioPlayerContextType => { 78 | const context = useContext(AudioPlayerContext); 79 | 80 | if (context === undefined) { 81 | throw new Error( 82 | 'useAudioPlayerContext must be used within an AudioPlayerProvider' 83 | ); 84 | } 85 | 86 | return context; 87 | }; 88 | -------------------------------------------------------------------------------- /src/data/We_Are_The_World.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/We_Are_The_World.mp3 -------------------------------------------------------------------------------- /src/data/a_beautiful_day.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/a_beautiful_day.mp3 -------------------------------------------------------------------------------- /src/data/cinematic-time-lapse-115672.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/cinematic-time-lapse-115672.mp3 -------------------------------------------------------------------------------- /src/data/dbang-world.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/dbang-world.mp3 -------------------------------------------------------------------------------- /src/data/dbanj.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/dbanj.png -------------------------------------------------------------------------------- /src/data/forest-lullaby-110624.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/forest-lullaby-110624.mp3 -------------------------------------------------------------------------------- /src/data/jackson.jpeg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/jackson.jpeg -------------------------------------------------------------------------------- /src/data/lexin.jpeg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/lexin.jpeg -------------------------------------------------------------------------------- /src/data/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/data/the-podcast-intro-111863.mp3: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/the-podcast-intro-111863.mp3 -------------------------------------------------------------------------------- /src/data/tracks.ts: -------------------------------------------------------------------------------- 1 | // audio files 2 | import beautiful from './a_beautiful_day.mp3'; 3 | import world from './We_Are_The_World.mp3'; 4 | import top from './dbang-world.mp3'; 5 | import cinematic from './cinematic-time-lapse-115672.mp3'; 6 | import forest from './forest-lullaby-110624.mp3'; 7 | import podcast from './the-podcast-intro-111863.mp3'; 8 | 9 | // audio thumbnails 10 | import lexin from './lexin.jpeg'; 11 | import dbanj from './dbanj.png'; 12 | import jackson from './jackson.jpeg'; 13 | import trinix from './trinix.jpeg'; 14 | 15 | export const tracks = [ 16 | { 17 | title: 'Trinix ft Rushawn – Its a beautiful day', 18 | src: beautiful, 19 | author: 'Trinix ft Rushawn', 20 | thumbnail: trinix, 21 | }, 22 | { 23 | title: 'Michael Jackson – We Are The World', 24 | src: world, 25 | author: 'Michael Jackson', 26 | thumbnail: jackson, 27 | }, 28 | { 29 | title: 'D’banj -Top Of The World', 30 | src: top, 31 | author: 'Dbanj', 32 | thumbnail: dbanj, 33 | }, 34 | { 35 | title: 'Cinematic Time Lapse', 36 | src: cinematic, 37 | author: 'Lexin Music', 38 | thumbnail: lexin, 39 | }, 40 | { 41 | title: 'Forest Lullaby', 42 | src: forest, 43 | author: 'Lesfm', 44 | }, 45 | { 46 | title: 'The Podcast Intro', 47 | src: podcast, 48 | author: 'Music Unlimited', 49 | }, 50 | ]; 51 | -------------------------------------------------------------------------------- /src/data/trinix.jpeg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Ibaslogic/react-audio-player/df8e74f8388fa8fb6c0f89821b7abe4c9d6c3a84/src/data/trinix.jpeg -------------------------------------------------------------------------------- /src/main.tsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom/client'; 3 | import App from './App.tsx'; 4 | import './styles/index.css'; 5 | import './styles/customize-progress-bar.css'; 6 | 7 | import { AudioPlayerProvider } from './context/audio-player-context.tsx'; 8 | 9 | ReactDOM.createRoot(document.getElementById('root')!).render( 10 | 11 | 12 | 13 | 14 | 15 | ); 16 | -------------------------------------------------------------------------------- /src/styles/customize-progress-bar.css: -------------------------------------------------------------------------------- 1 | /* ========================= 2 | Custom Input range 3 | =============================*/ 4 | 5 | /* Input range - chrome and safari */ 6 | input[type='range'] { 7 | --range-progress: 0; 8 | 9 | -webkit-appearance: none; 10 | appearance: none; 11 | position: relative; 12 | background: #ccc; 13 | width: 100%; 14 | height: 2px; 15 | border-radius: 2px; 16 | cursor: pointer; 17 | } 18 | 19 | /* Input range - firefox */ 20 | input[type='range']::-moz-range-track { 21 | position: relative; 22 | background: #ccc; 23 | width: 100%; 24 | height: 2px; 25 | border-radius: 2px; 26 | cursor: pointer; 27 | } 28 | 29 | /* played progress length - Chrome & safari*/ 30 | input[type='range']::before { 31 | content: ''; 32 | height: 2px; 33 | background: #f50; 34 | width: var(--range-progress); 35 | border-bottom-left-radius: 2px; 36 | border-top-left-radius: 2px; 37 | position: absolute; 38 | top: 0; 39 | left: 0; 40 | } 41 | 42 | /* played progress length - firefox */ 43 | input[type='range']::-moz-range-progress { 44 | background: #f50; 45 | border-bottom-left-radius: 2px; 46 | border-top-left-radius: 2px; 47 | height: 2px; 48 | } 49 | 50 | /* slider thumb - chrome and safari */ 51 | input[type='range']::-webkit-slider-thumb { 52 | -webkit-appearance: none; 53 | height: 8px; 54 | width: 8px; 55 | border-radius: 50%; 56 | border: none; 57 | cursor: pointer; 58 | position: relative; 59 | } 60 | 61 | .volumn::-webkit-slider-thumb { 62 | background-color: #f50; 63 | } 64 | 65 | /* dragging thumb - chrome and safari */ 66 | input[type='range']:active::-webkit-slider-thumb { 67 | transform: scale(1.2); 68 | background-color: #f50; 69 | } 70 | 71 | /* slider thumb - firefox */ 72 | input[type='range']::-moz-range-thumb { 73 | height: 8px; 74 | width: 8px; 75 | border-radius: 50%; 76 | background: #f50; 77 | cursor: pointer; 78 | border: transparent; 79 | position: relative; 80 | } 81 | /* dragging thumb - firefox */ 82 | input[type='range']:active::-moz-range-thumb { 83 | transform: scale(1.2); 84 | background-color: #f50; 85 | } 86 | -------------------------------------------------------------------------------- /src/styles/index.css: -------------------------------------------------------------------------------- 1 | @tailwind base; 2 | @tailwind components; 3 | @tailwind utilities; 4 | -------------------------------------------------------------------------------- /src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /tailwind.config.js: -------------------------------------------------------------------------------- 1 | /** @type {import('tailwindcss').Config} */ 2 | export default { 3 | content: ['./index.html', './src/**/*.{js,ts,jsx,tsx}'], 4 | theme: { 5 | extend: {}, 6 | }, 7 | plugins: [], 8 | }; 9 | -------------------------------------------------------------------------------- /tsconfig.app.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo", 5 | "target": "ES2020", 6 | "useDefineForClassFields": true, 7 | "lib": ["ES2020", "DOM", "DOM.Iterable"], 8 | "module": "ESNext", 9 | "skipLibCheck": true, 10 | 11 | /* Bundler mode */ 12 | "moduleResolution": "bundler", 13 | "allowImportingTsExtensions": true, 14 | "resolveJsonModule": true, 15 | "isolatedModules": true, 16 | "moduleDetection": "force", 17 | "noEmit": true, 18 | "jsx": "react-jsx", 19 | 20 | /* Linting */ 21 | "strict": true, 22 | "noUnusedLocals": true, 23 | "noUnusedParameters": true, 24 | "noFallthroughCasesInSwitch": true 25 | }, 26 | "include": ["src"] 27 | } 28 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "files": [], 3 | "references": [ 4 | { 5 | "path": "./tsconfig.app.json" 6 | }, 7 | { 8 | "path": "./tsconfig.node.json" 9 | } 10 | ] 11 | } 12 | -------------------------------------------------------------------------------- /tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo", 5 | "skipLibCheck": true, 6 | "module": "ESNext", 7 | "moduleResolution": "bundler", 8 | "allowSyntheticDefaultImports": true, 9 | "strict": true, 10 | "noEmit": true 11 | }, 12 | "include": ["vite.config.ts"] 13 | } 14 | -------------------------------------------------------------------------------- /vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | }) 8 | --------------------------------------------------------------------------------