├── .gitignore ├── backend ├── .choreo │ └── endpoints.yaml ├── .gitignore ├── Dockerfile ├── Procfile ├── manage.py ├── myapp │ ├── __init__.py │ ├── __pycache__ │ │ ├── __init__.cpython-311.pyc │ │ ├── admin.cpython-311.pyc │ │ ├── apps.cpython-311.pyc │ │ ├── models.cpython-311.pyc │ │ ├── serializers.cpython-311.pyc │ │ ├── urls.cpython-311.pyc │ │ └── views.cpython-311.pyc │ ├── admin.py │ ├── apps.py │ ├── migrations │ │ ├── 0001_initial.py │ │ ├── __init__.py │ │ └── __pycache__ │ │ │ ├── 0001_initial.cpython-311.pyc │ │ │ └── __init__.cpython-311.pyc │ ├── models.py │ ├── serializers.py │ ├── tests.py │ ├── urls.py │ └── views.py ├── myproject │ ├── __init__.py │ ├── __pycache__ │ │ ├── __init__.cpython-311.pyc │ │ ├── settings.cpython-311.pyc │ │ ├── urls.cpython-311.pyc │ │ └── wsgi.cpython-311.pyc │ ├── asgi.py │ ├── settings.py │ ├── urls.py │ └── wsgi.py └── requirements.txt ├── commands.txt └── frontend ├── .eslintrc.cjs ├── .gitignore ├── README.md ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.jsx ├── api.js ├── assets │ └── react.svg ├── components │ ├── LoadingIndicator.jsx │ ├── Note.jsx │ └── ProtectedRoute.jsx ├── constants.js ├── main.jsx ├── pages │ ├── Form.jsx │ ├── Home.jsx │ ├── Login.jsx │ ├── NotFound.jsx │ └── Register.jsx └── styles │ ├── FormStyles.css │ ├── LoadingIndicator.css │ ├── Note.css │ └── NoteStyles.css └── vite.config.js /.gitignore: -------------------------------------------------------------------------------- 1 | env/ -------------------------------------------------------------------------------- /backend/.choreo/endpoints.yaml: -------------------------------------------------------------------------------- 1 | # +required Version of the endpoint configuration YAML 2 | version: 0.1 3 | 4 | # +required List of endpoints to create 5 | endpoints: 6 | # +required Unique name for the endpoint. (This name will be used when generating the managed API) 7 | - name: Test REST Endpoint 8 | # +required Numeric port value that gets exposed via this endpoint 9 | port: 8080 10 | # +required Type of the traffic this endpoint is accepting. Example: REST, GraphQL, etc. 11 | # Allowed values: REST, GraphQL, GRPC 12 | type: REST 13 | # +optional Network level visibility of this endpoint. Defaults to Project 14 | # Accepted values: Project|Organization|Public. 15 | networkVisibility: Public 16 | # +optional Context (base path) of the API that is exposed via this endpoint. 17 | # This is mandatory if the endpoint type is set to REST or GraphQL. 18 | context: / -------------------------------------------------------------------------------- /backend/.gitignore: -------------------------------------------------------------------------------- 1 | *.sqlite3 2 | .env -------------------------------------------------------------------------------- /backend/Dockerfile: -------------------------------------------------------------------------------- 1 | # syntax=docker/dockerfile:1.4 2 | 3 | FROM --platform=$BUILDPLATFORM python:3.10-alpine AS builder 4 | EXPOSE 8000 5 | WORKDIR /app 6 | # Install system dependencies 7 | RUN apk update 8 | RUN apk add \ 9 | pkgconfig \ 10 | gcc \ 11 | musl-dev \ 12 | bash 13 | 14 | # Install any needed packages specified in requirements.txt 15 | COPY requirements.txt /app 16 | RUN pip install --no-cache-dir -r requirements.txt 17 | 18 | # Copy the current directory contents into the container at /usr/src/app 19 | COPY . /app 20 | # Run server 21 | ENTRYPOINT [ "python3"] 22 | CMD ["manage.py", "runserver", "0.0.0.0:8000"] 23 | 24 | -------------------------------------------------------------------------------- /backend/Procfile: -------------------------------------------------------------------------------- 1 | web: python manage.py runserver 0.0.0.0:8080 -------------------------------------------------------------------------------- /backend/manage.py: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env python 2 | """Django's command-line utility for administrative tasks.""" 3 | import os 4 | import sys 5 | 6 | 7 | def main(): 8 | """Run administrative tasks.""" 9 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings') 10 | try: 11 | from django.core.management import execute_from_command_line 12 | except ImportError as exc: 13 | raise ImportError( 14 | "Couldn't import Django. Are you sure it's installed and " 15 | "available on your PYTHONPATH environment variable? Did you " 16 | "forget to activate a virtual environment?" 17 | ) from exc 18 | execute_from_command_line(sys.argv) 19 | 20 | 21 | if __name__ == '__main__': 22 | main() 23 | -------------------------------------------------------------------------------- /backend/myapp/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__init__.py -------------------------------------------------------------------------------- /backend/myapp/__pycache__/__init__.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/__init__.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/admin.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/admin.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/apps.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/apps.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/models.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/models.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/serializers.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/serializers.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/urls.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/urls.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/__pycache__/views.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/__pycache__/views.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/admin.py: -------------------------------------------------------------------------------- 1 | from django.contrib import admin 2 | from .models import Note 3 | 4 | # Register your models here. 5 | admin.site.register(Note) 6 | -------------------------------------------------------------------------------- /backend/myapp/apps.py: -------------------------------------------------------------------------------- 1 | from django.apps import AppConfig 2 | 3 | 4 | class MyappConfig(AppConfig): 5 | default_auto_field = 'django.db.models.BigAutoField' 6 | name = 'myapp' 7 | -------------------------------------------------------------------------------- /backend/myapp/migrations/0001_initial.py: -------------------------------------------------------------------------------- 1 | # Generated by Django 5.0.2 on 2024-03-01 09:42 2 | 3 | import django.db.models.deletion 4 | from django.conf import settings 5 | from django.db import migrations, models 6 | 7 | 8 | class Migration(migrations.Migration): 9 | 10 | initial = True 11 | 12 | dependencies = [ 13 | migrations.swappable_dependency(settings.AUTH_USER_MODEL), 14 | ] 15 | 16 | operations = [ 17 | migrations.CreateModel( 18 | name='Note', 19 | fields=[ 20 | ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 21 | ('title', models.CharField(max_length=100)), 22 | ('content', models.TextField()), 23 | ('created_at', models.DateTimeField(auto_now_add=True)), 24 | ('author', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='notes', to=settings.AUTH_USER_MODEL)), 25 | ], 26 | ), 27 | ] 28 | -------------------------------------------------------------------------------- /backend/myapp/migrations/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/migrations/__init__.py -------------------------------------------------------------------------------- /backend/myapp/migrations/__pycache__/0001_initial.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/migrations/__pycache__/0001_initial.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/migrations/__pycache__/__init__.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myapp/migrations/__pycache__/__init__.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myapp/models.py: -------------------------------------------------------------------------------- 1 | from django.db import models 2 | from django.contrib.auth.models import User 3 | 4 | 5 | class Note(models.Model): 6 | title = models.CharField(max_length=100) 7 | content = models.TextField() 8 | created_at = models.DateTimeField(auto_now_add=True) 9 | author = models.ForeignKey(User, on_delete=models.CASCADE, related_name="notes") 10 | 11 | def __str__(self): 12 | return self.title 13 | -------------------------------------------------------------------------------- /backend/myapp/serializers.py: -------------------------------------------------------------------------------- 1 | from django.contrib.auth.models import User 2 | from rest_framework import serializers 3 | from .models import Note 4 | 5 | 6 | class UserSerializer(serializers.ModelSerializer): 7 | class Meta: 8 | model = User 9 | fields = ["id", "username", "password"] 10 | extra_kwargs = {"password": {"write_only": True}} 11 | 12 | def create(self, validated_data): 13 | user = User.objects.create_user(**validated_data) 14 | return user 15 | 16 | 17 | class NoteSerializer(serializers.ModelSerializer): 18 | class Meta: 19 | model = Note 20 | fields = ["id", "title", "content", "created_at", "author"] 21 | extra_kwargs = {"author": {"read_only": True}} 22 | -------------------------------------------------------------------------------- /backend/myapp/tests.py: -------------------------------------------------------------------------------- 1 | from django.test import TestCase 2 | 3 | # Create your tests here. 4 | -------------------------------------------------------------------------------- /backend/myapp/urls.py: -------------------------------------------------------------------------------- 1 | from django.urls import path 2 | from . import views 3 | 4 | urlpatterns = [ 5 | path("notes/", views.NoteListCreate.as_view(), name="note-list"), 6 | path("notes/delete//", views.NoteDelete.as_view(), name="note-delete"), 7 | ] 8 | -------------------------------------------------------------------------------- /backend/myapp/views.py: -------------------------------------------------------------------------------- 1 | from django.contrib.auth.models import User 2 | from rest_framework import generics 3 | from .serializers import UserSerializer, NoteSerializer 4 | from .models import Note 5 | from rest_framework.permissions import IsAuthenticated, AllowAny 6 | 7 | 8 | class NoteListCreate(generics.ListCreateAPIView): 9 | serializer_class = NoteSerializer 10 | permission_classes = [IsAuthenticated] 11 | 12 | def get_queryset(self): 13 | user = self.request.user 14 | return Note.objects.filter(author=user) 15 | 16 | def perform_create(self, serializer): 17 | if serializer.is_valid(): 18 | serializer.save(author=self.request.user) 19 | else: 20 | print(serializer.errors) # Add this line for debugging 21 | 22 | 23 | class NoteDelete(generics.DestroyAPIView): 24 | queryset = Note.objects.all() 25 | serializer_class = NoteSerializer 26 | permission_classes = [IsAuthenticated] 27 | 28 | def get_queryset(self): 29 | user = self.request.user 30 | return Note.objects.filter(author=user) 31 | 32 | 33 | class CreateUserView(generics.CreateAPIView): 34 | queryset = User.objects.all() 35 | serializer_class = UserSerializer 36 | permission_classes = [AllowAny] 37 | -------------------------------------------------------------------------------- /backend/myproject/__init__.py: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myproject/__init__.py -------------------------------------------------------------------------------- /backend/myproject/__pycache__/__init__.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myproject/__pycache__/__init__.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myproject/__pycache__/settings.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myproject/__pycache__/settings.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myproject/__pycache__/urls.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myproject/__pycache__/urls.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myproject/__pycache__/wsgi.cpython-311.pyc: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/techwithtim/Django-React-Sample/60991366439734dda8b29479bce207459ea91305/backend/myproject/__pycache__/wsgi.cpython-311.pyc -------------------------------------------------------------------------------- /backend/myproject/asgi.py: -------------------------------------------------------------------------------- 1 | """ 2 | ASGI config for myproject project. 3 | 4 | It exposes the ASGI callable as a module-level variable named ``application``. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/5.0/howto/deployment/asgi/ 8 | """ 9 | 10 | import os 11 | 12 | from django.core.asgi import get_asgi_application 13 | 14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings') 15 | 16 | application = get_asgi_application() 17 | -------------------------------------------------------------------------------- /backend/myproject/settings.py: -------------------------------------------------------------------------------- 1 | """ 2 | Django settings for myproject project. 3 | 4 | Generated by 'django-admin startproject' using Django 5.0.2. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/5.0/topics/settings/ 8 | 9 | For the full list of settings and their values, see 10 | https://docs.djangoproject.com/en/5.0/ref/settings/ 11 | """ 12 | 13 | from pathlib import Path 14 | from datetime import timedelta 15 | from dotenv import load_dotenv 16 | import os 17 | 18 | load_dotenv() 19 | 20 | # Build paths inside the project like this: BASE_DIR / 'subdir'. 21 | BASE_DIR = Path(__file__).resolve().parent.parent 22 | 23 | 24 | # Quick-start development settings - unsuitable for production 25 | # See https://docs.djangoproject.com/en/5.0/howto/deployment/checklist/ 26 | 27 | # SECURITY WARNING: keep the secret key used in production secret! 28 | SECRET_KEY = "django-insecure-pa&t9y8_gsj#eh_(eusc-x#-83vk(5wx=_-e7ixk$&rsmgu@wn" 29 | 30 | # SECURITY WARNING: don't run with debug turned on in production! 31 | DEBUG = False 32 | 33 | ALLOWED_HOSTS = ["*"] 34 | 35 | REST_FRAMEWORK = { 36 | "DEFAULT_AUTHENTICATION_CLASSES": ( 37 | "rest_framework_simplejwt.authentication.JWTAuthentication", 38 | ), 39 | "DEFAULT_PERMISSION_CLASSES": [ 40 | "rest_framework.permissions.IsAuthenticated", 41 | ], 42 | } 43 | 44 | SIMPLE_JWT = { 45 | "ACCESS_TOKEN_LIFETIME": timedelta(minutes=30), 46 | "REFRESH_TOKEN_LIFETIME": timedelta(days=1), 47 | } 48 | 49 | # Application definition 50 | 51 | INSTALLED_APPS = [ 52 | "corsheaders", 53 | "django.contrib.admin", 54 | "django.contrib.auth", 55 | "django.contrib.contenttypes", 56 | "django.contrib.sessions", 57 | "django.contrib.messages", 58 | "django.contrib.staticfiles", 59 | "myapp", 60 | "rest_framework", 61 | ] 62 | 63 | MIDDLEWARE = [ 64 | "corsheaders.middleware.CorsMiddleware", 65 | "django.middleware.security.SecurityMiddleware", 66 | "django.contrib.sessions.middleware.SessionMiddleware", 67 | "django.middleware.common.CommonMiddleware", 68 | "django.middleware.csrf.CsrfViewMiddleware", 69 | "django.contrib.auth.middleware.AuthenticationMiddleware", 70 | "django.contrib.messages.middleware.MessageMiddleware", 71 | "django.middleware.clickjacking.XFrameOptionsMiddleware", 72 | ] 73 | 74 | 75 | ROOT_URLCONF = "myproject.urls" 76 | 77 | TEMPLATES = [ 78 | { 79 | "BACKEND": "django.template.backends.django.DjangoTemplates", 80 | "DIRS": [], 81 | "APP_DIRS": True, 82 | "OPTIONS": { 83 | "context_processors": [ 84 | "django.template.context_processors.debug", 85 | "django.template.context_processors.request", 86 | "django.contrib.auth.context_processors.auth", 87 | "django.contrib.messages.context_processors.messages", 88 | ], 89 | }, 90 | }, 91 | ] 92 | 93 | WSGI_APPLICATION = "myproject.wsgi.application" 94 | 95 | 96 | # Database 97 | # https://docs.djangoproject.com/en/5.0/ref/settings/#databases 98 | 99 | DATABASES = { 100 | "default": { 101 | "ENGINE": "django.db.backends.postgresql", 102 | "NAME": os.getenv("DB_NAME"), 103 | "USER": os.getenv("DB_USER"), 104 | "PASSWORD": os.getenv("DB_PWD"), 105 | "HOST": os.getenv("DB_HOST"), # Or an IP Address that your DB is hosted on 106 | "PORT": os.getenv("DB_PORT"), 107 | } 108 | } 109 | 110 | 111 | # Password validation 112 | # https://docs.djangoproject.com/en/5.0/ref/settings/#auth-password-validators 113 | 114 | AUTH_PASSWORD_VALIDATORS = [ 115 | { 116 | "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator", 117 | }, 118 | { 119 | "NAME": "django.contrib.auth.password_validation.MinimumLengthValidator", 120 | }, 121 | { 122 | "NAME": "django.contrib.auth.password_validation.CommonPasswordValidator", 123 | }, 124 | { 125 | "NAME": "django.contrib.auth.password_validation.NumericPasswordValidator", 126 | }, 127 | ] 128 | 129 | 130 | # Internationalization 131 | # https://docs.djangoproject.com/en/5.0/topics/i18n/ 132 | 133 | LANGUAGE_CODE = "en-us" 134 | 135 | TIME_ZONE = "UTC" 136 | 137 | USE_I18N = True 138 | 139 | USE_TZ = True 140 | 141 | 142 | # Static files (CSS, JavaScript, Images) 143 | # https://docs.djangoproject.com/en/5.0/howto/static-files/ 144 | 145 | STATIC_URL = "static/" 146 | 147 | # Default primary key field type 148 | # https://docs.djangoproject.com/en/5.0/ref/settings/#default-auto-field 149 | 150 | DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField" 151 | 152 | CORS_ALLOW_ALL_ORIGINS = True 153 | CORS_ALLOW_CREDENTIALS = True 154 | -------------------------------------------------------------------------------- /backend/myproject/urls.py: -------------------------------------------------------------------------------- 1 | from django.contrib import admin 2 | from django.urls import path, include 3 | from myapp.views import CreateUserView 4 | from rest_framework_simplejwt.views import ( 5 | TokenObtainPairView, 6 | TokenRefreshView, 7 | ) 8 | 9 | urlpatterns = [ 10 | path("admin/", admin.site.urls), 11 | path("api/user/register/", CreateUserView.as_view(), name="register"), 12 | path("api/token/", TokenObtainPairView.as_view(), name="token_obtain_pair"), 13 | path("api/token/refresh/", TokenRefreshView.as_view(), name="token_refresh"), 14 | path("api-auth/", include("rest_framework.urls")), 15 | path("api/", include("myapp.urls")), 16 | ] 17 | -------------------------------------------------------------------------------- /backend/myproject/wsgi.py: -------------------------------------------------------------------------------- 1 | """ 2 | WSGI config for myproject project. 3 | 4 | It exposes the WSGI callable as a module-level variable named ``application``. 5 | 6 | For more information on this file, see 7 | https://docs.djangoproject.com/en/5.0/howto/deployment/wsgi/ 8 | """ 9 | 10 | import os 11 | 12 | from django.core.wsgi import get_wsgi_application 13 | 14 | os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'myproject.settings') 15 | 16 | application = get_wsgi_application() 17 | -------------------------------------------------------------------------------- /backend/requirements.txt: -------------------------------------------------------------------------------- 1 | asgiref 2 | Django 3 | django-cors-headers 4 | djangorestframework 5 | djangorestframework-simplejwt 6 | PyJWT 7 | pytz 8 | sqlparse 9 | psycopg2-binary 10 | python-dotenv 11 | -------------------------------------------------------------------------------- /commands.txt: -------------------------------------------------------------------------------- 1 | python3 -m venv env 2 | source env/bin/activate 3 | install all requirements 4 | 5 | 6 | django-admin startproject backend 7 | cd backend 8 | python manage.py startapp api 9 | 10 | --- 11 | add api and rest_framework to installed apps 12 | 13 | create models.py, urls and serializers.py 14 | cd .. 15 | 16 | --- 17 | npm create vite@latest frontend -- --template react 18 | npm install axios 19 | npm install react-router-dom 20 | npm install jwt-decode 21 | 22 | 23 | 24 | add: 25 | "proxy": "http://localhost:8000", 26 | to package.json 27 | 28 | -------------------------------------------------------------------------------- /frontend/.eslintrc.cjs: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | env: { browser: true, es2020: true }, 4 | extends: [ 5 | 'eslint:recommended', 6 | 'plugin:react/recommended', 7 | 'plugin:react/jsx-runtime', 8 | 'plugin:react-hooks/recommended', 9 | ], 10 | ignorePatterns: ['dist', '.eslintrc.cjs'], 11 | parserOptions: { ecmaVersion: 'latest', sourceType: 'module' }, 12 | settings: { react: { version: '18.2' } }, 13 | plugins: ['react-refresh'], 14 | rules: { 15 | 'react/jsx-no-target-blank': 'off', 16 | 'react-refresh/only-export-components': [ 17 | 'warn', 18 | { allowConstantExport: true }, 19 | ], 20 | }, 21 | } 22 | -------------------------------------------------------------------------------- /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 | 26 | .env -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /frontend/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | Vite + React 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | -------------------------------------------------------------------------------- /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.6.7", 12 | "dotenv": "^16.4.5", 13 | "jwt-decode": "^4.0.0", 14 | "react": "^18.2.0", 15 | "react-dom": "^18.2.0", 16 | "react-router-dom": "^6.22.2" 17 | }, 18 | "devDependencies": { 19 | "@types/react": "^18.2.56", 20 | "@types/react-dom": "^18.2.19", 21 | "@vitejs/plugin-react": "^4.2.1", 22 | "eslint": "^8.56.0", 23 | "eslint-plugin-react": "^7.33.2", 24 | "eslint-plugin-react-hooks": "^4.6.0", 25 | "eslint-plugin-react-refresh": "^0.4.5", 26 | "vite": "^5.1.4" 27 | } 28 | }, 29 | "node_modules/@aashutoshrathi/word-wrap": { 30 | "version": "1.2.6", 31 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 32 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 33 | "dev": true, 34 | "engines": { 35 | "node": ">=0.10.0" 36 | } 37 | }, 38 | "node_modules/@ampproject/remapping": { 39 | "version": "2.2.1", 40 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 41 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 42 | "dev": true, 43 | "dependencies": { 44 | "@jridgewell/gen-mapping": "^0.3.0", 45 | "@jridgewell/trace-mapping": "^0.3.9" 46 | }, 47 | "engines": { 48 | "node": ">=6.0.0" 49 | } 50 | }, 51 | "node_modules/@babel/code-frame": { 52 | "version": "7.23.5", 53 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 54 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 55 | "dev": true, 56 | "dependencies": { 57 | "@babel/highlight": "^7.23.4", 58 | "chalk": "^2.4.2" 59 | }, 60 | "engines": { 61 | "node": ">=6.9.0" 62 | } 63 | }, 64 | "node_modules/@babel/compat-data": { 65 | "version": "7.23.5", 66 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", 67 | "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", 68 | "dev": true, 69 | "engines": { 70 | "node": ">=6.9.0" 71 | } 72 | }, 73 | "node_modules/@babel/core": { 74 | "version": "7.24.0", 75 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.0.tgz", 76 | "integrity": "sha512-fQfkg0Gjkza3nf0c7/w6Xf34BW4YvzNfACRLmmb7XRLa6XHdR+K9AlJlxneFfWYf6uhOzuzZVTjF/8KfndZANw==", 77 | "dev": true, 78 | "dependencies": { 79 | "@ampproject/remapping": "^2.2.0", 80 | "@babel/code-frame": "^7.23.5", 81 | "@babel/generator": "^7.23.6", 82 | "@babel/helper-compilation-targets": "^7.23.6", 83 | "@babel/helper-module-transforms": "^7.23.3", 84 | "@babel/helpers": "^7.24.0", 85 | "@babel/parser": "^7.24.0", 86 | "@babel/template": "^7.24.0", 87 | "@babel/traverse": "^7.24.0", 88 | "@babel/types": "^7.24.0", 89 | "convert-source-map": "^2.0.0", 90 | "debug": "^4.1.0", 91 | "gensync": "^1.0.0-beta.2", 92 | "json5": "^2.2.3", 93 | "semver": "^6.3.1" 94 | }, 95 | "engines": { 96 | "node": ">=6.9.0" 97 | }, 98 | "funding": { 99 | "type": "opencollective", 100 | "url": "https://opencollective.com/babel" 101 | } 102 | }, 103 | "node_modules/@babel/generator": { 104 | "version": "7.23.6", 105 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", 106 | "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", 107 | "dev": true, 108 | "dependencies": { 109 | "@babel/types": "^7.23.6", 110 | "@jridgewell/gen-mapping": "^0.3.2", 111 | "@jridgewell/trace-mapping": "^0.3.17", 112 | "jsesc": "^2.5.1" 113 | }, 114 | "engines": { 115 | "node": ">=6.9.0" 116 | } 117 | }, 118 | "node_modules/@babel/helper-compilation-targets": { 119 | "version": "7.23.6", 120 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", 121 | "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", 122 | "dev": true, 123 | "dependencies": { 124 | "@babel/compat-data": "^7.23.5", 125 | "@babel/helper-validator-option": "^7.23.5", 126 | "browserslist": "^4.22.2", 127 | "lru-cache": "^5.1.1", 128 | "semver": "^6.3.1" 129 | }, 130 | "engines": { 131 | "node": ">=6.9.0" 132 | } 133 | }, 134 | "node_modules/@babel/helper-environment-visitor": { 135 | "version": "7.22.20", 136 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", 137 | "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", 138 | "dev": true, 139 | "engines": { 140 | "node": ">=6.9.0" 141 | } 142 | }, 143 | "node_modules/@babel/helper-function-name": { 144 | "version": "7.23.0", 145 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", 146 | "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", 147 | "dev": true, 148 | "dependencies": { 149 | "@babel/template": "^7.22.15", 150 | "@babel/types": "^7.23.0" 151 | }, 152 | "engines": { 153 | "node": ">=6.9.0" 154 | } 155 | }, 156 | "node_modules/@babel/helper-hoist-variables": { 157 | "version": "7.22.5", 158 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 159 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 160 | "dev": true, 161 | "dependencies": { 162 | "@babel/types": "^7.22.5" 163 | }, 164 | "engines": { 165 | "node": ">=6.9.0" 166 | } 167 | }, 168 | "node_modules/@babel/helper-module-imports": { 169 | "version": "7.22.15", 170 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", 171 | "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", 172 | "dev": true, 173 | "dependencies": { 174 | "@babel/types": "^7.22.15" 175 | }, 176 | "engines": { 177 | "node": ">=6.9.0" 178 | } 179 | }, 180 | "node_modules/@babel/helper-module-transforms": { 181 | "version": "7.23.3", 182 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz", 183 | "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==", 184 | "dev": true, 185 | "dependencies": { 186 | "@babel/helper-environment-visitor": "^7.22.20", 187 | "@babel/helper-module-imports": "^7.22.15", 188 | "@babel/helper-simple-access": "^7.22.5", 189 | "@babel/helper-split-export-declaration": "^7.22.6", 190 | "@babel/helper-validator-identifier": "^7.22.20" 191 | }, 192 | "engines": { 193 | "node": ">=6.9.0" 194 | }, 195 | "peerDependencies": { 196 | "@babel/core": "^7.0.0" 197 | } 198 | }, 199 | "node_modules/@babel/helper-plugin-utils": { 200 | "version": "7.24.0", 201 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.0.tgz", 202 | "integrity": "sha512-9cUznXMG0+FxRuJfvL82QlTqIzhVW9sL0KjMPHhAOOvpQGL8QtdxnBKILjBqxlHyliz0yCa1G903ZXI/FuHy2w==", 203 | "dev": true, 204 | "engines": { 205 | "node": ">=6.9.0" 206 | } 207 | }, 208 | "node_modules/@babel/helper-simple-access": { 209 | "version": "7.22.5", 210 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 211 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 212 | "dev": true, 213 | "dependencies": { 214 | "@babel/types": "^7.22.5" 215 | }, 216 | "engines": { 217 | "node": ">=6.9.0" 218 | } 219 | }, 220 | "node_modules/@babel/helper-split-export-declaration": { 221 | "version": "7.22.6", 222 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 223 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 224 | "dev": true, 225 | "dependencies": { 226 | "@babel/types": "^7.22.5" 227 | }, 228 | "engines": { 229 | "node": ">=6.9.0" 230 | } 231 | }, 232 | "node_modules/@babel/helper-string-parser": { 233 | "version": "7.23.4", 234 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", 235 | "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", 236 | "dev": true, 237 | "engines": { 238 | "node": ">=6.9.0" 239 | } 240 | }, 241 | "node_modules/@babel/helper-validator-identifier": { 242 | "version": "7.22.20", 243 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 244 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 245 | "dev": true, 246 | "engines": { 247 | "node": ">=6.9.0" 248 | } 249 | }, 250 | "node_modules/@babel/helper-validator-option": { 251 | "version": "7.23.5", 252 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz", 253 | "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==", 254 | "dev": true, 255 | "engines": { 256 | "node": ">=6.9.0" 257 | } 258 | }, 259 | "node_modules/@babel/helpers": { 260 | "version": "7.24.0", 261 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.0.tgz", 262 | "integrity": "sha512-ulDZdc0Aj5uLc5nETsa7EPx2L7rM0YJM8r7ck7U73AXi7qOV44IHHRAYZHY6iU1rr3C5N4NtTmMRUJP6kwCWeA==", 263 | "dev": true, 264 | "dependencies": { 265 | "@babel/template": "^7.24.0", 266 | "@babel/traverse": "^7.24.0", 267 | "@babel/types": "^7.24.0" 268 | }, 269 | "engines": { 270 | "node": ">=6.9.0" 271 | } 272 | }, 273 | "node_modules/@babel/highlight": { 274 | "version": "7.23.4", 275 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 276 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 277 | "dev": true, 278 | "dependencies": { 279 | "@babel/helper-validator-identifier": "^7.22.20", 280 | "chalk": "^2.4.2", 281 | "js-tokens": "^4.0.0" 282 | }, 283 | "engines": { 284 | "node": ">=6.9.0" 285 | } 286 | }, 287 | "node_modules/@babel/parser": { 288 | "version": "7.24.0", 289 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.0.tgz", 290 | "integrity": "sha512-QuP/FxEAzMSjXygs8v4N9dvdXzEHN4W1oF3PxuWAtPo08UdM17u89RDMgjLn/mlc56iM0HlLmVkO/wgR+rDgHg==", 291 | "dev": true, 292 | "bin": { 293 | "parser": "bin/babel-parser.js" 294 | }, 295 | "engines": { 296 | "node": ">=6.0.0" 297 | } 298 | }, 299 | "node_modules/@babel/plugin-transform-react-jsx-self": { 300 | "version": "7.23.3", 301 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.23.3.tgz", 302 | "integrity": "sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==", 303 | "dev": true, 304 | "dependencies": { 305 | "@babel/helper-plugin-utils": "^7.22.5" 306 | }, 307 | "engines": { 308 | "node": ">=6.9.0" 309 | }, 310 | "peerDependencies": { 311 | "@babel/core": "^7.0.0-0" 312 | } 313 | }, 314 | "node_modules/@babel/plugin-transform-react-jsx-source": { 315 | "version": "7.23.3", 316 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.23.3.tgz", 317 | "integrity": "sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==", 318 | "dev": true, 319 | "dependencies": { 320 | "@babel/helper-plugin-utils": "^7.22.5" 321 | }, 322 | "engines": { 323 | "node": ">=6.9.0" 324 | }, 325 | "peerDependencies": { 326 | "@babel/core": "^7.0.0-0" 327 | } 328 | }, 329 | "node_modules/@babel/template": { 330 | "version": "7.24.0", 331 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.0.tgz", 332 | "integrity": "sha512-Bkf2q8lMB0AFpX0NFEqSbx1OkTHf0f+0j82mkw+ZpzBnkk7e9Ql0891vlfgi+kHwOk8tQjiQHpqh4LaSa0fKEA==", 333 | "dev": true, 334 | "dependencies": { 335 | "@babel/code-frame": "^7.23.5", 336 | "@babel/parser": "^7.24.0", 337 | "@babel/types": "^7.24.0" 338 | }, 339 | "engines": { 340 | "node": ">=6.9.0" 341 | } 342 | }, 343 | "node_modules/@babel/traverse": { 344 | "version": "7.24.0", 345 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.0.tgz", 346 | "integrity": "sha512-HfuJlI8qq3dEDmNU5ChzzpZRWq+oxCZQyMzIMEqLho+AQnhMnKQUzH6ydo3RBl/YjPCuk68Y6s0Gx0AeyULiWw==", 347 | "dev": true, 348 | "dependencies": { 349 | "@babel/code-frame": "^7.23.5", 350 | "@babel/generator": "^7.23.6", 351 | "@babel/helper-environment-visitor": "^7.22.20", 352 | "@babel/helper-function-name": "^7.23.0", 353 | "@babel/helper-hoist-variables": "^7.22.5", 354 | "@babel/helper-split-export-declaration": "^7.22.6", 355 | "@babel/parser": "^7.24.0", 356 | "@babel/types": "^7.24.0", 357 | "debug": "^4.3.1", 358 | "globals": "^11.1.0" 359 | }, 360 | "engines": { 361 | "node": ">=6.9.0" 362 | } 363 | }, 364 | "node_modules/@babel/types": { 365 | "version": "7.24.0", 366 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.0.tgz", 367 | "integrity": "sha512-+j7a5c253RfKh8iABBhywc8NSfP5LURe7Uh4qpsh6jc+aLJguvmIUBdjSdEMQv2bENrCR5MfRdjGo7vzS/ob7w==", 368 | "dev": true, 369 | "dependencies": { 370 | "@babel/helper-string-parser": "^7.23.4", 371 | "@babel/helper-validator-identifier": "^7.22.20", 372 | "to-fast-properties": "^2.0.0" 373 | }, 374 | "engines": { 375 | "node": ">=6.9.0" 376 | } 377 | }, 378 | "node_modules/@esbuild/aix-ppc64": { 379 | "version": "0.19.12", 380 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz", 381 | "integrity": "sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA==", 382 | "cpu": [ 383 | "ppc64" 384 | ], 385 | "dev": true, 386 | "optional": true, 387 | "os": [ 388 | "aix" 389 | ], 390 | "engines": { 391 | "node": ">=12" 392 | } 393 | }, 394 | "node_modules/@esbuild/android-arm": { 395 | "version": "0.19.12", 396 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.12.tgz", 397 | "integrity": "sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w==", 398 | "cpu": [ 399 | "arm" 400 | ], 401 | "dev": true, 402 | "optional": true, 403 | "os": [ 404 | "android" 405 | ], 406 | "engines": { 407 | "node": ">=12" 408 | } 409 | }, 410 | "node_modules/@esbuild/android-arm64": { 411 | "version": "0.19.12", 412 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz", 413 | "integrity": "sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA==", 414 | "cpu": [ 415 | "arm64" 416 | ], 417 | "dev": true, 418 | "optional": true, 419 | "os": [ 420 | "android" 421 | ], 422 | "engines": { 423 | "node": ">=12" 424 | } 425 | }, 426 | "node_modules/@esbuild/android-x64": { 427 | "version": "0.19.12", 428 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.12.tgz", 429 | "integrity": "sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew==", 430 | "cpu": [ 431 | "x64" 432 | ], 433 | "dev": true, 434 | "optional": true, 435 | "os": [ 436 | "android" 437 | ], 438 | "engines": { 439 | "node": ">=12" 440 | } 441 | }, 442 | "node_modules/@esbuild/darwin-arm64": { 443 | "version": "0.19.12", 444 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz", 445 | "integrity": "sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g==", 446 | "cpu": [ 447 | "arm64" 448 | ], 449 | "dev": true, 450 | "optional": true, 451 | "os": [ 452 | "darwin" 453 | ], 454 | "engines": { 455 | "node": ">=12" 456 | } 457 | }, 458 | "node_modules/@esbuild/darwin-x64": { 459 | "version": "0.19.12", 460 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz", 461 | "integrity": "sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A==", 462 | "cpu": [ 463 | "x64" 464 | ], 465 | "dev": true, 466 | "optional": true, 467 | "os": [ 468 | "darwin" 469 | ], 470 | "engines": { 471 | "node": ">=12" 472 | } 473 | }, 474 | "node_modules/@esbuild/freebsd-arm64": { 475 | "version": "0.19.12", 476 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz", 477 | "integrity": "sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA==", 478 | "cpu": [ 479 | "arm64" 480 | ], 481 | "dev": true, 482 | "optional": true, 483 | "os": [ 484 | "freebsd" 485 | ], 486 | "engines": { 487 | "node": ">=12" 488 | } 489 | }, 490 | "node_modules/@esbuild/freebsd-x64": { 491 | "version": "0.19.12", 492 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz", 493 | "integrity": "sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg==", 494 | "cpu": [ 495 | "x64" 496 | ], 497 | "dev": true, 498 | "optional": true, 499 | "os": [ 500 | "freebsd" 501 | ], 502 | "engines": { 503 | "node": ">=12" 504 | } 505 | }, 506 | "node_modules/@esbuild/linux-arm": { 507 | "version": "0.19.12", 508 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz", 509 | "integrity": "sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w==", 510 | "cpu": [ 511 | "arm" 512 | ], 513 | "dev": true, 514 | "optional": true, 515 | "os": [ 516 | "linux" 517 | ], 518 | "engines": { 519 | "node": ">=12" 520 | } 521 | }, 522 | "node_modules/@esbuild/linux-arm64": { 523 | "version": "0.19.12", 524 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz", 525 | "integrity": "sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA==", 526 | "cpu": [ 527 | "arm64" 528 | ], 529 | "dev": true, 530 | "optional": true, 531 | "os": [ 532 | "linux" 533 | ], 534 | "engines": { 535 | "node": ">=12" 536 | } 537 | }, 538 | "node_modules/@esbuild/linux-ia32": { 539 | "version": "0.19.12", 540 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz", 541 | "integrity": "sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA==", 542 | "cpu": [ 543 | "ia32" 544 | ], 545 | "dev": true, 546 | "optional": true, 547 | "os": [ 548 | "linux" 549 | ], 550 | "engines": { 551 | "node": ">=12" 552 | } 553 | }, 554 | "node_modules/@esbuild/linux-loong64": { 555 | "version": "0.19.12", 556 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz", 557 | "integrity": "sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA==", 558 | "cpu": [ 559 | "loong64" 560 | ], 561 | "dev": true, 562 | "optional": true, 563 | "os": [ 564 | "linux" 565 | ], 566 | "engines": { 567 | "node": ">=12" 568 | } 569 | }, 570 | "node_modules/@esbuild/linux-mips64el": { 571 | "version": "0.19.12", 572 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz", 573 | "integrity": "sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w==", 574 | "cpu": [ 575 | "mips64el" 576 | ], 577 | "dev": true, 578 | "optional": true, 579 | "os": [ 580 | "linux" 581 | ], 582 | "engines": { 583 | "node": ">=12" 584 | } 585 | }, 586 | "node_modules/@esbuild/linux-ppc64": { 587 | "version": "0.19.12", 588 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz", 589 | "integrity": "sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg==", 590 | "cpu": [ 591 | "ppc64" 592 | ], 593 | "dev": true, 594 | "optional": true, 595 | "os": [ 596 | "linux" 597 | ], 598 | "engines": { 599 | "node": ">=12" 600 | } 601 | }, 602 | "node_modules/@esbuild/linux-riscv64": { 603 | "version": "0.19.12", 604 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz", 605 | "integrity": "sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg==", 606 | "cpu": [ 607 | "riscv64" 608 | ], 609 | "dev": true, 610 | "optional": true, 611 | "os": [ 612 | "linux" 613 | ], 614 | "engines": { 615 | "node": ">=12" 616 | } 617 | }, 618 | "node_modules/@esbuild/linux-s390x": { 619 | "version": "0.19.12", 620 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz", 621 | "integrity": "sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg==", 622 | "cpu": [ 623 | "s390x" 624 | ], 625 | "dev": true, 626 | "optional": true, 627 | "os": [ 628 | "linux" 629 | ], 630 | "engines": { 631 | "node": ">=12" 632 | } 633 | }, 634 | "node_modules/@esbuild/linux-x64": { 635 | "version": "0.19.12", 636 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz", 637 | "integrity": "sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg==", 638 | "cpu": [ 639 | "x64" 640 | ], 641 | "dev": true, 642 | "optional": true, 643 | "os": [ 644 | "linux" 645 | ], 646 | "engines": { 647 | "node": ">=12" 648 | } 649 | }, 650 | "node_modules/@esbuild/netbsd-x64": { 651 | "version": "0.19.12", 652 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz", 653 | "integrity": "sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA==", 654 | "cpu": [ 655 | "x64" 656 | ], 657 | "dev": true, 658 | "optional": true, 659 | "os": [ 660 | "netbsd" 661 | ], 662 | "engines": { 663 | "node": ">=12" 664 | } 665 | }, 666 | "node_modules/@esbuild/openbsd-x64": { 667 | "version": "0.19.12", 668 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz", 669 | "integrity": "sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw==", 670 | "cpu": [ 671 | "x64" 672 | ], 673 | "dev": true, 674 | "optional": true, 675 | "os": [ 676 | "openbsd" 677 | ], 678 | "engines": { 679 | "node": ">=12" 680 | } 681 | }, 682 | "node_modules/@esbuild/sunos-x64": { 683 | "version": "0.19.12", 684 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz", 685 | "integrity": "sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA==", 686 | "cpu": [ 687 | "x64" 688 | ], 689 | "dev": true, 690 | "optional": true, 691 | "os": [ 692 | "sunos" 693 | ], 694 | "engines": { 695 | "node": ">=12" 696 | } 697 | }, 698 | "node_modules/@esbuild/win32-arm64": { 699 | "version": "0.19.12", 700 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz", 701 | "integrity": "sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A==", 702 | "cpu": [ 703 | "arm64" 704 | ], 705 | "dev": true, 706 | "optional": true, 707 | "os": [ 708 | "win32" 709 | ], 710 | "engines": { 711 | "node": ">=12" 712 | } 713 | }, 714 | "node_modules/@esbuild/win32-ia32": { 715 | "version": "0.19.12", 716 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz", 717 | "integrity": "sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ==", 718 | "cpu": [ 719 | "ia32" 720 | ], 721 | "dev": true, 722 | "optional": true, 723 | "os": [ 724 | "win32" 725 | ], 726 | "engines": { 727 | "node": ">=12" 728 | } 729 | }, 730 | "node_modules/@esbuild/win32-x64": { 731 | "version": "0.19.12", 732 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz", 733 | "integrity": "sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA==", 734 | "cpu": [ 735 | "x64" 736 | ], 737 | "dev": true, 738 | "optional": true, 739 | "os": [ 740 | "win32" 741 | ], 742 | "engines": { 743 | "node": ">=12" 744 | } 745 | }, 746 | "node_modules/@eslint-community/eslint-utils": { 747 | "version": "4.4.0", 748 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 749 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 750 | "dev": true, 751 | "dependencies": { 752 | "eslint-visitor-keys": "^3.3.0" 753 | }, 754 | "engines": { 755 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 756 | }, 757 | "peerDependencies": { 758 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 759 | } 760 | }, 761 | "node_modules/@eslint-community/regexpp": { 762 | "version": "4.10.0", 763 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 764 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 765 | "dev": true, 766 | "engines": { 767 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 768 | } 769 | }, 770 | "node_modules/@eslint/eslintrc": { 771 | "version": "2.1.4", 772 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 773 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 774 | "dev": true, 775 | "dependencies": { 776 | "ajv": "^6.12.4", 777 | "debug": "^4.3.2", 778 | "espree": "^9.6.0", 779 | "globals": "^13.19.0", 780 | "ignore": "^5.2.0", 781 | "import-fresh": "^3.2.1", 782 | "js-yaml": "^4.1.0", 783 | "minimatch": "^3.1.2", 784 | "strip-json-comments": "^3.1.1" 785 | }, 786 | "engines": { 787 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 788 | }, 789 | "funding": { 790 | "url": "https://opencollective.com/eslint" 791 | } 792 | }, 793 | "node_modules/@eslint/eslintrc/node_modules/globals": { 794 | "version": "13.24.0", 795 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 796 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 797 | "dev": true, 798 | "dependencies": { 799 | "type-fest": "^0.20.2" 800 | }, 801 | "engines": { 802 | "node": ">=8" 803 | }, 804 | "funding": { 805 | "url": "https://github.com/sponsors/sindresorhus" 806 | } 807 | }, 808 | "node_modules/@eslint/js": { 809 | "version": "8.57.0", 810 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 811 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 812 | "dev": true, 813 | "engines": { 814 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 815 | } 816 | }, 817 | "node_modules/@humanwhocodes/config-array": { 818 | "version": "0.11.14", 819 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 820 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 821 | "dev": true, 822 | "dependencies": { 823 | "@humanwhocodes/object-schema": "^2.0.2", 824 | "debug": "^4.3.1", 825 | "minimatch": "^3.0.5" 826 | }, 827 | "engines": { 828 | "node": ">=10.10.0" 829 | } 830 | }, 831 | "node_modules/@humanwhocodes/module-importer": { 832 | "version": "1.0.1", 833 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 834 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 835 | "dev": true, 836 | "engines": { 837 | "node": ">=12.22" 838 | }, 839 | "funding": { 840 | "type": "github", 841 | "url": "https://github.com/sponsors/nzakas" 842 | } 843 | }, 844 | "node_modules/@humanwhocodes/object-schema": { 845 | "version": "2.0.2", 846 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 847 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 848 | "dev": true 849 | }, 850 | "node_modules/@jridgewell/gen-mapping": { 851 | "version": "0.3.5", 852 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 853 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 854 | "dev": true, 855 | "dependencies": { 856 | "@jridgewell/set-array": "^1.2.1", 857 | "@jridgewell/sourcemap-codec": "^1.4.10", 858 | "@jridgewell/trace-mapping": "^0.3.24" 859 | }, 860 | "engines": { 861 | "node": ">=6.0.0" 862 | } 863 | }, 864 | "node_modules/@jridgewell/resolve-uri": { 865 | "version": "3.1.2", 866 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 867 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 868 | "dev": true, 869 | "engines": { 870 | "node": ">=6.0.0" 871 | } 872 | }, 873 | "node_modules/@jridgewell/set-array": { 874 | "version": "1.2.1", 875 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 876 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 877 | "dev": true, 878 | "engines": { 879 | "node": ">=6.0.0" 880 | } 881 | }, 882 | "node_modules/@jridgewell/sourcemap-codec": { 883 | "version": "1.4.15", 884 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 885 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 886 | "dev": true 887 | }, 888 | "node_modules/@jridgewell/trace-mapping": { 889 | "version": "0.3.24", 890 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.24.tgz", 891 | "integrity": "sha512-+VaWXDa6+l6MhflBvVXjIEAzb59nQ2JUK3bwRp2zRpPtU+8TFRy9Gg/5oIcNlkEL5PGlBFGfemUVvIgLnTzq7Q==", 892 | "dev": true, 893 | "dependencies": { 894 | "@jridgewell/resolve-uri": "^3.1.0", 895 | "@jridgewell/sourcemap-codec": "^1.4.14" 896 | } 897 | }, 898 | "node_modules/@nodelib/fs.scandir": { 899 | "version": "2.1.5", 900 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 901 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 902 | "dev": true, 903 | "dependencies": { 904 | "@nodelib/fs.stat": "2.0.5", 905 | "run-parallel": "^1.1.9" 906 | }, 907 | "engines": { 908 | "node": ">= 8" 909 | } 910 | }, 911 | "node_modules/@nodelib/fs.stat": { 912 | "version": "2.0.5", 913 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 914 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 915 | "dev": true, 916 | "engines": { 917 | "node": ">= 8" 918 | } 919 | }, 920 | "node_modules/@nodelib/fs.walk": { 921 | "version": "1.2.8", 922 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 923 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 924 | "dev": true, 925 | "dependencies": { 926 | "@nodelib/fs.scandir": "2.1.5", 927 | "fastq": "^1.6.0" 928 | }, 929 | "engines": { 930 | "node": ">= 8" 931 | } 932 | }, 933 | "node_modules/@remix-run/router": { 934 | "version": "1.15.2", 935 | "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.15.2.tgz", 936 | "integrity": "sha512-+Rnav+CaoTE5QJc4Jcwh5toUpnVLKYbpU6Ys0zqbakqbaLQHeglLVHPfxOiQqdNmUy5C2lXz5dwC6tQNX2JW2Q==", 937 | "engines": { 938 | "node": ">=14.0.0" 939 | } 940 | }, 941 | "node_modules/@rollup/rollup-android-arm-eabi": { 942 | "version": "4.12.0", 943 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.12.0.tgz", 944 | "integrity": "sha512-+ac02NL/2TCKRrJu2wffk1kZ+RyqxVUlbjSagNgPm94frxtr+XDL12E5Ll1enWskLrtrZ2r8L3wED1orIibV/w==", 945 | "cpu": [ 946 | "arm" 947 | ], 948 | "dev": true, 949 | "optional": true, 950 | "os": [ 951 | "android" 952 | ] 953 | }, 954 | "node_modules/@rollup/rollup-android-arm64": { 955 | "version": "4.12.0", 956 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.12.0.tgz", 957 | "integrity": "sha512-OBqcX2BMe6nvjQ0Nyp7cC90cnumt8PXmO7Dp3gfAju/6YwG0Tj74z1vKrfRz7qAv23nBcYM8BCbhrsWqO7PzQQ==", 958 | "cpu": [ 959 | "arm64" 960 | ], 961 | "dev": true, 962 | "optional": true, 963 | "os": [ 964 | "android" 965 | ] 966 | }, 967 | "node_modules/@rollup/rollup-darwin-arm64": { 968 | "version": "4.12.0", 969 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.12.0.tgz", 970 | "integrity": "sha512-X64tZd8dRE/QTrBIEs63kaOBG0b5GVEd3ccoLtyf6IdXtHdh8h+I56C2yC3PtC9Ucnv0CpNFJLqKFVgCYe0lOQ==", 971 | "cpu": [ 972 | "arm64" 973 | ], 974 | "dev": true, 975 | "optional": true, 976 | "os": [ 977 | "darwin" 978 | ] 979 | }, 980 | "node_modules/@rollup/rollup-darwin-x64": { 981 | "version": "4.12.0", 982 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.12.0.tgz", 983 | "integrity": "sha512-cc71KUZoVbUJmGP2cOuiZ9HSOP14AzBAThn3OU+9LcA1+IUqswJyR1cAJj3Mg55HbjZP6OLAIscbQsQLrpgTOg==", 984 | "cpu": [ 985 | "x64" 986 | ], 987 | "dev": true, 988 | "optional": true, 989 | "os": [ 990 | "darwin" 991 | ] 992 | }, 993 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 994 | "version": "4.12.0", 995 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.12.0.tgz", 996 | "integrity": "sha512-a6w/Y3hyyO6GlpKL2xJ4IOh/7d+APaqLYdMf86xnczU3nurFTaVN9s9jOXQg97BE4nYm/7Ga51rjec5nfRdrvA==", 997 | "cpu": [ 998 | "arm" 999 | ], 1000 | "dev": true, 1001 | "optional": true, 1002 | "os": [ 1003 | "linux" 1004 | ] 1005 | }, 1006 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1007 | "version": "4.12.0", 1008 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.12.0.tgz", 1009 | "integrity": "sha512-0fZBq27b+D7Ar5CQMofVN8sggOVhEtzFUwOwPppQt0k+VR+7UHMZZY4y+64WJ06XOhBTKXtQB/Sv0NwQMXyNAA==", 1010 | "cpu": [ 1011 | "arm64" 1012 | ], 1013 | "dev": true, 1014 | "optional": true, 1015 | "os": [ 1016 | "linux" 1017 | ] 1018 | }, 1019 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1020 | "version": "4.12.0", 1021 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.12.0.tgz", 1022 | "integrity": "sha512-eTvzUS3hhhlgeAv6bfigekzWZjaEX9xP9HhxB0Dvrdbkk5w/b+1Sxct2ZuDxNJKzsRStSq1EaEkVSEe7A7ipgQ==", 1023 | "cpu": [ 1024 | "arm64" 1025 | ], 1026 | "dev": true, 1027 | "optional": true, 1028 | "os": [ 1029 | "linux" 1030 | ] 1031 | }, 1032 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1033 | "version": "4.12.0", 1034 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.12.0.tgz", 1035 | "integrity": "sha512-ix+qAB9qmrCRiaO71VFfY8rkiAZJL8zQRXveS27HS+pKdjwUfEhqo2+YF2oI+H/22Xsiski+qqwIBxVewLK7sw==", 1036 | "cpu": [ 1037 | "riscv64" 1038 | ], 1039 | "dev": true, 1040 | "optional": true, 1041 | "os": [ 1042 | "linux" 1043 | ] 1044 | }, 1045 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1046 | "version": "4.12.0", 1047 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.12.0.tgz", 1048 | "integrity": "sha512-TenQhZVOtw/3qKOPa7d+QgkeM6xY0LtwzR8OplmyL5LrgTWIXpTQg2Q2ycBf8jm+SFW2Wt/DTn1gf7nFp3ssVA==", 1049 | "cpu": [ 1050 | "x64" 1051 | ], 1052 | "dev": true, 1053 | "optional": true, 1054 | "os": [ 1055 | "linux" 1056 | ] 1057 | }, 1058 | "node_modules/@rollup/rollup-linux-x64-musl": { 1059 | "version": "4.12.0", 1060 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.12.0.tgz", 1061 | "integrity": "sha512-LfFdRhNnW0zdMvdCb5FNuWlls2WbbSridJvxOvYWgSBOYZtgBfW9UGNJG//rwMqTX1xQE9BAodvMH9tAusKDUw==", 1062 | "cpu": [ 1063 | "x64" 1064 | ], 1065 | "dev": true, 1066 | "optional": true, 1067 | "os": [ 1068 | "linux" 1069 | ] 1070 | }, 1071 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1072 | "version": "4.12.0", 1073 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.12.0.tgz", 1074 | "integrity": "sha512-JPDxovheWNp6d7AHCgsUlkuCKvtu3RB55iNEkaQcf0ttsDU/JZF+iQnYcQJSk/7PtT4mjjVG8N1kpwnI9SLYaw==", 1075 | "cpu": [ 1076 | "arm64" 1077 | ], 1078 | "dev": true, 1079 | "optional": true, 1080 | "os": [ 1081 | "win32" 1082 | ] 1083 | }, 1084 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1085 | "version": "4.12.0", 1086 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.12.0.tgz", 1087 | "integrity": "sha512-fjtuvMWRGJn1oZacG8IPnzIV6GF2/XG+h71FKn76OYFqySXInJtseAqdprVTDTyqPxQOG9Exak5/E9Z3+EJ8ZA==", 1088 | "cpu": [ 1089 | "ia32" 1090 | ], 1091 | "dev": true, 1092 | "optional": true, 1093 | "os": [ 1094 | "win32" 1095 | ] 1096 | }, 1097 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1098 | "version": "4.12.0", 1099 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.12.0.tgz", 1100 | "integrity": "sha512-ZYmr5mS2wd4Dew/JjT0Fqi2NPB/ZhZ2VvPp7SmvPZb4Y1CG/LRcS6tcRo2cYU7zLK5A7cdbhWnnWmUjoI4qapg==", 1101 | "cpu": [ 1102 | "x64" 1103 | ], 1104 | "dev": true, 1105 | "optional": true, 1106 | "os": [ 1107 | "win32" 1108 | ] 1109 | }, 1110 | "node_modules/@types/babel__core": { 1111 | "version": "7.20.5", 1112 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1113 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1114 | "dev": true, 1115 | "dependencies": { 1116 | "@babel/parser": "^7.20.7", 1117 | "@babel/types": "^7.20.7", 1118 | "@types/babel__generator": "*", 1119 | "@types/babel__template": "*", 1120 | "@types/babel__traverse": "*" 1121 | } 1122 | }, 1123 | "node_modules/@types/babel__generator": { 1124 | "version": "7.6.8", 1125 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 1126 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 1127 | "dev": true, 1128 | "dependencies": { 1129 | "@babel/types": "^7.0.0" 1130 | } 1131 | }, 1132 | "node_modules/@types/babel__template": { 1133 | "version": "7.4.4", 1134 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1135 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1136 | "dev": true, 1137 | "dependencies": { 1138 | "@babel/parser": "^7.1.0", 1139 | "@babel/types": "^7.0.0" 1140 | } 1141 | }, 1142 | "node_modules/@types/babel__traverse": { 1143 | "version": "7.20.5", 1144 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz", 1145 | "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==", 1146 | "dev": true, 1147 | "dependencies": { 1148 | "@babel/types": "^7.20.7" 1149 | } 1150 | }, 1151 | "node_modules/@types/estree": { 1152 | "version": "1.0.5", 1153 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1154 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1155 | "dev": true 1156 | }, 1157 | "node_modules/@types/prop-types": { 1158 | "version": "15.7.11", 1159 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", 1160 | "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", 1161 | "dev": true 1162 | }, 1163 | "node_modules/@types/react": { 1164 | "version": "18.2.61", 1165 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.61.tgz", 1166 | "integrity": "sha512-NURTN0qNnJa7O/k4XUkEW2yfygA+NxS0V5h1+kp9jPwhzZy95q3ADoGMP0+JypMhrZBTTgjKAUlTctde1zzeQA==", 1167 | "dev": true, 1168 | "dependencies": { 1169 | "@types/prop-types": "*", 1170 | "@types/scheduler": "*", 1171 | "csstype": "^3.0.2" 1172 | } 1173 | }, 1174 | "node_modules/@types/react-dom": { 1175 | "version": "18.2.19", 1176 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.19.tgz", 1177 | "integrity": "sha512-aZvQL6uUbIJpjZk4U8JZGbau9KDeAwMfmhyWorxgBkqDIEf6ROjRozcmPIicqsUwPUjbkDfHKgGee1Lq65APcA==", 1178 | "dev": true, 1179 | "dependencies": { 1180 | "@types/react": "*" 1181 | } 1182 | }, 1183 | "node_modules/@types/scheduler": { 1184 | "version": "0.16.8", 1185 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", 1186 | "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", 1187 | "dev": true 1188 | }, 1189 | "node_modules/@ungap/structured-clone": { 1190 | "version": "1.2.0", 1191 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 1192 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 1193 | "dev": true 1194 | }, 1195 | "node_modules/@vitejs/plugin-react": { 1196 | "version": "4.2.1", 1197 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.2.1.tgz", 1198 | "integrity": "sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==", 1199 | "dev": true, 1200 | "dependencies": { 1201 | "@babel/core": "^7.23.5", 1202 | "@babel/plugin-transform-react-jsx-self": "^7.23.3", 1203 | "@babel/plugin-transform-react-jsx-source": "^7.23.3", 1204 | "@types/babel__core": "^7.20.5", 1205 | "react-refresh": "^0.14.0" 1206 | }, 1207 | "engines": { 1208 | "node": "^14.18.0 || >=16.0.0" 1209 | }, 1210 | "peerDependencies": { 1211 | "vite": "^4.2.0 || ^5.0.0" 1212 | } 1213 | }, 1214 | "node_modules/acorn": { 1215 | "version": "8.11.3", 1216 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1217 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1218 | "dev": true, 1219 | "bin": { 1220 | "acorn": "bin/acorn" 1221 | }, 1222 | "engines": { 1223 | "node": ">=0.4.0" 1224 | } 1225 | }, 1226 | "node_modules/acorn-jsx": { 1227 | "version": "5.3.2", 1228 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1229 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1230 | "dev": true, 1231 | "peerDependencies": { 1232 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1233 | } 1234 | }, 1235 | "node_modules/ajv": { 1236 | "version": "6.12.6", 1237 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1238 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1239 | "dev": true, 1240 | "dependencies": { 1241 | "fast-deep-equal": "^3.1.1", 1242 | "fast-json-stable-stringify": "^2.0.0", 1243 | "json-schema-traverse": "^0.4.1", 1244 | "uri-js": "^4.2.2" 1245 | }, 1246 | "funding": { 1247 | "type": "github", 1248 | "url": "https://github.com/sponsors/epoberezkin" 1249 | } 1250 | }, 1251 | "node_modules/ansi-regex": { 1252 | "version": "5.0.1", 1253 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1254 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1255 | "dev": true, 1256 | "engines": { 1257 | "node": ">=8" 1258 | } 1259 | }, 1260 | "node_modules/ansi-styles": { 1261 | "version": "3.2.1", 1262 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1263 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1264 | "dev": true, 1265 | "dependencies": { 1266 | "color-convert": "^1.9.0" 1267 | }, 1268 | "engines": { 1269 | "node": ">=4" 1270 | } 1271 | }, 1272 | "node_modules/argparse": { 1273 | "version": "2.0.1", 1274 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1275 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1276 | "dev": true 1277 | }, 1278 | "node_modules/array-buffer-byte-length": { 1279 | "version": "1.0.1", 1280 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", 1281 | "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", 1282 | "dev": true, 1283 | "dependencies": { 1284 | "call-bind": "^1.0.5", 1285 | "is-array-buffer": "^3.0.4" 1286 | }, 1287 | "engines": { 1288 | "node": ">= 0.4" 1289 | }, 1290 | "funding": { 1291 | "url": "https://github.com/sponsors/ljharb" 1292 | } 1293 | }, 1294 | "node_modules/array-includes": { 1295 | "version": "3.1.7", 1296 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz", 1297 | "integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==", 1298 | "dev": true, 1299 | "dependencies": { 1300 | "call-bind": "^1.0.2", 1301 | "define-properties": "^1.2.0", 1302 | "es-abstract": "^1.22.1", 1303 | "get-intrinsic": "^1.2.1", 1304 | "is-string": "^1.0.7" 1305 | }, 1306 | "engines": { 1307 | "node": ">= 0.4" 1308 | }, 1309 | "funding": { 1310 | "url": "https://github.com/sponsors/ljharb" 1311 | } 1312 | }, 1313 | "node_modules/array.prototype.flat": { 1314 | "version": "1.3.2", 1315 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", 1316 | "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", 1317 | "dev": true, 1318 | "dependencies": { 1319 | "call-bind": "^1.0.2", 1320 | "define-properties": "^1.2.0", 1321 | "es-abstract": "^1.22.1", 1322 | "es-shim-unscopables": "^1.0.0" 1323 | }, 1324 | "engines": { 1325 | "node": ">= 0.4" 1326 | }, 1327 | "funding": { 1328 | "url": "https://github.com/sponsors/ljharb" 1329 | } 1330 | }, 1331 | "node_modules/array.prototype.flatmap": { 1332 | "version": "1.3.2", 1333 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", 1334 | "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", 1335 | "dev": true, 1336 | "dependencies": { 1337 | "call-bind": "^1.0.2", 1338 | "define-properties": "^1.2.0", 1339 | "es-abstract": "^1.22.1", 1340 | "es-shim-unscopables": "^1.0.0" 1341 | }, 1342 | "engines": { 1343 | "node": ">= 0.4" 1344 | }, 1345 | "funding": { 1346 | "url": "https://github.com/sponsors/ljharb" 1347 | } 1348 | }, 1349 | "node_modules/array.prototype.tosorted": { 1350 | "version": "1.1.3", 1351 | "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.3.tgz", 1352 | "integrity": "sha512-/DdH4TiTmOKzyQbp/eadcCVexiCb36xJg7HshYOYJnNZFDj33GEv0P7GxsynpShhq4OLYJzbGcBDkLsDt7MnNg==", 1353 | "dev": true, 1354 | "dependencies": { 1355 | "call-bind": "^1.0.5", 1356 | "define-properties": "^1.2.1", 1357 | "es-abstract": "^1.22.3", 1358 | "es-errors": "^1.1.0", 1359 | "es-shim-unscopables": "^1.0.2" 1360 | } 1361 | }, 1362 | "node_modules/arraybuffer.prototype.slice": { 1363 | "version": "1.0.3", 1364 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", 1365 | "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", 1366 | "dev": true, 1367 | "dependencies": { 1368 | "array-buffer-byte-length": "^1.0.1", 1369 | "call-bind": "^1.0.5", 1370 | "define-properties": "^1.2.1", 1371 | "es-abstract": "^1.22.3", 1372 | "es-errors": "^1.2.1", 1373 | "get-intrinsic": "^1.2.3", 1374 | "is-array-buffer": "^3.0.4", 1375 | "is-shared-array-buffer": "^1.0.2" 1376 | }, 1377 | "engines": { 1378 | "node": ">= 0.4" 1379 | }, 1380 | "funding": { 1381 | "url": "https://github.com/sponsors/ljharb" 1382 | } 1383 | }, 1384 | "node_modules/asynciterator.prototype": { 1385 | "version": "1.0.0", 1386 | "resolved": "https://registry.npmjs.org/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz", 1387 | "integrity": "sha512-wwHYEIS0Q80f5mosx3L/dfG5t5rjEa9Ft51GTaNt862EnpyGHpgz2RkZvLPp1oF5TnAiTohkEKVEu8pQPJI7Vg==", 1388 | "dev": true, 1389 | "dependencies": { 1390 | "has-symbols": "^1.0.3" 1391 | } 1392 | }, 1393 | "node_modules/asynckit": { 1394 | "version": "0.4.0", 1395 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1396 | "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" 1397 | }, 1398 | "node_modules/available-typed-arrays": { 1399 | "version": "1.0.7", 1400 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", 1401 | "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", 1402 | "dev": true, 1403 | "dependencies": { 1404 | "possible-typed-array-names": "^1.0.0" 1405 | }, 1406 | "engines": { 1407 | "node": ">= 0.4" 1408 | }, 1409 | "funding": { 1410 | "url": "https://github.com/sponsors/ljharb" 1411 | } 1412 | }, 1413 | "node_modules/axios": { 1414 | "version": "1.6.7", 1415 | "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.7.tgz", 1416 | "integrity": "sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==", 1417 | "dependencies": { 1418 | "follow-redirects": "^1.15.4", 1419 | "form-data": "^4.0.0", 1420 | "proxy-from-env": "^1.1.0" 1421 | } 1422 | }, 1423 | "node_modules/balanced-match": { 1424 | "version": "1.0.2", 1425 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1426 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1427 | "dev": true 1428 | }, 1429 | "node_modules/brace-expansion": { 1430 | "version": "1.1.11", 1431 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1432 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1433 | "dev": true, 1434 | "dependencies": { 1435 | "balanced-match": "^1.0.0", 1436 | "concat-map": "0.0.1" 1437 | } 1438 | }, 1439 | "node_modules/browserslist": { 1440 | "version": "4.23.0", 1441 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", 1442 | "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", 1443 | "dev": true, 1444 | "funding": [ 1445 | { 1446 | "type": "opencollective", 1447 | "url": "https://opencollective.com/browserslist" 1448 | }, 1449 | { 1450 | "type": "tidelift", 1451 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1452 | }, 1453 | { 1454 | "type": "github", 1455 | "url": "https://github.com/sponsors/ai" 1456 | } 1457 | ], 1458 | "dependencies": { 1459 | "caniuse-lite": "^1.0.30001587", 1460 | "electron-to-chromium": "^1.4.668", 1461 | "node-releases": "^2.0.14", 1462 | "update-browserslist-db": "^1.0.13" 1463 | }, 1464 | "bin": { 1465 | "browserslist": "cli.js" 1466 | }, 1467 | "engines": { 1468 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1469 | } 1470 | }, 1471 | "node_modules/call-bind": { 1472 | "version": "1.0.7", 1473 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", 1474 | "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", 1475 | "dev": true, 1476 | "dependencies": { 1477 | "es-define-property": "^1.0.0", 1478 | "es-errors": "^1.3.0", 1479 | "function-bind": "^1.1.2", 1480 | "get-intrinsic": "^1.2.4", 1481 | "set-function-length": "^1.2.1" 1482 | }, 1483 | "engines": { 1484 | "node": ">= 0.4" 1485 | }, 1486 | "funding": { 1487 | "url": "https://github.com/sponsors/ljharb" 1488 | } 1489 | }, 1490 | "node_modules/callsites": { 1491 | "version": "3.1.0", 1492 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1493 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1494 | "dev": true, 1495 | "engines": { 1496 | "node": ">=6" 1497 | } 1498 | }, 1499 | "node_modules/caniuse-lite": { 1500 | "version": "1.0.30001591", 1501 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001591.tgz", 1502 | "integrity": "sha512-PCzRMei/vXjJyL5mJtzNiUCKP59dm8Apqc3PH8gJkMnMXZGox93RbE76jHsmLwmIo6/3nsYIpJtx0O7u5PqFuQ==", 1503 | "dev": true, 1504 | "funding": [ 1505 | { 1506 | "type": "opencollective", 1507 | "url": "https://opencollective.com/browserslist" 1508 | }, 1509 | { 1510 | "type": "tidelift", 1511 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1512 | }, 1513 | { 1514 | "type": "github", 1515 | "url": "https://github.com/sponsors/ai" 1516 | } 1517 | ] 1518 | }, 1519 | "node_modules/chalk": { 1520 | "version": "2.4.2", 1521 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1522 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1523 | "dev": true, 1524 | "dependencies": { 1525 | "ansi-styles": "^3.2.1", 1526 | "escape-string-regexp": "^1.0.5", 1527 | "supports-color": "^5.3.0" 1528 | }, 1529 | "engines": { 1530 | "node": ">=4" 1531 | } 1532 | }, 1533 | "node_modules/color-convert": { 1534 | "version": "1.9.3", 1535 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1536 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1537 | "dev": true, 1538 | "dependencies": { 1539 | "color-name": "1.1.3" 1540 | } 1541 | }, 1542 | "node_modules/color-name": { 1543 | "version": "1.1.3", 1544 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1545 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1546 | "dev": true 1547 | }, 1548 | "node_modules/combined-stream": { 1549 | "version": "1.0.8", 1550 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1551 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1552 | "dependencies": { 1553 | "delayed-stream": "~1.0.0" 1554 | }, 1555 | "engines": { 1556 | "node": ">= 0.8" 1557 | } 1558 | }, 1559 | "node_modules/concat-map": { 1560 | "version": "0.0.1", 1561 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1562 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1563 | "dev": true 1564 | }, 1565 | "node_modules/convert-source-map": { 1566 | "version": "2.0.0", 1567 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1568 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1569 | "dev": true 1570 | }, 1571 | "node_modules/cross-spawn": { 1572 | "version": "7.0.3", 1573 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1574 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1575 | "dev": true, 1576 | "dependencies": { 1577 | "path-key": "^3.1.0", 1578 | "shebang-command": "^2.0.0", 1579 | "which": "^2.0.1" 1580 | }, 1581 | "engines": { 1582 | "node": ">= 8" 1583 | } 1584 | }, 1585 | "node_modules/csstype": { 1586 | "version": "3.1.3", 1587 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 1588 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 1589 | "dev": true 1590 | }, 1591 | "node_modules/debug": { 1592 | "version": "4.3.4", 1593 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1594 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1595 | "dev": true, 1596 | "dependencies": { 1597 | "ms": "2.1.2" 1598 | }, 1599 | "engines": { 1600 | "node": ">=6.0" 1601 | }, 1602 | "peerDependenciesMeta": { 1603 | "supports-color": { 1604 | "optional": true 1605 | } 1606 | } 1607 | }, 1608 | "node_modules/deep-is": { 1609 | "version": "0.1.4", 1610 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1611 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1612 | "dev": true 1613 | }, 1614 | "node_modules/define-data-property": { 1615 | "version": "1.1.4", 1616 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", 1617 | "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", 1618 | "dev": true, 1619 | "dependencies": { 1620 | "es-define-property": "^1.0.0", 1621 | "es-errors": "^1.3.0", 1622 | "gopd": "^1.0.1" 1623 | }, 1624 | "engines": { 1625 | "node": ">= 0.4" 1626 | }, 1627 | "funding": { 1628 | "url": "https://github.com/sponsors/ljharb" 1629 | } 1630 | }, 1631 | "node_modules/define-properties": { 1632 | "version": "1.2.1", 1633 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 1634 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 1635 | "dev": true, 1636 | "dependencies": { 1637 | "define-data-property": "^1.0.1", 1638 | "has-property-descriptors": "^1.0.0", 1639 | "object-keys": "^1.1.1" 1640 | }, 1641 | "engines": { 1642 | "node": ">= 0.4" 1643 | }, 1644 | "funding": { 1645 | "url": "https://github.com/sponsors/ljharb" 1646 | } 1647 | }, 1648 | "node_modules/delayed-stream": { 1649 | "version": "1.0.0", 1650 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1651 | "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", 1652 | "engines": { 1653 | "node": ">=0.4.0" 1654 | } 1655 | }, 1656 | "node_modules/doctrine": { 1657 | "version": "3.0.0", 1658 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1659 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1660 | "dev": true, 1661 | "dependencies": { 1662 | "esutils": "^2.0.2" 1663 | }, 1664 | "engines": { 1665 | "node": ">=6.0.0" 1666 | } 1667 | }, 1668 | "node_modules/dotenv": { 1669 | "version": "16.4.5", 1670 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", 1671 | "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", 1672 | "engines": { 1673 | "node": ">=12" 1674 | }, 1675 | "funding": { 1676 | "url": "https://dotenvx.com" 1677 | } 1678 | }, 1679 | "node_modules/electron-to-chromium": { 1680 | "version": "1.4.689", 1681 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.689.tgz", 1682 | "integrity": "sha512-GatzRKnGPS1go29ep25reM94xxd1Wj8ritU0yRhCJ/tr1Bg8gKnm6R9O/yPOhGQBoLMZ9ezfrpghNaTw97C/PQ==", 1683 | "dev": true 1684 | }, 1685 | "node_modules/es-abstract": { 1686 | "version": "1.22.5", 1687 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.5.tgz", 1688 | "integrity": "sha512-oW69R+4q2wG+Hc3KZePPZxOiisRIqfKBVo/HLx94QcJeWGU/8sZhCvc829rd1kS366vlJbzBfXf9yWwf0+Ko7w==", 1689 | "dev": true, 1690 | "dependencies": { 1691 | "array-buffer-byte-length": "^1.0.1", 1692 | "arraybuffer.prototype.slice": "^1.0.3", 1693 | "available-typed-arrays": "^1.0.7", 1694 | "call-bind": "^1.0.7", 1695 | "es-define-property": "^1.0.0", 1696 | "es-errors": "^1.3.0", 1697 | "es-set-tostringtag": "^2.0.3", 1698 | "es-to-primitive": "^1.2.1", 1699 | "function.prototype.name": "^1.1.6", 1700 | "get-intrinsic": "^1.2.4", 1701 | "get-symbol-description": "^1.0.2", 1702 | "globalthis": "^1.0.3", 1703 | "gopd": "^1.0.1", 1704 | "has-property-descriptors": "^1.0.2", 1705 | "has-proto": "^1.0.3", 1706 | "has-symbols": "^1.0.3", 1707 | "hasown": "^2.0.1", 1708 | "internal-slot": "^1.0.7", 1709 | "is-array-buffer": "^3.0.4", 1710 | "is-callable": "^1.2.7", 1711 | "is-negative-zero": "^2.0.3", 1712 | "is-regex": "^1.1.4", 1713 | "is-shared-array-buffer": "^1.0.3", 1714 | "is-string": "^1.0.7", 1715 | "is-typed-array": "^1.1.13", 1716 | "is-weakref": "^1.0.2", 1717 | "object-inspect": "^1.13.1", 1718 | "object-keys": "^1.1.1", 1719 | "object.assign": "^4.1.5", 1720 | "regexp.prototype.flags": "^1.5.2", 1721 | "safe-array-concat": "^1.1.0", 1722 | "safe-regex-test": "^1.0.3", 1723 | "string.prototype.trim": "^1.2.8", 1724 | "string.prototype.trimend": "^1.0.7", 1725 | "string.prototype.trimstart": "^1.0.7", 1726 | "typed-array-buffer": "^1.0.2", 1727 | "typed-array-byte-length": "^1.0.1", 1728 | "typed-array-byte-offset": "^1.0.2", 1729 | "typed-array-length": "^1.0.5", 1730 | "unbox-primitive": "^1.0.2", 1731 | "which-typed-array": "^1.1.14" 1732 | }, 1733 | "engines": { 1734 | "node": ">= 0.4" 1735 | }, 1736 | "funding": { 1737 | "url": "https://github.com/sponsors/ljharb" 1738 | } 1739 | }, 1740 | "node_modules/es-define-property": { 1741 | "version": "1.0.0", 1742 | "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", 1743 | "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", 1744 | "dev": true, 1745 | "dependencies": { 1746 | "get-intrinsic": "^1.2.4" 1747 | }, 1748 | "engines": { 1749 | "node": ">= 0.4" 1750 | } 1751 | }, 1752 | "node_modules/es-errors": { 1753 | "version": "1.3.0", 1754 | "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", 1755 | "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", 1756 | "dev": true, 1757 | "engines": { 1758 | "node": ">= 0.4" 1759 | } 1760 | }, 1761 | "node_modules/es-iterator-helpers": { 1762 | "version": "1.0.17", 1763 | "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.17.tgz", 1764 | "integrity": "sha512-lh7BsUqelv4KUbR5a/ZTaGGIMLCjPGPqJ6q+Oq24YP0RdyptX1uzm4vvaqzk7Zx3bpl/76YLTTDj9L7uYQ92oQ==", 1765 | "dev": true, 1766 | "dependencies": { 1767 | "asynciterator.prototype": "^1.0.0", 1768 | "call-bind": "^1.0.7", 1769 | "define-properties": "^1.2.1", 1770 | "es-abstract": "^1.22.4", 1771 | "es-errors": "^1.3.0", 1772 | "es-set-tostringtag": "^2.0.2", 1773 | "function-bind": "^1.1.2", 1774 | "get-intrinsic": "^1.2.4", 1775 | "globalthis": "^1.0.3", 1776 | "has-property-descriptors": "^1.0.2", 1777 | "has-proto": "^1.0.1", 1778 | "has-symbols": "^1.0.3", 1779 | "internal-slot": "^1.0.7", 1780 | "iterator.prototype": "^1.1.2", 1781 | "safe-array-concat": "^1.1.0" 1782 | }, 1783 | "engines": { 1784 | "node": ">= 0.4" 1785 | } 1786 | }, 1787 | "node_modules/es-set-tostringtag": { 1788 | "version": "2.0.3", 1789 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", 1790 | "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", 1791 | "dev": true, 1792 | "dependencies": { 1793 | "get-intrinsic": "^1.2.4", 1794 | "has-tostringtag": "^1.0.2", 1795 | "hasown": "^2.0.1" 1796 | }, 1797 | "engines": { 1798 | "node": ">= 0.4" 1799 | } 1800 | }, 1801 | "node_modules/es-shim-unscopables": { 1802 | "version": "1.0.2", 1803 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", 1804 | "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", 1805 | "dev": true, 1806 | "dependencies": { 1807 | "hasown": "^2.0.0" 1808 | } 1809 | }, 1810 | "node_modules/es-to-primitive": { 1811 | "version": "1.2.1", 1812 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1813 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1814 | "dev": true, 1815 | "dependencies": { 1816 | "is-callable": "^1.1.4", 1817 | "is-date-object": "^1.0.1", 1818 | "is-symbol": "^1.0.2" 1819 | }, 1820 | "engines": { 1821 | "node": ">= 0.4" 1822 | }, 1823 | "funding": { 1824 | "url": "https://github.com/sponsors/ljharb" 1825 | } 1826 | }, 1827 | "node_modules/esbuild": { 1828 | "version": "0.19.12", 1829 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.12.tgz", 1830 | "integrity": "sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg==", 1831 | "dev": true, 1832 | "hasInstallScript": true, 1833 | "bin": { 1834 | "esbuild": "bin/esbuild" 1835 | }, 1836 | "engines": { 1837 | "node": ">=12" 1838 | }, 1839 | "optionalDependencies": { 1840 | "@esbuild/aix-ppc64": "0.19.12", 1841 | "@esbuild/android-arm": "0.19.12", 1842 | "@esbuild/android-arm64": "0.19.12", 1843 | "@esbuild/android-x64": "0.19.12", 1844 | "@esbuild/darwin-arm64": "0.19.12", 1845 | "@esbuild/darwin-x64": "0.19.12", 1846 | "@esbuild/freebsd-arm64": "0.19.12", 1847 | "@esbuild/freebsd-x64": "0.19.12", 1848 | "@esbuild/linux-arm": "0.19.12", 1849 | "@esbuild/linux-arm64": "0.19.12", 1850 | "@esbuild/linux-ia32": "0.19.12", 1851 | "@esbuild/linux-loong64": "0.19.12", 1852 | "@esbuild/linux-mips64el": "0.19.12", 1853 | "@esbuild/linux-ppc64": "0.19.12", 1854 | "@esbuild/linux-riscv64": "0.19.12", 1855 | "@esbuild/linux-s390x": "0.19.12", 1856 | "@esbuild/linux-x64": "0.19.12", 1857 | "@esbuild/netbsd-x64": "0.19.12", 1858 | "@esbuild/openbsd-x64": "0.19.12", 1859 | "@esbuild/sunos-x64": "0.19.12", 1860 | "@esbuild/win32-arm64": "0.19.12", 1861 | "@esbuild/win32-ia32": "0.19.12", 1862 | "@esbuild/win32-x64": "0.19.12" 1863 | } 1864 | }, 1865 | "node_modules/escalade": { 1866 | "version": "3.1.2", 1867 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", 1868 | "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", 1869 | "dev": true, 1870 | "engines": { 1871 | "node": ">=6" 1872 | } 1873 | }, 1874 | "node_modules/escape-string-regexp": { 1875 | "version": "1.0.5", 1876 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1877 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1878 | "dev": true, 1879 | "engines": { 1880 | "node": ">=0.8.0" 1881 | } 1882 | }, 1883 | "node_modules/eslint": { 1884 | "version": "8.57.0", 1885 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 1886 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 1887 | "dev": true, 1888 | "dependencies": { 1889 | "@eslint-community/eslint-utils": "^4.2.0", 1890 | "@eslint-community/regexpp": "^4.6.1", 1891 | "@eslint/eslintrc": "^2.1.4", 1892 | "@eslint/js": "8.57.0", 1893 | "@humanwhocodes/config-array": "^0.11.14", 1894 | "@humanwhocodes/module-importer": "^1.0.1", 1895 | "@nodelib/fs.walk": "^1.2.8", 1896 | "@ungap/structured-clone": "^1.2.0", 1897 | "ajv": "^6.12.4", 1898 | "chalk": "^4.0.0", 1899 | "cross-spawn": "^7.0.2", 1900 | "debug": "^4.3.2", 1901 | "doctrine": "^3.0.0", 1902 | "escape-string-regexp": "^4.0.0", 1903 | "eslint-scope": "^7.2.2", 1904 | "eslint-visitor-keys": "^3.4.3", 1905 | "espree": "^9.6.1", 1906 | "esquery": "^1.4.2", 1907 | "esutils": "^2.0.2", 1908 | "fast-deep-equal": "^3.1.3", 1909 | "file-entry-cache": "^6.0.1", 1910 | "find-up": "^5.0.0", 1911 | "glob-parent": "^6.0.2", 1912 | "globals": "^13.19.0", 1913 | "graphemer": "^1.4.0", 1914 | "ignore": "^5.2.0", 1915 | "imurmurhash": "^0.1.4", 1916 | "is-glob": "^4.0.0", 1917 | "is-path-inside": "^3.0.3", 1918 | "js-yaml": "^4.1.0", 1919 | "json-stable-stringify-without-jsonify": "^1.0.1", 1920 | "levn": "^0.4.1", 1921 | "lodash.merge": "^4.6.2", 1922 | "minimatch": "^3.1.2", 1923 | "natural-compare": "^1.4.0", 1924 | "optionator": "^0.9.3", 1925 | "strip-ansi": "^6.0.1", 1926 | "text-table": "^0.2.0" 1927 | }, 1928 | "bin": { 1929 | "eslint": "bin/eslint.js" 1930 | }, 1931 | "engines": { 1932 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1933 | }, 1934 | "funding": { 1935 | "url": "https://opencollective.com/eslint" 1936 | } 1937 | }, 1938 | "node_modules/eslint-plugin-react": { 1939 | "version": "7.33.2", 1940 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.33.2.tgz", 1941 | "integrity": "sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw==", 1942 | "dev": true, 1943 | "dependencies": { 1944 | "array-includes": "^3.1.6", 1945 | "array.prototype.flatmap": "^1.3.1", 1946 | "array.prototype.tosorted": "^1.1.1", 1947 | "doctrine": "^2.1.0", 1948 | "es-iterator-helpers": "^1.0.12", 1949 | "estraverse": "^5.3.0", 1950 | "jsx-ast-utils": "^2.4.1 || ^3.0.0", 1951 | "minimatch": "^3.1.2", 1952 | "object.entries": "^1.1.6", 1953 | "object.fromentries": "^2.0.6", 1954 | "object.hasown": "^1.1.2", 1955 | "object.values": "^1.1.6", 1956 | "prop-types": "^15.8.1", 1957 | "resolve": "^2.0.0-next.4", 1958 | "semver": "^6.3.1", 1959 | "string.prototype.matchall": "^4.0.8" 1960 | }, 1961 | "engines": { 1962 | "node": ">=4" 1963 | }, 1964 | "peerDependencies": { 1965 | "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" 1966 | } 1967 | }, 1968 | "node_modules/eslint-plugin-react-hooks": { 1969 | "version": "4.6.0", 1970 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", 1971 | "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", 1972 | "dev": true, 1973 | "engines": { 1974 | "node": ">=10" 1975 | }, 1976 | "peerDependencies": { 1977 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 1978 | } 1979 | }, 1980 | "node_modules/eslint-plugin-react-refresh": { 1981 | "version": "0.4.5", 1982 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.5.tgz", 1983 | "integrity": "sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==", 1984 | "dev": true, 1985 | "peerDependencies": { 1986 | "eslint": ">=7" 1987 | } 1988 | }, 1989 | "node_modules/eslint-plugin-react/node_modules/doctrine": { 1990 | "version": "2.1.0", 1991 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1992 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1993 | "dev": true, 1994 | "dependencies": { 1995 | "esutils": "^2.0.2" 1996 | }, 1997 | "engines": { 1998 | "node": ">=0.10.0" 1999 | } 2000 | }, 2001 | "node_modules/eslint-scope": { 2002 | "version": "7.2.2", 2003 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 2004 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 2005 | "dev": true, 2006 | "dependencies": { 2007 | "esrecurse": "^4.3.0", 2008 | "estraverse": "^5.2.0" 2009 | }, 2010 | "engines": { 2011 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2012 | }, 2013 | "funding": { 2014 | "url": "https://opencollective.com/eslint" 2015 | } 2016 | }, 2017 | "node_modules/eslint-visitor-keys": { 2018 | "version": "3.4.3", 2019 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 2020 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 2021 | "dev": true, 2022 | "engines": { 2023 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2024 | }, 2025 | "funding": { 2026 | "url": "https://opencollective.com/eslint" 2027 | } 2028 | }, 2029 | "node_modules/eslint/node_modules/ansi-styles": { 2030 | "version": "4.3.0", 2031 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2032 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2033 | "dev": true, 2034 | "dependencies": { 2035 | "color-convert": "^2.0.1" 2036 | }, 2037 | "engines": { 2038 | "node": ">=8" 2039 | }, 2040 | "funding": { 2041 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2042 | } 2043 | }, 2044 | "node_modules/eslint/node_modules/chalk": { 2045 | "version": "4.1.2", 2046 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2047 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2048 | "dev": true, 2049 | "dependencies": { 2050 | "ansi-styles": "^4.1.0", 2051 | "supports-color": "^7.1.0" 2052 | }, 2053 | "engines": { 2054 | "node": ">=10" 2055 | }, 2056 | "funding": { 2057 | "url": "https://github.com/chalk/chalk?sponsor=1" 2058 | } 2059 | }, 2060 | "node_modules/eslint/node_modules/color-convert": { 2061 | "version": "2.0.1", 2062 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2063 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2064 | "dev": true, 2065 | "dependencies": { 2066 | "color-name": "~1.1.4" 2067 | }, 2068 | "engines": { 2069 | "node": ">=7.0.0" 2070 | } 2071 | }, 2072 | "node_modules/eslint/node_modules/color-name": { 2073 | "version": "1.1.4", 2074 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2075 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2076 | "dev": true 2077 | }, 2078 | "node_modules/eslint/node_modules/escape-string-regexp": { 2079 | "version": "4.0.0", 2080 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2081 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2082 | "dev": true, 2083 | "engines": { 2084 | "node": ">=10" 2085 | }, 2086 | "funding": { 2087 | "url": "https://github.com/sponsors/sindresorhus" 2088 | } 2089 | }, 2090 | "node_modules/eslint/node_modules/globals": { 2091 | "version": "13.24.0", 2092 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 2093 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 2094 | "dev": true, 2095 | "dependencies": { 2096 | "type-fest": "^0.20.2" 2097 | }, 2098 | "engines": { 2099 | "node": ">=8" 2100 | }, 2101 | "funding": { 2102 | "url": "https://github.com/sponsors/sindresorhus" 2103 | } 2104 | }, 2105 | "node_modules/eslint/node_modules/has-flag": { 2106 | "version": "4.0.0", 2107 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2108 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2109 | "dev": true, 2110 | "engines": { 2111 | "node": ">=8" 2112 | } 2113 | }, 2114 | "node_modules/eslint/node_modules/supports-color": { 2115 | "version": "7.2.0", 2116 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2117 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2118 | "dev": true, 2119 | "dependencies": { 2120 | "has-flag": "^4.0.0" 2121 | }, 2122 | "engines": { 2123 | "node": ">=8" 2124 | } 2125 | }, 2126 | "node_modules/espree": { 2127 | "version": "9.6.1", 2128 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2129 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2130 | "dev": true, 2131 | "dependencies": { 2132 | "acorn": "^8.9.0", 2133 | "acorn-jsx": "^5.3.2", 2134 | "eslint-visitor-keys": "^3.4.1" 2135 | }, 2136 | "engines": { 2137 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2138 | }, 2139 | "funding": { 2140 | "url": "https://opencollective.com/eslint" 2141 | } 2142 | }, 2143 | "node_modules/esquery": { 2144 | "version": "1.5.0", 2145 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2146 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2147 | "dev": true, 2148 | "dependencies": { 2149 | "estraverse": "^5.1.0" 2150 | }, 2151 | "engines": { 2152 | "node": ">=0.10" 2153 | } 2154 | }, 2155 | "node_modules/esrecurse": { 2156 | "version": "4.3.0", 2157 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2158 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2159 | "dev": true, 2160 | "dependencies": { 2161 | "estraverse": "^5.2.0" 2162 | }, 2163 | "engines": { 2164 | "node": ">=4.0" 2165 | } 2166 | }, 2167 | "node_modules/estraverse": { 2168 | "version": "5.3.0", 2169 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2170 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2171 | "dev": true, 2172 | "engines": { 2173 | "node": ">=4.0" 2174 | } 2175 | }, 2176 | "node_modules/esutils": { 2177 | "version": "2.0.3", 2178 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2179 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2180 | "dev": true, 2181 | "engines": { 2182 | "node": ">=0.10.0" 2183 | } 2184 | }, 2185 | "node_modules/fast-deep-equal": { 2186 | "version": "3.1.3", 2187 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2188 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2189 | "dev": true 2190 | }, 2191 | "node_modules/fast-json-stable-stringify": { 2192 | "version": "2.1.0", 2193 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2194 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2195 | "dev": true 2196 | }, 2197 | "node_modules/fast-levenshtein": { 2198 | "version": "2.0.6", 2199 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2200 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2201 | "dev": true 2202 | }, 2203 | "node_modules/fastq": { 2204 | "version": "1.17.1", 2205 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 2206 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 2207 | "dev": true, 2208 | "dependencies": { 2209 | "reusify": "^1.0.4" 2210 | } 2211 | }, 2212 | "node_modules/file-entry-cache": { 2213 | "version": "6.0.1", 2214 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2215 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2216 | "dev": true, 2217 | "dependencies": { 2218 | "flat-cache": "^3.0.4" 2219 | }, 2220 | "engines": { 2221 | "node": "^10.12.0 || >=12.0.0" 2222 | } 2223 | }, 2224 | "node_modules/find-up": { 2225 | "version": "5.0.0", 2226 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2227 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2228 | "dev": true, 2229 | "dependencies": { 2230 | "locate-path": "^6.0.0", 2231 | "path-exists": "^4.0.0" 2232 | }, 2233 | "engines": { 2234 | "node": ">=10" 2235 | }, 2236 | "funding": { 2237 | "url": "https://github.com/sponsors/sindresorhus" 2238 | } 2239 | }, 2240 | "node_modules/flat-cache": { 2241 | "version": "3.2.0", 2242 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2243 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2244 | "dev": true, 2245 | "dependencies": { 2246 | "flatted": "^3.2.9", 2247 | "keyv": "^4.5.3", 2248 | "rimraf": "^3.0.2" 2249 | }, 2250 | "engines": { 2251 | "node": "^10.12.0 || >=12.0.0" 2252 | } 2253 | }, 2254 | "node_modules/flatted": { 2255 | "version": "3.3.1", 2256 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 2257 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 2258 | "dev": true 2259 | }, 2260 | "node_modules/follow-redirects": { 2261 | "version": "1.15.5", 2262 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", 2263 | "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==", 2264 | "funding": [ 2265 | { 2266 | "type": "individual", 2267 | "url": "https://github.com/sponsors/RubenVerborgh" 2268 | } 2269 | ], 2270 | "engines": { 2271 | "node": ">=4.0" 2272 | }, 2273 | "peerDependenciesMeta": { 2274 | "debug": { 2275 | "optional": true 2276 | } 2277 | } 2278 | }, 2279 | "node_modules/for-each": { 2280 | "version": "0.3.3", 2281 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 2282 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 2283 | "dev": true, 2284 | "dependencies": { 2285 | "is-callable": "^1.1.3" 2286 | } 2287 | }, 2288 | "node_modules/form-data": { 2289 | "version": "4.0.0", 2290 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", 2291 | "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", 2292 | "dependencies": { 2293 | "asynckit": "^0.4.0", 2294 | "combined-stream": "^1.0.8", 2295 | "mime-types": "^2.1.12" 2296 | }, 2297 | "engines": { 2298 | "node": ">= 6" 2299 | } 2300 | }, 2301 | "node_modules/fs.realpath": { 2302 | "version": "1.0.0", 2303 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2304 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2305 | "dev": true 2306 | }, 2307 | "node_modules/fsevents": { 2308 | "version": "2.3.3", 2309 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2310 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2311 | "dev": true, 2312 | "hasInstallScript": true, 2313 | "optional": true, 2314 | "os": [ 2315 | "darwin" 2316 | ], 2317 | "engines": { 2318 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2319 | } 2320 | }, 2321 | "node_modules/function-bind": { 2322 | "version": "1.1.2", 2323 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 2324 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 2325 | "dev": true, 2326 | "funding": { 2327 | "url": "https://github.com/sponsors/ljharb" 2328 | } 2329 | }, 2330 | "node_modules/function.prototype.name": { 2331 | "version": "1.1.6", 2332 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 2333 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 2334 | "dev": true, 2335 | "dependencies": { 2336 | "call-bind": "^1.0.2", 2337 | "define-properties": "^1.2.0", 2338 | "es-abstract": "^1.22.1", 2339 | "functions-have-names": "^1.2.3" 2340 | }, 2341 | "engines": { 2342 | "node": ">= 0.4" 2343 | }, 2344 | "funding": { 2345 | "url": "https://github.com/sponsors/ljharb" 2346 | } 2347 | }, 2348 | "node_modules/functions-have-names": { 2349 | "version": "1.2.3", 2350 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 2351 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 2352 | "dev": true, 2353 | "funding": { 2354 | "url": "https://github.com/sponsors/ljharb" 2355 | } 2356 | }, 2357 | "node_modules/gensync": { 2358 | "version": "1.0.0-beta.2", 2359 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2360 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2361 | "dev": true, 2362 | "engines": { 2363 | "node": ">=6.9.0" 2364 | } 2365 | }, 2366 | "node_modules/get-intrinsic": { 2367 | "version": "1.2.4", 2368 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", 2369 | "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", 2370 | "dev": true, 2371 | "dependencies": { 2372 | "es-errors": "^1.3.0", 2373 | "function-bind": "^1.1.2", 2374 | "has-proto": "^1.0.1", 2375 | "has-symbols": "^1.0.3", 2376 | "hasown": "^2.0.0" 2377 | }, 2378 | "engines": { 2379 | "node": ">= 0.4" 2380 | }, 2381 | "funding": { 2382 | "url": "https://github.com/sponsors/ljharb" 2383 | } 2384 | }, 2385 | "node_modules/get-symbol-description": { 2386 | "version": "1.0.2", 2387 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", 2388 | "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", 2389 | "dev": true, 2390 | "dependencies": { 2391 | "call-bind": "^1.0.5", 2392 | "es-errors": "^1.3.0", 2393 | "get-intrinsic": "^1.2.4" 2394 | }, 2395 | "engines": { 2396 | "node": ">= 0.4" 2397 | }, 2398 | "funding": { 2399 | "url": "https://github.com/sponsors/ljharb" 2400 | } 2401 | }, 2402 | "node_modules/glob": { 2403 | "version": "7.2.3", 2404 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2405 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2406 | "dev": true, 2407 | "dependencies": { 2408 | "fs.realpath": "^1.0.0", 2409 | "inflight": "^1.0.4", 2410 | "inherits": "2", 2411 | "minimatch": "^3.1.1", 2412 | "once": "^1.3.0", 2413 | "path-is-absolute": "^1.0.0" 2414 | }, 2415 | "engines": { 2416 | "node": "*" 2417 | }, 2418 | "funding": { 2419 | "url": "https://github.com/sponsors/isaacs" 2420 | } 2421 | }, 2422 | "node_modules/glob-parent": { 2423 | "version": "6.0.2", 2424 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2425 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2426 | "dev": true, 2427 | "dependencies": { 2428 | "is-glob": "^4.0.3" 2429 | }, 2430 | "engines": { 2431 | "node": ">=10.13.0" 2432 | } 2433 | }, 2434 | "node_modules/globals": { 2435 | "version": "11.12.0", 2436 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2437 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2438 | "dev": true, 2439 | "engines": { 2440 | "node": ">=4" 2441 | } 2442 | }, 2443 | "node_modules/globalthis": { 2444 | "version": "1.0.3", 2445 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", 2446 | "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", 2447 | "dev": true, 2448 | "dependencies": { 2449 | "define-properties": "^1.1.3" 2450 | }, 2451 | "engines": { 2452 | "node": ">= 0.4" 2453 | }, 2454 | "funding": { 2455 | "url": "https://github.com/sponsors/ljharb" 2456 | } 2457 | }, 2458 | "node_modules/gopd": { 2459 | "version": "1.0.1", 2460 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 2461 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 2462 | "dev": true, 2463 | "dependencies": { 2464 | "get-intrinsic": "^1.1.3" 2465 | }, 2466 | "funding": { 2467 | "url": "https://github.com/sponsors/ljharb" 2468 | } 2469 | }, 2470 | "node_modules/graphemer": { 2471 | "version": "1.4.0", 2472 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2473 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2474 | "dev": true 2475 | }, 2476 | "node_modules/has-bigints": { 2477 | "version": "1.0.2", 2478 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 2479 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 2480 | "dev": true, 2481 | "funding": { 2482 | "url": "https://github.com/sponsors/ljharb" 2483 | } 2484 | }, 2485 | "node_modules/has-flag": { 2486 | "version": "3.0.0", 2487 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2488 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2489 | "dev": true, 2490 | "engines": { 2491 | "node": ">=4" 2492 | } 2493 | }, 2494 | "node_modules/has-property-descriptors": { 2495 | "version": "1.0.2", 2496 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", 2497 | "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", 2498 | "dev": true, 2499 | "dependencies": { 2500 | "es-define-property": "^1.0.0" 2501 | }, 2502 | "funding": { 2503 | "url": "https://github.com/sponsors/ljharb" 2504 | } 2505 | }, 2506 | "node_modules/has-proto": { 2507 | "version": "1.0.3", 2508 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", 2509 | "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", 2510 | "dev": true, 2511 | "engines": { 2512 | "node": ">= 0.4" 2513 | }, 2514 | "funding": { 2515 | "url": "https://github.com/sponsors/ljharb" 2516 | } 2517 | }, 2518 | "node_modules/has-symbols": { 2519 | "version": "1.0.3", 2520 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 2521 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 2522 | "dev": true, 2523 | "engines": { 2524 | "node": ">= 0.4" 2525 | }, 2526 | "funding": { 2527 | "url": "https://github.com/sponsors/ljharb" 2528 | } 2529 | }, 2530 | "node_modules/has-tostringtag": { 2531 | "version": "1.0.2", 2532 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", 2533 | "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", 2534 | "dev": true, 2535 | "dependencies": { 2536 | "has-symbols": "^1.0.3" 2537 | }, 2538 | "engines": { 2539 | "node": ">= 0.4" 2540 | }, 2541 | "funding": { 2542 | "url": "https://github.com/sponsors/ljharb" 2543 | } 2544 | }, 2545 | "node_modules/hasown": { 2546 | "version": "2.0.1", 2547 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.1.tgz", 2548 | "integrity": "sha512-1/th4MHjnwncwXsIW6QMzlvYL9kG5e/CpVvLRZe4XPa8TOUNbCELqmvhDmnkNsAjwaG4+I8gJJL0JBvTTLO9qA==", 2549 | "dev": true, 2550 | "dependencies": { 2551 | "function-bind": "^1.1.2" 2552 | }, 2553 | "engines": { 2554 | "node": ">= 0.4" 2555 | } 2556 | }, 2557 | "node_modules/ignore": { 2558 | "version": "5.3.1", 2559 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 2560 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 2561 | "dev": true, 2562 | "engines": { 2563 | "node": ">= 4" 2564 | } 2565 | }, 2566 | "node_modules/import-fresh": { 2567 | "version": "3.3.0", 2568 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2569 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2570 | "dev": true, 2571 | "dependencies": { 2572 | "parent-module": "^1.0.0", 2573 | "resolve-from": "^4.0.0" 2574 | }, 2575 | "engines": { 2576 | "node": ">=6" 2577 | }, 2578 | "funding": { 2579 | "url": "https://github.com/sponsors/sindresorhus" 2580 | } 2581 | }, 2582 | "node_modules/imurmurhash": { 2583 | "version": "0.1.4", 2584 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2585 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2586 | "dev": true, 2587 | "engines": { 2588 | "node": ">=0.8.19" 2589 | } 2590 | }, 2591 | "node_modules/inflight": { 2592 | "version": "1.0.6", 2593 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2594 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2595 | "dev": true, 2596 | "dependencies": { 2597 | "once": "^1.3.0", 2598 | "wrappy": "1" 2599 | } 2600 | }, 2601 | "node_modules/inherits": { 2602 | "version": "2.0.4", 2603 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2604 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2605 | "dev": true 2606 | }, 2607 | "node_modules/internal-slot": { 2608 | "version": "1.0.7", 2609 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", 2610 | "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", 2611 | "dev": true, 2612 | "dependencies": { 2613 | "es-errors": "^1.3.0", 2614 | "hasown": "^2.0.0", 2615 | "side-channel": "^1.0.4" 2616 | }, 2617 | "engines": { 2618 | "node": ">= 0.4" 2619 | } 2620 | }, 2621 | "node_modules/is-array-buffer": { 2622 | "version": "3.0.4", 2623 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", 2624 | "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", 2625 | "dev": true, 2626 | "dependencies": { 2627 | "call-bind": "^1.0.2", 2628 | "get-intrinsic": "^1.2.1" 2629 | }, 2630 | "engines": { 2631 | "node": ">= 0.4" 2632 | }, 2633 | "funding": { 2634 | "url": "https://github.com/sponsors/ljharb" 2635 | } 2636 | }, 2637 | "node_modules/is-async-function": { 2638 | "version": "2.0.0", 2639 | "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", 2640 | "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", 2641 | "dev": true, 2642 | "dependencies": { 2643 | "has-tostringtag": "^1.0.0" 2644 | }, 2645 | "engines": { 2646 | "node": ">= 0.4" 2647 | }, 2648 | "funding": { 2649 | "url": "https://github.com/sponsors/ljharb" 2650 | } 2651 | }, 2652 | "node_modules/is-bigint": { 2653 | "version": "1.0.4", 2654 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 2655 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 2656 | "dev": true, 2657 | "dependencies": { 2658 | "has-bigints": "^1.0.1" 2659 | }, 2660 | "funding": { 2661 | "url": "https://github.com/sponsors/ljharb" 2662 | } 2663 | }, 2664 | "node_modules/is-boolean-object": { 2665 | "version": "1.1.2", 2666 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 2667 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 2668 | "dev": true, 2669 | "dependencies": { 2670 | "call-bind": "^1.0.2", 2671 | "has-tostringtag": "^1.0.0" 2672 | }, 2673 | "engines": { 2674 | "node": ">= 0.4" 2675 | }, 2676 | "funding": { 2677 | "url": "https://github.com/sponsors/ljharb" 2678 | } 2679 | }, 2680 | "node_modules/is-callable": { 2681 | "version": "1.2.7", 2682 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 2683 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 2684 | "dev": true, 2685 | "engines": { 2686 | "node": ">= 0.4" 2687 | }, 2688 | "funding": { 2689 | "url": "https://github.com/sponsors/ljharb" 2690 | } 2691 | }, 2692 | "node_modules/is-core-module": { 2693 | "version": "2.13.1", 2694 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 2695 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 2696 | "dev": true, 2697 | "dependencies": { 2698 | "hasown": "^2.0.0" 2699 | }, 2700 | "funding": { 2701 | "url": "https://github.com/sponsors/ljharb" 2702 | } 2703 | }, 2704 | "node_modules/is-date-object": { 2705 | "version": "1.0.5", 2706 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 2707 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 2708 | "dev": true, 2709 | "dependencies": { 2710 | "has-tostringtag": "^1.0.0" 2711 | }, 2712 | "engines": { 2713 | "node": ">= 0.4" 2714 | }, 2715 | "funding": { 2716 | "url": "https://github.com/sponsors/ljharb" 2717 | } 2718 | }, 2719 | "node_modules/is-extglob": { 2720 | "version": "2.1.1", 2721 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2722 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2723 | "dev": true, 2724 | "engines": { 2725 | "node": ">=0.10.0" 2726 | } 2727 | }, 2728 | "node_modules/is-finalizationregistry": { 2729 | "version": "1.0.2", 2730 | "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", 2731 | "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", 2732 | "dev": true, 2733 | "dependencies": { 2734 | "call-bind": "^1.0.2" 2735 | }, 2736 | "funding": { 2737 | "url": "https://github.com/sponsors/ljharb" 2738 | } 2739 | }, 2740 | "node_modules/is-generator-function": { 2741 | "version": "1.0.10", 2742 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 2743 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 2744 | "dev": true, 2745 | "dependencies": { 2746 | "has-tostringtag": "^1.0.0" 2747 | }, 2748 | "engines": { 2749 | "node": ">= 0.4" 2750 | }, 2751 | "funding": { 2752 | "url": "https://github.com/sponsors/ljharb" 2753 | } 2754 | }, 2755 | "node_modules/is-glob": { 2756 | "version": "4.0.3", 2757 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2758 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2759 | "dev": true, 2760 | "dependencies": { 2761 | "is-extglob": "^2.1.1" 2762 | }, 2763 | "engines": { 2764 | "node": ">=0.10.0" 2765 | } 2766 | }, 2767 | "node_modules/is-map": { 2768 | "version": "2.0.2", 2769 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.2.tgz", 2770 | "integrity": "sha512-cOZFQQozTha1f4MxLFzlgKYPTyj26picdZTx82hbc/Xf4K/tZOOXSCkMvU4pKioRXGDLJRn0GM7Upe7kR721yg==", 2771 | "dev": true, 2772 | "funding": { 2773 | "url": "https://github.com/sponsors/ljharb" 2774 | } 2775 | }, 2776 | "node_modules/is-negative-zero": { 2777 | "version": "2.0.3", 2778 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", 2779 | "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", 2780 | "dev": true, 2781 | "engines": { 2782 | "node": ">= 0.4" 2783 | }, 2784 | "funding": { 2785 | "url": "https://github.com/sponsors/ljharb" 2786 | } 2787 | }, 2788 | "node_modules/is-number-object": { 2789 | "version": "1.0.7", 2790 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 2791 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 2792 | "dev": true, 2793 | "dependencies": { 2794 | "has-tostringtag": "^1.0.0" 2795 | }, 2796 | "engines": { 2797 | "node": ">= 0.4" 2798 | }, 2799 | "funding": { 2800 | "url": "https://github.com/sponsors/ljharb" 2801 | } 2802 | }, 2803 | "node_modules/is-path-inside": { 2804 | "version": "3.0.3", 2805 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2806 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2807 | "dev": true, 2808 | "engines": { 2809 | "node": ">=8" 2810 | } 2811 | }, 2812 | "node_modules/is-regex": { 2813 | "version": "1.1.4", 2814 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 2815 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 2816 | "dev": true, 2817 | "dependencies": { 2818 | "call-bind": "^1.0.2", 2819 | "has-tostringtag": "^1.0.0" 2820 | }, 2821 | "engines": { 2822 | "node": ">= 0.4" 2823 | }, 2824 | "funding": { 2825 | "url": "https://github.com/sponsors/ljharb" 2826 | } 2827 | }, 2828 | "node_modules/is-set": { 2829 | "version": "2.0.2", 2830 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.2.tgz", 2831 | "integrity": "sha512-+2cnTEZeY5z/iXGbLhPrOAaK/Mau5k5eXq9j14CpRTftq0pAJu2MwVRSZhyZWBzx3o6X795Lz6Bpb6R0GKf37g==", 2832 | "dev": true, 2833 | "funding": { 2834 | "url": "https://github.com/sponsors/ljharb" 2835 | } 2836 | }, 2837 | "node_modules/is-shared-array-buffer": { 2838 | "version": "1.0.3", 2839 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", 2840 | "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", 2841 | "dev": true, 2842 | "dependencies": { 2843 | "call-bind": "^1.0.7" 2844 | }, 2845 | "engines": { 2846 | "node": ">= 0.4" 2847 | }, 2848 | "funding": { 2849 | "url": "https://github.com/sponsors/ljharb" 2850 | } 2851 | }, 2852 | "node_modules/is-string": { 2853 | "version": "1.0.7", 2854 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 2855 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 2856 | "dev": true, 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-symbol": { 2868 | "version": "1.0.4", 2869 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 2870 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 2871 | "dev": true, 2872 | "dependencies": { 2873 | "has-symbols": "^1.0.2" 2874 | }, 2875 | "engines": { 2876 | "node": ">= 0.4" 2877 | }, 2878 | "funding": { 2879 | "url": "https://github.com/sponsors/ljharb" 2880 | } 2881 | }, 2882 | "node_modules/is-typed-array": { 2883 | "version": "1.1.13", 2884 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", 2885 | "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", 2886 | "dev": true, 2887 | "dependencies": { 2888 | "which-typed-array": "^1.1.14" 2889 | }, 2890 | "engines": { 2891 | "node": ">= 0.4" 2892 | }, 2893 | "funding": { 2894 | "url": "https://github.com/sponsors/ljharb" 2895 | } 2896 | }, 2897 | "node_modules/is-weakmap": { 2898 | "version": "2.0.1", 2899 | "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.1.tgz", 2900 | "integrity": "sha512-NSBR4kH5oVj1Uwvv970ruUkCV7O1mzgVFO4/rev2cLRda9Tm9HrL70ZPut4rOHgY0FNrUu9BCbXA2sdQ+x0chA==", 2901 | "dev": true, 2902 | "funding": { 2903 | "url": "https://github.com/sponsors/ljharb" 2904 | } 2905 | }, 2906 | "node_modules/is-weakref": { 2907 | "version": "1.0.2", 2908 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 2909 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 2910 | "dev": true, 2911 | "dependencies": { 2912 | "call-bind": "^1.0.2" 2913 | }, 2914 | "funding": { 2915 | "url": "https://github.com/sponsors/ljharb" 2916 | } 2917 | }, 2918 | "node_modules/is-weakset": { 2919 | "version": "2.0.2", 2920 | "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.2.tgz", 2921 | "integrity": "sha512-t2yVvttHkQktwnNNmBQ98AhENLdPUTDTE21uPqAQ0ARwQfGeQKRVS0NNurH7bTf7RrvcVn1OOge45CnBeHCSmg==", 2922 | "dev": true, 2923 | "dependencies": { 2924 | "call-bind": "^1.0.2", 2925 | "get-intrinsic": "^1.1.1" 2926 | }, 2927 | "funding": { 2928 | "url": "https://github.com/sponsors/ljharb" 2929 | } 2930 | }, 2931 | "node_modules/isarray": { 2932 | "version": "2.0.5", 2933 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 2934 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 2935 | "dev": true 2936 | }, 2937 | "node_modules/isexe": { 2938 | "version": "2.0.0", 2939 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2940 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2941 | "dev": true 2942 | }, 2943 | "node_modules/iterator.prototype": { 2944 | "version": "1.1.2", 2945 | "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.2.tgz", 2946 | "integrity": "sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==", 2947 | "dev": true, 2948 | "dependencies": { 2949 | "define-properties": "^1.2.1", 2950 | "get-intrinsic": "^1.2.1", 2951 | "has-symbols": "^1.0.3", 2952 | "reflect.getprototypeof": "^1.0.4", 2953 | "set-function-name": "^2.0.1" 2954 | } 2955 | }, 2956 | "node_modules/js-tokens": { 2957 | "version": "4.0.0", 2958 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2959 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2960 | }, 2961 | "node_modules/js-yaml": { 2962 | "version": "4.1.0", 2963 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2964 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2965 | "dev": true, 2966 | "dependencies": { 2967 | "argparse": "^2.0.1" 2968 | }, 2969 | "bin": { 2970 | "js-yaml": "bin/js-yaml.js" 2971 | } 2972 | }, 2973 | "node_modules/jsesc": { 2974 | "version": "2.5.2", 2975 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2976 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2977 | "dev": true, 2978 | "bin": { 2979 | "jsesc": "bin/jsesc" 2980 | }, 2981 | "engines": { 2982 | "node": ">=4" 2983 | } 2984 | }, 2985 | "node_modules/json-buffer": { 2986 | "version": "3.0.1", 2987 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2988 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2989 | "dev": true 2990 | }, 2991 | "node_modules/json-schema-traverse": { 2992 | "version": "0.4.1", 2993 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2994 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2995 | "dev": true 2996 | }, 2997 | "node_modules/json-stable-stringify-without-jsonify": { 2998 | "version": "1.0.1", 2999 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 3000 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 3001 | "dev": true 3002 | }, 3003 | "node_modules/json5": { 3004 | "version": "2.2.3", 3005 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 3006 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 3007 | "dev": true, 3008 | "bin": { 3009 | "json5": "lib/cli.js" 3010 | }, 3011 | "engines": { 3012 | "node": ">=6" 3013 | } 3014 | }, 3015 | "node_modules/jsx-ast-utils": { 3016 | "version": "3.3.5", 3017 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", 3018 | "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", 3019 | "dev": true, 3020 | "dependencies": { 3021 | "array-includes": "^3.1.6", 3022 | "array.prototype.flat": "^1.3.1", 3023 | "object.assign": "^4.1.4", 3024 | "object.values": "^1.1.6" 3025 | }, 3026 | "engines": { 3027 | "node": ">=4.0" 3028 | } 3029 | }, 3030 | "node_modules/jwt-decode": { 3031 | "version": "4.0.0", 3032 | "resolved": "https://registry.npmjs.org/jwt-decode/-/jwt-decode-4.0.0.tgz", 3033 | "integrity": "sha512-+KJGIyHgkGuIq3IEBNftfhW/LfWhXUIY6OmyVWjliu5KH1y0fw7VQ8YndE2O4qZdMSd9SqbnC8GOcZEy0Om7sA==", 3034 | "engines": { 3035 | "node": ">=18" 3036 | } 3037 | }, 3038 | "node_modules/keyv": { 3039 | "version": "4.5.4", 3040 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 3041 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 3042 | "dev": true, 3043 | "dependencies": { 3044 | "json-buffer": "3.0.1" 3045 | } 3046 | }, 3047 | "node_modules/levn": { 3048 | "version": "0.4.1", 3049 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 3050 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3051 | "dev": true, 3052 | "dependencies": { 3053 | "prelude-ls": "^1.2.1", 3054 | "type-check": "~0.4.0" 3055 | }, 3056 | "engines": { 3057 | "node": ">= 0.8.0" 3058 | } 3059 | }, 3060 | "node_modules/locate-path": { 3061 | "version": "6.0.0", 3062 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 3063 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 3064 | "dev": true, 3065 | "dependencies": { 3066 | "p-locate": "^5.0.0" 3067 | }, 3068 | "engines": { 3069 | "node": ">=10" 3070 | }, 3071 | "funding": { 3072 | "url": "https://github.com/sponsors/sindresorhus" 3073 | } 3074 | }, 3075 | "node_modules/lodash.merge": { 3076 | "version": "4.6.2", 3077 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3078 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 3079 | "dev": true 3080 | }, 3081 | "node_modules/loose-envify": { 3082 | "version": "1.4.0", 3083 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 3084 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 3085 | "dependencies": { 3086 | "js-tokens": "^3.0.0 || ^4.0.0" 3087 | }, 3088 | "bin": { 3089 | "loose-envify": "cli.js" 3090 | } 3091 | }, 3092 | "node_modules/lru-cache": { 3093 | "version": "5.1.1", 3094 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 3095 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 3096 | "dev": true, 3097 | "dependencies": { 3098 | "yallist": "^3.0.2" 3099 | } 3100 | }, 3101 | "node_modules/mime-db": { 3102 | "version": "1.52.0", 3103 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 3104 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 3105 | "engines": { 3106 | "node": ">= 0.6" 3107 | } 3108 | }, 3109 | "node_modules/mime-types": { 3110 | "version": "2.1.35", 3111 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 3112 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 3113 | "dependencies": { 3114 | "mime-db": "1.52.0" 3115 | }, 3116 | "engines": { 3117 | "node": ">= 0.6" 3118 | } 3119 | }, 3120 | "node_modules/minimatch": { 3121 | "version": "3.1.2", 3122 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3123 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3124 | "dev": true, 3125 | "dependencies": { 3126 | "brace-expansion": "^1.1.7" 3127 | }, 3128 | "engines": { 3129 | "node": "*" 3130 | } 3131 | }, 3132 | "node_modules/ms": { 3133 | "version": "2.1.2", 3134 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3135 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3136 | "dev": true 3137 | }, 3138 | "node_modules/nanoid": { 3139 | "version": "3.3.7", 3140 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 3141 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 3142 | "dev": true, 3143 | "funding": [ 3144 | { 3145 | "type": "github", 3146 | "url": "https://github.com/sponsors/ai" 3147 | } 3148 | ], 3149 | "bin": { 3150 | "nanoid": "bin/nanoid.cjs" 3151 | }, 3152 | "engines": { 3153 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 3154 | } 3155 | }, 3156 | "node_modules/natural-compare": { 3157 | "version": "1.4.0", 3158 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3159 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3160 | "dev": true 3161 | }, 3162 | "node_modules/node-releases": { 3163 | "version": "2.0.14", 3164 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", 3165 | "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", 3166 | "dev": true 3167 | }, 3168 | "node_modules/object-assign": { 3169 | "version": "4.1.1", 3170 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 3171 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 3172 | "dev": true, 3173 | "engines": { 3174 | "node": ">=0.10.0" 3175 | } 3176 | }, 3177 | "node_modules/object-inspect": { 3178 | "version": "1.13.1", 3179 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", 3180 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", 3181 | "dev": true, 3182 | "funding": { 3183 | "url": "https://github.com/sponsors/ljharb" 3184 | } 3185 | }, 3186 | "node_modules/object-keys": { 3187 | "version": "1.1.1", 3188 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 3189 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 3190 | "dev": true, 3191 | "engines": { 3192 | "node": ">= 0.4" 3193 | } 3194 | }, 3195 | "node_modules/object.assign": { 3196 | "version": "4.1.5", 3197 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", 3198 | "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", 3199 | "dev": true, 3200 | "dependencies": { 3201 | "call-bind": "^1.0.5", 3202 | "define-properties": "^1.2.1", 3203 | "has-symbols": "^1.0.3", 3204 | "object-keys": "^1.1.1" 3205 | }, 3206 | "engines": { 3207 | "node": ">= 0.4" 3208 | }, 3209 | "funding": { 3210 | "url": "https://github.com/sponsors/ljharb" 3211 | } 3212 | }, 3213 | "node_modules/object.entries": { 3214 | "version": "1.1.7", 3215 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.7.tgz", 3216 | "integrity": "sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA==", 3217 | "dev": true, 3218 | "dependencies": { 3219 | "call-bind": "^1.0.2", 3220 | "define-properties": "^1.2.0", 3221 | "es-abstract": "^1.22.1" 3222 | }, 3223 | "engines": { 3224 | "node": ">= 0.4" 3225 | } 3226 | }, 3227 | "node_modules/object.fromentries": { 3228 | "version": "2.0.7", 3229 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz", 3230 | "integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==", 3231 | "dev": true, 3232 | "dependencies": { 3233 | "call-bind": "^1.0.2", 3234 | "define-properties": "^1.2.0", 3235 | "es-abstract": "^1.22.1" 3236 | }, 3237 | "engines": { 3238 | "node": ">= 0.4" 3239 | }, 3240 | "funding": { 3241 | "url": "https://github.com/sponsors/ljharb" 3242 | } 3243 | }, 3244 | "node_modules/object.hasown": { 3245 | "version": "1.1.3", 3246 | "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.3.tgz", 3247 | "integrity": "sha512-fFI4VcYpRHvSLXxP7yiZOMAd331cPfd2p7PFDVbgUsYOfCT3tICVqXWngbjr4m49OvsBwUBQ6O2uQoJvy3RexA==", 3248 | "dev": true, 3249 | "dependencies": { 3250 | "define-properties": "^1.2.0", 3251 | "es-abstract": "^1.22.1" 3252 | }, 3253 | "funding": { 3254 | "url": "https://github.com/sponsors/ljharb" 3255 | } 3256 | }, 3257 | "node_modules/object.values": { 3258 | "version": "1.1.7", 3259 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz", 3260 | "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==", 3261 | "dev": true, 3262 | "dependencies": { 3263 | "call-bind": "^1.0.2", 3264 | "define-properties": "^1.2.0", 3265 | "es-abstract": "^1.22.1" 3266 | }, 3267 | "engines": { 3268 | "node": ">= 0.4" 3269 | }, 3270 | "funding": { 3271 | "url": "https://github.com/sponsors/ljharb" 3272 | } 3273 | }, 3274 | "node_modules/once": { 3275 | "version": "1.4.0", 3276 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3277 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3278 | "dev": true, 3279 | "dependencies": { 3280 | "wrappy": "1" 3281 | } 3282 | }, 3283 | "node_modules/optionator": { 3284 | "version": "0.9.3", 3285 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 3286 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 3287 | "dev": true, 3288 | "dependencies": { 3289 | "@aashutoshrathi/word-wrap": "^1.2.3", 3290 | "deep-is": "^0.1.3", 3291 | "fast-levenshtein": "^2.0.6", 3292 | "levn": "^0.4.1", 3293 | "prelude-ls": "^1.2.1", 3294 | "type-check": "^0.4.0" 3295 | }, 3296 | "engines": { 3297 | "node": ">= 0.8.0" 3298 | } 3299 | }, 3300 | "node_modules/p-limit": { 3301 | "version": "3.1.0", 3302 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3303 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3304 | "dev": true, 3305 | "dependencies": { 3306 | "yocto-queue": "^0.1.0" 3307 | }, 3308 | "engines": { 3309 | "node": ">=10" 3310 | }, 3311 | "funding": { 3312 | "url": "https://github.com/sponsors/sindresorhus" 3313 | } 3314 | }, 3315 | "node_modules/p-locate": { 3316 | "version": "5.0.0", 3317 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3318 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3319 | "dev": true, 3320 | "dependencies": { 3321 | "p-limit": "^3.0.2" 3322 | }, 3323 | "engines": { 3324 | "node": ">=10" 3325 | }, 3326 | "funding": { 3327 | "url": "https://github.com/sponsors/sindresorhus" 3328 | } 3329 | }, 3330 | "node_modules/parent-module": { 3331 | "version": "1.0.1", 3332 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3333 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3334 | "dev": true, 3335 | "dependencies": { 3336 | "callsites": "^3.0.0" 3337 | }, 3338 | "engines": { 3339 | "node": ">=6" 3340 | } 3341 | }, 3342 | "node_modules/path-exists": { 3343 | "version": "4.0.0", 3344 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3345 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3346 | "dev": true, 3347 | "engines": { 3348 | "node": ">=8" 3349 | } 3350 | }, 3351 | "node_modules/path-is-absolute": { 3352 | "version": "1.0.1", 3353 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3354 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3355 | "dev": true, 3356 | "engines": { 3357 | "node": ">=0.10.0" 3358 | } 3359 | }, 3360 | "node_modules/path-key": { 3361 | "version": "3.1.1", 3362 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3363 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3364 | "dev": true, 3365 | "engines": { 3366 | "node": ">=8" 3367 | } 3368 | }, 3369 | "node_modules/path-parse": { 3370 | "version": "1.0.7", 3371 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3372 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3373 | "dev": true 3374 | }, 3375 | "node_modules/picocolors": { 3376 | "version": "1.0.0", 3377 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 3378 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 3379 | "dev": true 3380 | }, 3381 | "node_modules/possible-typed-array-names": { 3382 | "version": "1.0.0", 3383 | "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", 3384 | "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", 3385 | "dev": true, 3386 | "engines": { 3387 | "node": ">= 0.4" 3388 | } 3389 | }, 3390 | "node_modules/postcss": { 3391 | "version": "8.4.35", 3392 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.35.tgz", 3393 | "integrity": "sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA==", 3394 | "dev": true, 3395 | "funding": [ 3396 | { 3397 | "type": "opencollective", 3398 | "url": "https://opencollective.com/postcss/" 3399 | }, 3400 | { 3401 | "type": "tidelift", 3402 | "url": "https://tidelift.com/funding/github/npm/postcss" 3403 | }, 3404 | { 3405 | "type": "github", 3406 | "url": "https://github.com/sponsors/ai" 3407 | } 3408 | ], 3409 | "dependencies": { 3410 | "nanoid": "^3.3.7", 3411 | "picocolors": "^1.0.0", 3412 | "source-map-js": "^1.0.2" 3413 | }, 3414 | "engines": { 3415 | "node": "^10 || ^12 || >=14" 3416 | } 3417 | }, 3418 | "node_modules/prelude-ls": { 3419 | "version": "1.2.1", 3420 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3421 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3422 | "dev": true, 3423 | "engines": { 3424 | "node": ">= 0.8.0" 3425 | } 3426 | }, 3427 | "node_modules/prop-types": { 3428 | "version": "15.8.1", 3429 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", 3430 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", 3431 | "dev": true, 3432 | "dependencies": { 3433 | "loose-envify": "^1.4.0", 3434 | "object-assign": "^4.1.1", 3435 | "react-is": "^16.13.1" 3436 | } 3437 | }, 3438 | "node_modules/proxy-from-env": { 3439 | "version": "1.1.0", 3440 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", 3441 | "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" 3442 | }, 3443 | "node_modules/punycode": { 3444 | "version": "2.3.1", 3445 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 3446 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 3447 | "dev": true, 3448 | "engines": { 3449 | "node": ">=6" 3450 | } 3451 | }, 3452 | "node_modules/queue-microtask": { 3453 | "version": "1.2.3", 3454 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3455 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3456 | "dev": true, 3457 | "funding": [ 3458 | { 3459 | "type": "github", 3460 | "url": "https://github.com/sponsors/feross" 3461 | }, 3462 | { 3463 | "type": "patreon", 3464 | "url": "https://www.patreon.com/feross" 3465 | }, 3466 | { 3467 | "type": "consulting", 3468 | "url": "https://feross.org/support" 3469 | } 3470 | ] 3471 | }, 3472 | "node_modules/react": { 3473 | "version": "18.2.0", 3474 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 3475 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 3476 | "dependencies": { 3477 | "loose-envify": "^1.1.0" 3478 | }, 3479 | "engines": { 3480 | "node": ">=0.10.0" 3481 | } 3482 | }, 3483 | "node_modules/react-dom": { 3484 | "version": "18.2.0", 3485 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 3486 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 3487 | "dependencies": { 3488 | "loose-envify": "^1.1.0", 3489 | "scheduler": "^0.23.0" 3490 | }, 3491 | "peerDependencies": { 3492 | "react": "^18.2.0" 3493 | } 3494 | }, 3495 | "node_modules/react-is": { 3496 | "version": "16.13.1", 3497 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 3498 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 3499 | "dev": true 3500 | }, 3501 | "node_modules/react-refresh": { 3502 | "version": "0.14.0", 3503 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 3504 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 3505 | "dev": true, 3506 | "engines": { 3507 | "node": ">=0.10.0" 3508 | } 3509 | }, 3510 | "node_modules/react-router": { 3511 | "version": "6.22.2", 3512 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.22.2.tgz", 3513 | "integrity": "sha512-YD3Dzprzpcq+tBMHBS822tCjnWD3iIZbTeSXMY9LPSG541EfoBGyZ3bS25KEnaZjLcmQpw2AVLkFyfgXY8uvcw==", 3514 | "dependencies": { 3515 | "@remix-run/router": "1.15.2" 3516 | }, 3517 | "engines": { 3518 | "node": ">=14.0.0" 3519 | }, 3520 | "peerDependencies": { 3521 | "react": ">=16.8" 3522 | } 3523 | }, 3524 | "node_modules/react-router-dom": { 3525 | "version": "6.22.2", 3526 | "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.22.2.tgz", 3527 | "integrity": "sha512-WgqxD2qySEIBPZ3w0sHH+PUAiamDeszls9tzqMPBDA1YYVucTBXLU7+gtRfcSnhe92A3glPnvSxK2dhNoAVOIQ==", 3528 | "dependencies": { 3529 | "@remix-run/router": "1.15.2", 3530 | "react-router": "6.22.2" 3531 | }, 3532 | "engines": { 3533 | "node": ">=14.0.0" 3534 | }, 3535 | "peerDependencies": { 3536 | "react": ">=16.8", 3537 | "react-dom": ">=16.8" 3538 | } 3539 | }, 3540 | "node_modules/reflect.getprototypeof": { 3541 | "version": "1.0.5", 3542 | "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.5.tgz", 3543 | "integrity": "sha512-62wgfC8dJWrmxv44CA36pLDnP6KKl3Vhxb7PL+8+qrrFMMoJij4vgiMP8zV4O8+CBMXY1mHxI5fITGHXFHVmQQ==", 3544 | "dev": true, 3545 | "dependencies": { 3546 | "call-bind": "^1.0.5", 3547 | "define-properties": "^1.2.1", 3548 | "es-abstract": "^1.22.3", 3549 | "es-errors": "^1.0.0", 3550 | "get-intrinsic": "^1.2.3", 3551 | "globalthis": "^1.0.3", 3552 | "which-builtin-type": "^1.1.3" 3553 | }, 3554 | "engines": { 3555 | "node": ">= 0.4" 3556 | }, 3557 | "funding": { 3558 | "url": "https://github.com/sponsors/ljharb" 3559 | } 3560 | }, 3561 | "node_modules/regexp.prototype.flags": { 3562 | "version": "1.5.2", 3563 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", 3564 | "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", 3565 | "dev": true, 3566 | "dependencies": { 3567 | "call-bind": "^1.0.6", 3568 | "define-properties": "^1.2.1", 3569 | "es-errors": "^1.3.0", 3570 | "set-function-name": "^2.0.1" 3571 | }, 3572 | "engines": { 3573 | "node": ">= 0.4" 3574 | }, 3575 | "funding": { 3576 | "url": "https://github.com/sponsors/ljharb" 3577 | } 3578 | }, 3579 | "node_modules/resolve": { 3580 | "version": "2.0.0-next.5", 3581 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", 3582 | "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", 3583 | "dev": true, 3584 | "dependencies": { 3585 | "is-core-module": "^2.13.0", 3586 | "path-parse": "^1.0.7", 3587 | "supports-preserve-symlinks-flag": "^1.0.0" 3588 | }, 3589 | "bin": { 3590 | "resolve": "bin/resolve" 3591 | }, 3592 | "funding": { 3593 | "url": "https://github.com/sponsors/ljharb" 3594 | } 3595 | }, 3596 | "node_modules/resolve-from": { 3597 | "version": "4.0.0", 3598 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3599 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3600 | "dev": true, 3601 | "engines": { 3602 | "node": ">=4" 3603 | } 3604 | }, 3605 | "node_modules/reusify": { 3606 | "version": "1.0.4", 3607 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3608 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3609 | "dev": true, 3610 | "engines": { 3611 | "iojs": ">=1.0.0", 3612 | "node": ">=0.10.0" 3613 | } 3614 | }, 3615 | "node_modules/rimraf": { 3616 | "version": "3.0.2", 3617 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3618 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3619 | "dev": true, 3620 | "dependencies": { 3621 | "glob": "^7.1.3" 3622 | }, 3623 | "bin": { 3624 | "rimraf": "bin.js" 3625 | }, 3626 | "funding": { 3627 | "url": "https://github.com/sponsors/isaacs" 3628 | } 3629 | }, 3630 | "node_modules/rollup": { 3631 | "version": "4.12.0", 3632 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.12.0.tgz", 3633 | "integrity": "sha512-wz66wn4t1OHIJw3+XU7mJJQV/2NAfw5OAk6G6Hoo3zcvz/XOfQ52Vgi+AN4Uxoxi0KBBwk2g8zPrTDA4btSB/Q==", 3634 | "dev": true, 3635 | "dependencies": { 3636 | "@types/estree": "1.0.5" 3637 | }, 3638 | "bin": { 3639 | "rollup": "dist/bin/rollup" 3640 | }, 3641 | "engines": { 3642 | "node": ">=18.0.0", 3643 | "npm": ">=8.0.0" 3644 | }, 3645 | "optionalDependencies": { 3646 | "@rollup/rollup-android-arm-eabi": "4.12.0", 3647 | "@rollup/rollup-android-arm64": "4.12.0", 3648 | "@rollup/rollup-darwin-arm64": "4.12.0", 3649 | "@rollup/rollup-darwin-x64": "4.12.0", 3650 | "@rollup/rollup-linux-arm-gnueabihf": "4.12.0", 3651 | "@rollup/rollup-linux-arm64-gnu": "4.12.0", 3652 | "@rollup/rollup-linux-arm64-musl": "4.12.0", 3653 | "@rollup/rollup-linux-riscv64-gnu": "4.12.0", 3654 | "@rollup/rollup-linux-x64-gnu": "4.12.0", 3655 | "@rollup/rollup-linux-x64-musl": "4.12.0", 3656 | "@rollup/rollup-win32-arm64-msvc": "4.12.0", 3657 | "@rollup/rollup-win32-ia32-msvc": "4.12.0", 3658 | "@rollup/rollup-win32-x64-msvc": "4.12.0", 3659 | "fsevents": "~2.3.2" 3660 | } 3661 | }, 3662 | "node_modules/run-parallel": { 3663 | "version": "1.2.0", 3664 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3665 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3666 | "dev": true, 3667 | "funding": [ 3668 | { 3669 | "type": "github", 3670 | "url": "https://github.com/sponsors/feross" 3671 | }, 3672 | { 3673 | "type": "patreon", 3674 | "url": "https://www.patreon.com/feross" 3675 | }, 3676 | { 3677 | "type": "consulting", 3678 | "url": "https://feross.org/support" 3679 | } 3680 | ], 3681 | "dependencies": { 3682 | "queue-microtask": "^1.2.2" 3683 | } 3684 | }, 3685 | "node_modules/safe-array-concat": { 3686 | "version": "1.1.0", 3687 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.0.tgz", 3688 | "integrity": "sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==", 3689 | "dev": true, 3690 | "dependencies": { 3691 | "call-bind": "^1.0.5", 3692 | "get-intrinsic": "^1.2.2", 3693 | "has-symbols": "^1.0.3", 3694 | "isarray": "^2.0.5" 3695 | }, 3696 | "engines": { 3697 | "node": ">=0.4" 3698 | }, 3699 | "funding": { 3700 | "url": "https://github.com/sponsors/ljharb" 3701 | } 3702 | }, 3703 | "node_modules/safe-regex-test": { 3704 | "version": "1.0.3", 3705 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", 3706 | "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", 3707 | "dev": true, 3708 | "dependencies": { 3709 | "call-bind": "^1.0.6", 3710 | "es-errors": "^1.3.0", 3711 | "is-regex": "^1.1.4" 3712 | }, 3713 | "engines": { 3714 | "node": ">= 0.4" 3715 | }, 3716 | "funding": { 3717 | "url": "https://github.com/sponsors/ljharb" 3718 | } 3719 | }, 3720 | "node_modules/scheduler": { 3721 | "version": "0.23.0", 3722 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 3723 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 3724 | "dependencies": { 3725 | "loose-envify": "^1.1.0" 3726 | } 3727 | }, 3728 | "node_modules/semver": { 3729 | "version": "6.3.1", 3730 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 3731 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 3732 | "dev": true, 3733 | "bin": { 3734 | "semver": "bin/semver.js" 3735 | } 3736 | }, 3737 | "node_modules/set-function-length": { 3738 | "version": "1.2.1", 3739 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.1.tgz", 3740 | "integrity": "sha512-j4t6ccc+VsKwYHso+kElc5neZpjtq9EnRICFZtWyBsLojhmeF/ZBd/elqm22WJh/BziDe/SBiOeAt0m2mfLD0g==", 3741 | "dev": true, 3742 | "dependencies": { 3743 | "define-data-property": "^1.1.2", 3744 | "es-errors": "^1.3.0", 3745 | "function-bind": "^1.1.2", 3746 | "get-intrinsic": "^1.2.3", 3747 | "gopd": "^1.0.1", 3748 | "has-property-descriptors": "^1.0.1" 3749 | }, 3750 | "engines": { 3751 | "node": ">= 0.4" 3752 | } 3753 | }, 3754 | "node_modules/set-function-name": { 3755 | "version": "2.0.2", 3756 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", 3757 | "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", 3758 | "dev": true, 3759 | "dependencies": { 3760 | "define-data-property": "^1.1.4", 3761 | "es-errors": "^1.3.0", 3762 | "functions-have-names": "^1.2.3", 3763 | "has-property-descriptors": "^1.0.2" 3764 | }, 3765 | "engines": { 3766 | "node": ">= 0.4" 3767 | } 3768 | }, 3769 | "node_modules/shebang-command": { 3770 | "version": "2.0.0", 3771 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3772 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3773 | "dev": true, 3774 | "dependencies": { 3775 | "shebang-regex": "^3.0.0" 3776 | }, 3777 | "engines": { 3778 | "node": ">=8" 3779 | } 3780 | }, 3781 | "node_modules/shebang-regex": { 3782 | "version": "3.0.0", 3783 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3784 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3785 | "dev": true, 3786 | "engines": { 3787 | "node": ">=8" 3788 | } 3789 | }, 3790 | "node_modules/side-channel": { 3791 | "version": "1.0.6", 3792 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", 3793 | "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", 3794 | "dev": true, 3795 | "dependencies": { 3796 | "call-bind": "^1.0.7", 3797 | "es-errors": "^1.3.0", 3798 | "get-intrinsic": "^1.2.4", 3799 | "object-inspect": "^1.13.1" 3800 | }, 3801 | "engines": { 3802 | "node": ">= 0.4" 3803 | }, 3804 | "funding": { 3805 | "url": "https://github.com/sponsors/ljharb" 3806 | } 3807 | }, 3808 | "node_modules/source-map-js": { 3809 | "version": "1.0.2", 3810 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 3811 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 3812 | "dev": true, 3813 | "engines": { 3814 | "node": ">=0.10.0" 3815 | } 3816 | }, 3817 | "node_modules/string.prototype.matchall": { 3818 | "version": "4.0.10", 3819 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.10.tgz", 3820 | "integrity": "sha512-rGXbGmOEosIQi6Qva94HUjgPs9vKW+dkG7Y8Q5O2OYkWL6wFaTRZO8zM4mhP94uX55wgyrXzfS2aGtGzUL7EJQ==", 3821 | "dev": true, 3822 | "dependencies": { 3823 | "call-bind": "^1.0.2", 3824 | "define-properties": "^1.2.0", 3825 | "es-abstract": "^1.22.1", 3826 | "get-intrinsic": "^1.2.1", 3827 | "has-symbols": "^1.0.3", 3828 | "internal-slot": "^1.0.5", 3829 | "regexp.prototype.flags": "^1.5.0", 3830 | "set-function-name": "^2.0.0", 3831 | "side-channel": "^1.0.4" 3832 | }, 3833 | "funding": { 3834 | "url": "https://github.com/sponsors/ljharb" 3835 | } 3836 | }, 3837 | "node_modules/string.prototype.trim": { 3838 | "version": "1.2.8", 3839 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", 3840 | "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", 3841 | "dev": true, 3842 | "dependencies": { 3843 | "call-bind": "^1.0.2", 3844 | "define-properties": "^1.2.0", 3845 | "es-abstract": "^1.22.1" 3846 | }, 3847 | "engines": { 3848 | "node": ">= 0.4" 3849 | }, 3850 | "funding": { 3851 | "url": "https://github.com/sponsors/ljharb" 3852 | } 3853 | }, 3854 | "node_modules/string.prototype.trimend": { 3855 | "version": "1.0.7", 3856 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", 3857 | "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", 3858 | "dev": true, 3859 | "dependencies": { 3860 | "call-bind": "^1.0.2", 3861 | "define-properties": "^1.2.0", 3862 | "es-abstract": "^1.22.1" 3863 | }, 3864 | "funding": { 3865 | "url": "https://github.com/sponsors/ljharb" 3866 | } 3867 | }, 3868 | "node_modules/string.prototype.trimstart": { 3869 | "version": "1.0.7", 3870 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", 3871 | "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", 3872 | "dev": true, 3873 | "dependencies": { 3874 | "call-bind": "^1.0.2", 3875 | "define-properties": "^1.2.0", 3876 | "es-abstract": "^1.22.1" 3877 | }, 3878 | "funding": { 3879 | "url": "https://github.com/sponsors/ljharb" 3880 | } 3881 | }, 3882 | "node_modules/strip-ansi": { 3883 | "version": "6.0.1", 3884 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3885 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3886 | "dev": true, 3887 | "dependencies": { 3888 | "ansi-regex": "^5.0.1" 3889 | }, 3890 | "engines": { 3891 | "node": ">=8" 3892 | } 3893 | }, 3894 | "node_modules/strip-json-comments": { 3895 | "version": "3.1.1", 3896 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3897 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3898 | "dev": true, 3899 | "engines": { 3900 | "node": ">=8" 3901 | }, 3902 | "funding": { 3903 | "url": "https://github.com/sponsors/sindresorhus" 3904 | } 3905 | }, 3906 | "node_modules/supports-color": { 3907 | "version": "5.5.0", 3908 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3909 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3910 | "dev": true, 3911 | "dependencies": { 3912 | "has-flag": "^3.0.0" 3913 | }, 3914 | "engines": { 3915 | "node": ">=4" 3916 | } 3917 | }, 3918 | "node_modules/supports-preserve-symlinks-flag": { 3919 | "version": "1.0.0", 3920 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3921 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3922 | "dev": true, 3923 | "engines": { 3924 | "node": ">= 0.4" 3925 | }, 3926 | "funding": { 3927 | "url": "https://github.com/sponsors/ljharb" 3928 | } 3929 | }, 3930 | "node_modules/text-table": { 3931 | "version": "0.2.0", 3932 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3933 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3934 | "dev": true 3935 | }, 3936 | "node_modules/to-fast-properties": { 3937 | "version": "2.0.0", 3938 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3939 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 3940 | "dev": true, 3941 | "engines": { 3942 | "node": ">=4" 3943 | } 3944 | }, 3945 | "node_modules/type-check": { 3946 | "version": "0.4.0", 3947 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3948 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3949 | "dev": true, 3950 | "dependencies": { 3951 | "prelude-ls": "^1.2.1" 3952 | }, 3953 | "engines": { 3954 | "node": ">= 0.8.0" 3955 | } 3956 | }, 3957 | "node_modules/type-fest": { 3958 | "version": "0.20.2", 3959 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3960 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3961 | "dev": true, 3962 | "engines": { 3963 | "node": ">=10" 3964 | }, 3965 | "funding": { 3966 | "url": "https://github.com/sponsors/sindresorhus" 3967 | } 3968 | }, 3969 | "node_modules/typed-array-buffer": { 3970 | "version": "1.0.2", 3971 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", 3972 | "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", 3973 | "dev": true, 3974 | "dependencies": { 3975 | "call-bind": "^1.0.7", 3976 | "es-errors": "^1.3.0", 3977 | "is-typed-array": "^1.1.13" 3978 | }, 3979 | "engines": { 3980 | "node": ">= 0.4" 3981 | } 3982 | }, 3983 | "node_modules/typed-array-byte-length": { 3984 | "version": "1.0.1", 3985 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", 3986 | "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", 3987 | "dev": true, 3988 | "dependencies": { 3989 | "call-bind": "^1.0.7", 3990 | "for-each": "^0.3.3", 3991 | "gopd": "^1.0.1", 3992 | "has-proto": "^1.0.3", 3993 | "is-typed-array": "^1.1.13" 3994 | }, 3995 | "engines": { 3996 | "node": ">= 0.4" 3997 | }, 3998 | "funding": { 3999 | "url": "https://github.com/sponsors/ljharb" 4000 | } 4001 | }, 4002 | "node_modules/typed-array-byte-offset": { 4003 | "version": "1.0.2", 4004 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", 4005 | "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", 4006 | "dev": true, 4007 | "dependencies": { 4008 | "available-typed-arrays": "^1.0.7", 4009 | "call-bind": "^1.0.7", 4010 | "for-each": "^0.3.3", 4011 | "gopd": "^1.0.1", 4012 | "has-proto": "^1.0.3", 4013 | "is-typed-array": "^1.1.13" 4014 | }, 4015 | "engines": { 4016 | "node": ">= 0.4" 4017 | }, 4018 | "funding": { 4019 | "url": "https://github.com/sponsors/ljharb" 4020 | } 4021 | }, 4022 | "node_modules/typed-array-length": { 4023 | "version": "1.0.5", 4024 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.5.tgz", 4025 | "integrity": "sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==", 4026 | "dev": true, 4027 | "dependencies": { 4028 | "call-bind": "^1.0.7", 4029 | "for-each": "^0.3.3", 4030 | "gopd": "^1.0.1", 4031 | "has-proto": "^1.0.3", 4032 | "is-typed-array": "^1.1.13", 4033 | "possible-typed-array-names": "^1.0.0" 4034 | }, 4035 | "engines": { 4036 | "node": ">= 0.4" 4037 | }, 4038 | "funding": { 4039 | "url": "https://github.com/sponsors/ljharb" 4040 | } 4041 | }, 4042 | "node_modules/unbox-primitive": { 4043 | "version": "1.0.2", 4044 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 4045 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 4046 | "dev": true, 4047 | "dependencies": { 4048 | "call-bind": "^1.0.2", 4049 | "has-bigints": "^1.0.2", 4050 | "has-symbols": "^1.0.3", 4051 | "which-boxed-primitive": "^1.0.2" 4052 | }, 4053 | "funding": { 4054 | "url": "https://github.com/sponsors/ljharb" 4055 | } 4056 | }, 4057 | "node_modules/update-browserslist-db": { 4058 | "version": "1.0.13", 4059 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", 4060 | "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", 4061 | "dev": true, 4062 | "funding": [ 4063 | { 4064 | "type": "opencollective", 4065 | "url": "https://opencollective.com/browserslist" 4066 | }, 4067 | { 4068 | "type": "tidelift", 4069 | "url": "https://tidelift.com/funding/github/npm/browserslist" 4070 | }, 4071 | { 4072 | "type": "github", 4073 | "url": "https://github.com/sponsors/ai" 4074 | } 4075 | ], 4076 | "dependencies": { 4077 | "escalade": "^3.1.1", 4078 | "picocolors": "^1.0.0" 4079 | }, 4080 | "bin": { 4081 | "update-browserslist-db": "cli.js" 4082 | }, 4083 | "peerDependencies": { 4084 | "browserslist": ">= 4.21.0" 4085 | } 4086 | }, 4087 | "node_modules/uri-js": { 4088 | "version": "4.4.1", 4089 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 4090 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 4091 | "dev": true, 4092 | "dependencies": { 4093 | "punycode": "^2.1.0" 4094 | } 4095 | }, 4096 | "node_modules/vite": { 4097 | "version": "5.1.4", 4098 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.1.4.tgz", 4099 | "integrity": "sha512-n+MPqzq+d9nMVTKyewqw6kSt+R3CkvF9QAKY8obiQn8g1fwTscKxyfaYnC632HtBXAQGc1Yjomphwn1dtwGAHg==", 4100 | "dev": true, 4101 | "dependencies": { 4102 | "esbuild": "^0.19.3", 4103 | "postcss": "^8.4.35", 4104 | "rollup": "^4.2.0" 4105 | }, 4106 | "bin": { 4107 | "vite": "bin/vite.js" 4108 | }, 4109 | "engines": { 4110 | "node": "^18.0.0 || >=20.0.0" 4111 | }, 4112 | "funding": { 4113 | "url": "https://github.com/vitejs/vite?sponsor=1" 4114 | }, 4115 | "optionalDependencies": { 4116 | "fsevents": "~2.3.3" 4117 | }, 4118 | "peerDependencies": { 4119 | "@types/node": "^18.0.0 || >=20.0.0", 4120 | "less": "*", 4121 | "lightningcss": "^1.21.0", 4122 | "sass": "*", 4123 | "stylus": "*", 4124 | "sugarss": "*", 4125 | "terser": "^5.4.0" 4126 | }, 4127 | "peerDependenciesMeta": { 4128 | "@types/node": { 4129 | "optional": true 4130 | }, 4131 | "less": { 4132 | "optional": true 4133 | }, 4134 | "lightningcss": { 4135 | "optional": true 4136 | }, 4137 | "sass": { 4138 | "optional": true 4139 | }, 4140 | "stylus": { 4141 | "optional": true 4142 | }, 4143 | "sugarss": { 4144 | "optional": true 4145 | }, 4146 | "terser": { 4147 | "optional": true 4148 | } 4149 | } 4150 | }, 4151 | "node_modules/which": { 4152 | "version": "2.0.2", 4153 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 4154 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 4155 | "dev": true, 4156 | "dependencies": { 4157 | "isexe": "^2.0.0" 4158 | }, 4159 | "bin": { 4160 | "node-which": "bin/node-which" 4161 | }, 4162 | "engines": { 4163 | "node": ">= 8" 4164 | } 4165 | }, 4166 | "node_modules/which-boxed-primitive": { 4167 | "version": "1.0.2", 4168 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 4169 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 4170 | "dev": true, 4171 | "dependencies": { 4172 | "is-bigint": "^1.0.1", 4173 | "is-boolean-object": "^1.1.0", 4174 | "is-number-object": "^1.0.4", 4175 | "is-string": "^1.0.5", 4176 | "is-symbol": "^1.0.3" 4177 | }, 4178 | "funding": { 4179 | "url": "https://github.com/sponsors/ljharb" 4180 | } 4181 | }, 4182 | "node_modules/which-builtin-type": { 4183 | "version": "1.1.3", 4184 | "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.3.tgz", 4185 | "integrity": "sha512-YmjsSMDBYsM1CaFiayOVT06+KJeXf0o5M/CAd4o1lTadFAtacTUM49zoYxr/oroopFDfhvN6iEcBxUyc3gvKmw==", 4186 | "dev": true, 4187 | "dependencies": { 4188 | "function.prototype.name": "^1.1.5", 4189 | "has-tostringtag": "^1.0.0", 4190 | "is-async-function": "^2.0.0", 4191 | "is-date-object": "^1.0.5", 4192 | "is-finalizationregistry": "^1.0.2", 4193 | "is-generator-function": "^1.0.10", 4194 | "is-regex": "^1.1.4", 4195 | "is-weakref": "^1.0.2", 4196 | "isarray": "^2.0.5", 4197 | "which-boxed-primitive": "^1.0.2", 4198 | "which-collection": "^1.0.1", 4199 | "which-typed-array": "^1.1.9" 4200 | }, 4201 | "engines": { 4202 | "node": ">= 0.4" 4203 | }, 4204 | "funding": { 4205 | "url": "https://github.com/sponsors/ljharb" 4206 | } 4207 | }, 4208 | "node_modules/which-collection": { 4209 | "version": "1.0.1", 4210 | "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.1.tgz", 4211 | "integrity": "sha512-W8xeTUwaln8i3K/cY1nGXzdnVZlidBcagyNFtBdD5kxnb4TvGKR7FfSIS3mYpwWS1QUCutfKz8IY8RjftB0+1A==", 4212 | "dev": true, 4213 | "dependencies": { 4214 | "is-map": "^2.0.1", 4215 | "is-set": "^2.0.1", 4216 | "is-weakmap": "^2.0.1", 4217 | "is-weakset": "^2.0.1" 4218 | }, 4219 | "funding": { 4220 | "url": "https://github.com/sponsors/ljharb" 4221 | } 4222 | }, 4223 | "node_modules/which-typed-array": { 4224 | "version": "1.1.14", 4225 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.14.tgz", 4226 | "integrity": "sha512-VnXFiIW8yNn9kIHN88xvZ4yOWchftKDsRJ8fEPacX/wl1lOvBrhsJ/OeJCXq7B0AaijRuqgzSKalJoPk+D8MPg==", 4227 | "dev": true, 4228 | "dependencies": { 4229 | "available-typed-arrays": "^1.0.6", 4230 | "call-bind": "^1.0.5", 4231 | "for-each": "^0.3.3", 4232 | "gopd": "^1.0.1", 4233 | "has-tostringtag": "^1.0.1" 4234 | }, 4235 | "engines": { 4236 | "node": ">= 0.4" 4237 | }, 4238 | "funding": { 4239 | "url": "https://github.com/sponsors/ljharb" 4240 | } 4241 | }, 4242 | "node_modules/wrappy": { 4243 | "version": "1.0.2", 4244 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4245 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 4246 | "dev": true 4247 | }, 4248 | "node_modules/yallist": { 4249 | "version": "3.1.1", 4250 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 4251 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 4252 | "dev": true 4253 | }, 4254 | "node_modules/yocto-queue": { 4255 | "version": "0.1.0", 4256 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4257 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4258 | "dev": true, 4259 | "engines": { 4260 | "node": ">=10" 4261 | }, 4262 | "funding": { 4263 | "url": "https://github.com/sponsors/sindresorhus" 4264 | } 4265 | } 4266 | } 4267 | } 4268 | -------------------------------------------------------------------------------- /frontend/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "frontend", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "proxy": "https://4982a3fe-045e-4500-b372-64a95b4d184b-dev.e1-us-east-azure.choreoapis.dev/ytit/backend/test-rest-endpoint-be2/v1.0", 7 | "scripts": { 8 | "dev": "vite", 9 | "build": "vite build", 10 | "lint": "eslint . --ext js,jsx --report-unused-disable-directives --max-warnings 0", 11 | "preview": "vite preview" 12 | }, 13 | "dependencies": { 14 | "axios": "^1.6.7", 15 | "jwt-decode": "^4.0.0", 16 | "react": "^18.2.0", 17 | "react-dom": "^18.2.0", 18 | "react-router-dom": "^6.22.2" 19 | }, 20 | "devDependencies": { 21 | "@types/react": "^18.2.56", 22 | "@types/react-dom": "^18.2.19", 23 | "@vitejs/plugin-react": "^4.2.1", 24 | "eslint": "^8.56.0", 25 | "eslint-plugin-react": "^7.33.2", 26 | "eslint-plugin-react-hooks": "^4.6.0", 27 | "eslint-plugin-react-refresh": "^0.4.5", 28 | "vite": "^5.1.4" 29 | } 30 | } -------------------------------------------------------------------------------- /frontend/public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /frontend/src/App.jsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import { BrowserRouter, Routes, Route, Navigate } from "react-router-dom"; 3 | import Login from "./pages/Login"; 4 | import Register from "./pages/Register"; 5 | import Home from "./pages/Home"; 6 | import NotFound from "./pages/NotFound" 7 | import ProtectedRoute from "./components/ProtectedRoute"; 8 | 9 | function Logout() { 10 | localStorage.clear() 11 | return 12 | } 13 | 14 | function RegisterAndLogout() { 15 | localStorage.clear() 16 | return 17 | } 18 | 19 | function App() { 20 | return ( 21 | 22 | 23 | 27 | 28 | 29 | } 30 | /> 31 | } /> 32 | } /> 33 | } /> 34 | } /> 35 | 36 | 37 | ); 38 | } 39 | 40 | export default App; 41 | -------------------------------------------------------------------------------- /frontend/src/api.js: -------------------------------------------------------------------------------- 1 | import axios from 'axios'; 2 | import { ACCESS_TOKEN } from './constants.js'; 3 | 4 | const apiUrl = window?.configs?.apiUrl ? window.configs.apiUrl : "/choreo-apis/npgb/backend-rjz/test-rest-endpoint-5c6/v1.0"; 5 | 6 | const api = axios.create({ 7 | baseURL: apiUrl ? apiUrl : import.meta.env.VITE_API_URL, 8 | }); 9 | 10 | console.log(apiUrl) 11 | 12 | api.interceptors.request.use( 13 | (config) => { 14 | const token = localStorage.getItem(ACCESS_TOKEN); 15 | if (token) { 16 | config.headers.Authorization = `Bearer ${token}`; 17 | } 18 | return config; 19 | }, 20 | (error) => { 21 | return Promise.reject(error); 22 | } 23 | ); 24 | 25 | 26 | export default api -------------------------------------------------------------------------------- /frontend/src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /frontend/src/components/LoadingIndicator.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import '../styles/LoadingIndicator.css'; // Make sure to create this CSS file in the same directory 3 | 4 | const LoadingIndicator = () => ( 5 |
6 |
7 |
8 | ); 9 | 10 | export default LoadingIndicator; -------------------------------------------------------------------------------- /frontend/src/components/Note.jsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import "../styles/Note.css"; 3 | 4 | function Note({ note, onDelete }) { 5 | // Assuming note.created_at is in ISO format, e.g., "2023-03-14T15:09:03.000Z" 6 | const formattedDate = new Date(note.created_at).toLocaleDateString("en-US"); 7 | 8 | return ( 9 |
10 |

{note.title}

11 |

{note.content}

12 |

{formattedDate}

13 | 16 |
17 | ); 18 | } 19 | 20 | export default Note; 21 | -------------------------------------------------------------------------------- /frontend/src/components/ProtectedRoute.jsx: -------------------------------------------------------------------------------- 1 | import React, { useEffect, useState } from "react"; 2 | import { Navigate } from "react-router-dom"; 3 | import { jwtDecode } from "jwt-decode"; 4 | import api from "../api"; 5 | import { REFRESH_TOKEN, ACCESS_TOKEN } from "../constants"; 6 | 7 | function ProtectedRoute({ children }) { 8 | const [isAuthorized, setIsAuthorized] = useState(null); 9 | 10 | useEffect(() => { 11 | auth().catch(() => setIsAuthorized(false)) 12 | }, []); 13 | 14 | const refreshToken = async () => { 15 | const refreshToken = localStorage.getItem(REFRESH_TOKEN); 16 | try { 17 | const res = await api.post("/api/token/refresh/", { 18 | refresh: refreshToken, 19 | }); 20 | if (res.status === 200) { 21 | localStorage.setItem(ACCESS_TOKEN, res.data.access); 22 | setIsAuthorized(true); 23 | } else { 24 | setIsAuthorized(false); 25 | } 26 | } catch (error) { 27 | setIsAuthorized(false); 28 | } 29 | } 30 | 31 | const auth = async () => { 32 | const token = localStorage.getItem(ACCESS_TOKEN); 33 | if (!token) { 34 | setIsAuthorized(false); 35 | return; 36 | } 37 | const decoded = jwtDecode(token); 38 | const tokenExpiration = decoded.exp; 39 | const now = Date.now() / 1000; // Convert to seconds 40 | 41 | if (tokenExpiration < now) { 42 | await refreshToken() 43 | } else { 44 | setIsAuthorized(true); 45 | } 46 | }; 47 | 48 | if (isAuthorized === null) { 49 | return
Loading...
; // Or any other loading indicator 50 | } 51 | 52 | return isAuthorized ? children : ; 53 | } 54 | 55 | export default ProtectedRoute; -------------------------------------------------------------------------------- /frontend/src/constants.js: -------------------------------------------------------------------------------- 1 | export const ACCESS_TOKEN = "access"; 2 | export const REFRESH_TOKEN = "refresh" -------------------------------------------------------------------------------- /frontend/src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react' 2 | import ReactDOM from 'react-dom/client' 3 | import App from './App.jsx' 4 | 5 | ReactDOM.createRoot(document.getElementById('root')).render( 6 | 7 | 8 | , 9 | ) 10 | -------------------------------------------------------------------------------- /frontend/src/pages/Form.jsx: -------------------------------------------------------------------------------- 1 | import React, { useState } from "react"; 2 | import api from "../api"; 3 | import { useNavigate } from "react-router-dom"; 4 | import { ACCESS_TOKEN, REFRESH_TOKEN } from "../constants"; 5 | import "../styles/FormStyles.css"; 6 | import LoadingIndicator from "../components/LoadingIndicator"; 7 | 8 | function Form({ route, method }) { 9 | const [username, setUsername] = useState(""); 10 | const [password, setPassword] = useState(""); 11 | const [loading, setLoading] = useState(false) 12 | const navigate = useNavigate(); 13 | 14 | const handleSubmit = async (e) => { 15 | setLoading(true) 16 | e.preventDefault(); 17 | try { 18 | const res = await api.post(route, { username, password }); 19 | if (method === "login") { 20 | localStorage.setItem(ACCESS_TOKEN, res.data.access); 21 | localStorage.setItem(REFRESH_TOKEN, res.data.refresh); 22 | navigate("/"); 23 | } else { 24 | navigate("/login"); 25 | } 26 | } catch (error) { 27 | alert(error); 28 | } finally { 29 | setLoading(false) 30 | } 31 | }; 32 | 33 | return ( 34 |
35 |

{method === "login" ? "Login" : "Register"}

36 | setUsername(e.target.value)} 41 | placeholder="Username" 42 | /> 43 | setPassword(e.target.value)} 48 | placeholder="Password" 49 | /> 50 | {loading && } 51 | 54 | 55 | ); 56 | } 57 | 58 | export default Form; 59 | -------------------------------------------------------------------------------- /frontend/src/pages/Home.jsx: -------------------------------------------------------------------------------- 1 | import React, { useState, useEffect } from "react"; 2 | import api from "../api"; 3 | import Note from "../components/Note"; 4 | import "../styles/NoteStyles.css" 5 | 6 | function Home() { 7 | const [notes, setNotes] = useState([]); 8 | const [content, setContent] = useState(""); 9 | const [title, setTitle] = useState(""); 10 | 11 | const getNotes = () => { 12 | api 13 | .get("/api/notes/") 14 | .then((res) => res.data) 15 | .then((data) => setNotes(data)) 16 | .catch((err) => { 17 | alert(err); 18 | }); 19 | }; 20 | 21 | const deleteNote = (id) => { 22 | api 23 | .delete(`/api/notes/delete/${id}/`) 24 | .then((res) => { 25 | if (res.status === 204) alert("Note deleted!"); 26 | else alert("Failed to delete note."); 27 | }) 28 | .catch((err) => alert(err)); 29 | getNotes() 30 | } 31 | 32 | const createNote = (e) => { 33 | e.preventDefault() 34 | api 35 | .post("/api/notes/", { content, title }) 36 | .then((res) => { 37 | if (res.status === 201) alert("Note created!"); 38 | else alert("Failed to create note."); 39 | }) 40 | .catch((err) => alert(err)); 41 | getNotes() 42 | }; 43 | 44 | useEffect(() => { 45 | getNotes(); 46 | }, []); 47 | 48 | return ( 49 |
50 |
51 |

Notes

52 | {notes.map((note) => )} 53 |
54 |

Create a Note

55 |
56 | 57 |
58 | setTitle(e.target.value)} 64 | /> 65 |
66 | 67 |
68 | 74 |
75 | 76 |
77 |
78 | ); 79 | } 80 | 81 | export default Home; 82 | -------------------------------------------------------------------------------- /frontend/src/pages/Login.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import Form from './Form'; 3 | 4 | function Login() { 5 | return
6 | } 7 | 8 | export default Login; 9 | -------------------------------------------------------------------------------- /frontend/src/pages/NotFound.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | const NotFoundPage = () => { 4 | return ( 5 |
6 |

404 Not Found

7 |

The page you're looking for doesn't exist.

8 |
9 | ); 10 | }; 11 | 12 | export default NotFoundPage; 13 | -------------------------------------------------------------------------------- /frontend/src/pages/Register.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import Form from './Form'; 3 | 4 | function Register() { 5 | return 6 | } 7 | 8 | export default Register; 9 | -------------------------------------------------------------------------------- /frontend/src/styles/FormStyles.css: -------------------------------------------------------------------------------- 1 | /* FormStyles.css */ 2 | .form-container { 3 | display: flex; 4 | flex-direction: column; 5 | align-items: center; 6 | justify-content: center; 7 | margin: 50px auto; 8 | padding: 20px; 9 | border-radius: 8px; 10 | box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); 11 | max-width: 400px; 12 | } 13 | 14 | .form-input { 15 | width: 90%; 16 | padding: 10px; 17 | margin: 10px 0; 18 | border: 1px solid #ccc; 19 | border-radius: 4px; 20 | box-sizing: border-box; 21 | } 22 | 23 | .form-button { 24 | width: 95%; 25 | padding: 10px; 26 | margin: 20px 0; 27 | background-color: #007bff; 28 | color: white; 29 | border: none; 30 | border-radius: 4px; 31 | cursor: pointer; 32 | transition: background-color 0.2s ease-in-out; 33 | } 34 | 35 | .form-button:hover { 36 | background-color: #0056b3; 37 | } 38 | -------------------------------------------------------------------------------- /frontend/src/styles/LoadingIndicator.css: -------------------------------------------------------------------------------- 1 | .loader-container { 2 | display: flex; 3 | justify-content: center; 4 | align-items: center; 5 | } 6 | 7 | .loader { 8 | border: 5px solid #f3f3f3; /* Light grey */ 9 | border-top: 5px solid #3498db; /* Blue */ 10 | border-radius: 50%; 11 | width: 50px; 12 | height: 50px; 13 | animation: spin 2s linear infinite; 14 | } 15 | 16 | @keyframes spin { 17 | 0% { 18 | transform: rotate(0deg); 19 | } 20 | 100% { 21 | transform: rotate(360deg); 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /frontend/src/styles/Note.css: -------------------------------------------------------------------------------- 1 | /* NoteStyles.css */ 2 | 3 | .note-container { 4 | padding: 10px; 5 | margin: 20px 0; 6 | border: 1px solid #ccc; 7 | border-radius: 5px; 8 | } 9 | 10 | .note-title { 11 | color: #333; 12 | } 13 | 14 | .note-content { 15 | color: #666; 16 | } 17 | 18 | .note-date { 19 | color: #999; 20 | font-size: 0.8rem; 21 | } 22 | 23 | .delete-button { 24 | background-color: #f44336; /* Red */ 25 | color: white; 26 | border: none; 27 | padding: 10px 20px; 28 | border-radius: 5px; 29 | cursor: pointer; 30 | transition: background-color 0.3s; 31 | } 32 | 33 | .delete-button:hover { 34 | background-color: #d32f2f; /* Darker red */ 35 | } 36 | -------------------------------------------------------------------------------- /frontend/src/styles/NoteStyles.css: -------------------------------------------------------------------------------- 1 | /* Container for the whole page */ 2 | div { 3 | font-family: Arial, sans-serif; 4 | } 5 | 6 | /* Styles for the notes section */ 7 | .notes-section { 8 | margin-bottom: 2rem; 9 | } 10 | 11 | .notes-section h2 { 12 | color: #333; 13 | font-size: 24px; 14 | } 15 | 16 | /* Styles for individual notes - assuming your Note component has some container element */ 17 | .note { 18 | background-color: #f9f9f9; 19 | border-left: 5px solid #007bff; 20 | margin: 10px 0; 21 | padding: 10px 15px; 22 | border-radius: 5px; 23 | } 24 | 25 | /* Styles for the form section */ 26 | form { 27 | background-color: #fff; 28 | padding: 20px; 29 | border-radius: 8px; 30 | box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); 31 | max-width: 500px; 32 | margin: auto; 33 | } 34 | 35 | form h2 { 36 | color: #333; 37 | font-size: 24px; 38 | margin-bottom: 20px; 39 | } 40 | 41 | form label { 42 | font-weight: bold; 43 | margin-top: 10px; 44 | } 45 | 46 | form input, 47 | form textarea { 48 | width: 100%; 49 | padding: 8px; 50 | margin: 8px 0 16px; 51 | border: 1px solid #ccc; 52 | border-radius: 4px; 53 | box-sizing: border-box; 54 | } 55 | 56 | form input[type="submit"] { 57 | background-color: #007bff; 58 | color: white; 59 | padding: 10px 20px; 60 | border: none; 61 | border-radius: 4px; 62 | cursor: pointer; 63 | font-size: 16px; 64 | } 65 | 66 | form input[type="submit"]:hover { 67 | background-color: #0056b3; 68 | } 69 | -------------------------------------------------------------------------------- /frontend/vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig, loadEnv } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | export default ({ mode }) => { 5 | process.env = {...process.env, ...loadEnv(mode, process.cwd())}; 6 | 7 | // import.meta.env.VITE_NAME available here with: process.env.VITE_NAME 8 | // import.meta.env.VITE_PORT available here with: process.env.VITE_PORT 9 | 10 | return defineConfig({ 11 | plugins: [react()], 12 | }); 13 | } --------------------------------------------------------------------------------