├── .gitignore
├── Auth
├── backend
│ ├── __init__.py
│ ├── __pycache__
│ │ ├── __init__.cpython-312.pyc
│ │ ├── database.cpython-312.pyc
│ │ ├── models.cpython-312.pyc
│ │ └── schemas.cpython-312.pyc
│ ├── auth
│ │ ├── __init__.py
│ │ ├── __pycache__
│ │ │ ├── __init__.cpython-312.pyc
│ │ │ └── auth_handler.cpython-312.pyc
│ │ └── auth_handler.py
│ ├── database.py
│ ├── models.py
│ ├── requirements.txt
│ ├── routers
│ │ ├── __init__.py
│ │ ├── __pycache__
│ │ │ ├── __init__.cpython-312.pyc
│ │ │ ├── auth.cpython-312.pyc
│ │ │ └── user.cpython-312.pyc
│ │ ├── auth.py
│ │ └── user.py
│ ├── schemas.py
│ └── test_main.http
├── frontend
│ ├── .gitignore
│ ├── README.md
│ ├── eslint.config.js
│ ├── index.html
│ ├── package-lock.json
│ ├── package.json
│ ├── public
│ │ └── vite.svg
│ ├── src
│ │ ├── App.css
│ │ ├── App.jsx
│ │ ├── api.js
│ │ ├── assets
│ │ │ └── react.svg
│ │ ├── components
│ │ │ ├── Login.jsx
│ │ │ ├── Register.jsx
│ │ │ └── UserProfile.jsx
│ │ ├── contexts
│ │ │ └── AuthContext.jsx
│ │ ├── index.css
│ │ └── main.jsx
│ └── vite.config.js
└── main.py
├── Simple
├── backend
│ ├── main.py
│ └── requirements.txt
└── frontend
│ ├── .gitignore
│ ├── README.md
│ ├── eslint.config.js
│ ├── index.html
│ ├── package-lock.json
│ ├── package.json
│ ├── public
│ └── vite.svg
│ ├── src
│ ├── App.css
│ ├── App.jsx
│ ├── api.js
│ ├── assets
│ │ └── react.svg
│ ├── components
│ │ ├── AddFruitForm.jsx
│ │ └── Fruits.jsx
│ ├── index.css
│ └── main.jsx
│ └── vite.config.js
└── notes.md
/.gitignore:
--------------------------------------------------------------------------------
1 | venv/
2 | test.db
3 | .idea/
--------------------------------------------------------------------------------
/Auth/backend/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/__init__.py
--------------------------------------------------------------------------------
/Auth/backend/__pycache__/__init__.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/__pycache__/__init__.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/__pycache__/database.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/__pycache__/database.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/__pycache__/models.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/__pycache__/models.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/__pycache__/schemas.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/__pycache__/schemas.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/auth/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/auth/__init__.py
--------------------------------------------------------------------------------
/Auth/backend/auth/__pycache__/__init__.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/auth/__pycache__/__init__.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/auth/__pycache__/auth_handler.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/auth/__pycache__/auth_handler.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/auth/auth_handler.py:
--------------------------------------------------------------------------------
1 | import jwt
2 | from fastapi import Depends, HTTPException, status, APIRouter
3 | from fastapi.security import OAuth2PasswordBearer
4 | from jwt.exceptions import InvalidTokenError
5 | from passlib.context import CryptContext
6 | from datetime import datetime, timedelta, timezone
7 |
8 | from sqlalchemy.orm import Session
9 |
10 | from ..database import get_db
11 | from ..schemas import TokenData
12 | from ..models import User
13 |
14 | # to get a string like this run:
15 | # openssl rand -hex 32
16 | SECRET_KEY = "09d25e094faa6ca2556c818166b7a9563b93f7099f6f0f4caa6cf63b88e8d3e7"
17 | ALGORITHM = "HS256"
18 | ACCESS_TOKEN_EXPIRE_MINUTES = 30
19 |
20 | pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto")
21 | oauth2_scheme = OAuth2PasswordBearer(tokenUrl="auth/token")
22 |
23 | router = APIRouter()
24 |
25 | def verify_password(plain_password, hashed_password):
26 | return pwd_context.verify(plain_password, hashed_password)
27 |
28 |
29 | def get_password_hash(password):
30 | return pwd_context.hash(password)
31 |
32 |
33 | def get_user(db: Session, username: str):
34 | db_user = db.query(User).filter(User.username == username).first()
35 | return db_user
36 |
37 |
38 | def authenticate_user(db: Session, username: str, password: str):
39 | user = get_user(db, username)
40 | if not user:
41 | return False
42 | if not verify_password(password, user.hashed_password):
43 | return False
44 | return user
45 |
46 |
47 | def create_access_token(data: dict, expires_delta: timedelta | None = None):
48 | to_encode = data.copy()
49 | if expires_delta:
50 | expire = datetime.now(timezone.utc) + expires_delta
51 | else:
52 | expire = datetime.now(timezone.utc) + timedelta(minutes=15)
53 | to_encode.update({"exp": expire})
54 | encoded_jwt = jwt.encode(to_encode, SECRET_KEY, algorithm=ALGORITHM)
55 | return encoded_jwt
56 |
57 |
58 | async def get_current_user(token: str = Depends(oauth2_scheme), db: Session = Depends(get_db)):
59 | credentials_exception = HTTPException(
60 | status_code=status.HTTP_401_UNAUTHORIZED,
61 | detail="Could not validate credentials",
62 | headers={"WWW-Authenticate": "Bearer"},
63 | )
64 | try:
65 | payload = jwt.decode(token, SECRET_KEY, algorithms=[ALGORITHM])
66 | username: str = payload.get("sub")
67 | if username is None:
68 | raise credentials_exception
69 | token_data = TokenData(username=username)
70 | except InvalidTokenError:
71 | raise credentials_exception
72 |
73 | user = db.query(User).filter(User.username == token_data.username).first()
74 | if user is None:
75 | raise credentials_exception
76 | return user
77 |
78 |
79 | async def get_current_active_user(current_user: User = Depends(get_current_user)):
80 | return current_user
81 |
--------------------------------------------------------------------------------
/Auth/backend/database.py:
--------------------------------------------------------------------------------
1 | # database.py
2 | from sqlalchemy import create_engine, MetaData
3 | from sqlalchemy.orm import sessionmaker
4 | from .models import Base
5 |
6 | DATABASE_URL = "sqlite:///./test.db" # You can use any database here
7 |
8 | engine = create_engine(DATABASE_URL)
9 | SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
10 | metadata = MetaData()
11 |
12 | def get_db():
13 | db = SessionLocal()
14 | try:
15 | yield db
16 | finally:
17 | db.close()
18 |
19 | Base.metadata.create_all(bind=engine)
--------------------------------------------------------------------------------
/Auth/backend/models.py:
--------------------------------------------------------------------------------
1 | # models.py
2 | from sqlalchemy import Column, Integer, String, Boolean
3 | from sqlalchemy.ext.declarative import declarative_base
4 |
5 | Base = declarative_base()
6 |
7 | class User(Base):
8 | __tablename__ = "users"
9 | id = Column(Integer, primary_key=True, index=True)
10 | username = Column(String, unique=True, index=True)
11 | email = Column(String, unique=True, index=True)
12 | hashed_password = Column(String)
13 | is_active = Column(Boolean, default=True)
14 |
--------------------------------------------------------------------------------
/Auth/backend/requirements.txt:
--------------------------------------------------------------------------------
1 | fastapi
2 | uvicorn
3 | pydantic
4 | sqlalchemy
5 | databases
6 | python-jose[cryptography]
7 | passlib[bcrypt]
8 | PyJWT
9 | python-decouple
10 | python-multipart
--------------------------------------------------------------------------------
/Auth/backend/routers/__init__.py:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/routers/__init__.py
--------------------------------------------------------------------------------
/Auth/backend/routers/__pycache__/__init__.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/routers/__pycache__/__init__.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/routers/__pycache__/auth.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/routers/__pycache__/auth.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/routers/__pycache__/user.cpython-312.pyc:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/techwithtim/FastAPI-React-Integration/8235008d8b384481d1ef9db732d809a1b54cbd19/Auth/backend/routers/__pycache__/user.cpython-312.pyc
--------------------------------------------------------------------------------
/Auth/backend/routers/auth.py:
--------------------------------------------------------------------------------
1 | from datetime import timedelta
2 |
3 | from fastapi.security import OAuth2PasswordRequestForm
4 | from fastapi import Depends, HTTPException, status, APIRouter
5 | from sqlalchemy.orm import Session
6 |
7 | from ..auth.auth_handler import authenticate_user, ACCESS_TOKEN_EXPIRE_MINUTES, create_access_token, get_user, get_password_hash
8 | from ..database import get_db
9 | from ..schemas import Token, UserCreate, UserResponse
10 | from ..models import User
11 |
12 | router = APIRouter()
13 |
14 |
15 | @router.post("/register", response_model=UserResponse)
16 | def register_user(user: UserCreate, db: Session = Depends(get_db)):
17 | db_user = get_user(db, user.username)
18 | if db_user:
19 | raise HTTPException(status_code=400, detail="Username already registered.")
20 | hashed_password = get_password_hash(user.password)
21 | db_user = User(username=user.username, email=user.email, hashed_password=hashed_password)
22 | db.add(db_user)
23 | db.commit()
24 | db.refresh(db_user)
25 | return db_user
26 |
27 |
28 | @router.post("/token")
29 | async def login_for_access_token(
30 | form_data: OAuth2PasswordRequestForm = Depends(),
31 | db: Session = Depends(get_db)
32 | ) -> Token:
33 | user = authenticate_user(db, form_data.username, form_data.password)
34 | if not user:
35 | raise HTTPException(
36 | status_code=status.HTTP_401_UNAUTHORIZED,
37 | detail="Incorrect username or password",
38 | headers={"WWW-Authenticate": "Bearer"},
39 | )
40 | access_token_expires = timedelta(minutes=ACCESS_TOKEN_EXPIRE_MINUTES)
41 | access_token = create_access_token(
42 | data={"sub": user.username}, expires_delta=access_token_expires
43 | )
44 | return Token(access_token=access_token, token_type="bearer")
45 |
--------------------------------------------------------------------------------
/Auth/backend/routers/user.py:
--------------------------------------------------------------------------------
1 | from fastapi import APIRouter, Depends
2 |
3 | from ..auth.auth_handler import get_current_active_user
4 | from ..schemas import UserResponse
5 | from ..models import User
6 |
7 | router = APIRouter()
8 |
9 | @router.get("/users/me/", response_model=UserResponse)
10 | async def read_users_me(current_user: User = Depends(get_current_active_user)):
11 | return current_user
12 |
--------------------------------------------------------------------------------
/Auth/backend/schemas.py:
--------------------------------------------------------------------------------
1 | # schemas.py
2 | from pydantic import BaseModel
3 |
4 |
5 | class Token(BaseModel):
6 | access_token: str
7 | token_type: str
8 |
9 |
10 | class TokenData(BaseModel):
11 | username: str | None = None
12 |
13 |
14 | class UserCreate(BaseModel):
15 | username: str
16 | email: str
17 | password: str
18 |
19 | class UserResponse(BaseModel):
20 | username: str
21 | email: str | None = None
22 |
23 | class UserInDB(UserResponse):
24 | hashed_password: str
--------------------------------------------------------------------------------
/Auth/backend/test_main.http:
--------------------------------------------------------------------------------
1 | # Test your FastAPI endpoints
2 |
3 | GET http://127.0.0.1:8000/
4 | Accept: application/json
5 |
6 | ###
7 |
8 | GET http://127.0.0.1:8000/hello/User
9 | Accept: application/json
10 |
11 | ###
12 |
--------------------------------------------------------------------------------
/Auth/frontend/.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 |
--------------------------------------------------------------------------------
/Auth/frontend/README.md:
--------------------------------------------------------------------------------
1 | # React + 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 |
--------------------------------------------------------------------------------
/Auth/frontend/eslint.config.js:
--------------------------------------------------------------------------------
1 | import js from '@eslint/js'
2 | import globals from 'globals'
3 | import react from 'eslint-plugin-react'
4 | import reactHooks from 'eslint-plugin-react-hooks'
5 | import reactRefresh from 'eslint-plugin-react-refresh'
6 |
7 | export default [
8 | { ignores: ['dist'] },
9 | {
10 | files: ['**/*.{js,jsx}'],
11 | languageOptions: {
12 | ecmaVersion: 2020,
13 | globals: globals.browser,
14 | parserOptions: {
15 | ecmaVersion: 'latest',
16 | ecmaFeatures: { jsx: true },
17 | sourceType: 'module',
18 | },
19 | },
20 | settings: { react: { version: '18.3' } },
21 | plugins: {
22 | react,
23 | 'react-hooks': reactHooks,
24 | 'react-refresh': reactRefresh,
25 | },
26 | rules: {
27 | ...js.configs.recommended.rules,
28 | ...react.configs.recommended.rules,
29 | ...react.configs['jsx-runtime'].rules,
30 | ...reactHooks.configs.recommended.rules,
31 | 'react/jsx-no-target-blank': 'off',
32 | 'react-refresh/only-export-components': [
33 | 'warn',
34 | { allowConstantExport: true },
35 | ],
36 | },
37 | },
38 | ]
39 |
--------------------------------------------------------------------------------
/Auth/frontend/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | Vite + React
8 |
9 |
10 |
11 |
12 |
13 |
14 |
--------------------------------------------------------------------------------
/Auth/frontend/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "version": "0.0.0",
4 | "lockfileVersion": 3,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "frontend",
9 | "version": "0.0.0",
10 | "dependencies": {
11 | "axios": "^1.7.7",
12 | "react": "^18.3.1",
13 | "react-dom": "^18.3.1",
14 | "react-router-dom": "^6.27.0"
15 | },
16 | "devDependencies": {
17 | "@eslint/js": "^9.13.0",
18 | "@types/react": "^18.3.12",
19 | "@types/react-dom": "^18.3.1",
20 | "@vitejs/plugin-react": "^4.3.3",
21 | "eslint": "^9.13.0",
22 | "eslint-plugin-react": "^7.37.2",
23 | "eslint-plugin-react-hooks": "^5.0.0",
24 | "eslint-plugin-react-refresh": "^0.4.14",
25 | "globals": "^15.11.0",
26 | "vite": "^5.4.10"
27 | }
28 | },
29 | "node_modules/@ampproject/remapping": {
30 | "version": "2.3.0",
31 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz",
32 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==",
33 | "dev": true,
34 | "license": "Apache-2.0",
35 | "dependencies": {
36 | "@jridgewell/gen-mapping": "^0.3.5",
37 | "@jridgewell/trace-mapping": "^0.3.24"
38 | },
39 | "engines": {
40 | "node": ">=6.0.0"
41 | }
42 | },
43 | "node_modules/@babel/code-frame": {
44 | "version": "7.26.2",
45 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz",
46 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==",
47 | "dev": true,
48 | "license": "MIT",
49 | "dependencies": {
50 | "@babel/helper-validator-identifier": "^7.25.9",
51 | "js-tokens": "^4.0.0",
52 | "picocolors": "^1.0.0"
53 | },
54 | "engines": {
55 | "node": ">=6.9.0"
56 | }
57 | },
58 | "node_modules/@babel/compat-data": {
59 | "version": "7.26.2",
60 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.26.2.tgz",
61 | "integrity": "sha512-Z0WgzSEa+aUcdiJuCIqgujCshpMWgUpgOxXotrYPSA53hA3qopNaqcJpyr0hVb1FeWdnqFA35/fUtXgBK8srQg==",
62 | "dev": true,
63 | "license": "MIT",
64 | "engines": {
65 | "node": ">=6.9.0"
66 | }
67 | },
68 | "node_modules/@babel/core": {
69 | "version": "7.26.0",
70 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.26.0.tgz",
71 | "integrity": "sha512-i1SLeK+DzNnQ3LL/CswPCa/E5u4lh1k6IAEphON8F+cXt0t9euTshDru0q7/IqMa1PMPz5RnHuHscF8/ZJsStg==",
72 | "dev": true,
73 | "license": "MIT",
74 | "dependencies": {
75 | "@ampproject/remapping": "^2.2.0",
76 | "@babel/code-frame": "^7.26.0",
77 | "@babel/generator": "^7.26.0",
78 | "@babel/helper-compilation-targets": "^7.25.9",
79 | "@babel/helper-module-transforms": "^7.26.0",
80 | "@babel/helpers": "^7.26.0",
81 | "@babel/parser": "^7.26.0",
82 | "@babel/template": "^7.25.9",
83 | "@babel/traverse": "^7.25.9",
84 | "@babel/types": "^7.26.0",
85 | "convert-source-map": "^2.0.0",
86 | "debug": "^4.1.0",
87 | "gensync": "^1.0.0-beta.2",
88 | "json5": "^2.2.3",
89 | "semver": "^6.3.1"
90 | },
91 | "engines": {
92 | "node": ">=6.9.0"
93 | },
94 | "funding": {
95 | "type": "opencollective",
96 | "url": "https://opencollective.com/babel"
97 | }
98 | },
99 | "node_modules/@babel/generator": {
100 | "version": "7.26.2",
101 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.2.tgz",
102 | "integrity": "sha512-zevQbhbau95nkoxSq3f/DC/SC+EEOUZd3DYqfSkMhY2/wfSeaHV1Ew4vk8e+x8lja31IbyuUa2uQ3JONqKbysw==",
103 | "dev": true,
104 | "license": "MIT",
105 | "dependencies": {
106 | "@babel/parser": "^7.26.2",
107 | "@babel/types": "^7.26.0",
108 | "@jridgewell/gen-mapping": "^0.3.5",
109 | "@jridgewell/trace-mapping": "^0.3.25",
110 | "jsesc": "^3.0.2"
111 | },
112 | "engines": {
113 | "node": ">=6.9.0"
114 | }
115 | },
116 | "node_modules/@babel/helper-compilation-targets": {
117 | "version": "7.25.9",
118 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.9.tgz",
119 | "integrity": "sha512-j9Db8Suy6yV/VHa4qzrj9yZfZxhLWQdVnRlXxmKLYlhWUVB1sB2G5sxuWYXk/whHD9iW76PmNzxZ4UCnTQTVEQ==",
120 | "dev": true,
121 | "license": "MIT",
122 | "dependencies": {
123 | "@babel/compat-data": "^7.25.9",
124 | "@babel/helper-validator-option": "^7.25.9",
125 | "browserslist": "^4.24.0",
126 | "lru-cache": "^5.1.1",
127 | "semver": "^6.3.1"
128 | },
129 | "engines": {
130 | "node": ">=6.9.0"
131 | }
132 | },
133 | "node_modules/@babel/helper-module-imports": {
134 | "version": "7.25.9",
135 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz",
136 | "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==",
137 | "dev": true,
138 | "license": "MIT",
139 | "dependencies": {
140 | "@babel/traverse": "^7.25.9",
141 | "@babel/types": "^7.25.9"
142 | },
143 | "engines": {
144 | "node": ">=6.9.0"
145 | }
146 | },
147 | "node_modules/@babel/helper-module-transforms": {
148 | "version": "7.26.0",
149 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz",
150 | "integrity": "sha512-xO+xu6B5K2czEnQye6BHA7DolFFmS3LB7stHZFaOLb1pAwO1HWLS8fXA+eh0A2yIvltPVmx3eNNDBJA2SLHXFw==",
151 | "dev": true,
152 | "license": "MIT",
153 | "dependencies": {
154 | "@babel/helper-module-imports": "^7.25.9",
155 | "@babel/helper-validator-identifier": "^7.25.9",
156 | "@babel/traverse": "^7.25.9"
157 | },
158 | "engines": {
159 | "node": ">=6.9.0"
160 | },
161 | "peerDependencies": {
162 | "@babel/core": "^7.0.0"
163 | }
164 | },
165 | "node_modules/@babel/helper-plugin-utils": {
166 | "version": "7.25.9",
167 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.25.9.tgz",
168 | "integrity": "sha512-kSMlyUVdWe25rEsRGviIgOWnoT/nfABVWlqt9N19/dIPWViAOW2s9wznP5tURbs/IDuNk4gPy3YdYRgH3uxhBw==",
169 | "dev": true,
170 | "license": "MIT",
171 | "engines": {
172 | "node": ">=6.9.0"
173 | }
174 | },
175 | "node_modules/@babel/helper-string-parser": {
176 | "version": "7.25.9",
177 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz",
178 | "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==",
179 | "dev": true,
180 | "license": "MIT",
181 | "engines": {
182 | "node": ">=6.9.0"
183 | }
184 | },
185 | "node_modules/@babel/helper-validator-identifier": {
186 | "version": "7.25.9",
187 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz",
188 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==",
189 | "dev": true,
190 | "license": "MIT",
191 | "engines": {
192 | "node": ">=6.9.0"
193 | }
194 | },
195 | "node_modules/@babel/helper-validator-option": {
196 | "version": "7.25.9",
197 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.9.tgz",
198 | "integrity": "sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw==",
199 | "dev": true,
200 | "license": "MIT",
201 | "engines": {
202 | "node": ">=6.9.0"
203 | }
204 | },
205 | "node_modules/@babel/helpers": {
206 | "version": "7.26.0",
207 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.26.0.tgz",
208 | "integrity": "sha512-tbhNuIxNcVb21pInl3ZSjksLCvgdZy9KwJ8brv993QtIVKJBBkYXz4q4ZbAv31GdnC+R90np23L5FbEBlthAEw==",
209 | "dev": true,
210 | "license": "MIT",
211 | "dependencies": {
212 | "@babel/template": "^7.25.9",
213 | "@babel/types": "^7.26.0"
214 | },
215 | "engines": {
216 | "node": ">=6.9.0"
217 | }
218 | },
219 | "node_modules/@babel/parser": {
220 | "version": "7.26.2",
221 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.2.tgz",
222 | "integrity": "sha512-DWMCZH9WA4Maitz2q21SRKHo9QXZxkDsbNZoVD62gusNtNBBqDg9i7uOhASfTfIGNzW+O+r7+jAlM8dwphcJKQ==",
223 | "dev": true,
224 | "license": "MIT",
225 | "dependencies": {
226 | "@babel/types": "^7.26.0"
227 | },
228 | "bin": {
229 | "parser": "bin/babel-parser.js"
230 | },
231 | "engines": {
232 | "node": ">=6.0.0"
233 | }
234 | },
235 | "node_modules/@babel/plugin-transform-react-jsx-self": {
236 | "version": "7.25.9",
237 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.25.9.tgz",
238 | "integrity": "sha512-y8quW6p0WHkEhmErnfe58r7x0A70uKphQm8Sp8cV7tjNQwK56sNVK0M73LK3WuYmsuyrftut4xAkjjgU0twaMg==",
239 | "dev": true,
240 | "license": "MIT",
241 | "dependencies": {
242 | "@babel/helper-plugin-utils": "^7.25.9"
243 | },
244 | "engines": {
245 | "node": ">=6.9.0"
246 | },
247 | "peerDependencies": {
248 | "@babel/core": "^7.0.0-0"
249 | }
250 | },
251 | "node_modules/@babel/plugin-transform-react-jsx-source": {
252 | "version": "7.25.9",
253 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.25.9.tgz",
254 | "integrity": "sha512-+iqjT8xmXhhYv4/uiYd8FNQsraMFZIfxVSqxxVSZP0WbbSAWvBXAul0m/zu+7Vv4O/3WtApy9pmaTMiumEZgfg==",
255 | "dev": true,
256 | "license": "MIT",
257 | "dependencies": {
258 | "@babel/helper-plugin-utils": "^7.25.9"
259 | },
260 | "engines": {
261 | "node": ">=6.9.0"
262 | },
263 | "peerDependencies": {
264 | "@babel/core": "^7.0.0-0"
265 | }
266 | },
267 | "node_modules/@babel/template": {
268 | "version": "7.25.9",
269 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.9.tgz",
270 | "integrity": "sha512-9DGttpmPvIxBb/2uwpVo3dqJ+O6RooAFOS+lB+xDqoE2PVCE8nfoHMdZLpfCQRLwvohzXISPZcgxt80xLfsuwg==",
271 | "dev": true,
272 | "license": "MIT",
273 | "dependencies": {
274 | "@babel/code-frame": "^7.25.9",
275 | "@babel/parser": "^7.25.9",
276 | "@babel/types": "^7.25.9"
277 | },
278 | "engines": {
279 | "node": ">=6.9.0"
280 | }
281 | },
282 | "node_modules/@babel/traverse": {
283 | "version": "7.25.9",
284 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.9.tgz",
285 | "integrity": "sha512-ZCuvfwOwlz/bawvAuvcj8rrithP2/N55Tzz342AkTvq4qaWbGfmCk/tKhNaV2cthijKrPAA8SRJV5WWe7IBMJw==",
286 | "dev": true,
287 | "license": "MIT",
288 | "dependencies": {
289 | "@babel/code-frame": "^7.25.9",
290 | "@babel/generator": "^7.25.9",
291 | "@babel/parser": "^7.25.9",
292 | "@babel/template": "^7.25.9",
293 | "@babel/types": "^7.25.9",
294 | "debug": "^4.3.1",
295 | "globals": "^11.1.0"
296 | },
297 | "engines": {
298 | "node": ">=6.9.0"
299 | }
300 | },
301 | "node_modules/@babel/traverse/node_modules/globals": {
302 | "version": "11.12.0",
303 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
304 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
305 | "dev": true,
306 | "license": "MIT",
307 | "engines": {
308 | "node": ">=4"
309 | }
310 | },
311 | "node_modules/@babel/types": {
312 | "version": "7.26.0",
313 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.0.tgz",
314 | "integrity": "sha512-Z/yiTPj+lDVnF7lWeKCIJzaIkI0vYO87dMpZ4bg4TDrFe4XXLFWL1TbXU27gBP3QccxV9mZICCrnjnYlJjXHOA==",
315 | "dev": true,
316 | "license": "MIT",
317 | "dependencies": {
318 | "@babel/helper-string-parser": "^7.25.9",
319 | "@babel/helper-validator-identifier": "^7.25.9"
320 | },
321 | "engines": {
322 | "node": ">=6.9.0"
323 | }
324 | },
325 | "node_modules/@esbuild/aix-ppc64": {
326 | "version": "0.21.5",
327 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz",
328 | "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==",
329 | "cpu": [
330 | "ppc64"
331 | ],
332 | "dev": true,
333 | "license": "MIT",
334 | "optional": true,
335 | "os": [
336 | "aix"
337 | ],
338 | "engines": {
339 | "node": ">=12"
340 | }
341 | },
342 | "node_modules/@esbuild/android-arm": {
343 | "version": "0.21.5",
344 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz",
345 | "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==",
346 | "cpu": [
347 | "arm"
348 | ],
349 | "dev": true,
350 | "license": "MIT",
351 | "optional": true,
352 | "os": [
353 | "android"
354 | ],
355 | "engines": {
356 | "node": ">=12"
357 | }
358 | },
359 | "node_modules/@esbuild/android-arm64": {
360 | "version": "0.21.5",
361 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz",
362 | "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==",
363 | "cpu": [
364 | "arm64"
365 | ],
366 | "dev": true,
367 | "license": "MIT",
368 | "optional": true,
369 | "os": [
370 | "android"
371 | ],
372 | "engines": {
373 | "node": ">=12"
374 | }
375 | },
376 | "node_modules/@esbuild/android-x64": {
377 | "version": "0.21.5",
378 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz",
379 | "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==",
380 | "cpu": [
381 | "x64"
382 | ],
383 | "dev": true,
384 | "license": "MIT",
385 | "optional": true,
386 | "os": [
387 | "android"
388 | ],
389 | "engines": {
390 | "node": ">=12"
391 | }
392 | },
393 | "node_modules/@esbuild/darwin-arm64": {
394 | "version": "0.21.5",
395 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz",
396 | "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==",
397 | "cpu": [
398 | "arm64"
399 | ],
400 | "dev": true,
401 | "license": "MIT",
402 | "optional": true,
403 | "os": [
404 | "darwin"
405 | ],
406 | "engines": {
407 | "node": ">=12"
408 | }
409 | },
410 | "node_modules/@esbuild/darwin-x64": {
411 | "version": "0.21.5",
412 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz",
413 | "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==",
414 | "cpu": [
415 | "x64"
416 | ],
417 | "dev": true,
418 | "license": "MIT",
419 | "optional": true,
420 | "os": [
421 | "darwin"
422 | ],
423 | "engines": {
424 | "node": ">=12"
425 | }
426 | },
427 | "node_modules/@esbuild/freebsd-arm64": {
428 | "version": "0.21.5",
429 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz",
430 | "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==",
431 | "cpu": [
432 | "arm64"
433 | ],
434 | "dev": true,
435 | "license": "MIT",
436 | "optional": true,
437 | "os": [
438 | "freebsd"
439 | ],
440 | "engines": {
441 | "node": ">=12"
442 | }
443 | },
444 | "node_modules/@esbuild/freebsd-x64": {
445 | "version": "0.21.5",
446 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz",
447 | "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==",
448 | "cpu": [
449 | "x64"
450 | ],
451 | "dev": true,
452 | "license": "MIT",
453 | "optional": true,
454 | "os": [
455 | "freebsd"
456 | ],
457 | "engines": {
458 | "node": ">=12"
459 | }
460 | },
461 | "node_modules/@esbuild/linux-arm": {
462 | "version": "0.21.5",
463 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz",
464 | "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==",
465 | "cpu": [
466 | "arm"
467 | ],
468 | "dev": true,
469 | "license": "MIT",
470 | "optional": true,
471 | "os": [
472 | "linux"
473 | ],
474 | "engines": {
475 | "node": ">=12"
476 | }
477 | },
478 | "node_modules/@esbuild/linux-arm64": {
479 | "version": "0.21.5",
480 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz",
481 | "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==",
482 | "cpu": [
483 | "arm64"
484 | ],
485 | "dev": true,
486 | "license": "MIT",
487 | "optional": true,
488 | "os": [
489 | "linux"
490 | ],
491 | "engines": {
492 | "node": ">=12"
493 | }
494 | },
495 | "node_modules/@esbuild/linux-ia32": {
496 | "version": "0.21.5",
497 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz",
498 | "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==",
499 | "cpu": [
500 | "ia32"
501 | ],
502 | "dev": true,
503 | "license": "MIT",
504 | "optional": true,
505 | "os": [
506 | "linux"
507 | ],
508 | "engines": {
509 | "node": ">=12"
510 | }
511 | },
512 | "node_modules/@esbuild/linux-loong64": {
513 | "version": "0.21.5",
514 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz",
515 | "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==",
516 | "cpu": [
517 | "loong64"
518 | ],
519 | "dev": true,
520 | "license": "MIT",
521 | "optional": true,
522 | "os": [
523 | "linux"
524 | ],
525 | "engines": {
526 | "node": ">=12"
527 | }
528 | },
529 | "node_modules/@esbuild/linux-mips64el": {
530 | "version": "0.21.5",
531 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz",
532 | "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==",
533 | "cpu": [
534 | "mips64el"
535 | ],
536 | "dev": true,
537 | "license": "MIT",
538 | "optional": true,
539 | "os": [
540 | "linux"
541 | ],
542 | "engines": {
543 | "node": ">=12"
544 | }
545 | },
546 | "node_modules/@esbuild/linux-ppc64": {
547 | "version": "0.21.5",
548 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz",
549 | "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==",
550 | "cpu": [
551 | "ppc64"
552 | ],
553 | "dev": true,
554 | "license": "MIT",
555 | "optional": true,
556 | "os": [
557 | "linux"
558 | ],
559 | "engines": {
560 | "node": ">=12"
561 | }
562 | },
563 | "node_modules/@esbuild/linux-riscv64": {
564 | "version": "0.21.5",
565 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz",
566 | "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==",
567 | "cpu": [
568 | "riscv64"
569 | ],
570 | "dev": true,
571 | "license": "MIT",
572 | "optional": true,
573 | "os": [
574 | "linux"
575 | ],
576 | "engines": {
577 | "node": ">=12"
578 | }
579 | },
580 | "node_modules/@esbuild/linux-s390x": {
581 | "version": "0.21.5",
582 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz",
583 | "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==",
584 | "cpu": [
585 | "s390x"
586 | ],
587 | "dev": true,
588 | "license": "MIT",
589 | "optional": true,
590 | "os": [
591 | "linux"
592 | ],
593 | "engines": {
594 | "node": ">=12"
595 | }
596 | },
597 | "node_modules/@esbuild/linux-x64": {
598 | "version": "0.21.5",
599 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz",
600 | "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==",
601 | "cpu": [
602 | "x64"
603 | ],
604 | "dev": true,
605 | "license": "MIT",
606 | "optional": true,
607 | "os": [
608 | "linux"
609 | ],
610 | "engines": {
611 | "node": ">=12"
612 | }
613 | },
614 | "node_modules/@esbuild/netbsd-x64": {
615 | "version": "0.21.5",
616 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz",
617 | "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==",
618 | "cpu": [
619 | "x64"
620 | ],
621 | "dev": true,
622 | "license": "MIT",
623 | "optional": true,
624 | "os": [
625 | "netbsd"
626 | ],
627 | "engines": {
628 | "node": ">=12"
629 | }
630 | },
631 | "node_modules/@esbuild/openbsd-x64": {
632 | "version": "0.21.5",
633 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz",
634 | "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==",
635 | "cpu": [
636 | "x64"
637 | ],
638 | "dev": true,
639 | "license": "MIT",
640 | "optional": true,
641 | "os": [
642 | "openbsd"
643 | ],
644 | "engines": {
645 | "node": ">=12"
646 | }
647 | },
648 | "node_modules/@esbuild/sunos-x64": {
649 | "version": "0.21.5",
650 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz",
651 | "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==",
652 | "cpu": [
653 | "x64"
654 | ],
655 | "dev": true,
656 | "license": "MIT",
657 | "optional": true,
658 | "os": [
659 | "sunos"
660 | ],
661 | "engines": {
662 | "node": ">=12"
663 | }
664 | },
665 | "node_modules/@esbuild/win32-arm64": {
666 | "version": "0.21.5",
667 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz",
668 | "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==",
669 | "cpu": [
670 | "arm64"
671 | ],
672 | "dev": true,
673 | "license": "MIT",
674 | "optional": true,
675 | "os": [
676 | "win32"
677 | ],
678 | "engines": {
679 | "node": ">=12"
680 | }
681 | },
682 | "node_modules/@esbuild/win32-ia32": {
683 | "version": "0.21.5",
684 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz",
685 | "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==",
686 | "cpu": [
687 | "ia32"
688 | ],
689 | "dev": true,
690 | "license": "MIT",
691 | "optional": true,
692 | "os": [
693 | "win32"
694 | ],
695 | "engines": {
696 | "node": ">=12"
697 | }
698 | },
699 | "node_modules/@esbuild/win32-x64": {
700 | "version": "0.21.5",
701 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz",
702 | "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==",
703 | "cpu": [
704 | "x64"
705 | ],
706 | "dev": true,
707 | "license": "MIT",
708 | "optional": true,
709 | "os": [
710 | "win32"
711 | ],
712 | "engines": {
713 | "node": ">=12"
714 | }
715 | },
716 | "node_modules/@eslint-community/eslint-utils": {
717 | "version": "4.4.1",
718 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz",
719 | "integrity": "sha512-s3O3waFUrMV8P/XaF/+ZTp1X9XBZW1a4B97ZnjQF2KYWaFD2A8KyFBsrsfSjEmjn3RGWAIuvlneuZm3CUK3jbA==",
720 | "dev": true,
721 | "license": "MIT",
722 | "dependencies": {
723 | "eslint-visitor-keys": "^3.4.3"
724 | },
725 | "engines": {
726 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
727 | },
728 | "funding": {
729 | "url": "https://opencollective.com/eslint"
730 | },
731 | "peerDependencies": {
732 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
733 | }
734 | },
735 | "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": {
736 | "version": "3.4.3",
737 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
738 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
739 | "dev": true,
740 | "license": "Apache-2.0",
741 | "engines": {
742 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
743 | },
744 | "funding": {
745 | "url": "https://opencollective.com/eslint"
746 | }
747 | },
748 | "node_modules/@eslint-community/regexpp": {
749 | "version": "4.12.1",
750 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz",
751 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==",
752 | "dev": true,
753 | "license": "MIT",
754 | "engines": {
755 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
756 | }
757 | },
758 | "node_modules/@eslint/config-array": {
759 | "version": "0.18.0",
760 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.18.0.tgz",
761 | "integrity": "sha512-fTxvnS1sRMu3+JjXwJG0j/i4RT9u4qJ+lqS/yCGap4lH4zZGzQ7tu+xZqQmcMZq5OBZDL4QRxQzRjkWcGt8IVw==",
762 | "dev": true,
763 | "license": "Apache-2.0",
764 | "dependencies": {
765 | "@eslint/object-schema": "^2.1.4",
766 | "debug": "^4.3.1",
767 | "minimatch": "^3.1.2"
768 | },
769 | "engines": {
770 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
771 | }
772 | },
773 | "node_modules/@eslint/core": {
774 | "version": "0.7.0",
775 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.7.0.tgz",
776 | "integrity": "sha512-xp5Jirz5DyPYlPiKat8jaq0EmYvDXKKpzTbxXMpT9eqlRJkRKIz9AGMdlvYjih+im+QlhWrpvVjl8IPC/lHlUw==",
777 | "dev": true,
778 | "license": "Apache-2.0",
779 | "engines": {
780 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
781 | }
782 | },
783 | "node_modules/@eslint/eslintrc": {
784 | "version": "3.1.0",
785 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz",
786 | "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==",
787 | "dev": true,
788 | "license": "MIT",
789 | "dependencies": {
790 | "ajv": "^6.12.4",
791 | "debug": "^4.3.2",
792 | "espree": "^10.0.1",
793 | "globals": "^14.0.0",
794 | "ignore": "^5.2.0",
795 | "import-fresh": "^3.2.1",
796 | "js-yaml": "^4.1.0",
797 | "minimatch": "^3.1.2",
798 | "strip-json-comments": "^3.1.1"
799 | },
800 | "engines": {
801 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
802 | },
803 | "funding": {
804 | "url": "https://opencollective.com/eslint"
805 | }
806 | },
807 | "node_modules/@eslint/eslintrc/node_modules/globals": {
808 | "version": "14.0.0",
809 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz",
810 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==",
811 | "dev": true,
812 | "license": "MIT",
813 | "engines": {
814 | "node": ">=18"
815 | },
816 | "funding": {
817 | "url": "https://github.com/sponsors/sindresorhus"
818 | }
819 | },
820 | "node_modules/@eslint/js": {
821 | "version": "9.13.0",
822 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.13.0.tgz",
823 | "integrity": "sha512-IFLyoY4d72Z5y/6o/BazFBezupzI/taV8sGumxTAVw3lXG9A6md1Dc34T9s1FoD/an9pJH8RHbAxsaEbBed9lA==",
824 | "dev": true,
825 | "license": "MIT",
826 | "engines": {
827 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
828 | }
829 | },
830 | "node_modules/@eslint/object-schema": {
831 | "version": "2.1.4",
832 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz",
833 | "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==",
834 | "dev": true,
835 | "license": "Apache-2.0",
836 | "engines": {
837 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
838 | }
839 | },
840 | "node_modules/@eslint/plugin-kit": {
841 | "version": "0.2.2",
842 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.2.tgz",
843 | "integrity": "sha512-CXtq5nR4Su+2I47WPOlWud98Y5Lv8Kyxp2ukhgFx/eW6Blm18VXJO5WuQylPugRo8nbluoi6GvvxBLqHcvqUUw==",
844 | "dev": true,
845 | "license": "Apache-2.0",
846 | "dependencies": {
847 | "levn": "^0.4.1"
848 | },
849 | "engines": {
850 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
851 | }
852 | },
853 | "node_modules/@humanfs/core": {
854 | "version": "0.19.1",
855 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
856 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
857 | "dev": true,
858 | "license": "Apache-2.0",
859 | "engines": {
860 | "node": ">=18.18.0"
861 | }
862 | },
863 | "node_modules/@humanfs/node": {
864 | "version": "0.16.6",
865 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz",
866 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==",
867 | "dev": true,
868 | "license": "Apache-2.0",
869 | "dependencies": {
870 | "@humanfs/core": "^0.19.1",
871 | "@humanwhocodes/retry": "^0.3.0"
872 | },
873 | "engines": {
874 | "node": ">=18.18.0"
875 | }
876 | },
877 | "node_modules/@humanwhocodes/module-importer": {
878 | "version": "1.0.1",
879 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
880 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
881 | "dev": true,
882 | "license": "Apache-2.0",
883 | "engines": {
884 | "node": ">=12.22"
885 | },
886 | "funding": {
887 | "type": "github",
888 | "url": "https://github.com/sponsors/nzakas"
889 | }
890 | },
891 | "node_modules/@humanwhocodes/retry": {
892 | "version": "0.3.1",
893 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz",
894 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==",
895 | "dev": true,
896 | "license": "Apache-2.0",
897 | "engines": {
898 | "node": ">=18.18"
899 | },
900 | "funding": {
901 | "type": "github",
902 | "url": "https://github.com/sponsors/nzakas"
903 | }
904 | },
905 | "node_modules/@jridgewell/gen-mapping": {
906 | "version": "0.3.5",
907 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz",
908 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==",
909 | "dev": true,
910 | "license": "MIT",
911 | "dependencies": {
912 | "@jridgewell/set-array": "^1.2.1",
913 | "@jridgewell/sourcemap-codec": "^1.4.10",
914 | "@jridgewell/trace-mapping": "^0.3.24"
915 | },
916 | "engines": {
917 | "node": ">=6.0.0"
918 | }
919 | },
920 | "node_modules/@jridgewell/resolve-uri": {
921 | "version": "3.1.2",
922 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz",
923 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==",
924 | "dev": true,
925 | "license": "MIT",
926 | "engines": {
927 | "node": ">=6.0.0"
928 | }
929 | },
930 | "node_modules/@jridgewell/set-array": {
931 | "version": "1.2.1",
932 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz",
933 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==",
934 | "dev": true,
935 | "license": "MIT",
936 | "engines": {
937 | "node": ">=6.0.0"
938 | }
939 | },
940 | "node_modules/@jridgewell/sourcemap-codec": {
941 | "version": "1.5.0",
942 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
943 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==",
944 | "dev": true,
945 | "license": "MIT"
946 | },
947 | "node_modules/@jridgewell/trace-mapping": {
948 | "version": "0.3.25",
949 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz",
950 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==",
951 | "dev": true,
952 | "license": "MIT",
953 | "dependencies": {
954 | "@jridgewell/resolve-uri": "^3.1.0",
955 | "@jridgewell/sourcemap-codec": "^1.4.14"
956 | }
957 | },
958 | "node_modules/@remix-run/router": {
959 | "version": "1.20.0",
960 | "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.20.0.tgz",
961 | "integrity": "sha512-mUnk8rPJBI9loFDZ+YzPGdeniYK+FTmRD1TMCz7ev2SNIozyKKpnGgsxO34u6Z4z/t0ITuu7voi/AshfsGsgFg==",
962 | "license": "MIT",
963 | "engines": {
964 | "node": ">=14.0.0"
965 | }
966 | },
967 | "node_modules/@rollup/rollup-android-arm-eabi": {
968 | "version": "4.24.3",
969 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.3.tgz",
970 | "integrity": "sha512-ufb2CH2KfBWPJok95frEZZ82LtDl0A6QKTa8MoM+cWwDZvVGl5/jNb79pIhRvAalUu+7LD91VYR0nwRD799HkQ==",
971 | "cpu": [
972 | "arm"
973 | ],
974 | "dev": true,
975 | "license": "MIT",
976 | "optional": true,
977 | "os": [
978 | "android"
979 | ]
980 | },
981 | "node_modules/@rollup/rollup-android-arm64": {
982 | "version": "4.24.3",
983 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.3.tgz",
984 | "integrity": "sha512-iAHpft/eQk9vkWIV5t22V77d90CRofgR2006UiCjHcHJFVI1E0oBkQIAbz+pLtthFw3hWEmVB4ilxGyBf48i2Q==",
985 | "cpu": [
986 | "arm64"
987 | ],
988 | "dev": true,
989 | "license": "MIT",
990 | "optional": true,
991 | "os": [
992 | "android"
993 | ]
994 | },
995 | "node_modules/@rollup/rollup-darwin-arm64": {
996 | "version": "4.24.3",
997 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.3.tgz",
998 | "integrity": "sha512-QPW2YmkWLlvqmOa2OwrfqLJqkHm7kJCIMq9kOz40Zo9Ipi40kf9ONG5Sz76zszrmIZZ4hgRIkez69YnTHgEz1w==",
999 | "cpu": [
1000 | "arm64"
1001 | ],
1002 | "dev": true,
1003 | "license": "MIT",
1004 | "optional": true,
1005 | "os": [
1006 | "darwin"
1007 | ]
1008 | },
1009 | "node_modules/@rollup/rollup-darwin-x64": {
1010 | "version": "4.24.3",
1011 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.3.tgz",
1012 | "integrity": "sha512-KO0pN5x3+uZm1ZXeIfDqwcvnQ9UEGN8JX5ufhmgH5Lz4ujjZMAnxQygZAVGemFWn+ZZC0FQopruV4lqmGMshow==",
1013 | "cpu": [
1014 | "x64"
1015 | ],
1016 | "dev": true,
1017 | "license": "MIT",
1018 | "optional": true,
1019 | "os": [
1020 | "darwin"
1021 | ]
1022 | },
1023 | "node_modules/@rollup/rollup-freebsd-arm64": {
1024 | "version": "4.24.3",
1025 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.24.3.tgz",
1026 | "integrity": "sha512-CsC+ZdIiZCZbBI+aRlWpYJMSWvVssPuWqrDy/zi9YfnatKKSLFCe6fjna1grHuo/nVaHG+kiglpRhyBQYRTK4A==",
1027 | "cpu": [
1028 | "arm64"
1029 | ],
1030 | "dev": true,
1031 | "license": "MIT",
1032 | "optional": true,
1033 | "os": [
1034 | "freebsd"
1035 | ]
1036 | },
1037 | "node_modules/@rollup/rollup-freebsd-x64": {
1038 | "version": "4.24.3",
1039 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.24.3.tgz",
1040 | "integrity": "sha512-F0nqiLThcfKvRQhZEzMIXOQG4EeX61im61VYL1jo4eBxv4aZRmpin6crnBJQ/nWnCsjH5F6J3W6Stdm0mBNqBg==",
1041 | "cpu": [
1042 | "x64"
1043 | ],
1044 | "dev": true,
1045 | "license": "MIT",
1046 | "optional": true,
1047 | "os": [
1048 | "freebsd"
1049 | ]
1050 | },
1051 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
1052 | "version": "4.24.3",
1053 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.3.tgz",
1054 | "integrity": "sha512-KRSFHyE/RdxQ1CSeOIBVIAxStFC/hnBgVcaiCkQaVC+EYDtTe4X7z5tBkFyRoBgUGtB6Xg6t9t2kulnX6wJc6A==",
1055 | "cpu": [
1056 | "arm"
1057 | ],
1058 | "dev": true,
1059 | "license": "MIT",
1060 | "optional": true,
1061 | "os": [
1062 | "linux"
1063 | ]
1064 | },
1065 | "node_modules/@rollup/rollup-linux-arm-musleabihf": {
1066 | "version": "4.24.3",
1067 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.3.tgz",
1068 | "integrity": "sha512-h6Q8MT+e05zP5BxEKz0vi0DhthLdrNEnspdLzkoFqGwnmOzakEHSlXfVyA4HJ322QtFy7biUAVFPvIDEDQa6rw==",
1069 | "cpu": [
1070 | "arm"
1071 | ],
1072 | "dev": true,
1073 | "license": "MIT",
1074 | "optional": true,
1075 | "os": [
1076 | "linux"
1077 | ]
1078 | },
1079 | "node_modules/@rollup/rollup-linux-arm64-gnu": {
1080 | "version": "4.24.3",
1081 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.3.tgz",
1082 | "integrity": "sha512-fKElSyXhXIJ9pqiYRqisfirIo2Z5pTTve5K438URf08fsypXrEkVmShkSfM8GJ1aUyvjakT+fn2W7Czlpd/0FQ==",
1083 | "cpu": [
1084 | "arm64"
1085 | ],
1086 | "dev": true,
1087 | "license": "MIT",
1088 | "optional": true,
1089 | "os": [
1090 | "linux"
1091 | ]
1092 | },
1093 | "node_modules/@rollup/rollup-linux-arm64-musl": {
1094 | "version": "4.24.3",
1095 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.3.tgz",
1096 | "integrity": "sha512-YlddZSUk8G0px9/+V9PVilVDC6ydMz7WquxozToozSnfFK6wa6ne1ATUjUvjin09jp34p84milxlY5ikueoenw==",
1097 | "cpu": [
1098 | "arm64"
1099 | ],
1100 | "dev": true,
1101 | "license": "MIT",
1102 | "optional": true,
1103 | "os": [
1104 | "linux"
1105 | ]
1106 | },
1107 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": {
1108 | "version": "4.24.3",
1109 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.3.tgz",
1110 | "integrity": "sha512-yNaWw+GAO8JjVx3s3cMeG5Esz1cKVzz8PkTJSfYzE5u7A+NvGmbVFEHP+BikTIyYWuz0+DX9kaA3pH9Sqxp69g==",
1111 | "cpu": [
1112 | "ppc64"
1113 | ],
1114 | "dev": true,
1115 | "license": "MIT",
1116 | "optional": true,
1117 | "os": [
1118 | "linux"
1119 | ]
1120 | },
1121 | "node_modules/@rollup/rollup-linux-riscv64-gnu": {
1122 | "version": "4.24.3",
1123 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.3.tgz",
1124 | "integrity": "sha512-lWKNQfsbpv14ZCtM/HkjCTm4oWTKTfxPmr7iPfp3AHSqyoTz5AgLemYkWLwOBWc+XxBbrU9SCokZP0WlBZM9lA==",
1125 | "cpu": [
1126 | "riscv64"
1127 | ],
1128 | "dev": true,
1129 | "license": "MIT",
1130 | "optional": true,
1131 | "os": [
1132 | "linux"
1133 | ]
1134 | },
1135 | "node_modules/@rollup/rollup-linux-s390x-gnu": {
1136 | "version": "4.24.3",
1137 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.3.tgz",
1138 | "integrity": "sha512-HoojGXTC2CgCcq0Woc/dn12wQUlkNyfH0I1ABK4Ni9YXyFQa86Fkt2Q0nqgLfbhkyfQ6003i3qQk9pLh/SpAYw==",
1139 | "cpu": [
1140 | "s390x"
1141 | ],
1142 | "dev": true,
1143 | "license": "MIT",
1144 | "optional": true,
1145 | "os": [
1146 | "linux"
1147 | ]
1148 | },
1149 | "node_modules/@rollup/rollup-linux-x64-gnu": {
1150 | "version": "4.24.3",
1151 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.3.tgz",
1152 | "integrity": "sha512-mnEOh4iE4USSccBOtcrjF5nj+5/zm6NcNhbSEfR3Ot0pxBwvEn5QVUXcuOwwPkapDtGZ6pT02xLoPaNv06w7KQ==",
1153 | "cpu": [
1154 | "x64"
1155 | ],
1156 | "dev": true,
1157 | "license": "MIT",
1158 | "optional": true,
1159 | "os": [
1160 | "linux"
1161 | ]
1162 | },
1163 | "node_modules/@rollup/rollup-linux-x64-musl": {
1164 | "version": "4.24.3",
1165 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.3.tgz",
1166 | "integrity": "sha512-rMTzawBPimBQkG9NKpNHvquIUTQPzrnPxPbCY1Xt+mFkW7pshvyIS5kYgcf74goxXOQk0CP3EoOC1zcEezKXhw==",
1167 | "cpu": [
1168 | "x64"
1169 | ],
1170 | "dev": true,
1171 | "license": "MIT",
1172 | "optional": true,
1173 | "os": [
1174 | "linux"
1175 | ]
1176 | },
1177 | "node_modules/@rollup/rollup-win32-arm64-msvc": {
1178 | "version": "4.24.3",
1179 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.3.tgz",
1180 | "integrity": "sha512-2lg1CE305xNvnH3SyiKwPVsTVLCg4TmNCF1z7PSHX2uZY2VbUpdkgAllVoISD7JO7zu+YynpWNSKAtOrX3AiuA==",
1181 | "cpu": [
1182 | "arm64"
1183 | ],
1184 | "dev": true,
1185 | "license": "MIT",
1186 | "optional": true,
1187 | "os": [
1188 | "win32"
1189 | ]
1190 | },
1191 | "node_modules/@rollup/rollup-win32-ia32-msvc": {
1192 | "version": "4.24.3",
1193 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.3.tgz",
1194 | "integrity": "sha512-9SjYp1sPyxJsPWuhOCX6F4jUMXGbVVd5obVpoVEi8ClZqo52ViZewA6eFz85y8ezuOA+uJMP5A5zo6Oz4S5rVQ==",
1195 | "cpu": [
1196 | "ia32"
1197 | ],
1198 | "dev": true,
1199 | "license": "MIT",
1200 | "optional": true,
1201 | "os": [
1202 | "win32"
1203 | ]
1204 | },
1205 | "node_modules/@rollup/rollup-win32-x64-msvc": {
1206 | "version": "4.24.3",
1207 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.3.tgz",
1208 | "integrity": "sha512-HGZgRFFYrMrP3TJlq58nR1xy8zHKId25vhmm5S9jETEfDf6xybPxsavFTJaufe2zgOGYJBskGlj49CwtEuFhWQ==",
1209 | "cpu": [
1210 | "x64"
1211 | ],
1212 | "dev": true,
1213 | "license": "MIT",
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 | "license": "MIT",
1225 | "dependencies": {
1226 | "@babel/parser": "^7.20.7",
1227 | "@babel/types": "^7.20.7",
1228 | "@types/babel__generator": "*",
1229 | "@types/babel__template": "*",
1230 | "@types/babel__traverse": "*"
1231 | }
1232 | },
1233 | "node_modules/@types/babel__generator": {
1234 | "version": "7.6.8",
1235 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz",
1236 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==",
1237 | "dev": true,
1238 | "license": "MIT",
1239 | "dependencies": {
1240 | "@babel/types": "^7.0.0"
1241 | }
1242 | },
1243 | "node_modules/@types/babel__template": {
1244 | "version": "7.4.4",
1245 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz",
1246 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==",
1247 | "dev": true,
1248 | "license": "MIT",
1249 | "dependencies": {
1250 | "@babel/parser": "^7.1.0",
1251 | "@babel/types": "^7.0.0"
1252 | }
1253 | },
1254 | "node_modules/@types/babel__traverse": {
1255 | "version": "7.20.6",
1256 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz",
1257 | "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==",
1258 | "dev": true,
1259 | "license": "MIT",
1260 | "dependencies": {
1261 | "@babel/types": "^7.20.7"
1262 | }
1263 | },
1264 | "node_modules/@types/estree": {
1265 | "version": "1.0.6",
1266 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz",
1267 | "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==",
1268 | "dev": true,
1269 | "license": "MIT"
1270 | },
1271 | "node_modules/@types/json-schema": {
1272 | "version": "7.0.15",
1273 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
1274 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
1275 | "dev": true,
1276 | "license": "MIT"
1277 | },
1278 | "node_modules/@types/prop-types": {
1279 | "version": "15.7.13",
1280 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.13.tgz",
1281 | "integrity": "sha512-hCZTSvwbzWGvhqxp/RqVqwU999pBf2vp7hzIjiYOsl8wqOmUxkQ6ddw1cV3l8811+kdUFus/q4d1Y3E3SyEifA==",
1282 | "dev": true,
1283 | "license": "MIT"
1284 | },
1285 | "node_modules/@types/react": {
1286 | "version": "18.3.12",
1287 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.12.tgz",
1288 | "integrity": "sha512-D2wOSq/d6Agt28q7rSI3jhU7G6aiuzljDGZ2hTZHIkrTLUI+AF3WMeKkEZ9nN2fkBAlcktT6vcZjDFiIhMYEQw==",
1289 | "dev": true,
1290 | "license": "MIT",
1291 | "dependencies": {
1292 | "@types/prop-types": "*",
1293 | "csstype": "^3.0.2"
1294 | }
1295 | },
1296 | "node_modules/@types/react-dom": {
1297 | "version": "18.3.1",
1298 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.1.tgz",
1299 | "integrity": "sha512-qW1Mfv8taImTthu4KoXgDfLuk4bydU6Q/TkADnDWWHwi4NX4BR+LWfTp2sVmTqRrsHvyDDTelgelxJ+SsejKKQ==",
1300 | "dev": true,
1301 | "license": "MIT",
1302 | "dependencies": {
1303 | "@types/react": "*"
1304 | }
1305 | },
1306 | "node_modules/@vitejs/plugin-react": {
1307 | "version": "4.3.3",
1308 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.3.3.tgz",
1309 | "integrity": "sha512-NooDe9GpHGqNns1i8XDERg0Vsg5SSYRhRxxyTGogUdkdNt47jal+fbuYi+Yfq6pzRCKXyoPcWisfxE6RIM3GKA==",
1310 | "dev": true,
1311 | "license": "MIT",
1312 | "dependencies": {
1313 | "@babel/core": "^7.25.2",
1314 | "@babel/plugin-transform-react-jsx-self": "^7.24.7",
1315 | "@babel/plugin-transform-react-jsx-source": "^7.24.7",
1316 | "@types/babel__core": "^7.20.5",
1317 | "react-refresh": "^0.14.2"
1318 | },
1319 | "engines": {
1320 | "node": "^14.18.0 || >=16.0.0"
1321 | },
1322 | "peerDependencies": {
1323 | "vite": "^4.2.0 || ^5.0.0"
1324 | }
1325 | },
1326 | "node_modules/acorn": {
1327 | "version": "8.14.0",
1328 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz",
1329 | "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==",
1330 | "dev": true,
1331 | "license": "MIT",
1332 | "bin": {
1333 | "acorn": "bin/acorn"
1334 | },
1335 | "engines": {
1336 | "node": ">=0.4.0"
1337 | }
1338 | },
1339 | "node_modules/acorn-jsx": {
1340 | "version": "5.3.2",
1341 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
1342 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
1343 | "dev": true,
1344 | "license": "MIT",
1345 | "peerDependencies": {
1346 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
1347 | }
1348 | },
1349 | "node_modules/ajv": {
1350 | "version": "6.12.6",
1351 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
1352 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
1353 | "dev": true,
1354 | "license": "MIT",
1355 | "dependencies": {
1356 | "fast-deep-equal": "^3.1.1",
1357 | "fast-json-stable-stringify": "^2.0.0",
1358 | "json-schema-traverse": "^0.4.1",
1359 | "uri-js": "^4.2.2"
1360 | },
1361 | "funding": {
1362 | "type": "github",
1363 | "url": "https://github.com/sponsors/epoberezkin"
1364 | }
1365 | },
1366 | "node_modules/ansi-styles": {
1367 | "version": "4.3.0",
1368 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
1369 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
1370 | "dev": true,
1371 | "license": "MIT",
1372 | "dependencies": {
1373 | "color-convert": "^2.0.1"
1374 | },
1375 | "engines": {
1376 | "node": ">=8"
1377 | },
1378 | "funding": {
1379 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1380 | }
1381 | },
1382 | "node_modules/argparse": {
1383 | "version": "2.0.1",
1384 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
1385 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
1386 | "dev": true,
1387 | "license": "Python-2.0"
1388 | },
1389 | "node_modules/array-buffer-byte-length": {
1390 | "version": "1.0.1",
1391 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz",
1392 | "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==",
1393 | "dev": true,
1394 | "license": "MIT",
1395 | "dependencies": {
1396 | "call-bind": "^1.0.5",
1397 | "is-array-buffer": "^3.0.4"
1398 | },
1399 | "engines": {
1400 | "node": ">= 0.4"
1401 | },
1402 | "funding": {
1403 | "url": "https://github.com/sponsors/ljharb"
1404 | }
1405 | },
1406 | "node_modules/array-includes": {
1407 | "version": "3.1.8",
1408 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz",
1409 | "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==",
1410 | "dev": true,
1411 | "license": "MIT",
1412 | "dependencies": {
1413 | "call-bind": "^1.0.7",
1414 | "define-properties": "^1.2.1",
1415 | "es-abstract": "^1.23.2",
1416 | "es-object-atoms": "^1.0.0",
1417 | "get-intrinsic": "^1.2.4",
1418 | "is-string": "^1.0.7"
1419 | },
1420 | "engines": {
1421 | "node": ">= 0.4"
1422 | },
1423 | "funding": {
1424 | "url": "https://github.com/sponsors/ljharb"
1425 | }
1426 | },
1427 | "node_modules/array.prototype.findlast": {
1428 | "version": "1.2.5",
1429 | "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz",
1430 | "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==",
1431 | "dev": true,
1432 | "license": "MIT",
1433 | "dependencies": {
1434 | "call-bind": "^1.0.7",
1435 | "define-properties": "^1.2.1",
1436 | "es-abstract": "^1.23.2",
1437 | "es-errors": "^1.3.0",
1438 | "es-object-atoms": "^1.0.0",
1439 | "es-shim-unscopables": "^1.0.2"
1440 | },
1441 | "engines": {
1442 | "node": ">= 0.4"
1443 | },
1444 | "funding": {
1445 | "url": "https://github.com/sponsors/ljharb"
1446 | }
1447 | },
1448 | "node_modules/array.prototype.flat": {
1449 | "version": "1.3.2",
1450 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz",
1451 | "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==",
1452 | "dev": true,
1453 | "license": "MIT",
1454 | "dependencies": {
1455 | "call-bind": "^1.0.2",
1456 | "define-properties": "^1.2.0",
1457 | "es-abstract": "^1.22.1",
1458 | "es-shim-unscopables": "^1.0.0"
1459 | },
1460 | "engines": {
1461 | "node": ">= 0.4"
1462 | },
1463 | "funding": {
1464 | "url": "https://github.com/sponsors/ljharb"
1465 | }
1466 | },
1467 | "node_modules/array.prototype.flatmap": {
1468 | "version": "1.3.2",
1469 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz",
1470 | "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==",
1471 | "dev": true,
1472 | "license": "MIT",
1473 | "dependencies": {
1474 | "call-bind": "^1.0.2",
1475 | "define-properties": "^1.2.0",
1476 | "es-abstract": "^1.22.1",
1477 | "es-shim-unscopables": "^1.0.0"
1478 | },
1479 | "engines": {
1480 | "node": ">= 0.4"
1481 | },
1482 | "funding": {
1483 | "url": "https://github.com/sponsors/ljharb"
1484 | }
1485 | },
1486 | "node_modules/array.prototype.tosorted": {
1487 | "version": "1.1.4",
1488 | "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz",
1489 | "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==",
1490 | "dev": true,
1491 | "license": "MIT",
1492 | "dependencies": {
1493 | "call-bind": "^1.0.7",
1494 | "define-properties": "^1.2.1",
1495 | "es-abstract": "^1.23.3",
1496 | "es-errors": "^1.3.0",
1497 | "es-shim-unscopables": "^1.0.2"
1498 | },
1499 | "engines": {
1500 | "node": ">= 0.4"
1501 | }
1502 | },
1503 | "node_modules/arraybuffer.prototype.slice": {
1504 | "version": "1.0.3",
1505 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz",
1506 | "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==",
1507 | "dev": true,
1508 | "license": "MIT",
1509 | "dependencies": {
1510 | "array-buffer-byte-length": "^1.0.1",
1511 | "call-bind": "^1.0.5",
1512 | "define-properties": "^1.2.1",
1513 | "es-abstract": "^1.22.3",
1514 | "es-errors": "^1.2.1",
1515 | "get-intrinsic": "^1.2.3",
1516 | "is-array-buffer": "^3.0.4",
1517 | "is-shared-array-buffer": "^1.0.2"
1518 | },
1519 | "engines": {
1520 | "node": ">= 0.4"
1521 | },
1522 | "funding": {
1523 | "url": "https://github.com/sponsors/ljharb"
1524 | }
1525 | },
1526 | "node_modules/asynckit": {
1527 | "version": "0.4.0",
1528 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
1529 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==",
1530 | "license": "MIT"
1531 | },
1532 | "node_modules/available-typed-arrays": {
1533 | "version": "1.0.7",
1534 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz",
1535 | "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==",
1536 | "dev": true,
1537 | "license": "MIT",
1538 | "dependencies": {
1539 | "possible-typed-array-names": "^1.0.0"
1540 | },
1541 | "engines": {
1542 | "node": ">= 0.4"
1543 | },
1544 | "funding": {
1545 | "url": "https://github.com/sponsors/ljharb"
1546 | }
1547 | },
1548 | "node_modules/axios": {
1549 | "version": "1.7.7",
1550 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.7.tgz",
1551 | "integrity": "sha512-S4kL7XrjgBmvdGut0sN3yJxqYzrDOnivkBiN0OFs6hLiUam3UPvswUo0kqGyhqUZGEOytHyumEdXsAkgCOUf3Q==",
1552 | "license": "MIT",
1553 | "dependencies": {
1554 | "follow-redirects": "^1.15.6",
1555 | "form-data": "^4.0.0",
1556 | "proxy-from-env": "^1.1.0"
1557 | }
1558 | },
1559 | "node_modules/balanced-match": {
1560 | "version": "1.0.2",
1561 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
1562 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
1563 | "dev": true,
1564 | "license": "MIT"
1565 | },
1566 | "node_modules/brace-expansion": {
1567 | "version": "1.1.11",
1568 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
1569 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
1570 | "dev": true,
1571 | "license": "MIT",
1572 | "dependencies": {
1573 | "balanced-match": "^1.0.0",
1574 | "concat-map": "0.0.1"
1575 | }
1576 | },
1577 | "node_modules/browserslist": {
1578 | "version": "4.24.2",
1579 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.2.tgz",
1580 | "integrity": "sha512-ZIc+Q62revdMcqC6aChtW4jz3My3klmCO1fEmINZY/8J3EpBg5/A/D0AKmBveUh6pgoeycoMkVMko84tuYS+Gg==",
1581 | "dev": true,
1582 | "funding": [
1583 | {
1584 | "type": "opencollective",
1585 | "url": "https://opencollective.com/browserslist"
1586 | },
1587 | {
1588 | "type": "tidelift",
1589 | "url": "https://tidelift.com/funding/github/npm/browserslist"
1590 | },
1591 | {
1592 | "type": "github",
1593 | "url": "https://github.com/sponsors/ai"
1594 | }
1595 | ],
1596 | "license": "MIT",
1597 | "dependencies": {
1598 | "caniuse-lite": "^1.0.30001669",
1599 | "electron-to-chromium": "^1.5.41",
1600 | "node-releases": "^2.0.18",
1601 | "update-browserslist-db": "^1.1.1"
1602 | },
1603 | "bin": {
1604 | "browserslist": "cli.js"
1605 | },
1606 | "engines": {
1607 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
1608 | }
1609 | },
1610 | "node_modules/call-bind": {
1611 | "version": "1.0.7",
1612 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz",
1613 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==",
1614 | "dev": true,
1615 | "license": "MIT",
1616 | "dependencies": {
1617 | "es-define-property": "^1.0.0",
1618 | "es-errors": "^1.3.0",
1619 | "function-bind": "^1.1.2",
1620 | "get-intrinsic": "^1.2.4",
1621 | "set-function-length": "^1.2.1"
1622 | },
1623 | "engines": {
1624 | "node": ">= 0.4"
1625 | },
1626 | "funding": {
1627 | "url": "https://github.com/sponsors/ljharb"
1628 | }
1629 | },
1630 | "node_modules/callsites": {
1631 | "version": "3.1.0",
1632 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
1633 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
1634 | "dev": true,
1635 | "license": "MIT",
1636 | "engines": {
1637 | "node": ">=6"
1638 | }
1639 | },
1640 | "node_modules/caniuse-lite": {
1641 | "version": "1.0.30001676",
1642 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001676.tgz",
1643 | "integrity": "sha512-Qz6zwGCiPghQXGJvgQAem79esjitvJ+CxSbSQkW9H/UX5hg8XM88d4lp2W+MEQ81j+Hip58Il+jGVdazk1z9cw==",
1644 | "dev": true,
1645 | "funding": [
1646 | {
1647 | "type": "opencollective",
1648 | "url": "https://opencollective.com/browserslist"
1649 | },
1650 | {
1651 | "type": "tidelift",
1652 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
1653 | },
1654 | {
1655 | "type": "github",
1656 | "url": "https://github.com/sponsors/ai"
1657 | }
1658 | ],
1659 | "license": "CC-BY-4.0"
1660 | },
1661 | "node_modules/chalk": {
1662 | "version": "4.1.2",
1663 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
1664 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
1665 | "dev": true,
1666 | "license": "MIT",
1667 | "dependencies": {
1668 | "ansi-styles": "^4.1.0",
1669 | "supports-color": "^7.1.0"
1670 | },
1671 | "engines": {
1672 | "node": ">=10"
1673 | },
1674 | "funding": {
1675 | "url": "https://github.com/chalk/chalk?sponsor=1"
1676 | }
1677 | },
1678 | "node_modules/color-convert": {
1679 | "version": "2.0.1",
1680 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
1681 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
1682 | "dev": true,
1683 | "license": "MIT",
1684 | "dependencies": {
1685 | "color-name": "~1.1.4"
1686 | },
1687 | "engines": {
1688 | "node": ">=7.0.0"
1689 | }
1690 | },
1691 | "node_modules/color-name": {
1692 | "version": "1.1.4",
1693 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
1694 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
1695 | "dev": true,
1696 | "license": "MIT"
1697 | },
1698 | "node_modules/combined-stream": {
1699 | "version": "1.0.8",
1700 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
1701 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
1702 | "license": "MIT",
1703 | "dependencies": {
1704 | "delayed-stream": "~1.0.0"
1705 | },
1706 | "engines": {
1707 | "node": ">= 0.8"
1708 | }
1709 | },
1710 | "node_modules/concat-map": {
1711 | "version": "0.0.1",
1712 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
1713 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
1714 | "dev": true,
1715 | "license": "MIT"
1716 | },
1717 | "node_modules/convert-source-map": {
1718 | "version": "2.0.0",
1719 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
1720 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
1721 | "dev": true,
1722 | "license": "MIT"
1723 | },
1724 | "node_modules/cross-spawn": {
1725 | "version": "7.0.3",
1726 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
1727 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
1728 | "dev": true,
1729 | "license": "MIT",
1730 | "dependencies": {
1731 | "path-key": "^3.1.0",
1732 | "shebang-command": "^2.0.0",
1733 | "which": "^2.0.1"
1734 | },
1735 | "engines": {
1736 | "node": ">= 8"
1737 | }
1738 | },
1739 | "node_modules/csstype": {
1740 | "version": "3.1.3",
1741 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz",
1742 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==",
1743 | "dev": true,
1744 | "license": "MIT"
1745 | },
1746 | "node_modules/data-view-buffer": {
1747 | "version": "1.0.1",
1748 | "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz",
1749 | "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==",
1750 | "dev": true,
1751 | "license": "MIT",
1752 | "dependencies": {
1753 | "call-bind": "^1.0.6",
1754 | "es-errors": "^1.3.0",
1755 | "is-data-view": "^1.0.1"
1756 | },
1757 | "engines": {
1758 | "node": ">= 0.4"
1759 | },
1760 | "funding": {
1761 | "url": "https://github.com/sponsors/ljharb"
1762 | }
1763 | },
1764 | "node_modules/data-view-byte-length": {
1765 | "version": "1.0.1",
1766 | "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz",
1767 | "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==",
1768 | "dev": true,
1769 | "license": "MIT",
1770 | "dependencies": {
1771 | "call-bind": "^1.0.7",
1772 | "es-errors": "^1.3.0",
1773 | "is-data-view": "^1.0.1"
1774 | },
1775 | "engines": {
1776 | "node": ">= 0.4"
1777 | },
1778 | "funding": {
1779 | "url": "https://github.com/sponsors/ljharb"
1780 | }
1781 | },
1782 | "node_modules/data-view-byte-offset": {
1783 | "version": "1.0.0",
1784 | "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz",
1785 | "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==",
1786 | "dev": true,
1787 | "license": "MIT",
1788 | "dependencies": {
1789 | "call-bind": "^1.0.6",
1790 | "es-errors": "^1.3.0",
1791 | "is-data-view": "^1.0.1"
1792 | },
1793 | "engines": {
1794 | "node": ">= 0.4"
1795 | },
1796 | "funding": {
1797 | "url": "https://github.com/sponsors/ljharb"
1798 | }
1799 | },
1800 | "node_modules/debug": {
1801 | "version": "4.3.7",
1802 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz",
1803 | "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==",
1804 | "dev": true,
1805 | "license": "MIT",
1806 | "dependencies": {
1807 | "ms": "^2.1.3"
1808 | },
1809 | "engines": {
1810 | "node": ">=6.0"
1811 | },
1812 | "peerDependenciesMeta": {
1813 | "supports-color": {
1814 | "optional": true
1815 | }
1816 | }
1817 | },
1818 | "node_modules/deep-is": {
1819 | "version": "0.1.4",
1820 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
1821 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
1822 | "dev": true,
1823 | "license": "MIT"
1824 | },
1825 | "node_modules/define-data-property": {
1826 | "version": "1.1.4",
1827 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz",
1828 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==",
1829 | "dev": true,
1830 | "license": "MIT",
1831 | "dependencies": {
1832 | "es-define-property": "^1.0.0",
1833 | "es-errors": "^1.3.0",
1834 | "gopd": "^1.0.1"
1835 | },
1836 | "engines": {
1837 | "node": ">= 0.4"
1838 | },
1839 | "funding": {
1840 | "url": "https://github.com/sponsors/ljharb"
1841 | }
1842 | },
1843 | "node_modules/define-properties": {
1844 | "version": "1.2.1",
1845 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz",
1846 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==",
1847 | "dev": true,
1848 | "license": "MIT",
1849 | "dependencies": {
1850 | "define-data-property": "^1.0.1",
1851 | "has-property-descriptors": "^1.0.0",
1852 | "object-keys": "^1.1.1"
1853 | },
1854 | "engines": {
1855 | "node": ">= 0.4"
1856 | },
1857 | "funding": {
1858 | "url": "https://github.com/sponsors/ljharb"
1859 | }
1860 | },
1861 | "node_modules/delayed-stream": {
1862 | "version": "1.0.0",
1863 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
1864 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
1865 | "license": "MIT",
1866 | "engines": {
1867 | "node": ">=0.4.0"
1868 | }
1869 | },
1870 | "node_modules/doctrine": {
1871 | "version": "2.1.0",
1872 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz",
1873 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==",
1874 | "dev": true,
1875 | "license": "Apache-2.0",
1876 | "dependencies": {
1877 | "esutils": "^2.0.2"
1878 | },
1879 | "engines": {
1880 | "node": ">=0.10.0"
1881 | }
1882 | },
1883 | "node_modules/electron-to-chromium": {
1884 | "version": "1.5.49",
1885 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.49.tgz",
1886 | "integrity": "sha512-ZXfs1Of8fDb6z7WEYZjXpgIRF6MEu8JdeGA0A40aZq6OQbS+eJpnnV49epZRna2DU/YsEjSQuGtQPPtvt6J65A==",
1887 | "dev": true,
1888 | "license": "ISC"
1889 | },
1890 | "node_modules/es-abstract": {
1891 | "version": "1.23.3",
1892 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz",
1893 | "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==",
1894 | "dev": true,
1895 | "license": "MIT",
1896 | "dependencies": {
1897 | "array-buffer-byte-length": "^1.0.1",
1898 | "arraybuffer.prototype.slice": "^1.0.3",
1899 | "available-typed-arrays": "^1.0.7",
1900 | "call-bind": "^1.0.7",
1901 | "data-view-buffer": "^1.0.1",
1902 | "data-view-byte-length": "^1.0.1",
1903 | "data-view-byte-offset": "^1.0.0",
1904 | "es-define-property": "^1.0.0",
1905 | "es-errors": "^1.3.0",
1906 | "es-object-atoms": "^1.0.0",
1907 | "es-set-tostringtag": "^2.0.3",
1908 | "es-to-primitive": "^1.2.1",
1909 | "function.prototype.name": "^1.1.6",
1910 | "get-intrinsic": "^1.2.4",
1911 | "get-symbol-description": "^1.0.2",
1912 | "globalthis": "^1.0.3",
1913 | "gopd": "^1.0.1",
1914 | "has-property-descriptors": "^1.0.2",
1915 | "has-proto": "^1.0.3",
1916 | "has-symbols": "^1.0.3",
1917 | "hasown": "^2.0.2",
1918 | "internal-slot": "^1.0.7",
1919 | "is-array-buffer": "^3.0.4",
1920 | "is-callable": "^1.2.7",
1921 | "is-data-view": "^1.0.1",
1922 | "is-negative-zero": "^2.0.3",
1923 | "is-regex": "^1.1.4",
1924 | "is-shared-array-buffer": "^1.0.3",
1925 | "is-string": "^1.0.7",
1926 | "is-typed-array": "^1.1.13",
1927 | "is-weakref": "^1.0.2",
1928 | "object-inspect": "^1.13.1",
1929 | "object-keys": "^1.1.1",
1930 | "object.assign": "^4.1.5",
1931 | "regexp.prototype.flags": "^1.5.2",
1932 | "safe-array-concat": "^1.1.2",
1933 | "safe-regex-test": "^1.0.3",
1934 | "string.prototype.trim": "^1.2.9",
1935 | "string.prototype.trimend": "^1.0.8",
1936 | "string.prototype.trimstart": "^1.0.8",
1937 | "typed-array-buffer": "^1.0.2",
1938 | "typed-array-byte-length": "^1.0.1",
1939 | "typed-array-byte-offset": "^1.0.2",
1940 | "typed-array-length": "^1.0.6",
1941 | "unbox-primitive": "^1.0.2",
1942 | "which-typed-array": "^1.1.15"
1943 | },
1944 | "engines": {
1945 | "node": ">= 0.4"
1946 | },
1947 | "funding": {
1948 | "url": "https://github.com/sponsors/ljharb"
1949 | }
1950 | },
1951 | "node_modules/es-define-property": {
1952 | "version": "1.0.0",
1953 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz",
1954 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==",
1955 | "dev": true,
1956 | "license": "MIT",
1957 | "dependencies": {
1958 | "get-intrinsic": "^1.2.4"
1959 | },
1960 | "engines": {
1961 | "node": ">= 0.4"
1962 | }
1963 | },
1964 | "node_modules/es-errors": {
1965 | "version": "1.3.0",
1966 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
1967 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
1968 | "dev": true,
1969 | "license": "MIT",
1970 | "engines": {
1971 | "node": ">= 0.4"
1972 | }
1973 | },
1974 | "node_modules/es-iterator-helpers": {
1975 | "version": "1.1.0",
1976 | "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.1.0.tgz",
1977 | "integrity": "sha512-/SurEfycdyssORP/E+bj4sEu1CWw4EmLDsHynHwSXQ7utgbrMRWW195pTrCjFgFCddf/UkYm3oqKPRq5i8bJbw==",
1978 | "dev": true,
1979 | "license": "MIT",
1980 | "dependencies": {
1981 | "call-bind": "^1.0.7",
1982 | "define-properties": "^1.2.1",
1983 | "es-abstract": "^1.23.3",
1984 | "es-errors": "^1.3.0",
1985 | "es-set-tostringtag": "^2.0.3",
1986 | "function-bind": "^1.1.2",
1987 | "get-intrinsic": "^1.2.4",
1988 | "globalthis": "^1.0.4",
1989 | "has-property-descriptors": "^1.0.2",
1990 | "has-proto": "^1.0.3",
1991 | "has-symbols": "^1.0.3",
1992 | "internal-slot": "^1.0.7",
1993 | "iterator.prototype": "^1.1.3",
1994 | "safe-array-concat": "^1.1.2"
1995 | },
1996 | "engines": {
1997 | "node": ">= 0.4"
1998 | }
1999 | },
2000 | "node_modules/es-object-atoms": {
2001 | "version": "1.0.0",
2002 | "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz",
2003 | "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==",
2004 | "dev": true,
2005 | "license": "MIT",
2006 | "dependencies": {
2007 | "es-errors": "^1.3.0"
2008 | },
2009 | "engines": {
2010 | "node": ">= 0.4"
2011 | }
2012 | },
2013 | "node_modules/es-set-tostringtag": {
2014 | "version": "2.0.3",
2015 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz",
2016 | "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==",
2017 | "dev": true,
2018 | "license": "MIT",
2019 | "dependencies": {
2020 | "get-intrinsic": "^1.2.4",
2021 | "has-tostringtag": "^1.0.2",
2022 | "hasown": "^2.0.1"
2023 | },
2024 | "engines": {
2025 | "node": ">= 0.4"
2026 | }
2027 | },
2028 | "node_modules/es-shim-unscopables": {
2029 | "version": "1.0.2",
2030 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz",
2031 | "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==",
2032 | "dev": true,
2033 | "license": "MIT",
2034 | "dependencies": {
2035 | "hasown": "^2.0.0"
2036 | }
2037 | },
2038 | "node_modules/es-to-primitive": {
2039 | "version": "1.2.1",
2040 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz",
2041 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==",
2042 | "dev": true,
2043 | "license": "MIT",
2044 | "dependencies": {
2045 | "is-callable": "^1.1.4",
2046 | "is-date-object": "^1.0.1",
2047 | "is-symbol": "^1.0.2"
2048 | },
2049 | "engines": {
2050 | "node": ">= 0.4"
2051 | },
2052 | "funding": {
2053 | "url": "https://github.com/sponsors/ljharb"
2054 | }
2055 | },
2056 | "node_modules/esbuild": {
2057 | "version": "0.21.5",
2058 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz",
2059 | "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==",
2060 | "dev": true,
2061 | "hasInstallScript": true,
2062 | "license": "MIT",
2063 | "bin": {
2064 | "esbuild": "bin/esbuild"
2065 | },
2066 | "engines": {
2067 | "node": ">=12"
2068 | },
2069 | "optionalDependencies": {
2070 | "@esbuild/aix-ppc64": "0.21.5",
2071 | "@esbuild/android-arm": "0.21.5",
2072 | "@esbuild/android-arm64": "0.21.5",
2073 | "@esbuild/android-x64": "0.21.5",
2074 | "@esbuild/darwin-arm64": "0.21.5",
2075 | "@esbuild/darwin-x64": "0.21.5",
2076 | "@esbuild/freebsd-arm64": "0.21.5",
2077 | "@esbuild/freebsd-x64": "0.21.5",
2078 | "@esbuild/linux-arm": "0.21.5",
2079 | "@esbuild/linux-arm64": "0.21.5",
2080 | "@esbuild/linux-ia32": "0.21.5",
2081 | "@esbuild/linux-loong64": "0.21.5",
2082 | "@esbuild/linux-mips64el": "0.21.5",
2083 | "@esbuild/linux-ppc64": "0.21.5",
2084 | "@esbuild/linux-riscv64": "0.21.5",
2085 | "@esbuild/linux-s390x": "0.21.5",
2086 | "@esbuild/linux-x64": "0.21.5",
2087 | "@esbuild/netbsd-x64": "0.21.5",
2088 | "@esbuild/openbsd-x64": "0.21.5",
2089 | "@esbuild/sunos-x64": "0.21.5",
2090 | "@esbuild/win32-arm64": "0.21.5",
2091 | "@esbuild/win32-ia32": "0.21.5",
2092 | "@esbuild/win32-x64": "0.21.5"
2093 | }
2094 | },
2095 | "node_modules/escalade": {
2096 | "version": "3.2.0",
2097 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz",
2098 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==",
2099 | "dev": true,
2100 | "license": "MIT",
2101 | "engines": {
2102 | "node": ">=6"
2103 | }
2104 | },
2105 | "node_modules/escape-string-regexp": {
2106 | "version": "4.0.0",
2107 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
2108 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
2109 | "dev": true,
2110 | "license": "MIT",
2111 | "engines": {
2112 | "node": ">=10"
2113 | },
2114 | "funding": {
2115 | "url": "https://github.com/sponsors/sindresorhus"
2116 | }
2117 | },
2118 | "node_modules/eslint": {
2119 | "version": "9.13.0",
2120 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.13.0.tgz",
2121 | "integrity": "sha512-EYZK6SX6zjFHST/HRytOdA/zE72Cq/bfw45LSyuwrdvcclb/gqV8RRQxywOBEWO2+WDpva6UZa4CcDeJKzUCFA==",
2122 | "dev": true,
2123 | "license": "MIT",
2124 | "dependencies": {
2125 | "@eslint-community/eslint-utils": "^4.2.0",
2126 | "@eslint-community/regexpp": "^4.11.0",
2127 | "@eslint/config-array": "^0.18.0",
2128 | "@eslint/core": "^0.7.0",
2129 | "@eslint/eslintrc": "^3.1.0",
2130 | "@eslint/js": "9.13.0",
2131 | "@eslint/plugin-kit": "^0.2.0",
2132 | "@humanfs/node": "^0.16.5",
2133 | "@humanwhocodes/module-importer": "^1.0.1",
2134 | "@humanwhocodes/retry": "^0.3.1",
2135 | "@types/estree": "^1.0.6",
2136 | "@types/json-schema": "^7.0.15",
2137 | "ajv": "^6.12.4",
2138 | "chalk": "^4.0.0",
2139 | "cross-spawn": "^7.0.2",
2140 | "debug": "^4.3.2",
2141 | "escape-string-regexp": "^4.0.0",
2142 | "eslint-scope": "^8.1.0",
2143 | "eslint-visitor-keys": "^4.1.0",
2144 | "espree": "^10.2.0",
2145 | "esquery": "^1.5.0",
2146 | "esutils": "^2.0.2",
2147 | "fast-deep-equal": "^3.1.3",
2148 | "file-entry-cache": "^8.0.0",
2149 | "find-up": "^5.0.0",
2150 | "glob-parent": "^6.0.2",
2151 | "ignore": "^5.2.0",
2152 | "imurmurhash": "^0.1.4",
2153 | "is-glob": "^4.0.0",
2154 | "json-stable-stringify-without-jsonify": "^1.0.1",
2155 | "lodash.merge": "^4.6.2",
2156 | "minimatch": "^3.1.2",
2157 | "natural-compare": "^1.4.0",
2158 | "optionator": "^0.9.3",
2159 | "text-table": "^0.2.0"
2160 | },
2161 | "bin": {
2162 | "eslint": "bin/eslint.js"
2163 | },
2164 | "engines": {
2165 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2166 | },
2167 | "funding": {
2168 | "url": "https://eslint.org/donate"
2169 | },
2170 | "peerDependencies": {
2171 | "jiti": "*"
2172 | },
2173 | "peerDependenciesMeta": {
2174 | "jiti": {
2175 | "optional": true
2176 | }
2177 | }
2178 | },
2179 | "node_modules/eslint-plugin-react": {
2180 | "version": "7.37.2",
2181 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.37.2.tgz",
2182 | "integrity": "sha512-EsTAnj9fLVr/GZleBLFbj/sSuXeWmp1eXIN60ceYnZveqEaUCyW4X+Vh4WTdUhCkW4xutXYqTXCUSyqD4rB75w==",
2183 | "dev": true,
2184 | "license": "MIT",
2185 | "dependencies": {
2186 | "array-includes": "^3.1.8",
2187 | "array.prototype.findlast": "^1.2.5",
2188 | "array.prototype.flatmap": "^1.3.2",
2189 | "array.prototype.tosorted": "^1.1.4",
2190 | "doctrine": "^2.1.0",
2191 | "es-iterator-helpers": "^1.1.0",
2192 | "estraverse": "^5.3.0",
2193 | "hasown": "^2.0.2",
2194 | "jsx-ast-utils": "^2.4.1 || ^3.0.0",
2195 | "minimatch": "^3.1.2",
2196 | "object.entries": "^1.1.8",
2197 | "object.fromentries": "^2.0.8",
2198 | "object.values": "^1.2.0",
2199 | "prop-types": "^15.8.1",
2200 | "resolve": "^2.0.0-next.5",
2201 | "semver": "^6.3.1",
2202 | "string.prototype.matchall": "^4.0.11",
2203 | "string.prototype.repeat": "^1.0.0"
2204 | },
2205 | "engines": {
2206 | "node": ">=4"
2207 | },
2208 | "peerDependencies": {
2209 | "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9.7"
2210 | }
2211 | },
2212 | "node_modules/eslint-plugin-react-hooks": {
2213 | "version": "5.0.0",
2214 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.0.0.tgz",
2215 | "integrity": "sha512-hIOwI+5hYGpJEc4uPRmz2ulCjAGD/N13Lukkh8cLV0i2IRk/bdZDYjgLVHj+U9Z704kLIdIO6iueGvxNur0sgw==",
2216 | "dev": true,
2217 | "license": "MIT",
2218 | "engines": {
2219 | "node": ">=10"
2220 | },
2221 | "peerDependencies": {
2222 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0"
2223 | }
2224 | },
2225 | "node_modules/eslint-plugin-react-refresh": {
2226 | "version": "0.4.14",
2227 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.14.tgz",
2228 | "integrity": "sha512-aXvzCTK7ZBv1e7fahFuR3Z/fyQQSIQ711yPgYRj+Oj64tyTgO4iQIDmYXDBqvSWQ/FA4OSCsXOStlF+noU0/NA==",
2229 | "dev": true,
2230 | "license": "MIT",
2231 | "peerDependencies": {
2232 | "eslint": ">=7"
2233 | }
2234 | },
2235 | "node_modules/eslint-scope": {
2236 | "version": "8.2.0",
2237 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.2.0.tgz",
2238 | "integrity": "sha512-PHlWUfG6lvPc3yvP5A4PNyBL1W8fkDUccmI21JUu/+GKZBoH/W5u6usENXUrWFRsyoW5ACUjFGgAFQp5gUlb/A==",
2239 | "dev": true,
2240 | "license": "BSD-2-Clause",
2241 | "dependencies": {
2242 | "esrecurse": "^4.3.0",
2243 | "estraverse": "^5.2.0"
2244 | },
2245 | "engines": {
2246 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2247 | },
2248 | "funding": {
2249 | "url": "https://opencollective.com/eslint"
2250 | }
2251 | },
2252 | "node_modules/eslint-visitor-keys": {
2253 | "version": "4.2.0",
2254 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz",
2255 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==",
2256 | "dev": true,
2257 | "license": "Apache-2.0",
2258 | "engines": {
2259 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2260 | },
2261 | "funding": {
2262 | "url": "https://opencollective.com/eslint"
2263 | }
2264 | },
2265 | "node_modules/espree": {
2266 | "version": "10.3.0",
2267 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz",
2268 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==",
2269 | "dev": true,
2270 | "license": "BSD-2-Clause",
2271 | "dependencies": {
2272 | "acorn": "^8.14.0",
2273 | "acorn-jsx": "^5.3.2",
2274 | "eslint-visitor-keys": "^4.2.0"
2275 | },
2276 | "engines": {
2277 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
2278 | },
2279 | "funding": {
2280 | "url": "https://opencollective.com/eslint"
2281 | }
2282 | },
2283 | "node_modules/esquery": {
2284 | "version": "1.6.0",
2285 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz",
2286 | "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==",
2287 | "dev": true,
2288 | "license": "BSD-3-Clause",
2289 | "dependencies": {
2290 | "estraverse": "^5.1.0"
2291 | },
2292 | "engines": {
2293 | "node": ">=0.10"
2294 | }
2295 | },
2296 | "node_modules/esrecurse": {
2297 | "version": "4.3.0",
2298 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
2299 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
2300 | "dev": true,
2301 | "license": "BSD-2-Clause",
2302 | "dependencies": {
2303 | "estraverse": "^5.2.0"
2304 | },
2305 | "engines": {
2306 | "node": ">=4.0"
2307 | }
2308 | },
2309 | "node_modules/estraverse": {
2310 | "version": "5.3.0",
2311 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
2312 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
2313 | "dev": true,
2314 | "license": "BSD-2-Clause",
2315 | "engines": {
2316 | "node": ">=4.0"
2317 | }
2318 | },
2319 | "node_modules/esutils": {
2320 | "version": "2.0.3",
2321 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
2322 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
2323 | "dev": true,
2324 | "license": "BSD-2-Clause",
2325 | "engines": {
2326 | "node": ">=0.10.0"
2327 | }
2328 | },
2329 | "node_modules/fast-deep-equal": {
2330 | "version": "3.1.3",
2331 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
2332 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
2333 | "dev": true,
2334 | "license": "MIT"
2335 | },
2336 | "node_modules/fast-json-stable-stringify": {
2337 | "version": "2.1.0",
2338 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
2339 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
2340 | "dev": true,
2341 | "license": "MIT"
2342 | },
2343 | "node_modules/fast-levenshtein": {
2344 | "version": "2.0.6",
2345 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
2346 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
2347 | "dev": true,
2348 | "license": "MIT"
2349 | },
2350 | "node_modules/file-entry-cache": {
2351 | "version": "8.0.0",
2352 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
2353 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
2354 | "dev": true,
2355 | "license": "MIT",
2356 | "dependencies": {
2357 | "flat-cache": "^4.0.0"
2358 | },
2359 | "engines": {
2360 | "node": ">=16.0.0"
2361 | }
2362 | },
2363 | "node_modules/find-up": {
2364 | "version": "5.0.0",
2365 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
2366 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
2367 | "dev": true,
2368 | "license": "MIT",
2369 | "dependencies": {
2370 | "locate-path": "^6.0.0",
2371 | "path-exists": "^4.0.0"
2372 | },
2373 | "engines": {
2374 | "node": ">=10"
2375 | },
2376 | "funding": {
2377 | "url": "https://github.com/sponsors/sindresorhus"
2378 | }
2379 | },
2380 | "node_modules/flat-cache": {
2381 | "version": "4.0.1",
2382 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
2383 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
2384 | "dev": true,
2385 | "license": "MIT",
2386 | "dependencies": {
2387 | "flatted": "^3.2.9",
2388 | "keyv": "^4.5.4"
2389 | },
2390 | "engines": {
2391 | "node": ">=16"
2392 | }
2393 | },
2394 | "node_modules/flatted": {
2395 | "version": "3.3.1",
2396 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz",
2397 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==",
2398 | "dev": true,
2399 | "license": "ISC"
2400 | },
2401 | "node_modules/follow-redirects": {
2402 | "version": "1.15.9",
2403 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz",
2404 | "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==",
2405 | "funding": [
2406 | {
2407 | "type": "individual",
2408 | "url": "https://github.com/sponsors/RubenVerborgh"
2409 | }
2410 | ],
2411 | "license": "MIT",
2412 | "engines": {
2413 | "node": ">=4.0"
2414 | },
2415 | "peerDependenciesMeta": {
2416 | "debug": {
2417 | "optional": true
2418 | }
2419 | }
2420 | },
2421 | "node_modules/for-each": {
2422 | "version": "0.3.3",
2423 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz",
2424 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==",
2425 | "dev": true,
2426 | "license": "MIT",
2427 | "dependencies": {
2428 | "is-callable": "^1.1.3"
2429 | }
2430 | },
2431 | "node_modules/form-data": {
2432 | "version": "4.0.1",
2433 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz",
2434 | "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==",
2435 | "license": "MIT",
2436 | "dependencies": {
2437 | "asynckit": "^0.4.0",
2438 | "combined-stream": "^1.0.8",
2439 | "mime-types": "^2.1.12"
2440 | },
2441 | "engines": {
2442 | "node": ">= 6"
2443 | }
2444 | },
2445 | "node_modules/fsevents": {
2446 | "version": "2.3.3",
2447 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
2448 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
2449 | "dev": true,
2450 | "hasInstallScript": true,
2451 | "license": "MIT",
2452 | "optional": true,
2453 | "os": [
2454 | "darwin"
2455 | ],
2456 | "engines": {
2457 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
2458 | }
2459 | },
2460 | "node_modules/function-bind": {
2461 | "version": "1.1.2",
2462 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
2463 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
2464 | "dev": true,
2465 | "license": "MIT",
2466 | "funding": {
2467 | "url": "https://github.com/sponsors/ljharb"
2468 | }
2469 | },
2470 | "node_modules/function.prototype.name": {
2471 | "version": "1.1.6",
2472 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz",
2473 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==",
2474 | "dev": true,
2475 | "license": "MIT",
2476 | "dependencies": {
2477 | "call-bind": "^1.0.2",
2478 | "define-properties": "^1.2.0",
2479 | "es-abstract": "^1.22.1",
2480 | "functions-have-names": "^1.2.3"
2481 | },
2482 | "engines": {
2483 | "node": ">= 0.4"
2484 | },
2485 | "funding": {
2486 | "url": "https://github.com/sponsors/ljharb"
2487 | }
2488 | },
2489 | "node_modules/functions-have-names": {
2490 | "version": "1.2.3",
2491 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz",
2492 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==",
2493 | "dev": true,
2494 | "license": "MIT",
2495 | "funding": {
2496 | "url": "https://github.com/sponsors/ljharb"
2497 | }
2498 | },
2499 | "node_modules/gensync": {
2500 | "version": "1.0.0-beta.2",
2501 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
2502 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
2503 | "dev": true,
2504 | "license": "MIT",
2505 | "engines": {
2506 | "node": ">=6.9.0"
2507 | }
2508 | },
2509 | "node_modules/get-intrinsic": {
2510 | "version": "1.2.4",
2511 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz",
2512 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==",
2513 | "dev": true,
2514 | "license": "MIT",
2515 | "dependencies": {
2516 | "es-errors": "^1.3.0",
2517 | "function-bind": "^1.1.2",
2518 | "has-proto": "^1.0.1",
2519 | "has-symbols": "^1.0.3",
2520 | "hasown": "^2.0.0"
2521 | },
2522 | "engines": {
2523 | "node": ">= 0.4"
2524 | },
2525 | "funding": {
2526 | "url": "https://github.com/sponsors/ljharb"
2527 | }
2528 | },
2529 | "node_modules/get-symbol-description": {
2530 | "version": "1.0.2",
2531 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz",
2532 | "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==",
2533 | "dev": true,
2534 | "license": "MIT",
2535 | "dependencies": {
2536 | "call-bind": "^1.0.5",
2537 | "es-errors": "^1.3.0",
2538 | "get-intrinsic": "^1.2.4"
2539 | },
2540 | "engines": {
2541 | "node": ">= 0.4"
2542 | },
2543 | "funding": {
2544 | "url": "https://github.com/sponsors/ljharb"
2545 | }
2546 | },
2547 | "node_modules/glob-parent": {
2548 | "version": "6.0.2",
2549 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
2550 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
2551 | "dev": true,
2552 | "license": "ISC",
2553 | "dependencies": {
2554 | "is-glob": "^4.0.3"
2555 | },
2556 | "engines": {
2557 | "node": ">=10.13.0"
2558 | }
2559 | },
2560 | "node_modules/globals": {
2561 | "version": "15.11.0",
2562 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.11.0.tgz",
2563 | "integrity": "sha512-yeyNSjdbyVaWurlwCpcA6XNBrHTMIeDdj0/hnvX/OLJ9ekOXYbLsLinH/MucQyGvNnXhidTdNhTtJaffL2sMfw==",
2564 | "dev": true,
2565 | "license": "MIT",
2566 | "engines": {
2567 | "node": ">=18"
2568 | },
2569 | "funding": {
2570 | "url": "https://github.com/sponsors/sindresorhus"
2571 | }
2572 | },
2573 | "node_modules/globalthis": {
2574 | "version": "1.0.4",
2575 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz",
2576 | "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==",
2577 | "dev": true,
2578 | "license": "MIT",
2579 | "dependencies": {
2580 | "define-properties": "^1.2.1",
2581 | "gopd": "^1.0.1"
2582 | },
2583 | "engines": {
2584 | "node": ">= 0.4"
2585 | },
2586 | "funding": {
2587 | "url": "https://github.com/sponsors/ljharb"
2588 | }
2589 | },
2590 | "node_modules/gopd": {
2591 | "version": "1.0.1",
2592 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz",
2593 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==",
2594 | "dev": true,
2595 | "license": "MIT",
2596 | "dependencies": {
2597 | "get-intrinsic": "^1.1.3"
2598 | },
2599 | "funding": {
2600 | "url": "https://github.com/sponsors/ljharb"
2601 | }
2602 | },
2603 | "node_modules/has-bigints": {
2604 | "version": "1.0.2",
2605 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz",
2606 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==",
2607 | "dev": true,
2608 | "license": "MIT",
2609 | "funding": {
2610 | "url": "https://github.com/sponsors/ljharb"
2611 | }
2612 | },
2613 | "node_modules/has-flag": {
2614 | "version": "4.0.0",
2615 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2616 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2617 | "dev": true,
2618 | "license": "MIT",
2619 | "engines": {
2620 | "node": ">=8"
2621 | }
2622 | },
2623 | "node_modules/has-property-descriptors": {
2624 | "version": "1.0.2",
2625 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz",
2626 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==",
2627 | "dev": true,
2628 | "license": "MIT",
2629 | "dependencies": {
2630 | "es-define-property": "^1.0.0"
2631 | },
2632 | "funding": {
2633 | "url": "https://github.com/sponsors/ljharb"
2634 | }
2635 | },
2636 | "node_modules/has-proto": {
2637 | "version": "1.0.3",
2638 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz",
2639 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==",
2640 | "dev": true,
2641 | "license": "MIT",
2642 | "engines": {
2643 | "node": ">= 0.4"
2644 | },
2645 | "funding": {
2646 | "url": "https://github.com/sponsors/ljharb"
2647 | }
2648 | },
2649 | "node_modules/has-symbols": {
2650 | "version": "1.0.3",
2651 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
2652 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
2653 | "dev": true,
2654 | "license": "MIT",
2655 | "engines": {
2656 | "node": ">= 0.4"
2657 | },
2658 | "funding": {
2659 | "url": "https://github.com/sponsors/ljharb"
2660 | }
2661 | },
2662 | "node_modules/has-tostringtag": {
2663 | "version": "1.0.2",
2664 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz",
2665 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==",
2666 | "dev": true,
2667 | "license": "MIT",
2668 | "dependencies": {
2669 | "has-symbols": "^1.0.3"
2670 | },
2671 | "engines": {
2672 | "node": ">= 0.4"
2673 | },
2674 | "funding": {
2675 | "url": "https://github.com/sponsors/ljharb"
2676 | }
2677 | },
2678 | "node_modules/hasown": {
2679 | "version": "2.0.2",
2680 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz",
2681 | "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==",
2682 | "dev": true,
2683 | "license": "MIT",
2684 | "dependencies": {
2685 | "function-bind": "^1.1.2"
2686 | },
2687 | "engines": {
2688 | "node": ">= 0.4"
2689 | }
2690 | },
2691 | "node_modules/ignore": {
2692 | "version": "5.3.2",
2693 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
2694 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
2695 | "dev": true,
2696 | "license": "MIT",
2697 | "engines": {
2698 | "node": ">= 4"
2699 | }
2700 | },
2701 | "node_modules/import-fresh": {
2702 | "version": "3.3.0",
2703 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
2704 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==",
2705 | "dev": true,
2706 | "license": "MIT",
2707 | "dependencies": {
2708 | "parent-module": "^1.0.0",
2709 | "resolve-from": "^4.0.0"
2710 | },
2711 | "engines": {
2712 | "node": ">=6"
2713 | },
2714 | "funding": {
2715 | "url": "https://github.com/sponsors/sindresorhus"
2716 | }
2717 | },
2718 | "node_modules/imurmurhash": {
2719 | "version": "0.1.4",
2720 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
2721 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==",
2722 | "dev": true,
2723 | "license": "MIT",
2724 | "engines": {
2725 | "node": ">=0.8.19"
2726 | }
2727 | },
2728 | "node_modules/internal-slot": {
2729 | "version": "1.0.7",
2730 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz",
2731 | "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==",
2732 | "dev": true,
2733 | "license": "MIT",
2734 | "dependencies": {
2735 | "es-errors": "^1.3.0",
2736 | "hasown": "^2.0.0",
2737 | "side-channel": "^1.0.4"
2738 | },
2739 | "engines": {
2740 | "node": ">= 0.4"
2741 | }
2742 | },
2743 | "node_modules/is-array-buffer": {
2744 | "version": "3.0.4",
2745 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz",
2746 | "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==",
2747 | "dev": true,
2748 | "license": "MIT",
2749 | "dependencies": {
2750 | "call-bind": "^1.0.2",
2751 | "get-intrinsic": "^1.2.1"
2752 | },
2753 | "engines": {
2754 | "node": ">= 0.4"
2755 | },
2756 | "funding": {
2757 | "url": "https://github.com/sponsors/ljharb"
2758 | }
2759 | },
2760 | "node_modules/is-async-function": {
2761 | "version": "2.0.0",
2762 | "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz",
2763 | "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==",
2764 | "dev": true,
2765 | "license": "MIT",
2766 | "dependencies": {
2767 | "has-tostringtag": "^1.0.0"
2768 | },
2769 | "engines": {
2770 | "node": ">= 0.4"
2771 | },
2772 | "funding": {
2773 | "url": "https://github.com/sponsors/ljharb"
2774 | }
2775 | },
2776 | "node_modules/is-bigint": {
2777 | "version": "1.0.4",
2778 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz",
2779 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==",
2780 | "dev": true,
2781 | "license": "MIT",
2782 | "dependencies": {
2783 | "has-bigints": "^1.0.1"
2784 | },
2785 | "funding": {
2786 | "url": "https://github.com/sponsors/ljharb"
2787 | }
2788 | },
2789 | "node_modules/is-boolean-object": {
2790 | "version": "1.1.2",
2791 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz",
2792 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==",
2793 | "dev": true,
2794 | "license": "MIT",
2795 | "dependencies": {
2796 | "call-bind": "^1.0.2",
2797 | "has-tostringtag": "^1.0.0"
2798 | },
2799 | "engines": {
2800 | "node": ">= 0.4"
2801 | },
2802 | "funding": {
2803 | "url": "https://github.com/sponsors/ljharb"
2804 | }
2805 | },
2806 | "node_modules/is-callable": {
2807 | "version": "1.2.7",
2808 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz",
2809 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==",
2810 | "dev": true,
2811 | "license": "MIT",
2812 | "engines": {
2813 | "node": ">= 0.4"
2814 | },
2815 | "funding": {
2816 | "url": "https://github.com/sponsors/ljharb"
2817 | }
2818 | },
2819 | "node_modules/is-core-module": {
2820 | "version": "2.15.1",
2821 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz",
2822 | "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==",
2823 | "dev": true,
2824 | "license": "MIT",
2825 | "dependencies": {
2826 | "hasown": "^2.0.2"
2827 | },
2828 | "engines": {
2829 | "node": ">= 0.4"
2830 | },
2831 | "funding": {
2832 | "url": "https://github.com/sponsors/ljharb"
2833 | }
2834 | },
2835 | "node_modules/is-data-view": {
2836 | "version": "1.0.1",
2837 | "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz",
2838 | "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==",
2839 | "dev": true,
2840 | "license": "MIT",
2841 | "dependencies": {
2842 | "is-typed-array": "^1.1.13"
2843 | },
2844 | "engines": {
2845 | "node": ">= 0.4"
2846 | },
2847 | "funding": {
2848 | "url": "https://github.com/sponsors/ljharb"
2849 | }
2850 | },
2851 | "node_modules/is-date-object": {
2852 | "version": "1.0.5",
2853 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz",
2854 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==",
2855 | "dev": true,
2856 | "license": "MIT",
2857 | "dependencies": {
2858 | "has-tostringtag": "^1.0.0"
2859 | },
2860 | "engines": {
2861 | "node": ">= 0.4"
2862 | },
2863 | "funding": {
2864 | "url": "https://github.com/sponsors/ljharb"
2865 | }
2866 | },
2867 | "node_modules/is-extglob": {
2868 | "version": "2.1.1",
2869 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2870 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
2871 | "dev": true,
2872 | "license": "MIT",
2873 | "engines": {
2874 | "node": ">=0.10.0"
2875 | }
2876 | },
2877 | "node_modules/is-finalizationregistry": {
2878 | "version": "1.0.2",
2879 | "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz",
2880 | "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==",
2881 | "dev": true,
2882 | "license": "MIT",
2883 | "dependencies": {
2884 | "call-bind": "^1.0.2"
2885 | },
2886 | "funding": {
2887 | "url": "https://github.com/sponsors/ljharb"
2888 | }
2889 | },
2890 | "node_modules/is-generator-function": {
2891 | "version": "1.0.10",
2892 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz",
2893 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==",
2894 | "dev": true,
2895 | "license": "MIT",
2896 | "dependencies": {
2897 | "has-tostringtag": "^1.0.0"
2898 | },
2899 | "engines": {
2900 | "node": ">= 0.4"
2901 | },
2902 | "funding": {
2903 | "url": "https://github.com/sponsors/ljharb"
2904 | }
2905 | },
2906 | "node_modules/is-glob": {
2907 | "version": "4.0.3",
2908 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
2909 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
2910 | "dev": true,
2911 | "license": "MIT",
2912 | "dependencies": {
2913 | "is-extglob": "^2.1.1"
2914 | },
2915 | "engines": {
2916 | "node": ">=0.10.0"
2917 | }
2918 | },
2919 | "node_modules/is-map": {
2920 | "version": "2.0.3",
2921 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz",
2922 | "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==",
2923 | "dev": true,
2924 | "license": "MIT",
2925 | "engines": {
2926 | "node": ">= 0.4"
2927 | },
2928 | "funding": {
2929 | "url": "https://github.com/sponsors/ljharb"
2930 | }
2931 | },
2932 | "node_modules/is-negative-zero": {
2933 | "version": "2.0.3",
2934 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz",
2935 | "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==",
2936 | "dev": true,
2937 | "license": "MIT",
2938 | "engines": {
2939 | "node": ">= 0.4"
2940 | },
2941 | "funding": {
2942 | "url": "https://github.com/sponsors/ljharb"
2943 | }
2944 | },
2945 | "node_modules/is-number-object": {
2946 | "version": "1.0.7",
2947 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz",
2948 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==",
2949 | "dev": true,
2950 | "license": "MIT",
2951 | "dependencies": {
2952 | "has-tostringtag": "^1.0.0"
2953 | },
2954 | "engines": {
2955 | "node": ">= 0.4"
2956 | },
2957 | "funding": {
2958 | "url": "https://github.com/sponsors/ljharb"
2959 | }
2960 | },
2961 | "node_modules/is-regex": {
2962 | "version": "1.1.4",
2963 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz",
2964 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==",
2965 | "dev": true,
2966 | "license": "MIT",
2967 | "dependencies": {
2968 | "call-bind": "^1.0.2",
2969 | "has-tostringtag": "^1.0.0"
2970 | },
2971 | "engines": {
2972 | "node": ">= 0.4"
2973 | },
2974 | "funding": {
2975 | "url": "https://github.com/sponsors/ljharb"
2976 | }
2977 | },
2978 | "node_modules/is-set": {
2979 | "version": "2.0.3",
2980 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz",
2981 | "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==",
2982 | "dev": true,
2983 | "license": "MIT",
2984 | "engines": {
2985 | "node": ">= 0.4"
2986 | },
2987 | "funding": {
2988 | "url": "https://github.com/sponsors/ljharb"
2989 | }
2990 | },
2991 | "node_modules/is-shared-array-buffer": {
2992 | "version": "1.0.3",
2993 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz",
2994 | "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==",
2995 | "dev": true,
2996 | "license": "MIT",
2997 | "dependencies": {
2998 | "call-bind": "^1.0.7"
2999 | },
3000 | "engines": {
3001 | "node": ">= 0.4"
3002 | },
3003 | "funding": {
3004 | "url": "https://github.com/sponsors/ljharb"
3005 | }
3006 | },
3007 | "node_modules/is-string": {
3008 | "version": "1.0.7",
3009 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz",
3010 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==",
3011 | "dev": true,
3012 | "license": "MIT",
3013 | "dependencies": {
3014 | "has-tostringtag": "^1.0.0"
3015 | },
3016 | "engines": {
3017 | "node": ">= 0.4"
3018 | },
3019 | "funding": {
3020 | "url": "https://github.com/sponsors/ljharb"
3021 | }
3022 | },
3023 | "node_modules/is-symbol": {
3024 | "version": "1.0.4",
3025 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz",
3026 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==",
3027 | "dev": true,
3028 | "license": "MIT",
3029 | "dependencies": {
3030 | "has-symbols": "^1.0.2"
3031 | },
3032 | "engines": {
3033 | "node": ">= 0.4"
3034 | },
3035 | "funding": {
3036 | "url": "https://github.com/sponsors/ljharb"
3037 | }
3038 | },
3039 | "node_modules/is-typed-array": {
3040 | "version": "1.1.13",
3041 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz",
3042 | "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==",
3043 | "dev": true,
3044 | "license": "MIT",
3045 | "dependencies": {
3046 | "which-typed-array": "^1.1.14"
3047 | },
3048 | "engines": {
3049 | "node": ">= 0.4"
3050 | },
3051 | "funding": {
3052 | "url": "https://github.com/sponsors/ljharb"
3053 | }
3054 | },
3055 | "node_modules/is-weakmap": {
3056 | "version": "2.0.2",
3057 | "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz",
3058 | "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==",
3059 | "dev": true,
3060 | "license": "MIT",
3061 | "engines": {
3062 | "node": ">= 0.4"
3063 | },
3064 | "funding": {
3065 | "url": "https://github.com/sponsors/ljharb"
3066 | }
3067 | },
3068 | "node_modules/is-weakref": {
3069 | "version": "1.0.2",
3070 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz",
3071 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==",
3072 | "dev": true,
3073 | "license": "MIT",
3074 | "dependencies": {
3075 | "call-bind": "^1.0.2"
3076 | },
3077 | "funding": {
3078 | "url": "https://github.com/sponsors/ljharb"
3079 | }
3080 | },
3081 | "node_modules/is-weakset": {
3082 | "version": "2.0.3",
3083 | "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz",
3084 | "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==",
3085 | "dev": true,
3086 | "license": "MIT",
3087 | "dependencies": {
3088 | "call-bind": "^1.0.7",
3089 | "get-intrinsic": "^1.2.4"
3090 | },
3091 | "engines": {
3092 | "node": ">= 0.4"
3093 | },
3094 | "funding": {
3095 | "url": "https://github.com/sponsors/ljharb"
3096 | }
3097 | },
3098 | "node_modules/isarray": {
3099 | "version": "2.0.5",
3100 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz",
3101 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==",
3102 | "dev": true,
3103 | "license": "MIT"
3104 | },
3105 | "node_modules/isexe": {
3106 | "version": "2.0.0",
3107 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
3108 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
3109 | "dev": true,
3110 | "license": "ISC"
3111 | },
3112 | "node_modules/iterator.prototype": {
3113 | "version": "1.1.3",
3114 | "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.3.tgz",
3115 | "integrity": "sha512-FW5iMbeQ6rBGm/oKgzq2aW4KvAGpxPzYES8N4g4xNXUKpL1mclMvOe+76AcLDTvD+Ze+sOpVhgdAQEKF4L9iGQ==",
3116 | "dev": true,
3117 | "license": "MIT",
3118 | "dependencies": {
3119 | "define-properties": "^1.2.1",
3120 | "get-intrinsic": "^1.2.1",
3121 | "has-symbols": "^1.0.3",
3122 | "reflect.getprototypeof": "^1.0.4",
3123 | "set-function-name": "^2.0.1"
3124 | },
3125 | "engines": {
3126 | "node": ">= 0.4"
3127 | }
3128 | },
3129 | "node_modules/js-tokens": {
3130 | "version": "4.0.0",
3131 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
3132 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
3133 | "license": "MIT"
3134 | },
3135 | "node_modules/js-yaml": {
3136 | "version": "4.1.0",
3137 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
3138 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
3139 | "dev": true,
3140 | "license": "MIT",
3141 | "dependencies": {
3142 | "argparse": "^2.0.1"
3143 | },
3144 | "bin": {
3145 | "js-yaml": "bin/js-yaml.js"
3146 | }
3147 | },
3148 | "node_modules/jsesc": {
3149 | "version": "3.0.2",
3150 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz",
3151 | "integrity": "sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==",
3152 | "dev": true,
3153 | "license": "MIT",
3154 | "bin": {
3155 | "jsesc": "bin/jsesc"
3156 | },
3157 | "engines": {
3158 | "node": ">=6"
3159 | }
3160 | },
3161 | "node_modules/json-buffer": {
3162 | "version": "3.0.1",
3163 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
3164 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
3165 | "dev": true,
3166 | "license": "MIT"
3167 | },
3168 | "node_modules/json-schema-traverse": {
3169 | "version": "0.4.1",
3170 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
3171 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
3172 | "dev": true,
3173 | "license": "MIT"
3174 | },
3175 | "node_modules/json-stable-stringify-without-jsonify": {
3176 | "version": "1.0.1",
3177 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
3178 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
3179 | "dev": true,
3180 | "license": "MIT"
3181 | },
3182 | "node_modules/json5": {
3183 | "version": "2.2.3",
3184 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
3185 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
3186 | "dev": true,
3187 | "license": "MIT",
3188 | "bin": {
3189 | "json5": "lib/cli.js"
3190 | },
3191 | "engines": {
3192 | "node": ">=6"
3193 | }
3194 | },
3195 | "node_modules/jsx-ast-utils": {
3196 | "version": "3.3.5",
3197 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz",
3198 | "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==",
3199 | "dev": true,
3200 | "license": "MIT",
3201 | "dependencies": {
3202 | "array-includes": "^3.1.6",
3203 | "array.prototype.flat": "^1.3.1",
3204 | "object.assign": "^4.1.4",
3205 | "object.values": "^1.1.6"
3206 | },
3207 | "engines": {
3208 | "node": ">=4.0"
3209 | }
3210 | },
3211 | "node_modules/keyv": {
3212 | "version": "4.5.4",
3213 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
3214 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
3215 | "dev": true,
3216 | "license": "MIT",
3217 | "dependencies": {
3218 | "json-buffer": "3.0.1"
3219 | }
3220 | },
3221 | "node_modules/levn": {
3222 | "version": "0.4.1",
3223 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
3224 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
3225 | "dev": true,
3226 | "license": "MIT",
3227 | "dependencies": {
3228 | "prelude-ls": "^1.2.1",
3229 | "type-check": "~0.4.0"
3230 | },
3231 | "engines": {
3232 | "node": ">= 0.8.0"
3233 | }
3234 | },
3235 | "node_modules/locate-path": {
3236 | "version": "6.0.0",
3237 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
3238 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
3239 | "dev": true,
3240 | "license": "MIT",
3241 | "dependencies": {
3242 | "p-locate": "^5.0.0"
3243 | },
3244 | "engines": {
3245 | "node": ">=10"
3246 | },
3247 | "funding": {
3248 | "url": "https://github.com/sponsors/sindresorhus"
3249 | }
3250 | },
3251 | "node_modules/lodash.merge": {
3252 | "version": "4.6.2",
3253 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
3254 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
3255 | "dev": true,
3256 | "license": "MIT"
3257 | },
3258 | "node_modules/loose-envify": {
3259 | "version": "1.4.0",
3260 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz",
3261 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==",
3262 | "license": "MIT",
3263 | "dependencies": {
3264 | "js-tokens": "^3.0.0 || ^4.0.0"
3265 | },
3266 | "bin": {
3267 | "loose-envify": "cli.js"
3268 | }
3269 | },
3270 | "node_modules/lru-cache": {
3271 | "version": "5.1.1",
3272 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
3273 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
3274 | "dev": true,
3275 | "license": "ISC",
3276 | "dependencies": {
3277 | "yallist": "^3.0.2"
3278 | }
3279 | },
3280 | "node_modules/mime-db": {
3281 | "version": "1.52.0",
3282 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
3283 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
3284 | "license": "MIT",
3285 | "engines": {
3286 | "node": ">= 0.6"
3287 | }
3288 | },
3289 | "node_modules/mime-types": {
3290 | "version": "2.1.35",
3291 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
3292 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
3293 | "license": "MIT",
3294 | "dependencies": {
3295 | "mime-db": "1.52.0"
3296 | },
3297 | "engines": {
3298 | "node": ">= 0.6"
3299 | }
3300 | },
3301 | "node_modules/minimatch": {
3302 | "version": "3.1.2",
3303 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
3304 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
3305 | "dev": true,
3306 | "license": "ISC",
3307 | "dependencies": {
3308 | "brace-expansion": "^1.1.7"
3309 | },
3310 | "engines": {
3311 | "node": "*"
3312 | }
3313 | },
3314 | "node_modules/ms": {
3315 | "version": "2.1.3",
3316 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
3317 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
3318 | "dev": true,
3319 | "license": "MIT"
3320 | },
3321 | "node_modules/nanoid": {
3322 | "version": "3.3.7",
3323 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz",
3324 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==",
3325 | "dev": true,
3326 | "funding": [
3327 | {
3328 | "type": "github",
3329 | "url": "https://github.com/sponsors/ai"
3330 | }
3331 | ],
3332 | "license": "MIT",
3333 | "bin": {
3334 | "nanoid": "bin/nanoid.cjs"
3335 | },
3336 | "engines": {
3337 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
3338 | }
3339 | },
3340 | "node_modules/natural-compare": {
3341 | "version": "1.4.0",
3342 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
3343 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
3344 | "dev": true,
3345 | "license": "MIT"
3346 | },
3347 | "node_modules/node-releases": {
3348 | "version": "2.0.18",
3349 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz",
3350 | "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==",
3351 | "dev": true,
3352 | "license": "MIT"
3353 | },
3354 | "node_modules/object-assign": {
3355 | "version": "4.1.1",
3356 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
3357 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==",
3358 | "dev": true,
3359 | "license": "MIT",
3360 | "engines": {
3361 | "node": ">=0.10.0"
3362 | }
3363 | },
3364 | "node_modules/object-inspect": {
3365 | "version": "1.13.2",
3366 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz",
3367 | "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==",
3368 | "dev": true,
3369 | "license": "MIT",
3370 | "engines": {
3371 | "node": ">= 0.4"
3372 | },
3373 | "funding": {
3374 | "url": "https://github.com/sponsors/ljharb"
3375 | }
3376 | },
3377 | "node_modules/object-keys": {
3378 | "version": "1.1.1",
3379 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz",
3380 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==",
3381 | "dev": true,
3382 | "license": "MIT",
3383 | "engines": {
3384 | "node": ">= 0.4"
3385 | }
3386 | },
3387 | "node_modules/object.assign": {
3388 | "version": "4.1.5",
3389 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz",
3390 | "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==",
3391 | "dev": true,
3392 | "license": "MIT",
3393 | "dependencies": {
3394 | "call-bind": "^1.0.5",
3395 | "define-properties": "^1.2.1",
3396 | "has-symbols": "^1.0.3",
3397 | "object-keys": "^1.1.1"
3398 | },
3399 | "engines": {
3400 | "node": ">= 0.4"
3401 | },
3402 | "funding": {
3403 | "url": "https://github.com/sponsors/ljharb"
3404 | }
3405 | },
3406 | "node_modules/object.entries": {
3407 | "version": "1.1.8",
3408 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz",
3409 | "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==",
3410 | "dev": true,
3411 | "license": "MIT",
3412 | "dependencies": {
3413 | "call-bind": "^1.0.7",
3414 | "define-properties": "^1.2.1",
3415 | "es-object-atoms": "^1.0.0"
3416 | },
3417 | "engines": {
3418 | "node": ">= 0.4"
3419 | }
3420 | },
3421 | "node_modules/object.fromentries": {
3422 | "version": "2.0.8",
3423 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz",
3424 | "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==",
3425 | "dev": true,
3426 | "license": "MIT",
3427 | "dependencies": {
3428 | "call-bind": "^1.0.7",
3429 | "define-properties": "^1.2.1",
3430 | "es-abstract": "^1.23.2",
3431 | "es-object-atoms": "^1.0.0"
3432 | },
3433 | "engines": {
3434 | "node": ">= 0.4"
3435 | },
3436 | "funding": {
3437 | "url": "https://github.com/sponsors/ljharb"
3438 | }
3439 | },
3440 | "node_modules/object.values": {
3441 | "version": "1.2.0",
3442 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz",
3443 | "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==",
3444 | "dev": true,
3445 | "license": "MIT",
3446 | "dependencies": {
3447 | "call-bind": "^1.0.7",
3448 | "define-properties": "^1.2.1",
3449 | "es-object-atoms": "^1.0.0"
3450 | },
3451 | "engines": {
3452 | "node": ">= 0.4"
3453 | },
3454 | "funding": {
3455 | "url": "https://github.com/sponsors/ljharb"
3456 | }
3457 | },
3458 | "node_modules/optionator": {
3459 | "version": "0.9.4",
3460 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz",
3461 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==",
3462 | "dev": true,
3463 | "license": "MIT",
3464 | "dependencies": {
3465 | "deep-is": "^0.1.3",
3466 | "fast-levenshtein": "^2.0.6",
3467 | "levn": "^0.4.1",
3468 | "prelude-ls": "^1.2.1",
3469 | "type-check": "^0.4.0",
3470 | "word-wrap": "^1.2.5"
3471 | },
3472 | "engines": {
3473 | "node": ">= 0.8.0"
3474 | }
3475 | },
3476 | "node_modules/p-limit": {
3477 | "version": "3.1.0",
3478 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
3479 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
3480 | "dev": true,
3481 | "license": "MIT",
3482 | "dependencies": {
3483 | "yocto-queue": "^0.1.0"
3484 | },
3485 | "engines": {
3486 | "node": ">=10"
3487 | },
3488 | "funding": {
3489 | "url": "https://github.com/sponsors/sindresorhus"
3490 | }
3491 | },
3492 | "node_modules/p-locate": {
3493 | "version": "5.0.0",
3494 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
3495 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
3496 | "dev": true,
3497 | "license": "MIT",
3498 | "dependencies": {
3499 | "p-limit": "^3.0.2"
3500 | },
3501 | "engines": {
3502 | "node": ">=10"
3503 | },
3504 | "funding": {
3505 | "url": "https://github.com/sponsors/sindresorhus"
3506 | }
3507 | },
3508 | "node_modules/parent-module": {
3509 | "version": "1.0.1",
3510 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
3511 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
3512 | "dev": true,
3513 | "license": "MIT",
3514 | "dependencies": {
3515 | "callsites": "^3.0.0"
3516 | },
3517 | "engines": {
3518 | "node": ">=6"
3519 | }
3520 | },
3521 | "node_modules/path-exists": {
3522 | "version": "4.0.0",
3523 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
3524 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
3525 | "dev": true,
3526 | "license": "MIT",
3527 | "engines": {
3528 | "node": ">=8"
3529 | }
3530 | },
3531 | "node_modules/path-key": {
3532 | "version": "3.1.1",
3533 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
3534 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
3535 | "dev": true,
3536 | "license": "MIT",
3537 | "engines": {
3538 | "node": ">=8"
3539 | }
3540 | },
3541 | "node_modules/path-parse": {
3542 | "version": "1.0.7",
3543 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz",
3544 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==",
3545 | "dev": true,
3546 | "license": "MIT"
3547 | },
3548 | "node_modules/picocolors": {
3549 | "version": "1.1.1",
3550 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
3551 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
3552 | "dev": true,
3553 | "license": "ISC"
3554 | },
3555 | "node_modules/possible-typed-array-names": {
3556 | "version": "1.0.0",
3557 | "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz",
3558 | "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==",
3559 | "dev": true,
3560 | "license": "MIT",
3561 | "engines": {
3562 | "node": ">= 0.4"
3563 | }
3564 | },
3565 | "node_modules/postcss": {
3566 | "version": "8.4.47",
3567 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz",
3568 | "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==",
3569 | "dev": true,
3570 | "funding": [
3571 | {
3572 | "type": "opencollective",
3573 | "url": "https://opencollective.com/postcss/"
3574 | },
3575 | {
3576 | "type": "tidelift",
3577 | "url": "https://tidelift.com/funding/github/npm/postcss"
3578 | },
3579 | {
3580 | "type": "github",
3581 | "url": "https://github.com/sponsors/ai"
3582 | }
3583 | ],
3584 | "license": "MIT",
3585 | "dependencies": {
3586 | "nanoid": "^3.3.7",
3587 | "picocolors": "^1.1.0",
3588 | "source-map-js": "^1.2.1"
3589 | },
3590 | "engines": {
3591 | "node": "^10 || ^12 || >=14"
3592 | }
3593 | },
3594 | "node_modules/prelude-ls": {
3595 | "version": "1.2.1",
3596 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
3597 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
3598 | "dev": true,
3599 | "license": "MIT",
3600 | "engines": {
3601 | "node": ">= 0.8.0"
3602 | }
3603 | },
3604 | "node_modules/prop-types": {
3605 | "version": "15.8.1",
3606 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz",
3607 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==",
3608 | "dev": true,
3609 | "license": "MIT",
3610 | "dependencies": {
3611 | "loose-envify": "^1.4.0",
3612 | "object-assign": "^4.1.1",
3613 | "react-is": "^16.13.1"
3614 | }
3615 | },
3616 | "node_modules/proxy-from-env": {
3617 | "version": "1.1.0",
3618 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz",
3619 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==",
3620 | "license": "MIT"
3621 | },
3622 | "node_modules/punycode": {
3623 | "version": "2.3.1",
3624 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
3625 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
3626 | "dev": true,
3627 | "license": "MIT",
3628 | "engines": {
3629 | "node": ">=6"
3630 | }
3631 | },
3632 | "node_modules/react": {
3633 | "version": "18.3.1",
3634 | "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz",
3635 | "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==",
3636 | "license": "MIT",
3637 | "dependencies": {
3638 | "loose-envify": "^1.1.0"
3639 | },
3640 | "engines": {
3641 | "node": ">=0.10.0"
3642 | }
3643 | },
3644 | "node_modules/react-dom": {
3645 | "version": "18.3.1",
3646 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz",
3647 | "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==",
3648 | "license": "MIT",
3649 | "dependencies": {
3650 | "loose-envify": "^1.1.0",
3651 | "scheduler": "^0.23.2"
3652 | },
3653 | "peerDependencies": {
3654 | "react": "^18.3.1"
3655 | }
3656 | },
3657 | "node_modules/react-is": {
3658 | "version": "16.13.1",
3659 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
3660 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==",
3661 | "dev": true,
3662 | "license": "MIT"
3663 | },
3664 | "node_modules/react-refresh": {
3665 | "version": "0.14.2",
3666 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.2.tgz",
3667 | "integrity": "sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==",
3668 | "dev": true,
3669 | "license": "MIT",
3670 | "engines": {
3671 | "node": ">=0.10.0"
3672 | }
3673 | },
3674 | "node_modules/react-router": {
3675 | "version": "6.27.0",
3676 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.27.0.tgz",
3677 | "integrity": "sha512-YA+HGZXz4jaAkVoYBE98VQl+nVzI+cVI2Oj/06F5ZM+0u3TgedN9Y9kmMRo2mnkSK2nCpNQn0DVob4HCsY/WLw==",
3678 | "license": "MIT",
3679 | "dependencies": {
3680 | "@remix-run/router": "1.20.0"
3681 | },
3682 | "engines": {
3683 | "node": ">=14.0.0"
3684 | },
3685 | "peerDependencies": {
3686 | "react": ">=16.8"
3687 | }
3688 | },
3689 | "node_modules/react-router-dom": {
3690 | "version": "6.27.0",
3691 | "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.27.0.tgz",
3692 | "integrity": "sha512-+bvtFWMC0DgAFrfKXKG9Fc+BcXWRUO1aJIihbB79xaeq0v5UzfvnM5houGUm1Y461WVRcgAQ+Clh5rdb1eCx4g==",
3693 | "license": "MIT",
3694 | "dependencies": {
3695 | "@remix-run/router": "1.20.0",
3696 | "react-router": "6.27.0"
3697 | },
3698 | "engines": {
3699 | "node": ">=14.0.0"
3700 | },
3701 | "peerDependencies": {
3702 | "react": ">=16.8",
3703 | "react-dom": ">=16.8"
3704 | }
3705 | },
3706 | "node_modules/reflect.getprototypeof": {
3707 | "version": "1.0.6",
3708 | "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz",
3709 | "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==",
3710 | "dev": true,
3711 | "license": "MIT",
3712 | "dependencies": {
3713 | "call-bind": "^1.0.7",
3714 | "define-properties": "^1.2.1",
3715 | "es-abstract": "^1.23.1",
3716 | "es-errors": "^1.3.0",
3717 | "get-intrinsic": "^1.2.4",
3718 | "globalthis": "^1.0.3",
3719 | "which-builtin-type": "^1.1.3"
3720 | },
3721 | "engines": {
3722 | "node": ">= 0.4"
3723 | },
3724 | "funding": {
3725 | "url": "https://github.com/sponsors/ljharb"
3726 | }
3727 | },
3728 | "node_modules/regexp.prototype.flags": {
3729 | "version": "1.5.3",
3730 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.3.tgz",
3731 | "integrity": "sha512-vqlC04+RQoFalODCbCumG2xIOvapzVMHwsyIGM/SIE8fRhFFsXeH8/QQ+s0T0kDAhKc4k30s73/0ydkHQz6HlQ==",
3732 | "dev": true,
3733 | "license": "MIT",
3734 | "dependencies": {
3735 | "call-bind": "^1.0.7",
3736 | "define-properties": "^1.2.1",
3737 | "es-errors": "^1.3.0",
3738 | "set-function-name": "^2.0.2"
3739 | },
3740 | "engines": {
3741 | "node": ">= 0.4"
3742 | },
3743 | "funding": {
3744 | "url": "https://github.com/sponsors/ljharb"
3745 | }
3746 | },
3747 | "node_modules/resolve": {
3748 | "version": "2.0.0-next.5",
3749 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz",
3750 | "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==",
3751 | "dev": true,
3752 | "license": "MIT",
3753 | "dependencies": {
3754 | "is-core-module": "^2.13.0",
3755 | "path-parse": "^1.0.7",
3756 | "supports-preserve-symlinks-flag": "^1.0.0"
3757 | },
3758 | "bin": {
3759 | "resolve": "bin/resolve"
3760 | },
3761 | "funding": {
3762 | "url": "https://github.com/sponsors/ljharb"
3763 | }
3764 | },
3765 | "node_modules/resolve-from": {
3766 | "version": "4.0.0",
3767 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
3768 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
3769 | "dev": true,
3770 | "license": "MIT",
3771 | "engines": {
3772 | "node": ">=4"
3773 | }
3774 | },
3775 | "node_modules/rollup": {
3776 | "version": "4.24.3",
3777 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.24.3.tgz",
3778 | "integrity": "sha512-HBW896xR5HGmoksbi3JBDtmVzWiPAYqp7wip50hjQ67JbDz61nyoMPdqu1DvVW9asYb2M65Z20ZHsyJCMqMyDg==",
3779 | "dev": true,
3780 | "license": "MIT",
3781 | "dependencies": {
3782 | "@types/estree": "1.0.6"
3783 | },
3784 | "bin": {
3785 | "rollup": "dist/bin/rollup"
3786 | },
3787 | "engines": {
3788 | "node": ">=18.0.0",
3789 | "npm": ">=8.0.0"
3790 | },
3791 | "optionalDependencies": {
3792 | "@rollup/rollup-android-arm-eabi": "4.24.3",
3793 | "@rollup/rollup-android-arm64": "4.24.3",
3794 | "@rollup/rollup-darwin-arm64": "4.24.3",
3795 | "@rollup/rollup-darwin-x64": "4.24.3",
3796 | "@rollup/rollup-freebsd-arm64": "4.24.3",
3797 | "@rollup/rollup-freebsd-x64": "4.24.3",
3798 | "@rollup/rollup-linux-arm-gnueabihf": "4.24.3",
3799 | "@rollup/rollup-linux-arm-musleabihf": "4.24.3",
3800 | "@rollup/rollup-linux-arm64-gnu": "4.24.3",
3801 | "@rollup/rollup-linux-arm64-musl": "4.24.3",
3802 | "@rollup/rollup-linux-powerpc64le-gnu": "4.24.3",
3803 | "@rollup/rollup-linux-riscv64-gnu": "4.24.3",
3804 | "@rollup/rollup-linux-s390x-gnu": "4.24.3",
3805 | "@rollup/rollup-linux-x64-gnu": "4.24.3",
3806 | "@rollup/rollup-linux-x64-musl": "4.24.3",
3807 | "@rollup/rollup-win32-arm64-msvc": "4.24.3",
3808 | "@rollup/rollup-win32-ia32-msvc": "4.24.3",
3809 | "@rollup/rollup-win32-x64-msvc": "4.24.3",
3810 | "fsevents": "~2.3.2"
3811 | }
3812 | },
3813 | "node_modules/safe-array-concat": {
3814 | "version": "1.1.2",
3815 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz",
3816 | "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==",
3817 | "dev": true,
3818 | "license": "MIT",
3819 | "dependencies": {
3820 | "call-bind": "^1.0.7",
3821 | "get-intrinsic": "^1.2.4",
3822 | "has-symbols": "^1.0.3",
3823 | "isarray": "^2.0.5"
3824 | },
3825 | "engines": {
3826 | "node": ">=0.4"
3827 | },
3828 | "funding": {
3829 | "url": "https://github.com/sponsors/ljharb"
3830 | }
3831 | },
3832 | "node_modules/safe-regex-test": {
3833 | "version": "1.0.3",
3834 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz",
3835 | "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==",
3836 | "dev": true,
3837 | "license": "MIT",
3838 | "dependencies": {
3839 | "call-bind": "^1.0.6",
3840 | "es-errors": "^1.3.0",
3841 | "is-regex": "^1.1.4"
3842 | },
3843 | "engines": {
3844 | "node": ">= 0.4"
3845 | },
3846 | "funding": {
3847 | "url": "https://github.com/sponsors/ljharb"
3848 | }
3849 | },
3850 | "node_modules/scheduler": {
3851 | "version": "0.23.2",
3852 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz",
3853 | "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==",
3854 | "license": "MIT",
3855 | "dependencies": {
3856 | "loose-envify": "^1.1.0"
3857 | }
3858 | },
3859 | "node_modules/semver": {
3860 | "version": "6.3.1",
3861 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
3862 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
3863 | "dev": true,
3864 | "license": "ISC",
3865 | "bin": {
3866 | "semver": "bin/semver.js"
3867 | }
3868 | },
3869 | "node_modules/set-function-length": {
3870 | "version": "1.2.2",
3871 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz",
3872 | "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==",
3873 | "dev": true,
3874 | "license": "MIT",
3875 | "dependencies": {
3876 | "define-data-property": "^1.1.4",
3877 | "es-errors": "^1.3.0",
3878 | "function-bind": "^1.1.2",
3879 | "get-intrinsic": "^1.2.4",
3880 | "gopd": "^1.0.1",
3881 | "has-property-descriptors": "^1.0.2"
3882 | },
3883 | "engines": {
3884 | "node": ">= 0.4"
3885 | }
3886 | },
3887 | "node_modules/set-function-name": {
3888 | "version": "2.0.2",
3889 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz",
3890 | "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==",
3891 | "dev": true,
3892 | "license": "MIT",
3893 | "dependencies": {
3894 | "define-data-property": "^1.1.4",
3895 | "es-errors": "^1.3.0",
3896 | "functions-have-names": "^1.2.3",
3897 | "has-property-descriptors": "^1.0.2"
3898 | },
3899 | "engines": {
3900 | "node": ">= 0.4"
3901 | }
3902 | },
3903 | "node_modules/shebang-command": {
3904 | "version": "2.0.0",
3905 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
3906 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
3907 | "dev": true,
3908 | "license": "MIT",
3909 | "dependencies": {
3910 | "shebang-regex": "^3.0.0"
3911 | },
3912 | "engines": {
3913 | "node": ">=8"
3914 | }
3915 | },
3916 | "node_modules/shebang-regex": {
3917 | "version": "3.0.0",
3918 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
3919 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
3920 | "dev": true,
3921 | "license": "MIT",
3922 | "engines": {
3923 | "node": ">=8"
3924 | }
3925 | },
3926 | "node_modules/side-channel": {
3927 | "version": "1.0.6",
3928 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz",
3929 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==",
3930 | "dev": true,
3931 | "license": "MIT",
3932 | "dependencies": {
3933 | "call-bind": "^1.0.7",
3934 | "es-errors": "^1.3.0",
3935 | "get-intrinsic": "^1.2.4",
3936 | "object-inspect": "^1.13.1"
3937 | },
3938 | "engines": {
3939 | "node": ">= 0.4"
3940 | },
3941 | "funding": {
3942 | "url": "https://github.com/sponsors/ljharb"
3943 | }
3944 | },
3945 | "node_modules/source-map-js": {
3946 | "version": "1.2.1",
3947 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
3948 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
3949 | "dev": true,
3950 | "license": "BSD-3-Clause",
3951 | "engines": {
3952 | "node": ">=0.10.0"
3953 | }
3954 | },
3955 | "node_modules/string.prototype.matchall": {
3956 | "version": "4.0.11",
3957 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz",
3958 | "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==",
3959 | "dev": true,
3960 | "license": "MIT",
3961 | "dependencies": {
3962 | "call-bind": "^1.0.7",
3963 | "define-properties": "^1.2.1",
3964 | "es-abstract": "^1.23.2",
3965 | "es-errors": "^1.3.0",
3966 | "es-object-atoms": "^1.0.0",
3967 | "get-intrinsic": "^1.2.4",
3968 | "gopd": "^1.0.1",
3969 | "has-symbols": "^1.0.3",
3970 | "internal-slot": "^1.0.7",
3971 | "regexp.prototype.flags": "^1.5.2",
3972 | "set-function-name": "^2.0.2",
3973 | "side-channel": "^1.0.6"
3974 | },
3975 | "engines": {
3976 | "node": ">= 0.4"
3977 | },
3978 | "funding": {
3979 | "url": "https://github.com/sponsors/ljharb"
3980 | }
3981 | },
3982 | "node_modules/string.prototype.repeat": {
3983 | "version": "1.0.0",
3984 | "resolved": "https://registry.npmjs.org/string.prototype.repeat/-/string.prototype.repeat-1.0.0.tgz",
3985 | "integrity": "sha512-0u/TldDbKD8bFCQ/4f5+mNRrXwZ8hg2w7ZR8wa16e8z9XpePWl3eGEcUD0OXpEH/VJH/2G3gjUtR3ZOiBe2S/w==",
3986 | "dev": true,
3987 | "license": "MIT",
3988 | "dependencies": {
3989 | "define-properties": "^1.1.3",
3990 | "es-abstract": "^1.17.5"
3991 | }
3992 | },
3993 | "node_modules/string.prototype.trim": {
3994 | "version": "1.2.9",
3995 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz",
3996 | "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==",
3997 | "dev": true,
3998 | "license": "MIT",
3999 | "dependencies": {
4000 | "call-bind": "^1.0.7",
4001 | "define-properties": "^1.2.1",
4002 | "es-abstract": "^1.23.0",
4003 | "es-object-atoms": "^1.0.0"
4004 | },
4005 | "engines": {
4006 | "node": ">= 0.4"
4007 | },
4008 | "funding": {
4009 | "url": "https://github.com/sponsors/ljharb"
4010 | }
4011 | },
4012 | "node_modules/string.prototype.trimend": {
4013 | "version": "1.0.8",
4014 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz",
4015 | "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==",
4016 | "dev": true,
4017 | "license": "MIT",
4018 | "dependencies": {
4019 | "call-bind": "^1.0.7",
4020 | "define-properties": "^1.2.1",
4021 | "es-object-atoms": "^1.0.0"
4022 | },
4023 | "funding": {
4024 | "url": "https://github.com/sponsors/ljharb"
4025 | }
4026 | },
4027 | "node_modules/string.prototype.trimstart": {
4028 | "version": "1.0.8",
4029 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz",
4030 | "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==",
4031 | "dev": true,
4032 | "license": "MIT",
4033 | "dependencies": {
4034 | "call-bind": "^1.0.7",
4035 | "define-properties": "^1.2.1",
4036 | "es-object-atoms": "^1.0.0"
4037 | },
4038 | "engines": {
4039 | "node": ">= 0.4"
4040 | },
4041 | "funding": {
4042 | "url": "https://github.com/sponsors/ljharb"
4043 | }
4044 | },
4045 | "node_modules/strip-json-comments": {
4046 | "version": "3.1.1",
4047 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
4048 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
4049 | "dev": true,
4050 | "license": "MIT",
4051 | "engines": {
4052 | "node": ">=8"
4053 | },
4054 | "funding": {
4055 | "url": "https://github.com/sponsors/sindresorhus"
4056 | }
4057 | },
4058 | "node_modules/supports-color": {
4059 | "version": "7.2.0",
4060 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
4061 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
4062 | "dev": true,
4063 | "license": "MIT",
4064 | "dependencies": {
4065 | "has-flag": "^4.0.0"
4066 | },
4067 | "engines": {
4068 | "node": ">=8"
4069 | }
4070 | },
4071 | "node_modules/supports-preserve-symlinks-flag": {
4072 | "version": "1.0.0",
4073 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
4074 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
4075 | "dev": true,
4076 | "license": "MIT",
4077 | "engines": {
4078 | "node": ">= 0.4"
4079 | },
4080 | "funding": {
4081 | "url": "https://github.com/sponsors/ljharb"
4082 | }
4083 | },
4084 | "node_modules/text-table": {
4085 | "version": "0.2.0",
4086 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz",
4087 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==",
4088 | "dev": true,
4089 | "license": "MIT"
4090 | },
4091 | "node_modules/type-check": {
4092 | "version": "0.4.0",
4093 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
4094 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
4095 | "dev": true,
4096 | "license": "MIT",
4097 | "dependencies": {
4098 | "prelude-ls": "^1.2.1"
4099 | },
4100 | "engines": {
4101 | "node": ">= 0.8.0"
4102 | }
4103 | },
4104 | "node_modules/typed-array-buffer": {
4105 | "version": "1.0.2",
4106 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz",
4107 | "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==",
4108 | "dev": true,
4109 | "license": "MIT",
4110 | "dependencies": {
4111 | "call-bind": "^1.0.7",
4112 | "es-errors": "^1.3.0",
4113 | "is-typed-array": "^1.1.13"
4114 | },
4115 | "engines": {
4116 | "node": ">= 0.4"
4117 | }
4118 | },
4119 | "node_modules/typed-array-byte-length": {
4120 | "version": "1.0.1",
4121 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz",
4122 | "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==",
4123 | "dev": true,
4124 | "license": "MIT",
4125 | "dependencies": {
4126 | "call-bind": "^1.0.7",
4127 | "for-each": "^0.3.3",
4128 | "gopd": "^1.0.1",
4129 | "has-proto": "^1.0.3",
4130 | "is-typed-array": "^1.1.13"
4131 | },
4132 | "engines": {
4133 | "node": ">= 0.4"
4134 | },
4135 | "funding": {
4136 | "url": "https://github.com/sponsors/ljharb"
4137 | }
4138 | },
4139 | "node_modules/typed-array-byte-offset": {
4140 | "version": "1.0.2",
4141 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz",
4142 | "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==",
4143 | "dev": true,
4144 | "license": "MIT",
4145 | "dependencies": {
4146 | "available-typed-arrays": "^1.0.7",
4147 | "call-bind": "^1.0.7",
4148 | "for-each": "^0.3.3",
4149 | "gopd": "^1.0.1",
4150 | "has-proto": "^1.0.3",
4151 | "is-typed-array": "^1.1.13"
4152 | },
4153 | "engines": {
4154 | "node": ">= 0.4"
4155 | },
4156 | "funding": {
4157 | "url": "https://github.com/sponsors/ljharb"
4158 | }
4159 | },
4160 | "node_modules/typed-array-length": {
4161 | "version": "1.0.6",
4162 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz",
4163 | "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==",
4164 | "dev": true,
4165 | "license": "MIT",
4166 | "dependencies": {
4167 | "call-bind": "^1.0.7",
4168 | "for-each": "^0.3.3",
4169 | "gopd": "^1.0.1",
4170 | "has-proto": "^1.0.3",
4171 | "is-typed-array": "^1.1.13",
4172 | "possible-typed-array-names": "^1.0.0"
4173 | },
4174 | "engines": {
4175 | "node": ">= 0.4"
4176 | },
4177 | "funding": {
4178 | "url": "https://github.com/sponsors/ljharb"
4179 | }
4180 | },
4181 | "node_modules/unbox-primitive": {
4182 | "version": "1.0.2",
4183 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz",
4184 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==",
4185 | "dev": true,
4186 | "license": "MIT",
4187 | "dependencies": {
4188 | "call-bind": "^1.0.2",
4189 | "has-bigints": "^1.0.2",
4190 | "has-symbols": "^1.0.3",
4191 | "which-boxed-primitive": "^1.0.2"
4192 | },
4193 | "funding": {
4194 | "url": "https://github.com/sponsors/ljharb"
4195 | }
4196 | },
4197 | "node_modules/update-browserslist-db": {
4198 | "version": "1.1.1",
4199 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz",
4200 | "integrity": "sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A==",
4201 | "dev": true,
4202 | "funding": [
4203 | {
4204 | "type": "opencollective",
4205 | "url": "https://opencollective.com/browserslist"
4206 | },
4207 | {
4208 | "type": "tidelift",
4209 | "url": "https://tidelift.com/funding/github/npm/browserslist"
4210 | },
4211 | {
4212 | "type": "github",
4213 | "url": "https://github.com/sponsors/ai"
4214 | }
4215 | ],
4216 | "license": "MIT",
4217 | "dependencies": {
4218 | "escalade": "^3.2.0",
4219 | "picocolors": "^1.1.0"
4220 | },
4221 | "bin": {
4222 | "update-browserslist-db": "cli.js"
4223 | },
4224 | "peerDependencies": {
4225 | "browserslist": ">= 4.21.0"
4226 | }
4227 | },
4228 | "node_modules/uri-js": {
4229 | "version": "4.4.1",
4230 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
4231 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
4232 | "dev": true,
4233 | "license": "BSD-2-Clause",
4234 | "dependencies": {
4235 | "punycode": "^2.1.0"
4236 | }
4237 | },
4238 | "node_modules/vite": {
4239 | "version": "5.4.10",
4240 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.10.tgz",
4241 | "integrity": "sha512-1hvaPshuPUtxeQ0hsVH3Mud0ZanOLwVTneA1EgbAM5LhaZEqyPWGRQ7BtaMvUrTDeEaC8pxtj6a6jku3x4z6SQ==",
4242 | "dev": true,
4243 | "license": "MIT",
4244 | "dependencies": {
4245 | "esbuild": "^0.21.3",
4246 | "postcss": "^8.4.43",
4247 | "rollup": "^4.20.0"
4248 | },
4249 | "bin": {
4250 | "vite": "bin/vite.js"
4251 | },
4252 | "engines": {
4253 | "node": "^18.0.0 || >=20.0.0"
4254 | },
4255 | "funding": {
4256 | "url": "https://github.com/vitejs/vite?sponsor=1"
4257 | },
4258 | "optionalDependencies": {
4259 | "fsevents": "~2.3.3"
4260 | },
4261 | "peerDependencies": {
4262 | "@types/node": "^18.0.0 || >=20.0.0",
4263 | "less": "*",
4264 | "lightningcss": "^1.21.0",
4265 | "sass": "*",
4266 | "sass-embedded": "*",
4267 | "stylus": "*",
4268 | "sugarss": "*",
4269 | "terser": "^5.4.0"
4270 | },
4271 | "peerDependenciesMeta": {
4272 | "@types/node": {
4273 | "optional": true
4274 | },
4275 | "less": {
4276 | "optional": true
4277 | },
4278 | "lightningcss": {
4279 | "optional": true
4280 | },
4281 | "sass": {
4282 | "optional": true
4283 | },
4284 | "sass-embedded": {
4285 | "optional": true
4286 | },
4287 | "stylus": {
4288 | "optional": true
4289 | },
4290 | "sugarss": {
4291 | "optional": true
4292 | },
4293 | "terser": {
4294 | "optional": true
4295 | }
4296 | }
4297 | },
4298 | "node_modules/which": {
4299 | "version": "2.0.2",
4300 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
4301 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
4302 | "dev": true,
4303 | "license": "ISC",
4304 | "dependencies": {
4305 | "isexe": "^2.0.0"
4306 | },
4307 | "bin": {
4308 | "node-which": "bin/node-which"
4309 | },
4310 | "engines": {
4311 | "node": ">= 8"
4312 | }
4313 | },
4314 | "node_modules/which-boxed-primitive": {
4315 | "version": "1.0.2",
4316 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz",
4317 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==",
4318 | "dev": true,
4319 | "license": "MIT",
4320 | "dependencies": {
4321 | "is-bigint": "^1.0.1",
4322 | "is-boolean-object": "^1.1.0",
4323 | "is-number-object": "^1.0.4",
4324 | "is-string": "^1.0.5",
4325 | "is-symbol": "^1.0.3"
4326 | },
4327 | "funding": {
4328 | "url": "https://github.com/sponsors/ljharb"
4329 | }
4330 | },
4331 | "node_modules/which-builtin-type": {
4332 | "version": "1.1.4",
4333 | "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.4.tgz",
4334 | "integrity": "sha512-bppkmBSsHFmIMSl8BO9TbsyzsvGjVoppt8xUiGzwiu/bhDCGxnpOKCxgqj6GuyHE0mINMDecBFPlOm2hzY084w==",
4335 | "dev": true,
4336 | "license": "MIT",
4337 | "dependencies": {
4338 | "function.prototype.name": "^1.1.6",
4339 | "has-tostringtag": "^1.0.2",
4340 | "is-async-function": "^2.0.0",
4341 | "is-date-object": "^1.0.5",
4342 | "is-finalizationregistry": "^1.0.2",
4343 | "is-generator-function": "^1.0.10",
4344 | "is-regex": "^1.1.4",
4345 | "is-weakref": "^1.0.2",
4346 | "isarray": "^2.0.5",
4347 | "which-boxed-primitive": "^1.0.2",
4348 | "which-collection": "^1.0.2",
4349 | "which-typed-array": "^1.1.15"
4350 | },
4351 | "engines": {
4352 | "node": ">= 0.4"
4353 | },
4354 | "funding": {
4355 | "url": "https://github.com/sponsors/ljharb"
4356 | }
4357 | },
4358 | "node_modules/which-collection": {
4359 | "version": "1.0.2",
4360 | "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz",
4361 | "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==",
4362 | "dev": true,
4363 | "license": "MIT",
4364 | "dependencies": {
4365 | "is-map": "^2.0.3",
4366 | "is-set": "^2.0.3",
4367 | "is-weakmap": "^2.0.2",
4368 | "is-weakset": "^2.0.3"
4369 | },
4370 | "engines": {
4371 | "node": ">= 0.4"
4372 | },
4373 | "funding": {
4374 | "url": "https://github.com/sponsors/ljharb"
4375 | }
4376 | },
4377 | "node_modules/which-typed-array": {
4378 | "version": "1.1.15",
4379 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz",
4380 | "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==",
4381 | "dev": true,
4382 | "license": "MIT",
4383 | "dependencies": {
4384 | "available-typed-arrays": "^1.0.7",
4385 | "call-bind": "^1.0.7",
4386 | "for-each": "^0.3.3",
4387 | "gopd": "^1.0.1",
4388 | "has-tostringtag": "^1.0.2"
4389 | },
4390 | "engines": {
4391 | "node": ">= 0.4"
4392 | },
4393 | "funding": {
4394 | "url": "https://github.com/sponsors/ljharb"
4395 | }
4396 | },
4397 | "node_modules/word-wrap": {
4398 | "version": "1.2.5",
4399 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz",
4400 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==",
4401 | "dev": true,
4402 | "license": "MIT",
4403 | "engines": {
4404 | "node": ">=0.10.0"
4405 | }
4406 | },
4407 | "node_modules/yallist": {
4408 | "version": "3.1.1",
4409 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
4410 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
4411 | "dev": true,
4412 | "license": "ISC"
4413 | },
4414 | "node_modules/yocto-queue": {
4415 | "version": "0.1.0",
4416 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
4417 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
4418 | "dev": true,
4419 | "license": "MIT",
4420 | "engines": {
4421 | "node": ">=10"
4422 | },
4423 | "funding": {
4424 | "url": "https://github.com/sponsors/sindresorhus"
4425 | }
4426 | }
4427 | }
4428 | }
4429 |
--------------------------------------------------------------------------------
/Auth/frontend/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "private": true,
4 | "version": "0.0.0",
5 | "type": "module",
6 | "scripts": {
7 | "dev": "vite",
8 | "build": "vite build",
9 | "lint": "eslint .",
10 | "preview": "vite preview"
11 | },
12 | "dependencies": {
13 | "axios": "^1.7.7",
14 | "react": "^18.3.1",
15 | "react-dom": "^18.3.1",
16 | "react-router-dom": "^6.27.0"
17 | },
18 | "devDependencies": {
19 | "@eslint/js": "^9.13.0",
20 | "@types/react": "^18.3.12",
21 | "@types/react-dom": "^18.3.1",
22 | "@vitejs/plugin-react": "^4.3.3",
23 | "eslint": "^9.13.0",
24 | "eslint-plugin-react": "^7.37.2",
25 | "eslint-plugin-react-hooks": "^5.0.0",
26 | "eslint-plugin-react-refresh": "^0.4.14",
27 | "globals": "^15.11.0",
28 | "vite": "^5.4.10"
29 | }
30 | }
31 |
--------------------------------------------------------------------------------
/Auth/frontend/public/vite.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/Auth/frontend/src/App.css:
--------------------------------------------------------------------------------
1 | #root {
2 | max-width: 1280px;
3 | margin: 0 auto;
4 | padding: 2rem;
5 | text-align: center;
6 | }
7 |
8 | .logo {
9 | height: 6em;
10 | padding: 1.5em;
11 | will-change: filter;
12 | transition: filter 300ms;
13 | }
14 | .logo:hover {
15 | filter: drop-shadow(0 0 2em #646cffaa);
16 | }
17 | .logo.react:hover {
18 | filter: drop-shadow(0 0 2em #61dafbaa);
19 | }
20 |
21 | @keyframes logo-spin {
22 | from {
23 | transform: rotate(0deg);
24 | }
25 | to {
26 | transform: rotate(360deg);
27 | }
28 | }
29 |
30 | @media (prefers-reduced-motion: no-preference) {
31 | a:nth-of-type(2) .logo {
32 | animation: logo-spin infinite 20s linear;
33 | }
34 | }
35 |
36 | .card {
37 | padding: 2em;
38 | }
39 |
40 | .read-the-docs {
41 | color: #888;
42 | }
43 |
--------------------------------------------------------------------------------
/Auth/frontend/src/App.jsx:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import {BrowserRouter as Router, Routes, Route, Link} from 'react-router-dom';
3 | import {AuthProvider} from './contexts/AuthContext.jsx';
4 | import Register from './components/Register.jsx';
5 | import Login from './components/Login.jsx';
6 | import UserProfile from './components/UserProfile.jsx';
7 |
8 | const App = () => {
9 | return (
10 |
11 |
12 |
13 |
14 |
21 |
22 | }/>
23 | }/>
24 | }/>
25 |
26 |
27 |
28 |
29 |
30 | );
31 | };
32 |
33 | export default App;
--------------------------------------------------------------------------------
/Auth/frontend/src/api.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios';
2 |
3 | const API_URL = 'http://localhost:8000';
4 |
5 | const loginUser = async (credentials) => {
6 | try {
7 | const params = new URLSearchParams();
8 | for (const key in credentials) {
9 | params.append(key, credentials[key]);
10 | }
11 |
12 | const response = await axios.post(
13 | `${API_URL}/auth/token`,
14 | params,
15 | {
16 | headers: {
17 | 'Content-Type': 'application/x-www-form-urlencoded',
18 | },
19 | }
20 | );
21 | return response.data;
22 | } catch (error) {
23 | console.error("Login error:", error);
24 | throw error;
25 | }
26 | };
27 |
28 | const registerUser = async (userData) => {
29 | try {
30 | await axios.post(`${API_URL}/auth/register`, userData);
31 | } catch (error) {
32 | console.error("Registration error:", error);
33 | throw error;
34 | }
35 | };
36 |
37 | const fetchUserProfile = async (token) => {
38 | try {
39 | const response = await axios.get(`${API_URL}/users/me/`, {
40 | headers: {
41 | Authorization: `Bearer ${token}`
42 | }
43 | });
44 | return response.data;
45 | } catch (error) {
46 | console.error("Fetch user profile error:", error);
47 | throw error;
48 | }
49 | };
50 |
51 | export { loginUser, registerUser, fetchUserProfile };
--------------------------------------------------------------------------------
/Auth/frontend/src/assets/react.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/Auth/frontend/src/components/Login.jsx:
--------------------------------------------------------------------------------
1 | // src/Login.jsx
2 | import React, { useState, useContext } from 'react';
3 | import { AuthContext } from '../contexts/AuthContext.jsx';
4 |
5 | const Login = () => {
6 | const [formData, setFormData] = useState({
7 | username: '',
8 | password: ''
9 | });
10 |
11 | const { login } = useContext(AuthContext);
12 |
13 | const handleChange = (e) => {
14 | setFormData({ ...formData, [e.target.name]: e.target.value });
15 | };
16 |
17 | const handleSubmit = (e) => {
18 | e.preventDefault();
19 | login(formData.username, formData.password);
20 | };
21 |
22 | return (
23 |
28 | );
29 | };
30 |
31 | export default Login;
--------------------------------------------------------------------------------
/Auth/frontend/src/components/Register.jsx:
--------------------------------------------------------------------------------
1 | // src/Register.jsx
2 | import React, { useState, useContext } from 'react';
3 | import { AuthContext } from '../contexts/AuthContext.jsx';
4 |
5 | const Register = () => {
6 | const [formData, setFormData] = useState({
7 | username: '',
8 | email: '',
9 | password: ''
10 | });
11 |
12 | const { register } = useContext(AuthContext);
13 |
14 | const handleChange = (e) => {
15 | setFormData({ ...formData, [e.target.name]: e.target.value });
16 | };
17 |
18 | const handleSubmit = (e) => {
19 | e.preventDefault();
20 | register(formData.username, formData.email, formData.password);
21 | };
22 |
23 | return (
24 |
30 | );
31 | };
32 |
33 | export default Register;
--------------------------------------------------------------------------------
/Auth/frontend/src/components/UserProfile.jsx:
--------------------------------------------------------------------------------
1 | // src/UserProfile.jsx
2 | import React, { useContext } from 'react';
3 | import { AuthContext } from '../contexts/AuthContext.jsx';
4 |
5 | const UserProfile = () => {
6 | const { user, logout } = useContext(AuthContext);
7 |
8 | if (!user) {
9 | return Loading...
;
10 | }
11 |
12 | return (
13 |
14 |
User Profile
15 |
Username: {user.username}
16 |
Email: {user.email}
17 |
18 |
19 | );
20 | };
21 |
22 | export default UserProfile;
--------------------------------------------------------------------------------
/Auth/frontend/src/contexts/AuthContext.jsx:
--------------------------------------------------------------------------------
1 | import React, { createContext, useState, useEffect } from 'react';
2 | import { useNavigate } from 'react-router-dom';
3 | import { loginUser, fetchUserProfile, registerUser } from '../api';
4 |
5 | const AuthContext = createContext({});
6 |
7 | const AuthProvider = ({ children }) => {
8 | const [token, setToken] = useState(localStorage.getItem('token'));
9 | const [user, setUser] = useState(null);
10 | const navigate = useNavigate();
11 |
12 | useEffect(() => {
13 | if (token) {
14 | const getUser = async () => {
15 | const user = await fetchUserProfile(token);
16 | setUser(user);
17 | };
18 | getUser();
19 | }
20 | }, [token]);
21 |
22 | const login = async (username, password) => {
23 | const response = await loginUser({ username, password });
24 | if (response?.access_token) {
25 | setToken(response.access_token);
26 | localStorage.setItem('token', response.access_token);
27 | const userProfile = await fetchUserProfile(response.access_token);
28 | setUser(userProfile);
29 | navigate('/profile');
30 | }
31 | };
32 |
33 | const register = async (username, email, password) => {
34 | await registerUser({ username, email, password });
35 | navigate('/login');
36 | };
37 |
38 | const logout = () => {
39 | setToken(null);
40 | setUser(null);
41 | localStorage.removeItem('token');
42 | navigate('/login');
43 | };
44 |
45 | return (
46 |
47 | {children}
48 |
49 | );
50 | };
51 |
52 | export {AuthProvider, AuthContext}
--------------------------------------------------------------------------------
/Auth/frontend/src/index.css:
--------------------------------------------------------------------------------
1 | :root {
2 | font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif;
3 | line-height: 1.5;
4 | font-weight: 400;
5 |
6 | color-scheme: light dark;
7 | color: rgba(255, 255, 255, 0.87);
8 | background-color: #242424;
9 |
10 | font-synthesis: none;
11 | text-rendering: optimizeLegibility;
12 | -webkit-font-smoothing: antialiased;
13 | -moz-osx-font-smoothing: grayscale;
14 | }
15 |
16 | a {
17 | font-weight: 500;
18 | color: #646cff;
19 | text-decoration: inherit;
20 | }
21 | a:hover {
22 | color: #535bf2;
23 | }
24 |
25 | body {
26 | margin: 0;
27 | display: flex;
28 | place-items: center;
29 | min-width: 320px;
30 | min-height: 100vh;
31 | }
32 |
33 | h1 {
34 | font-size: 3.2em;
35 | line-height: 1.1;
36 | }
37 |
38 | button {
39 | border-radius: 8px;
40 | border: 1px solid transparent;
41 | padding: 0.6em 1.2em;
42 | font-size: 1em;
43 | font-weight: 500;
44 | font-family: inherit;
45 | background-color: #1a1a1a;
46 | cursor: pointer;
47 | transition: border-color 0.25s;
48 | }
49 | button:hover {
50 | border-color: #646cff;
51 | }
52 | button:focus,
53 | button:focus-visible {
54 | outline: 4px auto -webkit-focus-ring-color;
55 | }
56 |
57 | @media (prefers-color-scheme: light) {
58 | :root {
59 | color: #213547;
60 | background-color: #ffffff;
61 | }
62 | a:hover {
63 | color: #747bff;
64 | }
65 | button {
66 | background-color: #f9f9f9;
67 | }
68 | }
69 |
--------------------------------------------------------------------------------
/Auth/frontend/src/main.jsx:
--------------------------------------------------------------------------------
1 | import { StrictMode } from 'react'
2 | import { createRoot } from 'react-dom/client'
3 | import './index.css'
4 | import App from './App.jsx'
5 |
6 | createRoot(document.getElementById('root')).render(
7 |
8 |
9 | ,
10 | )
11 |
--------------------------------------------------------------------------------
/Auth/frontend/vite.config.js:
--------------------------------------------------------------------------------
1 | import { defineConfig } from 'vite'
2 | import react from '@vitejs/plugin-react'
3 |
4 | // https://vite.dev/config/
5 | export default defineConfig({
6 | plugins: [react()],
7 | })
8 |
--------------------------------------------------------------------------------
/Auth/main.py:
--------------------------------------------------------------------------------
1 | # main.py
2 | import uvicorn
3 | from fastapi import FastAPI
4 | from fastapi.middleware.cors import CORSMiddleware
5 |
6 | from backend.routers import auth
7 | from backend.routers import user
8 |
9 | app = FastAPI(debug=True)
10 |
11 | origins = [
12 | "http://localhost:5174",
13 | # Add more origins here
14 | ]
15 |
16 | app.add_middleware(
17 | CORSMiddleware,
18 | allow_origins=origins,
19 | allow_credentials=True,
20 | allow_methods=["*"],
21 | allow_headers=["*"],
22 | )
23 |
24 | app.include_router(user.router)
25 | app.include_router(auth.router, prefix="/auth")
26 |
27 | if __name__ == "__main__":
28 | uvicorn.run(app, host="0.0.0.0", port=8000)
29 |
--------------------------------------------------------------------------------
/Simple/backend/main.py:
--------------------------------------------------------------------------------
1 | import uvicorn
2 | from fastapi import FastAPI
3 | from fastapi.middleware.cors import CORSMiddleware
4 | from pydantic import BaseModel
5 | from typing import List
6 |
7 |
8 | class Fruit(BaseModel):
9 | name: str
10 |
11 |
12 | class Fruits(BaseModel):
13 | fruits: List[Fruit]
14 |
15 |
16 | app = FastAPI(debug=True)
17 |
18 | origins = [
19 | "http://localhost:5173",
20 | # Add more origins here
21 | ]
22 |
23 | app.add_middleware(
24 | CORSMiddleware,
25 | allow_origins=origins,
26 | allow_credentials=True,
27 | allow_methods=["*"],
28 | allow_headers=["*"],
29 | )
30 |
31 | memory_db = {"fruits": []}
32 |
33 | @app.get("/fruits", response_model=Fruits)
34 | def get_fruits():
35 | return Fruits(fruits=memory_db["fruits"])
36 |
37 |
38 | @app.post("/fruits")
39 | def add_fruit(fruit: Fruit):
40 | memory_db["fruits"].append(fruit)
41 | return fruit
42 |
43 |
44 | if __name__ == "__main__":
45 | uvicorn.run(app, host="0.0.0.0", port=8000)
--------------------------------------------------------------------------------
/Simple/backend/requirements.txt:
--------------------------------------------------------------------------------
1 | fastapi
2 | uvicorn
3 | pydantic
--------------------------------------------------------------------------------
/Simple/frontend/.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 |
--------------------------------------------------------------------------------
/Simple/frontend/README.md:
--------------------------------------------------------------------------------
1 | # React + 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 |
--------------------------------------------------------------------------------
/Simple/frontend/eslint.config.js:
--------------------------------------------------------------------------------
1 | import js from '@eslint/js'
2 | import globals from 'globals'
3 | import react from 'eslint-plugin-react'
4 | import reactHooks from 'eslint-plugin-react-hooks'
5 | import reactRefresh from 'eslint-plugin-react-refresh'
6 |
7 | export default [
8 | { ignores: ['dist'] },
9 | {
10 | files: ['**/*.{js,jsx}'],
11 | languageOptions: {
12 | ecmaVersion: 2020,
13 | globals: globals.browser,
14 | parserOptions: {
15 | ecmaVersion: 'latest',
16 | ecmaFeatures: { jsx: true },
17 | sourceType: 'module',
18 | },
19 | },
20 | settings: { react: { version: '18.3' } },
21 | plugins: {
22 | react,
23 | 'react-hooks': reactHooks,
24 | 'react-refresh': reactRefresh,
25 | },
26 | rules: {
27 | ...js.configs.recommended.rules,
28 | ...react.configs.recommended.rules,
29 | ...react.configs['jsx-runtime'].rules,
30 | ...reactHooks.configs.recommended.rules,
31 | 'react/jsx-no-target-blank': 'off',
32 | 'react-refresh/only-export-components': [
33 | 'warn',
34 | { allowConstantExport: true },
35 | ],
36 | },
37 | },
38 | ]
39 |
--------------------------------------------------------------------------------
/Simple/frontend/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | Vite + React
8 |
9 |
10 |
11 |
12 |
13 |
14 |
--------------------------------------------------------------------------------
/Simple/frontend/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "frontend",
3 | "private": true,
4 | "version": "0.0.0",
5 | "type": "module",
6 | "scripts": {
7 | "dev": "vite",
8 | "build": "vite build",
9 | "lint": "eslint .",
10 | "preview": "vite preview"
11 | },
12 | "dependencies": {
13 | "axios": "^1.7.7",
14 | "react": "^18.3.1",
15 | "react-dom": "^18.3.1",
16 | "react-router-dom": "^6.27.0"
17 | },
18 | "devDependencies": {
19 | "@eslint/js": "^9.13.0",
20 | "@types/react": "^18.3.12",
21 | "@types/react-dom": "^18.3.1",
22 | "@vitejs/plugin-react": "^4.3.3",
23 | "eslint": "^9.13.0",
24 | "eslint-plugin-react": "^7.37.2",
25 | "eslint-plugin-react-hooks": "^5.0.0",
26 | "eslint-plugin-react-refresh": "^0.4.14",
27 | "globals": "^15.11.0",
28 | "vite": "^5.4.10"
29 | }
30 | }
31 |
--------------------------------------------------------------------------------
/Simple/frontend/public/vite.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/Simple/frontend/src/App.css:
--------------------------------------------------------------------------------
1 | #root {
2 | max-width: 1280px;
3 | margin: 0 auto;
4 | padding: 2rem;
5 | text-align: center;
6 | }
7 |
8 | .logo {
9 | height: 6em;
10 | padding: 1.5em;
11 | will-change: filter;
12 | transition: filter 300ms;
13 | }
14 | .logo:hover {
15 | filter: drop-shadow(0 0 2em #646cffaa);
16 | }
17 | .logo.react:hover {
18 | filter: drop-shadow(0 0 2em #61dafbaa);
19 | }
20 |
21 | @keyframes logo-spin {
22 | from {
23 | transform: rotate(0deg);
24 | }
25 | to {
26 | transform: rotate(360deg);
27 | }
28 | }
29 |
30 | @media (prefers-reduced-motion: no-preference) {
31 | a:nth-of-type(2) .logo {
32 | animation: logo-spin infinite 20s linear;
33 | }
34 | }
35 |
36 | .card {
37 | padding: 2em;
38 | }
39 |
40 | .read-the-docs {
41 | color: #888;
42 | }
43 |
--------------------------------------------------------------------------------
/Simple/frontend/src/App.jsx:
--------------------------------------------------------------------------------
1 | import React from 'react';
2 | import './App.css';
3 | import FruitList from './components/Fruits';
4 |
5 | const App = () => {
6 | return (
7 |
8 |
9 | Fruit Management App
10 |
11 |
12 |
13 |
14 |
15 | );
16 | };
17 |
18 | export default App;
--------------------------------------------------------------------------------
/Simple/frontend/src/api.js:
--------------------------------------------------------------------------------
1 | import axios from 'axios';
2 |
3 | // Create an instance of axios with the base URL
4 | const api = axios.create({
5 | baseURL: "http://localhost:8000"
6 | });
7 |
8 | // Export the Axios instance
9 | export default api;
--------------------------------------------------------------------------------
/Simple/frontend/src/assets/react.svg:
--------------------------------------------------------------------------------
1 |
--------------------------------------------------------------------------------
/Simple/frontend/src/components/AddFruitForm.jsx:
--------------------------------------------------------------------------------
1 | import React, { useState } from 'react';
2 |
3 | const AddFruitForm = ({ addFruit }) => {
4 | const [fruitName, setFruitName] = useState('');
5 |
6 | const handleSubmit = (event) => {
7 | event.preventDefault();
8 | if (fruitName) {
9 | addFruit(fruitName);
10 | setFruitName('');
11 | }
12 | };
13 |
14 | return (
15 |
24 | );
25 | };
26 |
27 | export default AddFruitForm;
--------------------------------------------------------------------------------
/Simple/frontend/src/components/Fruits.jsx:
--------------------------------------------------------------------------------
1 | import React, { useEffect, useState } from 'react';
2 | import AddFruitForm from './AddFruitForm';
3 | import api from '../api';
4 |
5 | const FruitList = () => {
6 | const [fruits, setFruits] = useState([]);
7 |
8 | const fetchFruits = async () => {
9 | try {
10 | const response = await api.get('/fruits');
11 | setFruits(response.data.fruits);
12 | } catch (error) {
13 | console.error("Error fetching fruits", error);
14 | }
15 | };
16 |
17 | const addFruit = async (fruitName) => {
18 | try {
19 | await api.post('/fruits', { name: fruitName });
20 | fetchFruits(); // Refresh the list after adding a fruit
21 | } catch (error) {
22 | console.error("Error adding fruit", error);
23 | }
24 | };
25 |
26 | useEffect(() => {
27 | fetchFruits();
28 | }, []);
29 |
30 | return (
31 |
32 |
Fruits List
33 |
34 | {fruits.map((fruit, index) => (
35 | - {fruit.name}
36 | ))}
37 |
38 |
39 |
40 | );
41 | };
42 |
43 | export default FruitList;
--------------------------------------------------------------------------------
/Simple/frontend/src/index.css:
--------------------------------------------------------------------------------
1 | :root {
2 | font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif;
3 | line-height: 1.5;
4 | font-weight: 400;
5 |
6 | color-scheme: light dark;
7 | color: rgba(255, 255, 255, 0.87);
8 | background-color: #242424;
9 |
10 | font-synthesis: none;
11 | text-rendering: optimizeLegibility;
12 | -webkit-font-smoothing: antialiased;
13 | -moz-osx-font-smoothing: grayscale;
14 | }
15 |
16 | a {
17 | font-weight: 500;
18 | color: #646cff;
19 | text-decoration: inherit;
20 | }
21 | a:hover {
22 | color: #535bf2;
23 | }
24 |
25 | body {
26 | margin: 0;
27 | display: flex;
28 | place-items: center;
29 | min-width: 320px;
30 | min-height: 100vh;
31 | }
32 |
33 | h1 {
34 | font-size: 3.2em;
35 | line-height: 1.1;
36 | }
37 |
38 | button {
39 | border-radius: 8px;
40 | border: 1px solid transparent;
41 | padding: 0.6em 1.2em;
42 | font-size: 1em;
43 | font-weight: 500;
44 | font-family: inherit;
45 | background-color: #1a1a1a;
46 | cursor: pointer;
47 | transition: border-color 0.25s;
48 | }
49 | button:hover {
50 | border-color: #646cff;
51 | }
52 | button:focus,
53 | button:focus-visible {
54 | outline: 4px auto -webkit-focus-ring-color;
55 | }
56 |
57 | @media (prefers-color-scheme: light) {
58 | :root {
59 | color: #213547;
60 | background-color: #ffffff;
61 | }
62 | a:hover {
63 | color: #747bff;
64 | }
65 | button {
66 | background-color: #f9f9f9;
67 | }
68 | }
69 |
--------------------------------------------------------------------------------
/Simple/frontend/src/main.jsx:
--------------------------------------------------------------------------------
1 | import { StrictMode } from 'react'
2 | import { createRoot } from 'react-dom/client'
3 | import './index.css'
4 | import App from './App.jsx'
5 |
6 | createRoot(document.getElementById('root')).render(
7 |
8 |
9 | ,
10 | )
11 |
--------------------------------------------------------------------------------
/Simple/frontend/vite.config.js:
--------------------------------------------------------------------------------
1 | import { defineConfig } from 'vite'
2 | import react from '@vitejs/plugin-react'
3 |
4 | // https://vite.dev/config/
5 | export default defineConfig({
6 | plugins: [react()],
7 | })
8 |
--------------------------------------------------------------------------------
/notes.md:
--------------------------------------------------------------------------------
1 | # FastAPI + React
2 |
3 | ## FastAPI Setup
4 |
5 | ### Dependencies
6 |
7 | - Python 3.9+
8 |
9 | ### Setup
10 |
11 | - `mkdir backend`
12 | - `cd backend`
13 | - Create a virtual environment: `python3 -m venv venv`
14 | - Activate the virtual environment:
15 | - Mac/Linux: `source ./venv/bin/activate`
16 | - Windows: `.\venv\Scripts\activate`
17 | - Install the dependencies from [requirements.txt](./backend/requirements.txt)
18 | - `pip install -r requirements.txt`
19 |
20 | ### Basic FastAPI Without Auth
21 |
22 | ```python
23 | import uvicorn
24 | from fastapi import FastAPI
25 | from fastapi.middleware.cors import CORSMiddleware
26 | from pydantic import BaseModel
27 | from typing import List
28 |
29 | class Fruit(BaseModel):
30 | name: str
31 |
32 | class Fruits(BaseModel):
33 | fruits: List[Fruit]
34 |
35 | app = FastAPI(debug=True)
36 |
37 | origins = [
38 | "http://localhost:3000",
39 | # Add more origins here
40 | ]
41 |
42 | app.add_middleware(
43 | CORSMiddleware,
44 | allow_origins=origins,
45 | allow_credentials=True,
46 | allow_methods=["*"],
47 | allow_headers=["*"],
48 | )
49 |
50 | memory_db = {"fruits": []}
51 |
52 | @app.get("/fruits", response_model=Fruits)
53 | def get_fruits():
54 | return Fruits(fruits=memory_db["fruits"])
55 |
56 | @app.post("/fruits")
57 | def add_fruit(fruit: Fruit):
58 | memory_db["fruits"].append(fruit)
59 | return fruit
60 |
61 |
62 | if __name__ == "__main__":
63 | uvicorn.run(app, host="0.0.0.0", port=8000)
64 | ```
65 |
66 | ### Run the API
67 |
68 | - `python main.py`
69 |
70 | ## React Setup
71 |
72 | ### Dependencies
73 |
74 | - NodeJS
75 |
76 | ### Setup
77 |
78 | - `npm create vite@latest frontend --template react`
79 | - `cd frontend`
80 | - `npm install`
81 | - `npm install axios`
82 |
83 | ### Components
84 |
85 | - Make the following dir structure
86 | - src/
87 | - components/
88 | - Fruits.jsx
89 | - AddFruitForm.jsx
90 | - App.jsx
91 | - main.jsx
92 | - api.js
93 |
94 | ### Fruits.jsx
95 |
96 | ```jsx
97 | import React, { useEffect, useState } from 'react';
98 | import api from "../api.js";
99 | import AddFruitForm from './AddFruitForm';
100 |
101 | const FruitList = () => {
102 | const [fruits, setFruits] = useState([]);
103 |
104 | const fetchFruits = async () => {
105 | try {
106 | const response = await api.get('/fruits');
107 | setFruits(response.data.fruits);
108 | } catch (error) {
109 | console.error("Error fetching fruits", error);
110 | }
111 | };
112 |
113 | const addFruit = async (fruitName) => {
114 | try {
115 | await api.post('/fruits', { name: fruitName });
116 | fetchFruits(); // Refresh the list after adding a fruit
117 | } catch (error) {
118 | console.error("Error adding fruit", error);
119 | }
120 | };
121 |
122 | useEffect(() => {
123 | fetchFruits();
124 | }, []);
125 |
126 | return (
127 |
128 |
Fruits List
129 |
130 | {fruits.map((fruit, index) => (
131 | - {fruit.name}
132 | ))}
133 |
134 |
135 |
136 | );
137 | };
138 |
139 | export default FruitList;
140 | ```
141 |
142 | ### AddFruitForm.jsx
143 |
144 | ```jsx
145 | import React, { useState } from 'react';
146 |
147 | const AddFruitForm = ({ addFruit }) => {
148 | const [fruitName, setFruitName] = useState('');
149 |
150 | const handleSubmit = (event) => {
151 | event.preventDefault();
152 | if (fruitName) {
153 | addFruit(fruitName);
154 | setFruitName('');
155 | }
156 | };
157 |
158 | return (
159 |
168 | );
169 | };
170 |
171 | export default AddFruitForm;
172 | ```
173 |
174 | ### App.jsx
175 |
176 | ```jsx
177 | import React from 'react';
178 | import './App.css';
179 | import FruitList from './components/Fruits';
180 |
181 | const App = () => {
182 | return (
183 |
184 |
185 | Fruit Management App
186 |
187 |
188 |
189 |
190 |
191 | );
192 | };
193 |
194 | export default App;
195 | ```
196 |
197 | ### api.js
198 |
199 | ```js
200 | import axios from 'axios';
201 |
202 | // Create an instance of axios with the base URL
203 | const api = axios.create({
204 | baseURL: "http://localhost:8000"
205 | });
206 |
207 | // Export the Axios instance
208 | export default api;
209 | ```
210 |
211 | ### Run the App
212 |
213 | - `npm run dev`
214 |
--------------------------------------------------------------------------------