├── .env ├── .eslintrc.cjs ├── .gitattributes ├── .gitignore ├── README.md ├── firebase.js ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.css ├── App.jsx ├── assets │ └── react.svg ├── components │ ├── Dashboard.jsx │ └── Login.jsx ├── context │ └── AuthContext.jsx ├── index.css └── main.jsx └── vite.config.js /.env: -------------------------------------------------------------------------------- 1 | VITE_APIKEY= 2 | VITE_AUTHDOMAIN= 3 | VITE_PROJECTID= 4 | VITE_STORAGEBUCKET= 5 | VITE_MESSAGINGSENDERID= 6 | VITE_APPID= -------------------------------------------------------------------------------- /.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-refresh/only-export-components': [ 16 | 'warn', 17 | { allowConstantExport: true }, 18 | ], 19 | }, 20 | } 21 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | # Auto detect text files and perform LF normalization 2 | * text=auto 3 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Authentication + Database Speed Run [React.js & Firebase] 2 | 3 | Let this guide be the auth + database speed run from the heavens to get your ideas underway ASAP, today. We’ll be developing this full stack system with React.js on the frontend, although the process is analogous for Next.js apps too, and Firebase on the backend because they handle all the heavy logic lifting and they have a phenomenal free tier for both authentication and with the Firestore NoSQL database. You can deploy your projects live today, for free, and you won’t incur any costs until you’re already making absolute bank! 4 | 5 | ## Chapter 1 — Project Initialization 6 | 7 | Square one, al principio, we begin by creating a React.js project with [Vite](https://vitejs.dev/guide/). It’s a rudimentary process; you simply run this command in your terminal! 8 | 9 | `npm create vite@latest my-fullstack-react-app -- --template react` 10 | 11 | Phew, that was easy. Now we can go ahead and open our project inside of your code editor! 12 | 13 | Then we'll quickly need to install firebase as an NPM dependancy for our project by running the following command in our terminal: 14 | 15 | `npm i firebase` 16 | 17 | The next task on our list is to create the following files: 18 | 19 | 1. `/firebase.js` 20 | 2. `/src/context/AuthContext.jsx` 21 | 3. `/.env` 22 | 4. `/src/components/Login.jsx` 23 | 5. `/src/components/Dashboard.jsx` 24 | 25 | ### 1.0 Firebase.js 26 | 27 | The `firebase.js` file can contain the following code: 28 | 29 | ``` 30 | import {initializeApp} from 'firebase/app' 31 | import {getAuth} from 'firebase/auth' 32 | import {getFirestore} from 'firebase/firestore' 33 | 34 | // Your web app's Firebase configuration 35 | const firebaseConfig = { 36 | apiKey: import.meta.env.VITE_APIKEY, 37 | authDomain: import.meta.env.VITE_AUTHDOMAIN, 38 | projectId: import.meta.env.VITE_PROJECTID, 39 | storageBucket: import.meta.env.VITE_STORAGEBUCKET, 40 | messagingSenderId: import.meta.env.VITE_MESSAGINGSENDERID, 41 | appId: import.meta.env.VITE_APPID 42 | }; 43 | 44 | // Initialize Firebase 45 | const app = initializeApp(firebaseConfig); 46 | 47 | export const auth = getAuth(app) 48 | export const db = getFirestore(app) 49 | ``` 50 | 51 | This code initializes Firebase in our React.js codebase in addition to also initializing and then exporting our Firebase authentication & database so that they may be accessed elsewhere within our projects. 52 | 53 | ### 2.0 AuthContext.jsx 54 | 55 | The `AuthContext.jsx` component is ever so slightly more complex: 56 | 57 | ``` 58 | import React, { useContext, useState, useEffect } from 'react' 59 | import { auth, db } from '../../firebase' 60 | import { signInWithEmailAndPassword, createUserWithEmailAndPassword, signOut, onAuthStateChanged } from 'firebase/auth' 61 | 62 | const AuthContext = React.createContext() 63 | 64 | export function useAuth() { 65 | // create a useAuth hook to access the context throughout our app 66 | return useContext(AuthContext) 67 | } 68 | 69 | export function AuthProvider({ children }) { 70 | // create the auth wrapper component for our application 71 | // could optionally define a userData state and add to context 72 | const [currentUser, setCurrentUser] = useState(null) 73 | 74 | 75 | function signup(email, password) { 76 | return createUserWithEmailAndPassword(auth, email, password) 77 | } 78 | 79 | function login(email, password) { 80 | return signInWithEmailAndPassword(auth, email, password) 81 | } 82 | 83 | function logout() { 84 | return signOut(auth) 85 | } 86 | 87 | useEffect(() => { 88 | const unsubscribe = onAuthStateChanged(auth, user => { 89 | // This is where you could fetch generic user data from firebase 90 | setCurrentUser(user) 91 | }) 92 | return unsubscribe 93 | }, []) 94 | 95 | const value = { 96 | currentUser, 97 | signup, 98 | logout, 99 | login 100 | } 101 | 102 | return ( 103 | 104 | {children} 105 | 106 | ) 107 | } 108 | ``` 109 | 110 | This component has two functions, one that creates an auth hook that we can use to access the auth state throughout our application, and the second is an auth wrapper component with which we will encapsulate our entire application. 111 | 112 | We also define some logic that monitors the auth state, so that our application is responsive to the users different authentication states. Three functions are defined to demonstrate the primary authentication methods, however more can be created in the same vein. Finally, we pass both the auth status and methods down as a context to our entire app, allowing them to be accessed from within any component. 113 | 114 | > The users login state is cleverly stored in cookies so even if the page is refreshed, the authentication state can be maintained for a period of time without the user having to sign in again! 115 | 116 | ### 3.0 Environment Variables 117 | 118 | To keep our application secure, we save our keys within a `.env` file. The file can be initialized as follows: 119 | 120 | ``` 121 | VITE_APIKEY= 122 | VITE_AUTHDOMAIN= 123 | VITE_PROJECTID= 124 | VITE_STORAGEBUCKET= 125 | VITE_MESSAGINGSENDERID= 126 | VITE_APPID= 127 | ``` 128 | 129 | We will soon fill out the actual key values in here to then be accessed within the `firebase.js` file. 130 | 131 | ### 4.0 Login.jsx 132 | 133 | Now we need to initialize a Login component to handle the users sign-in and sign-up functionalities: 134 | 135 | ``` 136 | import React, { useState } from 'react' 137 | import { useAuth } from '../context/AuthContext' 138 | 139 | export default function Login() { 140 | const [createAccount, setCreateAccount] = useState(false) 141 | const [userCreds, setUserCreds] = useState({ email: '', password: '' }) 142 | 143 | const { signup, login } = useAuth() 144 | 145 | function updateEmail(e) { 146 | setUserCreds({ ...userCreds, email: e.target.value }) 147 | } 148 | 149 | function updatePassword(e) { 150 | setUserCreds({ ...userCreds, password: e.target.value }) 151 | } 152 | 153 | function handleSubmit(e) { 154 | e.preventDefault() 155 | // prevents signup if form not completed 156 | if (!userCreds.email || !userCreds.password) { return } 157 | 158 | if (createAccount) { 159 | // recommended to add password regex check in here 160 | console.log('Registering') 161 | signup(userCreds.email, userCreds.password) 162 | } else { 163 | console.log('Logging in') 164 | login(userCreds.email, userCreds.password) 165 | } 166 | } 167 | 168 | return ( 169 |
170 | { 171 | updateEmail(e) 172 | }}> 173 | { 174 | updatePassword(e) 175 | }}> 176 | 179 | 182 |
183 | ) 184 | } 185 | ``` 186 | 187 | And we cleverly access both methods by calling the `useContext()` hook and destructuring the methods from within! In the component JSX we create two input fields for the email and password respectively, a button to submit the form, and a button to swap between the registration and login states. 188 | 189 | ### 5.0 Dashboard.jsx 190 | 191 | And finally, we can display a dashboard component for anyone who is logged in :P 192 | 193 | ``` 194 | import React from 'react' 195 | import { doc, increment, serverTimestamp, setDoc } from "firebase/firestore"; 196 | import { useAuth } from '../context/AuthContext' 197 | import { db } from '../../firebase'; 198 | 199 | export default function Dashboard() { 200 | const { logout, currentUser } = useAuth() 201 | 202 | async function handleIncrement() { 203 | const userRef = doc(db, 'users', currentUser.uid); 204 | await setDoc(userRef, { counter: increment(1), timestamp: serverTimestamp() }, { merge: true }); 205 | } 206 | 207 | return ( 208 |
209 |

hello world & welcome to the dashboard

210 | 211 | 212 |
213 | ) 214 | } 215 | ``` 216 | 217 | The dashboard also has an increment counter to demonstrate how we can modify information in the database specific to the user by connecting the two via the users ID. Additionally, it contains a logout function for when the user wishes to logout from their account. 218 | 219 | You can read more about CRUD operations with Firebase/Firestore here: 220 | 221 | * https://firebase.google.com/docs/firestore/manage-data/add-data 222 | 223 | 224 | ### Chapter 2 — Modifying App.jsx & Main.jsx 225 | 226 | With all our components and files created, we can quickly make a modification to our `app.jsx` component so that it renders the login component for unauthenticated users, and the dashboard for those logged in already. 227 | 228 | ``` 229 | import { useAuth } from './context/AuthContext' 230 | import Login from './components/Login' 231 | import Dashboard from './components/Dashboard' 232 | 233 | function App() { 234 | const { currentUser } = useAuth() 235 | return ( 236 |
237 | {currentUser ? ( 238 | 239 | ) : ( 240 | 241 | )} 242 |
243 | ) 244 | } 245 | 246 | export default App 247 | ``` 248 | 249 | This very simple app component accesses the currentUser state using the auth context and conditionally renders either our dashboard or login component depending on whether or not a user is found! 250 | 251 | Our `main.jsx` receives a very simple update, simply wrapping the app in the new context: 252 | 253 | ``` 254 | import React from 'react' 255 | import ReactDOM from 'react-dom/client' 256 | import App from './App.jsx' 257 | import { AuthProvider } from './context/AuthContext.jsx' 258 | 259 | ReactDOM.createRoot(document.getElementById('root')).render( 260 | 261 | 262 | 263 | 264 | , 265 | ) 266 | 267 | ``` 268 | 269 | ## Chapter 3 — Initializing Firebase 270 | 271 | Finally, we can provision some firebase resources to manage our authentication and database utilities within the cloud (not to mention it’s free for a solid amount of usage)! 272 | 273 | If we visit the following page and click **Get Started**, we’ll be taken to our developer console: 274 | 275 | * https://firebase.google.com/ 276 | 277 | From here, we’ll hit **Add Project**, give our project a name, optionally opt for googles analytics, and finally be taken through to the dashboard for our new project. It should look a bit as follows! 278 | 279 | 280 | ![Firebase Project Dashboard](https://miro.medium.com/v2/resize:fit:1400/format:webp/1*JWhmL6jR5iHTgaQDgLgMjA.png) 281 | 282 | Now we can finish the setup by following these steps: 283 | 284 | 1. From here, we’ll first select Authentication. 285 | 286 | ![Select authentication!](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*feoEuhfGUA1JDYbXZhgibA.png) 287 | 288 | 2. Hit **Get Started** on the following page. 289 | 290 | 3. Select Email/Password to enable authentication with email and password. 291 | 292 | ![Select Email/Password](https://miro.medium.com/v2/resize:fit:1400/format:webp/1*9a9q6tFbp-yziGBl8aqAzw.png) 293 | 294 | 4. Enable Email/Password and hit save. 295 | 296 | ![Enable Email/Password](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*eWgqbZWqMjQY-THOFboHuQ.png) 297 | 298 | That should do it to configure Firebase authentication. Now we initialize the database! 299 | 300 | 5. Select Cloud Firestore from the home dashboard. 301 | 302 | ![Back to homepage then select Cloud Firestore](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*Z5riX6ACBqgcdQrE5MZaLw.png) 303 | 304 | 6. From here we’ll create a database. The only thing you need to consider is your location database if you’re extremely concerned about latency. Then hit **Next**. 305 | 306 | ![Optionally update location](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*vfjlRhtRaV2op6_l8IzSMA.png) 307 | 308 | 7. Now we set the database to Test Mode to ensure that the read and write options are open. 309 | 310 | ![Start database in test mode](https://miro.medium.com/v2/resize:fit:1400/format:webp/1*LPgIWtkef_BNtHYYdC8cJw.png) 311 | 312 | 8. And now, back to the dashboard to configure our Firebase project for a web application. Select the web option. 313 | 314 | ![Back to home page then enable firebase for web app](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*EMUWOmXql_VQaXlpuXfGag.png) 315 | 316 | 9. From here, create an app name and hit **Register app**. 317 | 318 | ![Name your web app](https://miro.medium.com/v2/resize:fit:2000/format:webp/1*Os94H4ju0yx0kbsWrQU8Bg.png) 319 | 320 | 10. And finally, you’ll be directed to the config screen that will present you with all your valuable keys to be inserted into your `.env` file in the React codebase. 321 | 322 | ![Enter your keys into the .env file](https://miro.medium.com/v2/resize:fit:1400/format:webp/1*LCJKqy_wA7pf0jxjRNi2vA.png) 323 | 324 | ## Chapter 4 — Update Your `.ENV` File 325 | 326 | Now that we have access to the keys required for our project, we can enter them into our `.env` file so that it looks as follows: 327 | 328 | ``` 329 | VITE_APIKEY=AIzaSyA3uUJXfR1241241KvUZWi3QnuUel3Y_euSnyg 330 | VITE_AUTHDOMAIN=test123–22ba3.firebaseapp.com 331 | VITE_PROJECTID=test123–22ba3 332 | VITE_STORAGEBUCKET=test123–22ba3.appspot.com 333 | VITE_MESSAGINGSENDERID=176123123817312 334 | VITE_APPID=1:176123123817312:web:89asdklj8123klj8asdf6623c4ffc5 335 | ``` 336 | 337 | > For any opportunist out there, I’m afraid the project has been deleted which will invalidate these keys :P 338 | 339 | ## Chapter 5 — Run Your App 340 | 341 | And finally, our project is ready for action. We can run our app using the following terminal command: 342 | 343 | `npm run dev` 344 | 345 | And boot it up on http://localhost:5173 ! 346 | 347 | From there you should be able to register an account, and once logged in, hit the increment button. To confirm your application is working, inspect the Firestore console from the Firebase home page and you should see your user data incremented along with a timestamp. 348 | 349 | And that’s it! Congratulations on completed the React.js + Firebase Authentication & Database speed run. May your full stack projects be secure and manage loads of user data :P -------------------------------------------------------------------------------- /firebase.js: -------------------------------------------------------------------------------- 1 | import { initializeApp } from 'firebase/app' 2 | import { getAuth } from 'firebase/auth' 3 | import { getFirestore } from 'firebase/firestore' 4 | 5 | // Your web app's Firebase configuration 6 | const firebaseConfig = { 7 | apiKey: import.meta.env.VITE_APIKEY, 8 | authDomain: import.meta.env.VITE_AUTHDOMAIN, 9 | projectId: import.meta.env.VITE_PROJECTID, 10 | storageBucket: import.meta.env.VITE_STORAGEBUCKET, 11 | messagingSenderId: import.meta.env.VITE_MESSAGINGSENDERID, 12 | appId: import.meta.env.VITE_APPID 13 | }; 14 | 15 | // Initialize Firebase 16 | const app = initializeApp(firebaseConfig); 17 | 18 | export const auth = getAuth(app) 19 | export const db = getFirestore(app) -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-firebase-auth-db-template", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "react-firebase-auth-db-template", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "firebase": "^10.7.1", 12 | "react": "^18.2.0", 13 | "react-dom": "^18.2.0" 14 | }, 15 | "devDependencies": { 16 | "@types/react": "^18.2.43", 17 | "@types/react-dom": "^18.2.17", 18 | "@vitejs/plugin-react": "^4.2.1", 19 | "eslint": "^8.55.0", 20 | "eslint-plugin-react": "^7.33.2", 21 | "eslint-plugin-react-hooks": "^4.6.0", 22 | "eslint-plugin-react-refresh": "^0.4.5", 23 | "vite": "^5.0.8" 24 | } 25 | }, 26 | "node_modules/@aashutoshrathi/word-wrap": { 27 | "version": "1.2.6", 28 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 29 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 30 | "dev": true, 31 | "engines": { 32 | "node": ">=0.10.0" 33 | } 34 | }, 35 | "node_modules/@ampproject/remapping": { 36 | "version": "2.2.1", 37 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 38 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 39 | "dev": true, 40 | "dependencies": { 41 | "@jridgewell/gen-mapping": "^0.3.0", 42 | "@jridgewell/trace-mapping": "^0.3.9" 43 | }, 44 | "engines": { 45 | "node": ">=6.0.0" 46 | } 47 | }, 48 | "node_modules/@babel/code-frame": { 49 | "version": "7.23.5", 50 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 51 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 52 | "dev": true, 53 | "dependencies": { 54 | "@babel/highlight": "^7.23.4", 55 | "chalk": "^2.4.2" 56 | }, 57 | "engines": { 58 | "node": ">=6.9.0" 59 | } 60 | }, 61 | "node_modules/@babel/compat-data": { 62 | "version": "7.23.5", 63 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", 64 | "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", 65 | "dev": true, 66 | "engines": { 67 | "node": ">=6.9.0" 68 | } 69 | }, 70 | "node_modules/@babel/core": { 71 | "version": "7.23.7", 72 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.7.tgz", 73 | "integrity": "sha512-+UpDgowcmqe36d4NwqvKsyPMlOLNGMsfMmQ5WGCu+siCe3t3dfe9njrzGfdN4qq+bcNUt0+Vw6haRxBOycs4dw==", 74 | "dev": true, 75 | "dependencies": { 76 | "@ampproject/remapping": "^2.2.0", 77 | "@babel/code-frame": "^7.23.5", 78 | "@babel/generator": "^7.23.6", 79 | "@babel/helper-compilation-targets": "^7.23.6", 80 | "@babel/helper-module-transforms": "^7.23.3", 81 | "@babel/helpers": "^7.23.7", 82 | "@babel/parser": "^7.23.6", 83 | "@babel/template": "^7.22.15", 84 | "@babel/traverse": "^7.23.7", 85 | "@babel/types": "^7.23.6", 86 | "convert-source-map": "^2.0.0", 87 | "debug": "^4.1.0", 88 | "gensync": "^1.0.0-beta.2", 89 | "json5": "^2.2.3", 90 | "semver": "^6.3.1" 91 | }, 92 | "engines": { 93 | "node": ">=6.9.0" 94 | }, 95 | "funding": { 96 | "type": "opencollective", 97 | "url": "https://opencollective.com/babel" 98 | } 99 | }, 100 | "node_modules/@babel/generator": { 101 | "version": "7.23.6", 102 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", 103 | "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", 104 | "dev": true, 105 | "dependencies": { 106 | "@babel/types": "^7.23.6", 107 | "@jridgewell/gen-mapping": "^0.3.2", 108 | "@jridgewell/trace-mapping": "^0.3.17", 109 | "jsesc": "^2.5.1" 110 | }, 111 | "engines": { 112 | "node": ">=6.9.0" 113 | } 114 | }, 115 | "node_modules/@babel/helper-compilation-targets": { 116 | "version": "7.23.6", 117 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", 118 | "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", 119 | "dev": true, 120 | "dependencies": { 121 | "@babel/compat-data": "^7.23.5", 122 | "@babel/helper-validator-option": "^7.23.5", 123 | "browserslist": "^4.22.2", 124 | "lru-cache": "^5.1.1", 125 | "semver": "^6.3.1" 126 | }, 127 | "engines": { 128 | "node": ">=6.9.0" 129 | } 130 | }, 131 | "node_modules/@babel/helper-environment-visitor": { 132 | "version": "7.22.20", 133 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", 134 | "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", 135 | "dev": true, 136 | "engines": { 137 | "node": ">=6.9.0" 138 | } 139 | }, 140 | "node_modules/@babel/helper-function-name": { 141 | "version": "7.23.0", 142 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", 143 | "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", 144 | "dev": true, 145 | "dependencies": { 146 | "@babel/template": "^7.22.15", 147 | "@babel/types": "^7.23.0" 148 | }, 149 | "engines": { 150 | "node": ">=6.9.0" 151 | } 152 | }, 153 | "node_modules/@babel/helper-hoist-variables": { 154 | "version": "7.22.5", 155 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 156 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 157 | "dev": true, 158 | "dependencies": { 159 | "@babel/types": "^7.22.5" 160 | }, 161 | "engines": { 162 | "node": ">=6.9.0" 163 | } 164 | }, 165 | "node_modules/@babel/helper-module-imports": { 166 | "version": "7.22.15", 167 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", 168 | "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", 169 | "dev": true, 170 | "dependencies": { 171 | "@babel/types": "^7.22.15" 172 | }, 173 | "engines": { 174 | "node": ">=6.9.0" 175 | } 176 | }, 177 | "node_modules/@babel/helper-module-transforms": { 178 | "version": "7.23.3", 179 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz", 180 | "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==", 181 | "dev": true, 182 | "dependencies": { 183 | "@babel/helper-environment-visitor": "^7.22.20", 184 | "@babel/helper-module-imports": "^7.22.15", 185 | "@babel/helper-simple-access": "^7.22.5", 186 | "@babel/helper-split-export-declaration": "^7.22.6", 187 | "@babel/helper-validator-identifier": "^7.22.20" 188 | }, 189 | "engines": { 190 | "node": ">=6.9.0" 191 | }, 192 | "peerDependencies": { 193 | "@babel/core": "^7.0.0" 194 | } 195 | }, 196 | "node_modules/@babel/helper-plugin-utils": { 197 | "version": "7.22.5", 198 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", 199 | "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", 200 | "dev": true, 201 | "engines": { 202 | "node": ">=6.9.0" 203 | } 204 | }, 205 | "node_modules/@babel/helper-simple-access": { 206 | "version": "7.22.5", 207 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 208 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 209 | "dev": true, 210 | "dependencies": { 211 | "@babel/types": "^7.22.5" 212 | }, 213 | "engines": { 214 | "node": ">=6.9.0" 215 | } 216 | }, 217 | "node_modules/@babel/helper-split-export-declaration": { 218 | "version": "7.22.6", 219 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 220 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 221 | "dev": true, 222 | "dependencies": { 223 | "@babel/types": "^7.22.5" 224 | }, 225 | "engines": { 226 | "node": ">=6.9.0" 227 | } 228 | }, 229 | "node_modules/@babel/helper-string-parser": { 230 | "version": "7.23.4", 231 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", 232 | "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", 233 | "dev": true, 234 | "engines": { 235 | "node": ">=6.9.0" 236 | } 237 | }, 238 | "node_modules/@babel/helper-validator-identifier": { 239 | "version": "7.22.20", 240 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 241 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 242 | "dev": true, 243 | "engines": { 244 | "node": ">=6.9.0" 245 | } 246 | }, 247 | "node_modules/@babel/helper-validator-option": { 248 | "version": "7.23.5", 249 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz", 250 | "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==", 251 | "dev": true, 252 | "engines": { 253 | "node": ">=6.9.0" 254 | } 255 | }, 256 | "node_modules/@babel/helpers": { 257 | "version": "7.23.8", 258 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.8.tgz", 259 | "integrity": "sha512-KDqYz4PiOWvDFrdHLPhKtCThtIcKVy6avWD2oG4GEvyQ+XDZwHD4YQd+H2vNMnq2rkdxsDkU82T+Vk8U/WXHRQ==", 260 | "dev": true, 261 | "dependencies": { 262 | "@babel/template": "^7.22.15", 263 | "@babel/traverse": "^7.23.7", 264 | "@babel/types": "^7.23.6" 265 | }, 266 | "engines": { 267 | "node": ">=6.9.0" 268 | } 269 | }, 270 | "node_modules/@babel/highlight": { 271 | "version": "7.23.4", 272 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 273 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 274 | "dev": true, 275 | "dependencies": { 276 | "@babel/helper-validator-identifier": "^7.22.20", 277 | "chalk": "^2.4.2", 278 | "js-tokens": "^4.0.0" 279 | }, 280 | "engines": { 281 | "node": ">=6.9.0" 282 | } 283 | }, 284 | "node_modules/@babel/parser": { 285 | "version": "7.23.6", 286 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz", 287 | "integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==", 288 | "dev": true, 289 | "bin": { 290 | "parser": "bin/babel-parser.js" 291 | }, 292 | "engines": { 293 | "node": ">=6.0.0" 294 | } 295 | }, 296 | "node_modules/@babel/plugin-transform-react-jsx-self": { 297 | "version": "7.23.3", 298 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.23.3.tgz", 299 | "integrity": "sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==", 300 | "dev": true, 301 | "dependencies": { 302 | "@babel/helper-plugin-utils": "^7.22.5" 303 | }, 304 | "engines": { 305 | "node": ">=6.9.0" 306 | }, 307 | "peerDependencies": { 308 | "@babel/core": "^7.0.0-0" 309 | } 310 | }, 311 | "node_modules/@babel/plugin-transform-react-jsx-source": { 312 | "version": "7.23.3", 313 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.23.3.tgz", 314 | "integrity": "sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==", 315 | "dev": true, 316 | "dependencies": { 317 | "@babel/helper-plugin-utils": "^7.22.5" 318 | }, 319 | "engines": { 320 | "node": ">=6.9.0" 321 | }, 322 | "peerDependencies": { 323 | "@babel/core": "^7.0.0-0" 324 | } 325 | }, 326 | "node_modules/@babel/template": { 327 | "version": "7.22.15", 328 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", 329 | "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", 330 | "dev": true, 331 | "dependencies": { 332 | "@babel/code-frame": "^7.22.13", 333 | "@babel/parser": "^7.22.15", 334 | "@babel/types": "^7.22.15" 335 | }, 336 | "engines": { 337 | "node": ">=6.9.0" 338 | } 339 | }, 340 | "node_modules/@babel/traverse": { 341 | "version": "7.23.7", 342 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.7.tgz", 343 | "integrity": "sha512-tY3mM8rH9jM0YHFGyfC0/xf+SB5eKUu7HPj7/k3fpi9dAlsMc5YbQvDi0Sh2QTPXqMhyaAtzAr807TIyfQrmyg==", 344 | "dev": true, 345 | "dependencies": { 346 | "@babel/code-frame": "^7.23.5", 347 | "@babel/generator": "^7.23.6", 348 | "@babel/helper-environment-visitor": "^7.22.20", 349 | "@babel/helper-function-name": "^7.23.0", 350 | "@babel/helper-hoist-variables": "^7.22.5", 351 | "@babel/helper-split-export-declaration": "^7.22.6", 352 | "@babel/parser": "^7.23.6", 353 | "@babel/types": "^7.23.6", 354 | "debug": "^4.3.1", 355 | "globals": "^11.1.0" 356 | }, 357 | "engines": { 358 | "node": ">=6.9.0" 359 | } 360 | }, 361 | "node_modules/@babel/types": { 362 | "version": "7.23.6", 363 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.6.tgz", 364 | "integrity": "sha512-+uarb83brBzPKN38NX1MkB6vb6+mwvR6amUulqAE7ccQw1pEl+bCia9TbdG1lsnFP7lZySvUn37CHyXQdfTwzg==", 365 | "dev": true, 366 | "dependencies": { 367 | "@babel/helper-string-parser": "^7.23.4", 368 | "@babel/helper-validator-identifier": "^7.22.20", 369 | "to-fast-properties": "^2.0.0" 370 | }, 371 | "engines": { 372 | "node": ">=6.9.0" 373 | } 374 | }, 375 | "node_modules/@esbuild/aix-ppc64": { 376 | "version": "0.19.11", 377 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.11.tgz", 378 | "integrity": "sha512-FnzU0LyE3ySQk7UntJO4+qIiQgI7KoODnZg5xzXIrFJlKd2P2gwHsHY4927xj9y5PJmJSzULiUCWmv7iWnNa7g==", 379 | "cpu": [ 380 | "ppc64" 381 | ], 382 | "dev": true, 383 | "optional": true, 384 | "os": [ 385 | "aix" 386 | ], 387 | "engines": { 388 | "node": ">=12" 389 | } 390 | }, 391 | "node_modules/@esbuild/android-arm": { 392 | "version": "0.19.11", 393 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.11.tgz", 394 | "integrity": "sha512-5OVapq0ClabvKvQ58Bws8+wkLCV+Rxg7tUVbo9xu034Nm536QTII4YzhaFriQ7rMrorfnFKUsArD2lqKbFY4vw==", 395 | "cpu": [ 396 | "arm" 397 | ], 398 | "dev": true, 399 | "optional": true, 400 | "os": [ 401 | "android" 402 | ], 403 | "engines": { 404 | "node": ">=12" 405 | } 406 | }, 407 | "node_modules/@esbuild/android-arm64": { 408 | "version": "0.19.11", 409 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.11.tgz", 410 | "integrity": "sha512-aiu7K/5JnLj//KOnOfEZ0D90obUkRzDMyqd/wNAUQ34m4YUPVhRZpnqKV9uqDGxT7cToSDnIHsGooyIczu9T+Q==", 411 | "cpu": [ 412 | "arm64" 413 | ], 414 | "dev": true, 415 | "optional": true, 416 | "os": [ 417 | "android" 418 | ], 419 | "engines": { 420 | "node": ">=12" 421 | } 422 | }, 423 | "node_modules/@esbuild/android-x64": { 424 | "version": "0.19.11", 425 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.11.tgz", 426 | "integrity": "sha512-eccxjlfGw43WYoY9QgB82SgGgDbibcqyDTlk3l3C0jOVHKxrjdc9CTwDUQd0vkvYg5um0OH+GpxYvp39r+IPOg==", 427 | "cpu": [ 428 | "x64" 429 | ], 430 | "dev": true, 431 | "optional": true, 432 | "os": [ 433 | "android" 434 | ], 435 | "engines": { 436 | "node": ">=12" 437 | } 438 | }, 439 | "node_modules/@esbuild/darwin-arm64": { 440 | "version": "0.19.11", 441 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.11.tgz", 442 | "integrity": "sha512-ETp87DRWuSt9KdDVkqSoKoLFHYTrkyz2+65fj9nfXsaV3bMhTCjtQfw3y+um88vGRKRiF7erPrh/ZuIdLUIVxQ==", 443 | "cpu": [ 444 | "arm64" 445 | ], 446 | "dev": true, 447 | "optional": true, 448 | "os": [ 449 | "darwin" 450 | ], 451 | "engines": { 452 | "node": ">=12" 453 | } 454 | }, 455 | "node_modules/@esbuild/darwin-x64": { 456 | "version": "0.19.11", 457 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.11.tgz", 458 | "integrity": "sha512-fkFUiS6IUK9WYUO/+22omwetaSNl5/A8giXvQlcinLIjVkxwTLSktbF5f/kJMftM2MJp9+fXqZ5ezS7+SALp4g==", 459 | "cpu": [ 460 | "x64" 461 | ], 462 | "dev": true, 463 | "optional": true, 464 | "os": [ 465 | "darwin" 466 | ], 467 | "engines": { 468 | "node": ">=12" 469 | } 470 | }, 471 | "node_modules/@esbuild/freebsd-arm64": { 472 | "version": "0.19.11", 473 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.11.tgz", 474 | "integrity": "sha512-lhoSp5K6bxKRNdXUtHoNc5HhbXVCS8V0iZmDvyWvYq9S5WSfTIHU2UGjcGt7UeS6iEYp9eeymIl5mJBn0yiuxA==", 475 | "cpu": [ 476 | "arm64" 477 | ], 478 | "dev": true, 479 | "optional": true, 480 | "os": [ 481 | "freebsd" 482 | ], 483 | "engines": { 484 | "node": ">=12" 485 | } 486 | }, 487 | "node_modules/@esbuild/freebsd-x64": { 488 | "version": "0.19.11", 489 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.11.tgz", 490 | "integrity": "sha512-JkUqn44AffGXitVI6/AbQdoYAq0TEullFdqcMY/PCUZ36xJ9ZJRtQabzMA+Vi7r78+25ZIBosLTOKnUXBSi1Kw==", 491 | "cpu": [ 492 | "x64" 493 | ], 494 | "dev": true, 495 | "optional": true, 496 | "os": [ 497 | "freebsd" 498 | ], 499 | "engines": { 500 | "node": ">=12" 501 | } 502 | }, 503 | "node_modules/@esbuild/linux-arm": { 504 | "version": "0.19.11", 505 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.11.tgz", 506 | "integrity": "sha512-3CRkr9+vCV2XJbjwgzjPtO8T0SZUmRZla+UL1jw+XqHZPkPgZiyWvbDvl9rqAN8Zl7qJF0O/9ycMtjU67HN9/Q==", 507 | "cpu": [ 508 | "arm" 509 | ], 510 | "dev": true, 511 | "optional": true, 512 | "os": [ 513 | "linux" 514 | ], 515 | "engines": { 516 | "node": ">=12" 517 | } 518 | }, 519 | "node_modules/@esbuild/linux-arm64": { 520 | "version": "0.19.11", 521 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.11.tgz", 522 | "integrity": "sha512-LneLg3ypEeveBSMuoa0kwMpCGmpu8XQUh+mL8XXwoYZ6Be2qBnVtcDI5azSvh7vioMDhoJFZzp9GWp9IWpYoUg==", 523 | "cpu": [ 524 | "arm64" 525 | ], 526 | "dev": true, 527 | "optional": true, 528 | "os": [ 529 | "linux" 530 | ], 531 | "engines": { 532 | "node": ">=12" 533 | } 534 | }, 535 | "node_modules/@esbuild/linux-ia32": { 536 | "version": "0.19.11", 537 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.11.tgz", 538 | "integrity": "sha512-caHy++CsD8Bgq2V5CodbJjFPEiDPq8JJmBdeyZ8GWVQMjRD0sU548nNdwPNvKjVpamYYVL40AORekgfIubwHoA==", 539 | "cpu": [ 540 | "ia32" 541 | ], 542 | "dev": true, 543 | "optional": true, 544 | "os": [ 545 | "linux" 546 | ], 547 | "engines": { 548 | "node": ">=12" 549 | } 550 | }, 551 | "node_modules/@esbuild/linux-loong64": { 552 | "version": "0.19.11", 553 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.11.tgz", 554 | "integrity": "sha512-ppZSSLVpPrwHccvC6nQVZaSHlFsvCQyjnvirnVjbKSHuE5N24Yl8F3UwYUUR1UEPaFObGD2tSvVKbvR+uT1Nrg==", 555 | "cpu": [ 556 | "loong64" 557 | ], 558 | "dev": true, 559 | "optional": true, 560 | "os": [ 561 | "linux" 562 | ], 563 | "engines": { 564 | "node": ">=12" 565 | } 566 | }, 567 | "node_modules/@esbuild/linux-mips64el": { 568 | "version": "0.19.11", 569 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.11.tgz", 570 | "integrity": "sha512-B5x9j0OgjG+v1dF2DkH34lr+7Gmv0kzX6/V0afF41FkPMMqaQ77pH7CrhWeR22aEeHKaeZVtZ6yFwlxOKPVFyg==", 571 | "cpu": [ 572 | "mips64el" 573 | ], 574 | "dev": true, 575 | "optional": true, 576 | "os": [ 577 | "linux" 578 | ], 579 | "engines": { 580 | "node": ">=12" 581 | } 582 | }, 583 | "node_modules/@esbuild/linux-ppc64": { 584 | "version": "0.19.11", 585 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.11.tgz", 586 | "integrity": "sha512-MHrZYLeCG8vXblMetWyttkdVRjQlQUb/oMgBNurVEnhj4YWOr4G5lmBfZjHYQHHN0g6yDmCAQRR8MUHldvvRDA==", 587 | "cpu": [ 588 | "ppc64" 589 | ], 590 | "dev": true, 591 | "optional": true, 592 | "os": [ 593 | "linux" 594 | ], 595 | "engines": { 596 | "node": ">=12" 597 | } 598 | }, 599 | "node_modules/@esbuild/linux-riscv64": { 600 | "version": "0.19.11", 601 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.11.tgz", 602 | "integrity": "sha512-f3DY++t94uVg141dozDu4CCUkYW+09rWtaWfnb3bqe4w5NqmZd6nPVBm+qbz7WaHZCoqXqHz5p6CM6qv3qnSSQ==", 603 | "cpu": [ 604 | "riscv64" 605 | ], 606 | "dev": true, 607 | "optional": true, 608 | "os": [ 609 | "linux" 610 | ], 611 | "engines": { 612 | "node": ">=12" 613 | } 614 | }, 615 | "node_modules/@esbuild/linux-s390x": { 616 | "version": "0.19.11", 617 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.11.tgz", 618 | "integrity": "sha512-A5xdUoyWJHMMlcSMcPGVLzYzpcY8QP1RtYzX5/bS4dvjBGVxdhuiYyFwp7z74ocV7WDc0n1harxmpq2ePOjI0Q==", 619 | "cpu": [ 620 | "s390x" 621 | ], 622 | "dev": true, 623 | "optional": true, 624 | "os": [ 625 | "linux" 626 | ], 627 | "engines": { 628 | "node": ">=12" 629 | } 630 | }, 631 | "node_modules/@esbuild/linux-x64": { 632 | "version": "0.19.11", 633 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.11.tgz", 634 | "integrity": "sha512-grbyMlVCvJSfxFQUndw5mCtWs5LO1gUlwP4CDi4iJBbVpZcqLVT29FxgGuBJGSzyOxotFG4LoO5X+M1350zmPA==", 635 | "cpu": [ 636 | "x64" 637 | ], 638 | "dev": true, 639 | "optional": true, 640 | "os": [ 641 | "linux" 642 | ], 643 | "engines": { 644 | "node": ">=12" 645 | } 646 | }, 647 | "node_modules/@esbuild/netbsd-x64": { 648 | "version": "0.19.11", 649 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.11.tgz", 650 | "integrity": "sha512-13jvrQZJc3P230OhU8xgwUnDeuC/9egsjTkXN49b3GcS5BKvJqZn86aGM8W9pd14Kd+u7HuFBMVtrNGhh6fHEQ==", 651 | "cpu": [ 652 | "x64" 653 | ], 654 | "dev": true, 655 | "optional": true, 656 | "os": [ 657 | "netbsd" 658 | ], 659 | "engines": { 660 | "node": ">=12" 661 | } 662 | }, 663 | "node_modules/@esbuild/openbsd-x64": { 664 | "version": "0.19.11", 665 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.11.tgz", 666 | "integrity": "sha512-ysyOGZuTp6SNKPE11INDUeFVVQFrhcNDVUgSQVDzqsqX38DjhPEPATpid04LCoUr2WXhQTEZ8ct/EgJCUDpyNw==", 667 | "cpu": [ 668 | "x64" 669 | ], 670 | "dev": true, 671 | "optional": true, 672 | "os": [ 673 | "openbsd" 674 | ], 675 | "engines": { 676 | "node": ">=12" 677 | } 678 | }, 679 | "node_modules/@esbuild/sunos-x64": { 680 | "version": "0.19.11", 681 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.11.tgz", 682 | "integrity": "sha512-Hf+Sad9nVwvtxy4DXCZQqLpgmRTQqyFyhT3bZ4F2XlJCjxGmRFF0Shwn9rzhOYRB61w9VMXUkxlBy56dk9JJiQ==", 683 | "cpu": [ 684 | "x64" 685 | ], 686 | "dev": true, 687 | "optional": true, 688 | "os": [ 689 | "sunos" 690 | ], 691 | "engines": { 692 | "node": ">=12" 693 | } 694 | }, 695 | "node_modules/@esbuild/win32-arm64": { 696 | "version": "0.19.11", 697 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.11.tgz", 698 | "integrity": "sha512-0P58Sbi0LctOMOQbpEOvOL44Ne0sqbS0XWHMvvrg6NE5jQ1xguCSSw9jQeUk2lfrXYsKDdOe6K+oZiwKPilYPQ==", 699 | "cpu": [ 700 | "arm64" 701 | ], 702 | "dev": true, 703 | "optional": true, 704 | "os": [ 705 | "win32" 706 | ], 707 | "engines": { 708 | "node": ">=12" 709 | } 710 | }, 711 | "node_modules/@esbuild/win32-ia32": { 712 | "version": "0.19.11", 713 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.11.tgz", 714 | "integrity": "sha512-6YOrWS+sDJDmshdBIQU+Uoyh7pQKrdykdefC1avn76ss5c+RN6gut3LZA4E2cH5xUEp5/cA0+YxRaVtRAb0xBg==", 715 | "cpu": [ 716 | "ia32" 717 | ], 718 | "dev": true, 719 | "optional": true, 720 | "os": [ 721 | "win32" 722 | ], 723 | "engines": { 724 | "node": ">=12" 725 | } 726 | }, 727 | "node_modules/@esbuild/win32-x64": { 728 | "version": "0.19.11", 729 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.11.tgz", 730 | "integrity": "sha512-vfkhltrjCAb603XaFhqhAF4LGDi2M4OrCRrFusyQ+iTLQ/o60QQXxc9cZC/FFpihBI9N1Grn6SMKVJ4KP7Fuiw==", 731 | "cpu": [ 732 | "x64" 733 | ], 734 | "dev": true, 735 | "optional": true, 736 | "os": [ 737 | "win32" 738 | ], 739 | "engines": { 740 | "node": ">=12" 741 | } 742 | }, 743 | "node_modules/@eslint-community/eslint-utils": { 744 | "version": "4.4.0", 745 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 746 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 747 | "dev": true, 748 | "dependencies": { 749 | "eslint-visitor-keys": "^3.3.0" 750 | }, 751 | "engines": { 752 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 753 | }, 754 | "peerDependencies": { 755 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 756 | } 757 | }, 758 | "node_modules/@eslint-community/regexpp": { 759 | "version": "4.10.0", 760 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 761 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 762 | "dev": true, 763 | "engines": { 764 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 765 | } 766 | }, 767 | "node_modules/@eslint/eslintrc": { 768 | "version": "2.1.4", 769 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 770 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 771 | "dev": true, 772 | "dependencies": { 773 | "ajv": "^6.12.4", 774 | "debug": "^4.3.2", 775 | "espree": "^9.6.0", 776 | "globals": "^13.19.0", 777 | "ignore": "^5.2.0", 778 | "import-fresh": "^3.2.1", 779 | "js-yaml": "^4.1.0", 780 | "minimatch": "^3.1.2", 781 | "strip-json-comments": "^3.1.1" 782 | }, 783 | "engines": { 784 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 785 | }, 786 | "funding": { 787 | "url": "https://opencollective.com/eslint" 788 | } 789 | }, 790 | "node_modules/@eslint/eslintrc/node_modules/globals": { 791 | "version": "13.24.0", 792 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 793 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 794 | "dev": true, 795 | "dependencies": { 796 | "type-fest": "^0.20.2" 797 | }, 798 | "engines": { 799 | "node": ">=8" 800 | }, 801 | "funding": { 802 | "url": "https://github.com/sponsors/sindresorhus" 803 | } 804 | }, 805 | "node_modules/@eslint/js": { 806 | "version": "8.56.0", 807 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", 808 | "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==", 809 | "dev": true, 810 | "engines": { 811 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 812 | } 813 | }, 814 | "node_modules/@fastify/busboy": { 815 | "version": "2.1.0", 816 | "resolved": "https://registry.npmjs.org/@fastify/busboy/-/busboy-2.1.0.tgz", 817 | "integrity": "sha512-+KpH+QxZU7O4675t3mnkQKcZZg56u+K/Ct2K+N2AZYNVK8kyeo/bI18tI8aPm3tvNNRyTWfj6s5tnGNlcbQRsA==", 818 | "engines": { 819 | "node": ">=14" 820 | } 821 | }, 822 | "node_modules/@firebase/analytics": { 823 | "version": "0.10.0", 824 | "resolved": "https://registry.npmjs.org/@firebase/analytics/-/analytics-0.10.0.tgz", 825 | "integrity": "sha512-Locv8gAqx0e+GX/0SI3dzmBY5e9kjVDtD+3zCFLJ0tH2hJwuCAiL+5WkHuxKj92rqQj/rvkBUCfA1ewlX2hehg==", 826 | "dependencies": { 827 | "@firebase/component": "0.6.4", 828 | "@firebase/installations": "0.6.4", 829 | "@firebase/logger": "0.4.0", 830 | "@firebase/util": "1.9.3", 831 | "tslib": "^2.1.0" 832 | }, 833 | "peerDependencies": { 834 | "@firebase/app": "0.x" 835 | } 836 | }, 837 | "node_modules/@firebase/analytics-compat": { 838 | "version": "0.2.6", 839 | "resolved": "https://registry.npmjs.org/@firebase/analytics-compat/-/analytics-compat-0.2.6.tgz", 840 | "integrity": "sha512-4MqpVLFkGK7NJf/5wPEEP7ePBJatwYpyjgJ+wQHQGHfzaCDgntOnl9rL2vbVGGKCnRqWtZDIWhctB86UWXaX2Q==", 841 | "dependencies": { 842 | "@firebase/analytics": "0.10.0", 843 | "@firebase/analytics-types": "0.8.0", 844 | "@firebase/component": "0.6.4", 845 | "@firebase/util": "1.9.3", 846 | "tslib": "^2.1.0" 847 | }, 848 | "peerDependencies": { 849 | "@firebase/app-compat": "0.x" 850 | } 851 | }, 852 | "node_modules/@firebase/analytics-types": { 853 | "version": "0.8.0", 854 | "resolved": "https://registry.npmjs.org/@firebase/analytics-types/-/analytics-types-0.8.0.tgz", 855 | "integrity": "sha512-iRP+QKI2+oz3UAh4nPEq14CsEjrjD6a5+fuypjScisAh9kXKFvdJOZJDwk7kikLvWVLGEs9+kIUS4LPQV7VZVw==" 856 | }, 857 | "node_modules/@firebase/app": { 858 | "version": "0.9.25", 859 | "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.9.25.tgz", 860 | "integrity": "sha512-fX22gL5USXhOK21Hlh3oTeOzQZ6th6S2JrjXNEpBARmwzuUkqmVGVdsOCIFYIsLpK0dQE3o8xZnLrRg5wnzZ/g==", 861 | "dependencies": { 862 | "@firebase/component": "0.6.4", 863 | "@firebase/logger": "0.4.0", 864 | "@firebase/util": "1.9.3", 865 | "idb": "7.1.1", 866 | "tslib": "^2.1.0" 867 | } 868 | }, 869 | "node_modules/@firebase/app-check": { 870 | "version": "0.8.1", 871 | "resolved": "https://registry.npmjs.org/@firebase/app-check/-/app-check-0.8.1.tgz", 872 | "integrity": "sha512-zi3vbM5tb/eGRWyiqf+1DXbxFu9Q07dnm46rweodgUpH9B8svxYkHfNwYWx7F5mjHU70SQDuaojH1We5ws9OKA==", 873 | "dependencies": { 874 | "@firebase/component": "0.6.4", 875 | "@firebase/logger": "0.4.0", 876 | "@firebase/util": "1.9.3", 877 | "tslib": "^2.1.0" 878 | }, 879 | "peerDependencies": { 880 | "@firebase/app": "0.x" 881 | } 882 | }, 883 | "node_modules/@firebase/app-check-compat": { 884 | "version": "0.3.8", 885 | "resolved": "https://registry.npmjs.org/@firebase/app-check-compat/-/app-check-compat-0.3.8.tgz", 886 | "integrity": "sha512-EaETtChR4UgMokJFw+r6jfcIyCTUZSe0a6ivF37D9MxlG9G3wzK1COyXgxoX96GzXmDPc2aubX4PxCrdVHhrnA==", 887 | "dependencies": { 888 | "@firebase/app-check": "0.8.1", 889 | "@firebase/app-check-types": "0.5.0", 890 | "@firebase/component": "0.6.4", 891 | "@firebase/logger": "0.4.0", 892 | "@firebase/util": "1.9.3", 893 | "tslib": "^2.1.0" 894 | }, 895 | "peerDependencies": { 896 | "@firebase/app-compat": "0.x" 897 | } 898 | }, 899 | "node_modules/@firebase/app-check-interop-types": { 900 | "version": "0.3.0", 901 | "resolved": "https://registry.npmjs.org/@firebase/app-check-interop-types/-/app-check-interop-types-0.3.0.tgz", 902 | "integrity": "sha512-xAxHPZPIgFXnI+vb4sbBjZcde7ZluzPPaSK7Lx3/nmuVk4TjZvnL8ONnkd4ERQKL8WePQySU+pRcWkh8rDf5Sg==" 903 | }, 904 | "node_modules/@firebase/app-check-types": { 905 | "version": "0.5.0", 906 | "resolved": "https://registry.npmjs.org/@firebase/app-check-types/-/app-check-types-0.5.0.tgz", 907 | "integrity": "sha512-uwSUj32Mlubybw7tedRzR24RP8M8JUVR3NPiMk3/Z4bCmgEKTlQBwMXrehDAZ2wF+TsBq0SN1c6ema71U/JPyQ==" 908 | }, 909 | "node_modules/@firebase/app-compat": { 910 | "version": "0.2.25", 911 | "resolved": "https://registry.npmjs.org/@firebase/app-compat/-/app-compat-0.2.25.tgz", 912 | "integrity": "sha512-B/JtCp1FsTuzlh1tIGQpYM2AXps21/zlzpFsk5LRsROOTRhBcR2N45AyaONPFD06C0yS0Tw19foxADzHyOSC3A==", 913 | "dependencies": { 914 | "@firebase/app": "0.9.25", 915 | "@firebase/component": "0.6.4", 916 | "@firebase/logger": "0.4.0", 917 | "@firebase/util": "1.9.3", 918 | "tslib": "^2.1.0" 919 | } 920 | }, 921 | "node_modules/@firebase/app-types": { 922 | "version": "0.9.0", 923 | "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.9.0.tgz", 924 | "integrity": "sha512-AeweANOIo0Mb8GiYm3xhTEBVCmPwTYAu9Hcd2qSkLuga/6+j9b1Jskl5bpiSQWy9eJ/j5pavxj6eYogmnuzm+Q==" 925 | }, 926 | "node_modules/@firebase/auth": { 927 | "version": "1.5.1", 928 | "resolved": "https://registry.npmjs.org/@firebase/auth/-/auth-1.5.1.tgz", 929 | "integrity": "sha512-sVi7rq2YneLGJFqHa5S6nDfCHix9yuVV3RLhj/pWPlB4a36ofXal4E6PJwpeMc8uLjWEr1aovYN1jkXWNB6Avw==", 930 | "dependencies": { 931 | "@firebase/component": "0.6.4", 932 | "@firebase/logger": "0.4.0", 933 | "@firebase/util": "1.9.3", 934 | "tslib": "^2.1.0", 935 | "undici": "5.26.5" 936 | }, 937 | "peerDependencies": { 938 | "@firebase/app": "0.x", 939 | "@react-native-async-storage/async-storage": "^1.18.1" 940 | }, 941 | "peerDependenciesMeta": { 942 | "@react-native-async-storage/async-storage": { 943 | "optional": true 944 | } 945 | } 946 | }, 947 | "node_modules/@firebase/auth-compat": { 948 | "version": "0.5.1", 949 | "resolved": "https://registry.npmjs.org/@firebase/auth-compat/-/auth-compat-0.5.1.tgz", 950 | "integrity": "sha512-rgDZnrDoekRvtzXVji8Z61wxxkof6pTkjYEkybILrjM8tGP9tx4xa9qGpF4ax3AzF+rKr7mIa9NnoXEK4UNqmQ==", 951 | "dependencies": { 952 | "@firebase/auth": "1.5.1", 953 | "@firebase/auth-types": "0.12.0", 954 | "@firebase/component": "0.6.4", 955 | "@firebase/util": "1.9.3", 956 | "tslib": "^2.1.0", 957 | "undici": "5.26.5" 958 | }, 959 | "peerDependencies": { 960 | "@firebase/app-compat": "0.x" 961 | } 962 | }, 963 | "node_modules/@firebase/auth-interop-types": { 964 | "version": "0.2.1", 965 | "resolved": "https://registry.npmjs.org/@firebase/auth-interop-types/-/auth-interop-types-0.2.1.tgz", 966 | "integrity": "sha512-VOaGzKp65MY6P5FI84TfYKBXEPi6LmOCSMMzys6o2BN2LOsqy7pCuZCup7NYnfbk5OkkQKzvIfHOzTm0UDpkyg==" 967 | }, 968 | "node_modules/@firebase/auth-types": { 969 | "version": "0.12.0", 970 | "resolved": "https://registry.npmjs.org/@firebase/auth-types/-/auth-types-0.12.0.tgz", 971 | "integrity": "sha512-pPwaZt+SPOshK8xNoiQlK5XIrS97kFYc3Rc7xmy373QsOJ9MmqXxLaYssP5Kcds4wd2qK//amx/c+A8O2fVeZA==", 972 | "peerDependencies": { 973 | "@firebase/app-types": "0.x", 974 | "@firebase/util": "1.x" 975 | } 976 | }, 977 | "node_modules/@firebase/component": { 978 | "version": "0.6.4", 979 | "resolved": "https://registry.npmjs.org/@firebase/component/-/component-0.6.4.tgz", 980 | "integrity": "sha512-rLMyrXuO9jcAUCaQXCMjCMUsWrba5fzHlNK24xz5j2W6A/SRmK8mZJ/hn7V0fViLbxC0lPMtrK1eYzk6Fg03jA==", 981 | "dependencies": { 982 | "@firebase/util": "1.9.3", 983 | "tslib": "^2.1.0" 984 | } 985 | }, 986 | "node_modules/@firebase/database": { 987 | "version": "1.0.2", 988 | "resolved": "https://registry.npmjs.org/@firebase/database/-/database-1.0.2.tgz", 989 | "integrity": "sha512-8X6NBJgUQzDz0xQVaCISoOLINKat594N2eBbMR3Mu/MH/ei4WM+aAMlsNzngF22eljXu1SILP5G3evkyvsG3Ng==", 990 | "dependencies": { 991 | "@firebase/app-check-interop-types": "0.3.0", 992 | "@firebase/auth-interop-types": "0.2.1", 993 | "@firebase/component": "0.6.4", 994 | "@firebase/logger": "0.4.0", 995 | "@firebase/util": "1.9.3", 996 | "faye-websocket": "0.11.4", 997 | "tslib": "^2.1.0" 998 | } 999 | }, 1000 | "node_modules/@firebase/database-compat": { 1001 | "version": "1.0.2", 1002 | "resolved": "https://registry.npmjs.org/@firebase/database-compat/-/database-compat-1.0.2.tgz", 1003 | "integrity": "sha512-09ryJnXDvuycsxn8aXBzLhBTuCos3HEnCOBWY6hosxfYlNCGnLvG8YMlbSAt5eNhf7/00B095AEfDsdrrLjxqA==", 1004 | "dependencies": { 1005 | "@firebase/component": "0.6.4", 1006 | "@firebase/database": "1.0.2", 1007 | "@firebase/database-types": "1.0.0", 1008 | "@firebase/logger": "0.4.0", 1009 | "@firebase/util": "1.9.3", 1010 | "tslib": "^2.1.0" 1011 | } 1012 | }, 1013 | "node_modules/@firebase/database-types": { 1014 | "version": "1.0.0", 1015 | "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-1.0.0.tgz", 1016 | "integrity": "sha512-SjnXStoE0Q56HcFgNQ+9SsmJc0c8TqGARdI/T44KXy+Ets3r6x/ivhQozT66bMnCEjJRywYoxNurRTMlZF8VNg==", 1017 | "dependencies": { 1018 | "@firebase/app-types": "0.9.0", 1019 | "@firebase/util": "1.9.3" 1020 | } 1021 | }, 1022 | "node_modules/@firebase/firestore": { 1023 | "version": "4.4.0", 1024 | "resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-4.4.0.tgz", 1025 | "integrity": "sha512-VeDXD9PUjvcWY1tInBOMTIu2pijR3YYy+QAe5cxCo1Q1vW+aA/mpQHhebPM1J6b4Zd1MuUh8xpBRvH9ujKR56A==", 1026 | "dependencies": { 1027 | "@firebase/component": "0.6.4", 1028 | "@firebase/logger": "0.4.0", 1029 | "@firebase/util": "1.9.3", 1030 | "@firebase/webchannel-wrapper": "0.10.5", 1031 | "@grpc/grpc-js": "~1.9.0", 1032 | "@grpc/proto-loader": "^0.7.8", 1033 | "tslib": "^2.1.0", 1034 | "undici": "5.26.5" 1035 | }, 1036 | "engines": { 1037 | "node": ">=10.10.0" 1038 | }, 1039 | "peerDependencies": { 1040 | "@firebase/app": "0.x" 1041 | } 1042 | }, 1043 | "node_modules/@firebase/firestore-compat": { 1044 | "version": "0.3.23", 1045 | "resolved": "https://registry.npmjs.org/@firebase/firestore-compat/-/firestore-compat-0.3.23.tgz", 1046 | "integrity": "sha512-uUTBiP0GLVBETaOCfB11d33OWB8x1r2G1Xrl0sRK3Va0N5LJ/GRvKVSGfM7VScj+ypeHe8RpdwKoCqLpN1e+uA==", 1047 | "dependencies": { 1048 | "@firebase/component": "0.6.4", 1049 | "@firebase/firestore": "4.4.0", 1050 | "@firebase/firestore-types": "3.0.0", 1051 | "@firebase/util": "1.9.3", 1052 | "tslib": "^2.1.0" 1053 | }, 1054 | "peerDependencies": { 1055 | "@firebase/app-compat": "0.x" 1056 | } 1057 | }, 1058 | "node_modules/@firebase/firestore-types": { 1059 | "version": "3.0.0", 1060 | "resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-3.0.0.tgz", 1061 | "integrity": "sha512-Meg4cIezHo9zLamw0ymFYBD4SMjLb+ZXIbuN7T7ddXN6MGoICmOTq3/ltdCGoDCS2u+H1XJs2u/cYp75jsX9Qw==", 1062 | "peerDependencies": { 1063 | "@firebase/app-types": "0.x", 1064 | "@firebase/util": "1.x" 1065 | } 1066 | }, 1067 | "node_modules/@firebase/functions": { 1068 | "version": "0.11.0", 1069 | "resolved": "https://registry.npmjs.org/@firebase/functions/-/functions-0.11.0.tgz", 1070 | "integrity": "sha512-n1PZxKnJ++k73Q8khTPwihlbeKo6emnGzE0hX6QVQJsMq82y/XKmNpw2t/q30VJgwaia3ZXU1fd1C5wHncL+Zg==", 1071 | "dependencies": { 1072 | "@firebase/app-check-interop-types": "0.3.0", 1073 | "@firebase/auth-interop-types": "0.2.1", 1074 | "@firebase/component": "0.6.4", 1075 | "@firebase/messaging-interop-types": "0.2.0", 1076 | "@firebase/util": "1.9.3", 1077 | "tslib": "^2.1.0", 1078 | "undici": "5.26.5" 1079 | }, 1080 | "peerDependencies": { 1081 | "@firebase/app": "0.x" 1082 | } 1083 | }, 1084 | "node_modules/@firebase/functions-compat": { 1085 | "version": "0.3.6", 1086 | "resolved": "https://registry.npmjs.org/@firebase/functions-compat/-/functions-compat-0.3.6.tgz", 1087 | "integrity": "sha512-RQpO3yuHtnkqLqExuAT2d0u3zh8SDbeBYK5EwSCBKI9mjrFeJRXBnd3pEG+x5SxGJLy56/5pQf73mwt0OuH5yg==", 1088 | "dependencies": { 1089 | "@firebase/component": "0.6.4", 1090 | "@firebase/functions": "0.11.0", 1091 | "@firebase/functions-types": "0.6.0", 1092 | "@firebase/util": "1.9.3", 1093 | "tslib": "^2.1.0" 1094 | }, 1095 | "peerDependencies": { 1096 | "@firebase/app-compat": "0.x" 1097 | } 1098 | }, 1099 | "node_modules/@firebase/functions-types": { 1100 | "version": "0.6.0", 1101 | "resolved": "https://registry.npmjs.org/@firebase/functions-types/-/functions-types-0.6.0.tgz", 1102 | "integrity": "sha512-hfEw5VJtgWXIRf92ImLkgENqpL6IWpYaXVYiRkFY1jJ9+6tIhWM7IzzwbevwIIud/jaxKVdRzD7QBWfPmkwCYw==" 1103 | }, 1104 | "node_modules/@firebase/installations": { 1105 | "version": "0.6.4", 1106 | "resolved": "https://registry.npmjs.org/@firebase/installations/-/installations-0.6.4.tgz", 1107 | "integrity": "sha512-u5y88rtsp7NYkCHC3ElbFBrPtieUybZluXyzl7+4BsIz4sqb4vSAuwHEUgCgCeaQhvsnxDEU6icly8U9zsJigA==", 1108 | "dependencies": { 1109 | "@firebase/component": "0.6.4", 1110 | "@firebase/util": "1.9.3", 1111 | "idb": "7.0.1", 1112 | "tslib": "^2.1.0" 1113 | }, 1114 | "peerDependencies": { 1115 | "@firebase/app": "0.x" 1116 | } 1117 | }, 1118 | "node_modules/@firebase/installations-compat": { 1119 | "version": "0.2.4", 1120 | "resolved": "https://registry.npmjs.org/@firebase/installations-compat/-/installations-compat-0.2.4.tgz", 1121 | "integrity": "sha512-LI9dYjp0aT9Njkn9U4JRrDqQ6KXeAmFbRC0E7jI7+hxl5YmRWysq5qgQl22hcWpTk+cm3es66d/apoDU/A9n6Q==", 1122 | "dependencies": { 1123 | "@firebase/component": "0.6.4", 1124 | "@firebase/installations": "0.6.4", 1125 | "@firebase/installations-types": "0.5.0", 1126 | "@firebase/util": "1.9.3", 1127 | "tslib": "^2.1.0" 1128 | }, 1129 | "peerDependencies": { 1130 | "@firebase/app-compat": "0.x" 1131 | } 1132 | }, 1133 | "node_modules/@firebase/installations-types": { 1134 | "version": "0.5.0", 1135 | "resolved": "https://registry.npmjs.org/@firebase/installations-types/-/installations-types-0.5.0.tgz", 1136 | "integrity": "sha512-9DP+RGfzoI2jH7gY4SlzqvZ+hr7gYzPODrbzVD82Y12kScZ6ZpRg/i3j6rleto8vTFC8n6Len4560FnV1w2IRg==", 1137 | "peerDependencies": { 1138 | "@firebase/app-types": "0.x" 1139 | } 1140 | }, 1141 | "node_modules/@firebase/installations/node_modules/idb": { 1142 | "version": "7.0.1", 1143 | "resolved": "https://registry.npmjs.org/idb/-/idb-7.0.1.tgz", 1144 | "integrity": "sha512-UUxlE7vGWK5RfB/fDwEGgRf84DY/ieqNha6msMV99UsEMQhJ1RwbCd8AYBj3QMgnE3VZnfQvm4oKVCJTYlqIgg==" 1145 | }, 1146 | "node_modules/@firebase/logger": { 1147 | "version": "0.4.0", 1148 | "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.4.0.tgz", 1149 | "integrity": "sha512-eRKSeykumZ5+cJPdxxJRgAC3G5NknY2GwEbKfymdnXtnT0Ucm4pspfR6GT4MUQEDuJwRVbVcSx85kgJulMoFFA==", 1150 | "dependencies": { 1151 | "tslib": "^2.1.0" 1152 | } 1153 | }, 1154 | "node_modules/@firebase/messaging": { 1155 | "version": "0.12.5", 1156 | "resolved": "https://registry.npmjs.org/@firebase/messaging/-/messaging-0.12.5.tgz", 1157 | "integrity": "sha512-i/rrEI2k9ueFhdIr8KQsptWGskrsnkC5TkohCTrJKz9P0C/PbNv14IAMkwhMJTqIur5VwuOnrUkc9Kdz7awekw==", 1158 | "dependencies": { 1159 | "@firebase/component": "0.6.4", 1160 | "@firebase/installations": "0.6.4", 1161 | "@firebase/messaging-interop-types": "0.2.0", 1162 | "@firebase/util": "1.9.3", 1163 | "idb": "7.1.1", 1164 | "tslib": "^2.1.0" 1165 | }, 1166 | "peerDependencies": { 1167 | "@firebase/app": "0.x" 1168 | } 1169 | }, 1170 | "node_modules/@firebase/messaging-compat": { 1171 | "version": "0.2.5", 1172 | "resolved": "https://registry.npmjs.org/@firebase/messaging-compat/-/messaging-compat-0.2.5.tgz", 1173 | "integrity": "sha512-qHQZxm4hEG8/HFU/ls5/bU+rpnlPDoZoqi3ATMeb6s4hovYV9+PfV5I7ZrKV5eFFv47Hx1PWLe5uPnS4e7gMwQ==", 1174 | "dependencies": { 1175 | "@firebase/component": "0.6.4", 1176 | "@firebase/messaging": "0.12.5", 1177 | "@firebase/util": "1.9.3", 1178 | "tslib": "^2.1.0" 1179 | }, 1180 | "peerDependencies": { 1181 | "@firebase/app-compat": "0.x" 1182 | } 1183 | }, 1184 | "node_modules/@firebase/messaging-interop-types": { 1185 | "version": "0.2.0", 1186 | "resolved": "https://registry.npmjs.org/@firebase/messaging-interop-types/-/messaging-interop-types-0.2.0.tgz", 1187 | "integrity": "sha512-ujA8dcRuVeBixGR9CtegfpU4YmZf3Lt7QYkcj693FFannwNuZgfAYaTmbJ40dtjB81SAu6tbFPL9YLNT15KmOQ==" 1188 | }, 1189 | "node_modules/@firebase/performance": { 1190 | "version": "0.6.4", 1191 | "resolved": "https://registry.npmjs.org/@firebase/performance/-/performance-0.6.4.tgz", 1192 | "integrity": "sha512-HfTn/bd8mfy/61vEqaBelNiNnvAbUtME2S25A67Nb34zVuCSCRIX4SseXY6zBnOFj3oLisaEqhVcJmVPAej67g==", 1193 | "dependencies": { 1194 | "@firebase/component": "0.6.4", 1195 | "@firebase/installations": "0.6.4", 1196 | "@firebase/logger": "0.4.0", 1197 | "@firebase/util": "1.9.3", 1198 | "tslib": "^2.1.0" 1199 | }, 1200 | "peerDependencies": { 1201 | "@firebase/app": "0.x" 1202 | } 1203 | }, 1204 | "node_modules/@firebase/performance-compat": { 1205 | "version": "0.2.4", 1206 | "resolved": "https://registry.npmjs.org/@firebase/performance-compat/-/performance-compat-0.2.4.tgz", 1207 | "integrity": "sha512-nnHUb8uP9G8islzcld/k6Bg5RhX62VpbAb/Anj7IXs/hp32Eb2LqFPZK4sy3pKkBUO5wcrlRWQa6wKOxqlUqsg==", 1208 | "dependencies": { 1209 | "@firebase/component": "0.6.4", 1210 | "@firebase/logger": "0.4.0", 1211 | "@firebase/performance": "0.6.4", 1212 | "@firebase/performance-types": "0.2.0", 1213 | "@firebase/util": "1.9.3", 1214 | "tslib": "^2.1.0" 1215 | }, 1216 | "peerDependencies": { 1217 | "@firebase/app-compat": "0.x" 1218 | } 1219 | }, 1220 | "node_modules/@firebase/performance-types": { 1221 | "version": "0.2.0", 1222 | "resolved": "https://registry.npmjs.org/@firebase/performance-types/-/performance-types-0.2.0.tgz", 1223 | "integrity": "sha512-kYrbr8e/CYr1KLrLYZZt2noNnf+pRwDq2KK9Au9jHrBMnb0/C9X9yWSXmZkFt4UIdsQknBq8uBB7fsybZdOBTA==" 1224 | }, 1225 | "node_modules/@firebase/remote-config": { 1226 | "version": "0.4.4", 1227 | "resolved": "https://registry.npmjs.org/@firebase/remote-config/-/remote-config-0.4.4.tgz", 1228 | "integrity": "sha512-x1ioTHGX8ZwDSTOVp8PBLv2/wfwKzb4pxi0gFezS5GCJwbLlloUH4YYZHHS83IPxnua8b6l0IXUaWd0RgbWwzQ==", 1229 | "dependencies": { 1230 | "@firebase/component": "0.6.4", 1231 | "@firebase/installations": "0.6.4", 1232 | "@firebase/logger": "0.4.0", 1233 | "@firebase/util": "1.9.3", 1234 | "tslib": "^2.1.0" 1235 | }, 1236 | "peerDependencies": { 1237 | "@firebase/app": "0.x" 1238 | } 1239 | }, 1240 | "node_modules/@firebase/remote-config-compat": { 1241 | "version": "0.2.4", 1242 | "resolved": "https://registry.npmjs.org/@firebase/remote-config-compat/-/remote-config-compat-0.2.4.tgz", 1243 | "integrity": "sha512-FKiki53jZirrDFkBHglB3C07j5wBpitAaj8kLME6g8Mx+aq7u9P7qfmuSRytiOItADhWUj7O1JIv7n9q87SuwA==", 1244 | "dependencies": { 1245 | "@firebase/component": "0.6.4", 1246 | "@firebase/logger": "0.4.0", 1247 | "@firebase/remote-config": "0.4.4", 1248 | "@firebase/remote-config-types": "0.3.0", 1249 | "@firebase/util": "1.9.3", 1250 | "tslib": "^2.1.0" 1251 | }, 1252 | "peerDependencies": { 1253 | "@firebase/app-compat": "0.x" 1254 | } 1255 | }, 1256 | "node_modules/@firebase/remote-config-types": { 1257 | "version": "0.3.0", 1258 | "resolved": "https://registry.npmjs.org/@firebase/remote-config-types/-/remote-config-types-0.3.0.tgz", 1259 | "integrity": "sha512-RtEH4vdcbXZuZWRZbIRmQVBNsE7VDQpet2qFvq6vwKLBIQRQR5Kh58M4ok3A3US8Sr3rubYnaGqZSurCwI8uMA==" 1260 | }, 1261 | "node_modules/@firebase/storage": { 1262 | "version": "0.12.0", 1263 | "resolved": "https://registry.npmjs.org/@firebase/storage/-/storage-0.12.0.tgz", 1264 | "integrity": "sha512-SGs02Y/mmWBRsqZiYLpv4Sf7uZYZzMWVNN+aKiDqPsFBCzD6hLvGkXz+u98KAl8FqcjgB8BtSu01wm4pm76KHA==", 1265 | "dependencies": { 1266 | "@firebase/component": "0.6.4", 1267 | "@firebase/util": "1.9.3", 1268 | "tslib": "^2.1.0", 1269 | "undici": "5.26.5" 1270 | }, 1271 | "peerDependencies": { 1272 | "@firebase/app": "0.x" 1273 | } 1274 | }, 1275 | "node_modules/@firebase/storage-compat": { 1276 | "version": "0.3.3", 1277 | "resolved": "https://registry.npmjs.org/@firebase/storage-compat/-/storage-compat-0.3.3.tgz", 1278 | "integrity": "sha512-WNtjYPhpOA1nKcRu5lIodX0wZtP8pI0VxDJnk6lr+av7QZNS1s6zvr+ERDTve+Qu4Hq/ZnNaf3kBEQR2ccXn6A==", 1279 | "dependencies": { 1280 | "@firebase/component": "0.6.4", 1281 | "@firebase/storage": "0.12.0", 1282 | "@firebase/storage-types": "0.8.0", 1283 | "@firebase/util": "1.9.3", 1284 | "tslib": "^2.1.0" 1285 | }, 1286 | "peerDependencies": { 1287 | "@firebase/app-compat": "0.x" 1288 | } 1289 | }, 1290 | "node_modules/@firebase/storage-types": { 1291 | "version": "0.8.0", 1292 | "resolved": "https://registry.npmjs.org/@firebase/storage-types/-/storage-types-0.8.0.tgz", 1293 | "integrity": "sha512-isRHcGrTs9kITJC0AVehHfpraWFui39MPaU7Eo8QfWlqW7YPymBmRgjDrlOgFdURh6Cdeg07zmkLP5tzTKRSpg==", 1294 | "peerDependencies": { 1295 | "@firebase/app-types": "0.x", 1296 | "@firebase/util": "1.x" 1297 | } 1298 | }, 1299 | "node_modules/@firebase/util": { 1300 | "version": "1.9.3", 1301 | "resolved": "https://registry.npmjs.org/@firebase/util/-/util-1.9.3.tgz", 1302 | "integrity": "sha512-DY02CRhOZwpzO36fHpuVysz6JZrscPiBXD0fXp6qSrL9oNOx5KWICKdR95C0lSITzxp0TZosVyHqzatE8JbcjA==", 1303 | "dependencies": { 1304 | "tslib": "^2.1.0" 1305 | } 1306 | }, 1307 | "node_modules/@firebase/webchannel-wrapper": { 1308 | "version": "0.10.5", 1309 | "resolved": "https://registry.npmjs.org/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.10.5.tgz", 1310 | "integrity": "sha512-eSkJsnhBWv5kCTSU1tSUVl9mpFu+5NXXunZc83le8GMjMlsWwQArSc7cJJ4yl+aDFY0NGLi0AjZWMn1axOrkRg==" 1311 | }, 1312 | "node_modules/@grpc/grpc-js": { 1313 | "version": "1.9.13", 1314 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.9.13.tgz", 1315 | "integrity": "sha512-OEZZu9v9AA+7/tghMDE8o5DAMD5THVnwSqDWuh7PPYO5287rTyqy0xEHT6/e4pbqSrhyLPdQFsam4TwFQVVIIw==", 1316 | "dependencies": { 1317 | "@grpc/proto-loader": "^0.7.8", 1318 | "@types/node": ">=12.12.47" 1319 | }, 1320 | "engines": { 1321 | "node": "^8.13.0 || >=10.10.0" 1322 | } 1323 | }, 1324 | "node_modules/@grpc/proto-loader": { 1325 | "version": "0.7.10", 1326 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.7.10.tgz", 1327 | "integrity": "sha512-CAqDfoaQ8ykFd9zqBDn4k6iWT9loLAlc2ETmDFS9JCD70gDcnA4L3AFEo2iV7KyAtAAHFW9ftq1Fz+Vsgq80RQ==", 1328 | "dependencies": { 1329 | "lodash.camelcase": "^4.3.0", 1330 | "long": "^5.0.0", 1331 | "protobufjs": "^7.2.4", 1332 | "yargs": "^17.7.2" 1333 | }, 1334 | "bin": { 1335 | "proto-loader-gen-types": "build/bin/proto-loader-gen-types.js" 1336 | }, 1337 | "engines": { 1338 | "node": ">=6" 1339 | } 1340 | }, 1341 | "node_modules/@humanwhocodes/config-array": { 1342 | "version": "0.11.14", 1343 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 1344 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 1345 | "dev": true, 1346 | "dependencies": { 1347 | "@humanwhocodes/object-schema": "^2.0.2", 1348 | "debug": "^4.3.1", 1349 | "minimatch": "^3.0.5" 1350 | }, 1351 | "engines": { 1352 | "node": ">=10.10.0" 1353 | } 1354 | }, 1355 | "node_modules/@humanwhocodes/module-importer": { 1356 | "version": "1.0.1", 1357 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 1358 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 1359 | "dev": true, 1360 | "engines": { 1361 | "node": ">=12.22" 1362 | }, 1363 | "funding": { 1364 | "type": "github", 1365 | "url": "https://github.com/sponsors/nzakas" 1366 | } 1367 | }, 1368 | "node_modules/@humanwhocodes/object-schema": { 1369 | "version": "2.0.2", 1370 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 1371 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 1372 | "dev": true 1373 | }, 1374 | "node_modules/@jridgewell/gen-mapping": { 1375 | "version": "0.3.3", 1376 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 1377 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 1378 | "dev": true, 1379 | "dependencies": { 1380 | "@jridgewell/set-array": "^1.0.1", 1381 | "@jridgewell/sourcemap-codec": "^1.4.10", 1382 | "@jridgewell/trace-mapping": "^0.3.9" 1383 | }, 1384 | "engines": { 1385 | "node": ">=6.0.0" 1386 | } 1387 | }, 1388 | "node_modules/@jridgewell/resolve-uri": { 1389 | "version": "3.1.1", 1390 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", 1391 | "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", 1392 | "dev": true, 1393 | "engines": { 1394 | "node": ">=6.0.0" 1395 | } 1396 | }, 1397 | "node_modules/@jridgewell/set-array": { 1398 | "version": "1.1.2", 1399 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 1400 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 1401 | "dev": true, 1402 | "engines": { 1403 | "node": ">=6.0.0" 1404 | } 1405 | }, 1406 | "node_modules/@jridgewell/sourcemap-codec": { 1407 | "version": "1.4.15", 1408 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 1409 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 1410 | "dev": true 1411 | }, 1412 | "node_modules/@jridgewell/trace-mapping": { 1413 | "version": "0.3.21", 1414 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.21.tgz", 1415 | "integrity": "sha512-SRfKmRe1KvYnxjEMtxEr+J4HIeMX5YBg/qhRHpxEIGjhX1rshcHlnFUE9K0GazhVKWM7B+nARSkV8LuvJdJ5/g==", 1416 | "dev": true, 1417 | "dependencies": { 1418 | "@jridgewell/resolve-uri": "^3.1.0", 1419 | "@jridgewell/sourcemap-codec": "^1.4.14" 1420 | } 1421 | }, 1422 | "node_modules/@nodelib/fs.scandir": { 1423 | "version": "2.1.5", 1424 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 1425 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 1426 | "dev": true, 1427 | "dependencies": { 1428 | "@nodelib/fs.stat": "2.0.5", 1429 | "run-parallel": "^1.1.9" 1430 | }, 1431 | "engines": { 1432 | "node": ">= 8" 1433 | } 1434 | }, 1435 | "node_modules/@nodelib/fs.stat": { 1436 | "version": "2.0.5", 1437 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 1438 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 1439 | "dev": true, 1440 | "engines": { 1441 | "node": ">= 8" 1442 | } 1443 | }, 1444 | "node_modules/@nodelib/fs.walk": { 1445 | "version": "1.2.8", 1446 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 1447 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 1448 | "dev": true, 1449 | "dependencies": { 1450 | "@nodelib/fs.scandir": "2.1.5", 1451 | "fastq": "^1.6.0" 1452 | }, 1453 | "engines": { 1454 | "node": ">= 8" 1455 | } 1456 | }, 1457 | "node_modules/@protobufjs/aspromise": { 1458 | "version": "1.1.2", 1459 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 1460 | "integrity": "sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ==" 1461 | }, 1462 | "node_modules/@protobufjs/base64": { 1463 | "version": "1.1.2", 1464 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 1465 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 1466 | }, 1467 | "node_modules/@protobufjs/codegen": { 1468 | "version": "2.0.4", 1469 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 1470 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 1471 | }, 1472 | "node_modules/@protobufjs/eventemitter": { 1473 | "version": "1.1.0", 1474 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 1475 | "integrity": "sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q==" 1476 | }, 1477 | "node_modules/@protobufjs/fetch": { 1478 | "version": "1.1.0", 1479 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 1480 | "integrity": "sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ==", 1481 | "dependencies": { 1482 | "@protobufjs/aspromise": "^1.1.1", 1483 | "@protobufjs/inquire": "^1.1.0" 1484 | } 1485 | }, 1486 | "node_modules/@protobufjs/float": { 1487 | "version": "1.0.2", 1488 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 1489 | "integrity": "sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ==" 1490 | }, 1491 | "node_modules/@protobufjs/inquire": { 1492 | "version": "1.1.0", 1493 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 1494 | "integrity": "sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q==" 1495 | }, 1496 | "node_modules/@protobufjs/path": { 1497 | "version": "1.1.2", 1498 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 1499 | "integrity": "sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA==" 1500 | }, 1501 | "node_modules/@protobufjs/pool": { 1502 | "version": "1.1.0", 1503 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 1504 | "integrity": "sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw==" 1505 | }, 1506 | "node_modules/@protobufjs/utf8": { 1507 | "version": "1.1.0", 1508 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 1509 | "integrity": "sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw==" 1510 | }, 1511 | "node_modules/@rollup/rollup-android-arm-eabi": { 1512 | "version": "4.9.5", 1513 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.5.tgz", 1514 | "integrity": "sha512-idWaG8xeSRCfRq9KpRysDHJ/rEHBEXcHuJ82XY0yYFIWnLMjZv9vF/7DOq8djQ2n3Lk6+3qfSH8AqlmHlmi1MA==", 1515 | "cpu": [ 1516 | "arm" 1517 | ], 1518 | "dev": true, 1519 | "optional": true, 1520 | "os": [ 1521 | "android" 1522 | ] 1523 | }, 1524 | "node_modules/@rollup/rollup-android-arm64": { 1525 | "version": "4.9.5", 1526 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.5.tgz", 1527 | "integrity": "sha512-f14d7uhAMtsCGjAYwZGv6TwuS3IFaM4ZnGMUn3aCBgkcHAYErhV1Ad97WzBvS2o0aaDv4mVz+syiN0ElMyfBPg==", 1528 | "cpu": [ 1529 | "arm64" 1530 | ], 1531 | "dev": true, 1532 | "optional": true, 1533 | "os": [ 1534 | "android" 1535 | ] 1536 | }, 1537 | "node_modules/@rollup/rollup-darwin-arm64": { 1538 | "version": "4.9.5", 1539 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.5.tgz", 1540 | "integrity": "sha512-ndoXeLx455FffL68OIUrVr89Xu1WLzAG4n65R8roDlCoYiQcGGg6MALvs2Ap9zs7AHg8mpHtMpwC8jBBjZrT/w==", 1541 | "cpu": [ 1542 | "arm64" 1543 | ], 1544 | "dev": true, 1545 | "optional": true, 1546 | "os": [ 1547 | "darwin" 1548 | ] 1549 | }, 1550 | "node_modules/@rollup/rollup-darwin-x64": { 1551 | "version": "4.9.5", 1552 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.5.tgz", 1553 | "integrity": "sha512-UmElV1OY2m/1KEEqTlIjieKfVwRg0Zwg4PLgNf0s3glAHXBN99KLpw5A5lrSYCa1Kp63czTpVll2MAqbZYIHoA==", 1554 | "cpu": [ 1555 | "x64" 1556 | ], 1557 | "dev": true, 1558 | "optional": true, 1559 | "os": [ 1560 | "darwin" 1561 | ] 1562 | }, 1563 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 1564 | "version": "4.9.5", 1565 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.5.tgz", 1566 | "integrity": "sha512-Q0LcU61v92tQB6ae+udZvOyZ0wfpGojtAKrrpAaIqmJ7+psq4cMIhT/9lfV6UQIpeItnq/2QDROhNLo00lOD1g==", 1567 | "cpu": [ 1568 | "arm" 1569 | ], 1570 | "dev": true, 1571 | "optional": true, 1572 | "os": [ 1573 | "linux" 1574 | ] 1575 | }, 1576 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1577 | "version": "4.9.5", 1578 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.5.tgz", 1579 | "integrity": "sha512-dkRscpM+RrR2Ee3eOQmRWFjmV/payHEOrjyq1VZegRUa5OrZJ2MAxBNs05bZuY0YCtpqETDy1Ix4i/hRqX98cA==", 1580 | "cpu": [ 1581 | "arm64" 1582 | ], 1583 | "dev": true, 1584 | "optional": true, 1585 | "os": [ 1586 | "linux" 1587 | ] 1588 | }, 1589 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1590 | "version": "4.9.5", 1591 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.5.tgz", 1592 | "integrity": "sha512-QaKFVOzzST2xzY4MAmiDmURagWLFh+zZtttuEnuNn19AiZ0T3fhPyjPPGwLNdiDT82ZE91hnfJsUiDwF9DClIQ==", 1593 | "cpu": [ 1594 | "arm64" 1595 | ], 1596 | "dev": true, 1597 | "optional": true, 1598 | "os": [ 1599 | "linux" 1600 | ] 1601 | }, 1602 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1603 | "version": "4.9.5", 1604 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.5.tgz", 1605 | "integrity": "sha512-HeGqmRJuyVg6/X6MpE2ur7GbymBPS8Np0S/vQFHDmocfORT+Zt76qu+69NUoxXzGqVP1pzaY6QIi0FJWLC3OPA==", 1606 | "cpu": [ 1607 | "riscv64" 1608 | ], 1609 | "dev": true, 1610 | "optional": true, 1611 | "os": [ 1612 | "linux" 1613 | ] 1614 | }, 1615 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1616 | "version": "4.9.5", 1617 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.5.tgz", 1618 | "integrity": "sha512-Dq1bqBdLaZ1Gb/l2e5/+o3B18+8TI9ANlA1SkejZqDgdU/jK/ThYaMPMJpVMMXy2uRHvGKbkz9vheVGdq3cJfA==", 1619 | "cpu": [ 1620 | "x64" 1621 | ], 1622 | "dev": true, 1623 | "optional": true, 1624 | "os": [ 1625 | "linux" 1626 | ] 1627 | }, 1628 | "node_modules/@rollup/rollup-linux-x64-musl": { 1629 | "version": "4.9.5", 1630 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.5.tgz", 1631 | "integrity": "sha512-ezyFUOwldYpj7AbkwyW9AJ203peub81CaAIVvckdkyH8EvhEIoKzaMFJj0G4qYJ5sw3BpqhFrsCc30t54HV8vg==", 1632 | "cpu": [ 1633 | "x64" 1634 | ], 1635 | "dev": true, 1636 | "optional": true, 1637 | "os": [ 1638 | "linux" 1639 | ] 1640 | }, 1641 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1642 | "version": "4.9.5", 1643 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.5.tgz", 1644 | "integrity": "sha512-aHSsMnUw+0UETB0Hlv7B/ZHOGY5bQdwMKJSzGfDfvyhnpmVxLMGnQPGNE9wgqkLUs3+gbG1Qx02S2LLfJ5GaRQ==", 1645 | "cpu": [ 1646 | "arm64" 1647 | ], 1648 | "dev": true, 1649 | "optional": true, 1650 | "os": [ 1651 | "win32" 1652 | ] 1653 | }, 1654 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1655 | "version": "4.9.5", 1656 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.5.tgz", 1657 | "integrity": "sha512-AiqiLkb9KSf7Lj/o1U3SEP9Zn+5NuVKgFdRIZkvd4N0+bYrTOovVd0+LmYCPQGbocT4kvFyK+LXCDiXPBF3fyA==", 1658 | "cpu": [ 1659 | "ia32" 1660 | ], 1661 | "dev": true, 1662 | "optional": true, 1663 | "os": [ 1664 | "win32" 1665 | ] 1666 | }, 1667 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1668 | "version": "4.9.5", 1669 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.5.tgz", 1670 | "integrity": "sha512-1q+mykKE3Vot1kaFJIDoUFv5TuW+QQVaf2FmTT9krg86pQrGStOSJJ0Zil7CFagyxDuouTepzt5Y5TVzyajOdQ==", 1671 | "cpu": [ 1672 | "x64" 1673 | ], 1674 | "dev": true, 1675 | "optional": true, 1676 | "os": [ 1677 | "win32" 1678 | ] 1679 | }, 1680 | "node_modules/@types/babel__core": { 1681 | "version": "7.20.5", 1682 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1683 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1684 | "dev": true, 1685 | "dependencies": { 1686 | "@babel/parser": "^7.20.7", 1687 | "@babel/types": "^7.20.7", 1688 | "@types/babel__generator": "*", 1689 | "@types/babel__template": "*", 1690 | "@types/babel__traverse": "*" 1691 | } 1692 | }, 1693 | "node_modules/@types/babel__generator": { 1694 | "version": "7.6.8", 1695 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 1696 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 1697 | "dev": true, 1698 | "dependencies": { 1699 | "@babel/types": "^7.0.0" 1700 | } 1701 | }, 1702 | "node_modules/@types/babel__template": { 1703 | "version": "7.4.4", 1704 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1705 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1706 | "dev": true, 1707 | "dependencies": { 1708 | "@babel/parser": "^7.1.0", 1709 | "@babel/types": "^7.0.0" 1710 | } 1711 | }, 1712 | "node_modules/@types/babel__traverse": { 1713 | "version": "7.20.5", 1714 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz", 1715 | "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==", 1716 | "dev": true, 1717 | "dependencies": { 1718 | "@babel/types": "^7.20.7" 1719 | } 1720 | }, 1721 | "node_modules/@types/estree": { 1722 | "version": "1.0.5", 1723 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1724 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1725 | "dev": true 1726 | }, 1727 | "node_modules/@types/node": { 1728 | "version": "20.11.3", 1729 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.3.tgz", 1730 | "integrity": "sha512-nrlmbvGPNGaj84IJZXMPhQuCMEVTT/hXZMJJG/aIqVL9fKxqk814sGGtJA4GI6hpJSLQjpi6cn0Qx9eOf9SDVg==", 1731 | "dependencies": { 1732 | "undici-types": "~5.26.4" 1733 | } 1734 | }, 1735 | "node_modules/@types/prop-types": { 1736 | "version": "15.7.11", 1737 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", 1738 | "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", 1739 | "dev": true 1740 | }, 1741 | "node_modules/@types/react": { 1742 | "version": "18.2.48", 1743 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.48.tgz", 1744 | "integrity": "sha512-qboRCl6Ie70DQQG9hhNREz81jqC1cs9EVNcjQ1AU+jH6NFfSAhVVbrrY/+nSF+Bsk4AOwm9Qa61InvMCyV+H3w==", 1745 | "dev": true, 1746 | "dependencies": { 1747 | "@types/prop-types": "*", 1748 | "@types/scheduler": "*", 1749 | "csstype": "^3.0.2" 1750 | } 1751 | }, 1752 | "node_modules/@types/react-dom": { 1753 | "version": "18.2.18", 1754 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.18.tgz", 1755 | "integrity": "sha512-TJxDm6OfAX2KJWJdMEVTwWke5Sc/E/RlnPGvGfS0W7+6ocy2xhDVQVh/KvC2Uf7kACs+gDytdusDSdWfWkaNzw==", 1756 | "dev": true, 1757 | "dependencies": { 1758 | "@types/react": "*" 1759 | } 1760 | }, 1761 | "node_modules/@types/scheduler": { 1762 | "version": "0.16.8", 1763 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", 1764 | "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", 1765 | "dev": true 1766 | }, 1767 | "node_modules/@ungap/structured-clone": { 1768 | "version": "1.2.0", 1769 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 1770 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 1771 | "dev": true 1772 | }, 1773 | "node_modules/@vitejs/plugin-react": { 1774 | "version": "4.2.1", 1775 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.2.1.tgz", 1776 | "integrity": "sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==", 1777 | "dev": true, 1778 | "dependencies": { 1779 | "@babel/core": "^7.23.5", 1780 | "@babel/plugin-transform-react-jsx-self": "^7.23.3", 1781 | "@babel/plugin-transform-react-jsx-source": "^7.23.3", 1782 | "@types/babel__core": "^7.20.5", 1783 | "react-refresh": "^0.14.0" 1784 | }, 1785 | "engines": { 1786 | "node": "^14.18.0 || >=16.0.0" 1787 | }, 1788 | "peerDependencies": { 1789 | "vite": "^4.2.0 || ^5.0.0" 1790 | } 1791 | }, 1792 | "node_modules/acorn": { 1793 | "version": "8.11.3", 1794 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1795 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1796 | "dev": true, 1797 | "bin": { 1798 | "acorn": "bin/acorn" 1799 | }, 1800 | "engines": { 1801 | "node": ">=0.4.0" 1802 | } 1803 | }, 1804 | "node_modules/acorn-jsx": { 1805 | "version": "5.3.2", 1806 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1807 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1808 | "dev": true, 1809 | "peerDependencies": { 1810 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1811 | } 1812 | }, 1813 | "node_modules/ajv": { 1814 | "version": "6.12.6", 1815 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1816 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1817 | "dev": true, 1818 | "dependencies": { 1819 | "fast-deep-equal": "^3.1.1", 1820 | "fast-json-stable-stringify": "^2.0.0", 1821 | "json-schema-traverse": "^0.4.1", 1822 | "uri-js": "^4.2.2" 1823 | }, 1824 | "funding": { 1825 | "type": "github", 1826 | "url": "https://github.com/sponsors/epoberezkin" 1827 | } 1828 | }, 1829 | "node_modules/ansi-regex": { 1830 | "version": "5.0.1", 1831 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1832 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1833 | "engines": { 1834 | "node": ">=8" 1835 | } 1836 | }, 1837 | "node_modules/ansi-styles": { 1838 | "version": "3.2.1", 1839 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1840 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1841 | "dev": true, 1842 | "dependencies": { 1843 | "color-convert": "^1.9.0" 1844 | }, 1845 | "engines": { 1846 | "node": ">=4" 1847 | } 1848 | }, 1849 | "node_modules/argparse": { 1850 | "version": "2.0.1", 1851 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1852 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1853 | "dev": true 1854 | }, 1855 | "node_modules/array-buffer-byte-length": { 1856 | "version": "1.0.0", 1857 | "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", 1858 | "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", 1859 | "dev": true, 1860 | "dependencies": { 1861 | "call-bind": "^1.0.2", 1862 | "is-array-buffer": "^3.0.1" 1863 | }, 1864 | "funding": { 1865 | "url": "https://github.com/sponsors/ljharb" 1866 | } 1867 | }, 1868 | "node_modules/array-includes": { 1869 | "version": "3.1.7", 1870 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz", 1871 | "integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==", 1872 | "dev": true, 1873 | "dependencies": { 1874 | "call-bind": "^1.0.2", 1875 | "define-properties": "^1.2.0", 1876 | "es-abstract": "^1.22.1", 1877 | "get-intrinsic": "^1.2.1", 1878 | "is-string": "^1.0.7" 1879 | }, 1880 | "engines": { 1881 | "node": ">= 0.4" 1882 | }, 1883 | "funding": { 1884 | "url": "https://github.com/sponsors/ljharb" 1885 | } 1886 | }, 1887 | "node_modules/array.prototype.flat": { 1888 | "version": "1.3.2", 1889 | "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", 1890 | "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", 1891 | "dev": true, 1892 | "dependencies": { 1893 | "call-bind": "^1.0.2", 1894 | "define-properties": "^1.2.0", 1895 | "es-abstract": "^1.22.1", 1896 | "es-shim-unscopables": "^1.0.0" 1897 | }, 1898 | "engines": { 1899 | "node": ">= 0.4" 1900 | }, 1901 | "funding": { 1902 | "url": "https://github.com/sponsors/ljharb" 1903 | } 1904 | }, 1905 | "node_modules/array.prototype.flatmap": { 1906 | "version": "1.3.2", 1907 | "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", 1908 | "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", 1909 | "dev": true, 1910 | "dependencies": { 1911 | "call-bind": "^1.0.2", 1912 | "define-properties": "^1.2.0", 1913 | "es-abstract": "^1.22.1", 1914 | "es-shim-unscopables": "^1.0.0" 1915 | }, 1916 | "engines": { 1917 | "node": ">= 0.4" 1918 | }, 1919 | "funding": { 1920 | "url": "https://github.com/sponsors/ljharb" 1921 | } 1922 | }, 1923 | "node_modules/array.prototype.tosorted": { 1924 | "version": "1.1.2", 1925 | "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.2.tgz", 1926 | "integrity": "sha512-HuQCHOlk1Weat5jzStICBCd83NxiIMwqDg/dHEsoefabn/hJRj5pVdWcPUSpRrwhwxZOsQassMpgN/xRYFBMIg==", 1927 | "dev": true, 1928 | "dependencies": { 1929 | "call-bind": "^1.0.2", 1930 | "define-properties": "^1.2.0", 1931 | "es-abstract": "^1.22.1", 1932 | "es-shim-unscopables": "^1.0.0", 1933 | "get-intrinsic": "^1.2.1" 1934 | } 1935 | }, 1936 | "node_modules/arraybuffer.prototype.slice": { 1937 | "version": "1.0.2", 1938 | "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", 1939 | "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", 1940 | "dev": true, 1941 | "dependencies": { 1942 | "array-buffer-byte-length": "^1.0.0", 1943 | "call-bind": "^1.0.2", 1944 | "define-properties": "^1.2.0", 1945 | "es-abstract": "^1.22.1", 1946 | "get-intrinsic": "^1.2.1", 1947 | "is-array-buffer": "^3.0.2", 1948 | "is-shared-array-buffer": "^1.0.2" 1949 | }, 1950 | "engines": { 1951 | "node": ">= 0.4" 1952 | }, 1953 | "funding": { 1954 | "url": "https://github.com/sponsors/ljharb" 1955 | } 1956 | }, 1957 | "node_modules/asynciterator.prototype": { 1958 | "version": "1.0.0", 1959 | "resolved": "https://registry.npmjs.org/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz", 1960 | "integrity": "sha512-wwHYEIS0Q80f5mosx3L/dfG5t5rjEa9Ft51GTaNt862EnpyGHpgz2RkZvLPp1oF5TnAiTohkEKVEu8pQPJI7Vg==", 1961 | "dev": true, 1962 | "dependencies": { 1963 | "has-symbols": "^1.0.3" 1964 | } 1965 | }, 1966 | "node_modules/available-typed-arrays": { 1967 | "version": "1.0.5", 1968 | "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", 1969 | "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", 1970 | "dev": true, 1971 | "engines": { 1972 | "node": ">= 0.4" 1973 | }, 1974 | "funding": { 1975 | "url": "https://github.com/sponsors/ljharb" 1976 | } 1977 | }, 1978 | "node_modules/balanced-match": { 1979 | "version": "1.0.2", 1980 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1981 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1982 | "dev": true 1983 | }, 1984 | "node_modules/brace-expansion": { 1985 | "version": "1.1.11", 1986 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1987 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1988 | "dev": true, 1989 | "dependencies": { 1990 | "balanced-match": "^1.0.0", 1991 | "concat-map": "0.0.1" 1992 | } 1993 | }, 1994 | "node_modules/browserslist": { 1995 | "version": "4.22.2", 1996 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", 1997 | "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", 1998 | "dev": true, 1999 | "funding": [ 2000 | { 2001 | "type": "opencollective", 2002 | "url": "https://opencollective.com/browserslist" 2003 | }, 2004 | { 2005 | "type": "tidelift", 2006 | "url": "https://tidelift.com/funding/github/npm/browserslist" 2007 | }, 2008 | { 2009 | "type": "github", 2010 | "url": "https://github.com/sponsors/ai" 2011 | } 2012 | ], 2013 | "dependencies": { 2014 | "caniuse-lite": "^1.0.30001565", 2015 | "electron-to-chromium": "^1.4.601", 2016 | "node-releases": "^2.0.14", 2017 | "update-browserslist-db": "^1.0.13" 2018 | }, 2019 | "bin": { 2020 | "browserslist": "cli.js" 2021 | }, 2022 | "engines": { 2023 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 2024 | } 2025 | }, 2026 | "node_modules/call-bind": { 2027 | "version": "1.0.5", 2028 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz", 2029 | "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==", 2030 | "dev": true, 2031 | "dependencies": { 2032 | "function-bind": "^1.1.2", 2033 | "get-intrinsic": "^1.2.1", 2034 | "set-function-length": "^1.1.1" 2035 | }, 2036 | "funding": { 2037 | "url": "https://github.com/sponsors/ljharb" 2038 | } 2039 | }, 2040 | "node_modules/callsites": { 2041 | "version": "3.1.0", 2042 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2043 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2044 | "dev": true, 2045 | "engines": { 2046 | "node": ">=6" 2047 | } 2048 | }, 2049 | "node_modules/caniuse-lite": { 2050 | "version": "1.0.30001576", 2051 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001576.tgz", 2052 | "integrity": "sha512-ff5BdakGe2P3SQsMsiqmt1Lc8221NR1VzHj5jXN5vBny9A6fpze94HiVV/n7XRosOlsShJcvMv5mdnpjOGCEgg==", 2053 | "dev": true, 2054 | "funding": [ 2055 | { 2056 | "type": "opencollective", 2057 | "url": "https://opencollective.com/browserslist" 2058 | }, 2059 | { 2060 | "type": "tidelift", 2061 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 2062 | }, 2063 | { 2064 | "type": "github", 2065 | "url": "https://github.com/sponsors/ai" 2066 | } 2067 | ] 2068 | }, 2069 | "node_modules/chalk": { 2070 | "version": "2.4.2", 2071 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2072 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2073 | "dev": true, 2074 | "dependencies": { 2075 | "ansi-styles": "^3.2.1", 2076 | "escape-string-regexp": "^1.0.5", 2077 | "supports-color": "^5.3.0" 2078 | }, 2079 | "engines": { 2080 | "node": ">=4" 2081 | } 2082 | }, 2083 | "node_modules/cliui": { 2084 | "version": "8.0.1", 2085 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 2086 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 2087 | "dependencies": { 2088 | "string-width": "^4.2.0", 2089 | "strip-ansi": "^6.0.1", 2090 | "wrap-ansi": "^7.0.0" 2091 | }, 2092 | "engines": { 2093 | "node": ">=12" 2094 | } 2095 | }, 2096 | "node_modules/color-convert": { 2097 | "version": "1.9.3", 2098 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2099 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2100 | "dev": true, 2101 | "dependencies": { 2102 | "color-name": "1.1.3" 2103 | } 2104 | }, 2105 | "node_modules/color-name": { 2106 | "version": "1.1.3", 2107 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2108 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 2109 | "dev": true 2110 | }, 2111 | "node_modules/concat-map": { 2112 | "version": "0.0.1", 2113 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2114 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2115 | "dev": true 2116 | }, 2117 | "node_modules/convert-source-map": { 2118 | "version": "2.0.0", 2119 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 2120 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 2121 | "dev": true 2122 | }, 2123 | "node_modules/cross-spawn": { 2124 | "version": "7.0.3", 2125 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2126 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2127 | "dev": true, 2128 | "dependencies": { 2129 | "path-key": "^3.1.0", 2130 | "shebang-command": "^2.0.0", 2131 | "which": "^2.0.1" 2132 | }, 2133 | "engines": { 2134 | "node": ">= 8" 2135 | } 2136 | }, 2137 | "node_modules/csstype": { 2138 | "version": "3.1.3", 2139 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 2140 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", 2141 | "dev": true 2142 | }, 2143 | "node_modules/debug": { 2144 | "version": "4.3.4", 2145 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2146 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2147 | "dev": true, 2148 | "dependencies": { 2149 | "ms": "2.1.2" 2150 | }, 2151 | "engines": { 2152 | "node": ">=6.0" 2153 | }, 2154 | "peerDependenciesMeta": { 2155 | "supports-color": { 2156 | "optional": true 2157 | } 2158 | } 2159 | }, 2160 | "node_modules/deep-is": { 2161 | "version": "0.1.4", 2162 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2163 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2164 | "dev": true 2165 | }, 2166 | "node_modules/define-data-property": { 2167 | "version": "1.1.1", 2168 | "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz", 2169 | "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==", 2170 | "dev": true, 2171 | "dependencies": { 2172 | "get-intrinsic": "^1.2.1", 2173 | "gopd": "^1.0.1", 2174 | "has-property-descriptors": "^1.0.0" 2175 | }, 2176 | "engines": { 2177 | "node": ">= 0.4" 2178 | } 2179 | }, 2180 | "node_modules/define-properties": { 2181 | "version": "1.2.1", 2182 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", 2183 | "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", 2184 | "dev": true, 2185 | "dependencies": { 2186 | "define-data-property": "^1.0.1", 2187 | "has-property-descriptors": "^1.0.0", 2188 | "object-keys": "^1.1.1" 2189 | }, 2190 | "engines": { 2191 | "node": ">= 0.4" 2192 | }, 2193 | "funding": { 2194 | "url": "https://github.com/sponsors/ljharb" 2195 | } 2196 | }, 2197 | "node_modules/doctrine": { 2198 | "version": "3.0.0", 2199 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2200 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2201 | "dev": true, 2202 | "dependencies": { 2203 | "esutils": "^2.0.2" 2204 | }, 2205 | "engines": { 2206 | "node": ">=6.0.0" 2207 | } 2208 | }, 2209 | "node_modules/electron-to-chromium": { 2210 | "version": "1.4.631", 2211 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.631.tgz", 2212 | "integrity": "sha512-g73CJB/rMPjdxpiNJYmV1homV7mLVUNe/R0z/HhqMfpjkt58FpYmkTjbtuv3zymdbTTJ+VOEqe1c+lkTjSOhmQ==", 2213 | "dev": true 2214 | }, 2215 | "node_modules/emoji-regex": { 2216 | "version": "8.0.0", 2217 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2218 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2219 | }, 2220 | "node_modules/es-abstract": { 2221 | "version": "1.22.3", 2222 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz", 2223 | "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==", 2224 | "dev": true, 2225 | "dependencies": { 2226 | "array-buffer-byte-length": "^1.0.0", 2227 | "arraybuffer.prototype.slice": "^1.0.2", 2228 | "available-typed-arrays": "^1.0.5", 2229 | "call-bind": "^1.0.5", 2230 | "es-set-tostringtag": "^2.0.1", 2231 | "es-to-primitive": "^1.2.1", 2232 | "function.prototype.name": "^1.1.6", 2233 | "get-intrinsic": "^1.2.2", 2234 | "get-symbol-description": "^1.0.0", 2235 | "globalthis": "^1.0.3", 2236 | "gopd": "^1.0.1", 2237 | "has-property-descriptors": "^1.0.0", 2238 | "has-proto": "^1.0.1", 2239 | "has-symbols": "^1.0.3", 2240 | "hasown": "^2.0.0", 2241 | "internal-slot": "^1.0.5", 2242 | "is-array-buffer": "^3.0.2", 2243 | "is-callable": "^1.2.7", 2244 | "is-negative-zero": "^2.0.2", 2245 | "is-regex": "^1.1.4", 2246 | "is-shared-array-buffer": "^1.0.2", 2247 | "is-string": "^1.0.7", 2248 | "is-typed-array": "^1.1.12", 2249 | "is-weakref": "^1.0.2", 2250 | "object-inspect": "^1.13.1", 2251 | "object-keys": "^1.1.1", 2252 | "object.assign": "^4.1.4", 2253 | "regexp.prototype.flags": "^1.5.1", 2254 | "safe-array-concat": "^1.0.1", 2255 | "safe-regex-test": "^1.0.0", 2256 | "string.prototype.trim": "^1.2.8", 2257 | "string.prototype.trimend": "^1.0.7", 2258 | "string.prototype.trimstart": "^1.0.7", 2259 | "typed-array-buffer": "^1.0.0", 2260 | "typed-array-byte-length": "^1.0.0", 2261 | "typed-array-byte-offset": "^1.0.0", 2262 | "typed-array-length": "^1.0.4", 2263 | "unbox-primitive": "^1.0.2", 2264 | "which-typed-array": "^1.1.13" 2265 | }, 2266 | "engines": { 2267 | "node": ">= 0.4" 2268 | }, 2269 | "funding": { 2270 | "url": "https://github.com/sponsors/ljharb" 2271 | } 2272 | }, 2273 | "node_modules/es-iterator-helpers": { 2274 | "version": "1.0.15", 2275 | "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.15.tgz", 2276 | "integrity": "sha512-GhoY8uYqd6iwUl2kgjTm4CZAf6oo5mHK7BPqx3rKgx893YSsy0LGHV6gfqqQvZt/8xM8xeOnfXBCfqclMKkJ5g==", 2277 | "dev": true, 2278 | "dependencies": { 2279 | "asynciterator.prototype": "^1.0.0", 2280 | "call-bind": "^1.0.2", 2281 | "define-properties": "^1.2.1", 2282 | "es-abstract": "^1.22.1", 2283 | "es-set-tostringtag": "^2.0.1", 2284 | "function-bind": "^1.1.1", 2285 | "get-intrinsic": "^1.2.1", 2286 | "globalthis": "^1.0.3", 2287 | "has-property-descriptors": "^1.0.0", 2288 | "has-proto": "^1.0.1", 2289 | "has-symbols": "^1.0.3", 2290 | "internal-slot": "^1.0.5", 2291 | "iterator.prototype": "^1.1.2", 2292 | "safe-array-concat": "^1.0.1" 2293 | } 2294 | }, 2295 | "node_modules/es-set-tostringtag": { 2296 | "version": "2.0.2", 2297 | "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", 2298 | "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==", 2299 | "dev": true, 2300 | "dependencies": { 2301 | "get-intrinsic": "^1.2.2", 2302 | "has-tostringtag": "^1.0.0", 2303 | "hasown": "^2.0.0" 2304 | }, 2305 | "engines": { 2306 | "node": ">= 0.4" 2307 | } 2308 | }, 2309 | "node_modules/es-shim-unscopables": { 2310 | "version": "1.0.2", 2311 | "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", 2312 | "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", 2313 | "dev": true, 2314 | "dependencies": { 2315 | "hasown": "^2.0.0" 2316 | } 2317 | }, 2318 | "node_modules/es-to-primitive": { 2319 | "version": "1.2.1", 2320 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 2321 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 2322 | "dev": true, 2323 | "dependencies": { 2324 | "is-callable": "^1.1.4", 2325 | "is-date-object": "^1.0.1", 2326 | "is-symbol": "^1.0.2" 2327 | }, 2328 | "engines": { 2329 | "node": ">= 0.4" 2330 | }, 2331 | "funding": { 2332 | "url": "https://github.com/sponsors/ljharb" 2333 | } 2334 | }, 2335 | "node_modules/esbuild": { 2336 | "version": "0.19.11", 2337 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.11.tgz", 2338 | "integrity": "sha512-HJ96Hev2hX/6i5cDVwcqiJBBtuo9+FeIJOtZ9W1kA5M6AMJRHUZlpYZ1/SbEwtO0ioNAW8rUooVpC/WehY2SfA==", 2339 | "dev": true, 2340 | "hasInstallScript": true, 2341 | "bin": { 2342 | "esbuild": "bin/esbuild" 2343 | }, 2344 | "engines": { 2345 | "node": ">=12" 2346 | }, 2347 | "optionalDependencies": { 2348 | "@esbuild/aix-ppc64": "0.19.11", 2349 | "@esbuild/android-arm": "0.19.11", 2350 | "@esbuild/android-arm64": "0.19.11", 2351 | "@esbuild/android-x64": "0.19.11", 2352 | "@esbuild/darwin-arm64": "0.19.11", 2353 | "@esbuild/darwin-x64": "0.19.11", 2354 | "@esbuild/freebsd-arm64": "0.19.11", 2355 | "@esbuild/freebsd-x64": "0.19.11", 2356 | "@esbuild/linux-arm": "0.19.11", 2357 | "@esbuild/linux-arm64": "0.19.11", 2358 | "@esbuild/linux-ia32": "0.19.11", 2359 | "@esbuild/linux-loong64": "0.19.11", 2360 | "@esbuild/linux-mips64el": "0.19.11", 2361 | "@esbuild/linux-ppc64": "0.19.11", 2362 | "@esbuild/linux-riscv64": "0.19.11", 2363 | "@esbuild/linux-s390x": "0.19.11", 2364 | "@esbuild/linux-x64": "0.19.11", 2365 | "@esbuild/netbsd-x64": "0.19.11", 2366 | "@esbuild/openbsd-x64": "0.19.11", 2367 | "@esbuild/sunos-x64": "0.19.11", 2368 | "@esbuild/win32-arm64": "0.19.11", 2369 | "@esbuild/win32-ia32": "0.19.11", 2370 | "@esbuild/win32-x64": "0.19.11" 2371 | } 2372 | }, 2373 | "node_modules/escalade": { 2374 | "version": "3.1.1", 2375 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2376 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2377 | "engines": { 2378 | "node": ">=6" 2379 | } 2380 | }, 2381 | "node_modules/escape-string-regexp": { 2382 | "version": "1.0.5", 2383 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2384 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 2385 | "dev": true, 2386 | "engines": { 2387 | "node": ">=0.8.0" 2388 | } 2389 | }, 2390 | "node_modules/eslint": { 2391 | "version": "8.56.0", 2392 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", 2393 | "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", 2394 | "dev": true, 2395 | "dependencies": { 2396 | "@eslint-community/eslint-utils": "^4.2.0", 2397 | "@eslint-community/regexpp": "^4.6.1", 2398 | "@eslint/eslintrc": "^2.1.4", 2399 | "@eslint/js": "8.56.0", 2400 | "@humanwhocodes/config-array": "^0.11.13", 2401 | "@humanwhocodes/module-importer": "^1.0.1", 2402 | "@nodelib/fs.walk": "^1.2.8", 2403 | "@ungap/structured-clone": "^1.2.0", 2404 | "ajv": "^6.12.4", 2405 | "chalk": "^4.0.0", 2406 | "cross-spawn": "^7.0.2", 2407 | "debug": "^4.3.2", 2408 | "doctrine": "^3.0.0", 2409 | "escape-string-regexp": "^4.0.0", 2410 | "eslint-scope": "^7.2.2", 2411 | "eslint-visitor-keys": "^3.4.3", 2412 | "espree": "^9.6.1", 2413 | "esquery": "^1.4.2", 2414 | "esutils": "^2.0.2", 2415 | "fast-deep-equal": "^3.1.3", 2416 | "file-entry-cache": "^6.0.1", 2417 | "find-up": "^5.0.0", 2418 | "glob-parent": "^6.0.2", 2419 | "globals": "^13.19.0", 2420 | "graphemer": "^1.4.0", 2421 | "ignore": "^5.2.0", 2422 | "imurmurhash": "^0.1.4", 2423 | "is-glob": "^4.0.0", 2424 | "is-path-inside": "^3.0.3", 2425 | "js-yaml": "^4.1.0", 2426 | "json-stable-stringify-without-jsonify": "^1.0.1", 2427 | "levn": "^0.4.1", 2428 | "lodash.merge": "^4.6.2", 2429 | "minimatch": "^3.1.2", 2430 | "natural-compare": "^1.4.0", 2431 | "optionator": "^0.9.3", 2432 | "strip-ansi": "^6.0.1", 2433 | "text-table": "^0.2.0" 2434 | }, 2435 | "bin": { 2436 | "eslint": "bin/eslint.js" 2437 | }, 2438 | "engines": { 2439 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2440 | }, 2441 | "funding": { 2442 | "url": "https://opencollective.com/eslint" 2443 | } 2444 | }, 2445 | "node_modules/eslint-plugin-react": { 2446 | "version": "7.33.2", 2447 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.33.2.tgz", 2448 | "integrity": "sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw==", 2449 | "dev": true, 2450 | "dependencies": { 2451 | "array-includes": "^3.1.6", 2452 | "array.prototype.flatmap": "^1.3.1", 2453 | "array.prototype.tosorted": "^1.1.1", 2454 | "doctrine": "^2.1.0", 2455 | "es-iterator-helpers": "^1.0.12", 2456 | "estraverse": "^5.3.0", 2457 | "jsx-ast-utils": "^2.4.1 || ^3.0.0", 2458 | "minimatch": "^3.1.2", 2459 | "object.entries": "^1.1.6", 2460 | "object.fromentries": "^2.0.6", 2461 | "object.hasown": "^1.1.2", 2462 | "object.values": "^1.1.6", 2463 | "prop-types": "^15.8.1", 2464 | "resolve": "^2.0.0-next.4", 2465 | "semver": "^6.3.1", 2466 | "string.prototype.matchall": "^4.0.8" 2467 | }, 2468 | "engines": { 2469 | "node": ">=4" 2470 | }, 2471 | "peerDependencies": { 2472 | "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" 2473 | } 2474 | }, 2475 | "node_modules/eslint-plugin-react-hooks": { 2476 | "version": "4.6.0", 2477 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", 2478 | "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", 2479 | "dev": true, 2480 | "engines": { 2481 | "node": ">=10" 2482 | }, 2483 | "peerDependencies": { 2484 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 2485 | } 2486 | }, 2487 | "node_modules/eslint-plugin-react-refresh": { 2488 | "version": "0.4.5", 2489 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.5.tgz", 2490 | "integrity": "sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==", 2491 | "dev": true, 2492 | "peerDependencies": { 2493 | "eslint": ">=7" 2494 | } 2495 | }, 2496 | "node_modules/eslint-plugin-react/node_modules/doctrine": { 2497 | "version": "2.1.0", 2498 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 2499 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 2500 | "dev": true, 2501 | "dependencies": { 2502 | "esutils": "^2.0.2" 2503 | }, 2504 | "engines": { 2505 | "node": ">=0.10.0" 2506 | } 2507 | }, 2508 | "node_modules/eslint-scope": { 2509 | "version": "7.2.2", 2510 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 2511 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 2512 | "dev": true, 2513 | "dependencies": { 2514 | "esrecurse": "^4.3.0", 2515 | "estraverse": "^5.2.0" 2516 | }, 2517 | "engines": { 2518 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2519 | }, 2520 | "funding": { 2521 | "url": "https://opencollective.com/eslint" 2522 | } 2523 | }, 2524 | "node_modules/eslint-visitor-keys": { 2525 | "version": "3.4.3", 2526 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 2527 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 2528 | "dev": true, 2529 | "engines": { 2530 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2531 | }, 2532 | "funding": { 2533 | "url": "https://opencollective.com/eslint" 2534 | } 2535 | }, 2536 | "node_modules/eslint/node_modules/ansi-styles": { 2537 | "version": "4.3.0", 2538 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2539 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2540 | "dev": true, 2541 | "dependencies": { 2542 | "color-convert": "^2.0.1" 2543 | }, 2544 | "engines": { 2545 | "node": ">=8" 2546 | }, 2547 | "funding": { 2548 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2549 | } 2550 | }, 2551 | "node_modules/eslint/node_modules/chalk": { 2552 | "version": "4.1.2", 2553 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2554 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2555 | "dev": true, 2556 | "dependencies": { 2557 | "ansi-styles": "^4.1.0", 2558 | "supports-color": "^7.1.0" 2559 | }, 2560 | "engines": { 2561 | "node": ">=10" 2562 | }, 2563 | "funding": { 2564 | "url": "https://github.com/chalk/chalk?sponsor=1" 2565 | } 2566 | }, 2567 | "node_modules/eslint/node_modules/color-convert": { 2568 | "version": "2.0.1", 2569 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2570 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2571 | "dev": true, 2572 | "dependencies": { 2573 | "color-name": "~1.1.4" 2574 | }, 2575 | "engines": { 2576 | "node": ">=7.0.0" 2577 | } 2578 | }, 2579 | "node_modules/eslint/node_modules/color-name": { 2580 | "version": "1.1.4", 2581 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2582 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2583 | "dev": true 2584 | }, 2585 | "node_modules/eslint/node_modules/escape-string-regexp": { 2586 | "version": "4.0.0", 2587 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2588 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2589 | "dev": true, 2590 | "engines": { 2591 | "node": ">=10" 2592 | }, 2593 | "funding": { 2594 | "url": "https://github.com/sponsors/sindresorhus" 2595 | } 2596 | }, 2597 | "node_modules/eslint/node_modules/globals": { 2598 | "version": "13.24.0", 2599 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 2600 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 2601 | "dev": true, 2602 | "dependencies": { 2603 | "type-fest": "^0.20.2" 2604 | }, 2605 | "engines": { 2606 | "node": ">=8" 2607 | }, 2608 | "funding": { 2609 | "url": "https://github.com/sponsors/sindresorhus" 2610 | } 2611 | }, 2612 | "node_modules/eslint/node_modules/has-flag": { 2613 | "version": "4.0.0", 2614 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2615 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2616 | "dev": true, 2617 | "engines": { 2618 | "node": ">=8" 2619 | } 2620 | }, 2621 | "node_modules/eslint/node_modules/supports-color": { 2622 | "version": "7.2.0", 2623 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2624 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2625 | "dev": true, 2626 | "dependencies": { 2627 | "has-flag": "^4.0.0" 2628 | }, 2629 | "engines": { 2630 | "node": ">=8" 2631 | } 2632 | }, 2633 | "node_modules/espree": { 2634 | "version": "9.6.1", 2635 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2636 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2637 | "dev": true, 2638 | "dependencies": { 2639 | "acorn": "^8.9.0", 2640 | "acorn-jsx": "^5.3.2", 2641 | "eslint-visitor-keys": "^3.4.1" 2642 | }, 2643 | "engines": { 2644 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2645 | }, 2646 | "funding": { 2647 | "url": "https://opencollective.com/eslint" 2648 | } 2649 | }, 2650 | "node_modules/esquery": { 2651 | "version": "1.5.0", 2652 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2653 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2654 | "dev": true, 2655 | "dependencies": { 2656 | "estraverse": "^5.1.0" 2657 | }, 2658 | "engines": { 2659 | "node": ">=0.10" 2660 | } 2661 | }, 2662 | "node_modules/esrecurse": { 2663 | "version": "4.3.0", 2664 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2665 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2666 | "dev": true, 2667 | "dependencies": { 2668 | "estraverse": "^5.2.0" 2669 | }, 2670 | "engines": { 2671 | "node": ">=4.0" 2672 | } 2673 | }, 2674 | "node_modules/estraverse": { 2675 | "version": "5.3.0", 2676 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2677 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2678 | "dev": true, 2679 | "engines": { 2680 | "node": ">=4.0" 2681 | } 2682 | }, 2683 | "node_modules/esutils": { 2684 | "version": "2.0.3", 2685 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2686 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2687 | "dev": true, 2688 | "engines": { 2689 | "node": ">=0.10.0" 2690 | } 2691 | }, 2692 | "node_modules/fast-deep-equal": { 2693 | "version": "3.1.3", 2694 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2695 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2696 | "dev": true 2697 | }, 2698 | "node_modules/fast-json-stable-stringify": { 2699 | "version": "2.1.0", 2700 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2701 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2702 | "dev": true 2703 | }, 2704 | "node_modules/fast-levenshtein": { 2705 | "version": "2.0.6", 2706 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2707 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2708 | "dev": true 2709 | }, 2710 | "node_modules/fastq": { 2711 | "version": "1.16.0", 2712 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", 2713 | "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", 2714 | "dev": true, 2715 | "dependencies": { 2716 | "reusify": "^1.0.4" 2717 | } 2718 | }, 2719 | "node_modules/faye-websocket": { 2720 | "version": "0.11.4", 2721 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", 2722 | "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", 2723 | "dependencies": { 2724 | "websocket-driver": ">=0.5.1" 2725 | }, 2726 | "engines": { 2727 | "node": ">=0.8.0" 2728 | } 2729 | }, 2730 | "node_modules/file-entry-cache": { 2731 | "version": "6.0.1", 2732 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2733 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2734 | "dev": true, 2735 | "dependencies": { 2736 | "flat-cache": "^3.0.4" 2737 | }, 2738 | "engines": { 2739 | "node": "^10.12.0 || >=12.0.0" 2740 | } 2741 | }, 2742 | "node_modules/find-up": { 2743 | "version": "5.0.0", 2744 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2745 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2746 | "dev": true, 2747 | "dependencies": { 2748 | "locate-path": "^6.0.0", 2749 | "path-exists": "^4.0.0" 2750 | }, 2751 | "engines": { 2752 | "node": ">=10" 2753 | }, 2754 | "funding": { 2755 | "url": "https://github.com/sponsors/sindresorhus" 2756 | } 2757 | }, 2758 | "node_modules/firebase": { 2759 | "version": "10.7.1", 2760 | "resolved": "https://registry.npmjs.org/firebase/-/firebase-10.7.1.tgz", 2761 | "integrity": "sha512-Mlt7y7zQ43FtKp4SCyYie3tnrOL3UMF2XXiV4ZXMrC0d0wtcOYmABuybhkJpJCKILpdekxr39wjnaai0DZlWFg==", 2762 | "dependencies": { 2763 | "@firebase/analytics": "0.10.0", 2764 | "@firebase/analytics-compat": "0.2.6", 2765 | "@firebase/app": "0.9.25", 2766 | "@firebase/app-check": "0.8.1", 2767 | "@firebase/app-check-compat": "0.3.8", 2768 | "@firebase/app-compat": "0.2.25", 2769 | "@firebase/app-types": "0.9.0", 2770 | "@firebase/auth": "1.5.1", 2771 | "@firebase/auth-compat": "0.5.1", 2772 | "@firebase/database": "1.0.2", 2773 | "@firebase/database-compat": "1.0.2", 2774 | "@firebase/firestore": "4.4.0", 2775 | "@firebase/firestore-compat": "0.3.23", 2776 | "@firebase/functions": "0.11.0", 2777 | "@firebase/functions-compat": "0.3.6", 2778 | "@firebase/installations": "0.6.4", 2779 | "@firebase/installations-compat": "0.2.4", 2780 | "@firebase/messaging": "0.12.5", 2781 | "@firebase/messaging-compat": "0.2.5", 2782 | "@firebase/performance": "0.6.4", 2783 | "@firebase/performance-compat": "0.2.4", 2784 | "@firebase/remote-config": "0.4.4", 2785 | "@firebase/remote-config-compat": "0.2.4", 2786 | "@firebase/storage": "0.12.0", 2787 | "@firebase/storage-compat": "0.3.3", 2788 | "@firebase/util": "1.9.3" 2789 | } 2790 | }, 2791 | "node_modules/flat-cache": { 2792 | "version": "3.2.0", 2793 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2794 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2795 | "dev": true, 2796 | "dependencies": { 2797 | "flatted": "^3.2.9", 2798 | "keyv": "^4.5.3", 2799 | "rimraf": "^3.0.2" 2800 | }, 2801 | "engines": { 2802 | "node": "^10.12.0 || >=12.0.0" 2803 | } 2804 | }, 2805 | "node_modules/flatted": { 2806 | "version": "3.2.9", 2807 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 2808 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 2809 | "dev": true 2810 | }, 2811 | "node_modules/for-each": { 2812 | "version": "0.3.3", 2813 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", 2814 | "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", 2815 | "dev": true, 2816 | "dependencies": { 2817 | "is-callable": "^1.1.3" 2818 | } 2819 | }, 2820 | "node_modules/fs.realpath": { 2821 | "version": "1.0.0", 2822 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2823 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2824 | "dev": true 2825 | }, 2826 | "node_modules/fsevents": { 2827 | "version": "2.3.3", 2828 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2829 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2830 | "dev": true, 2831 | "hasInstallScript": true, 2832 | "optional": true, 2833 | "os": [ 2834 | "darwin" 2835 | ], 2836 | "engines": { 2837 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2838 | } 2839 | }, 2840 | "node_modules/function-bind": { 2841 | "version": "1.1.2", 2842 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", 2843 | "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", 2844 | "dev": true, 2845 | "funding": { 2846 | "url": "https://github.com/sponsors/ljharb" 2847 | } 2848 | }, 2849 | "node_modules/function.prototype.name": { 2850 | "version": "1.1.6", 2851 | "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", 2852 | "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", 2853 | "dev": true, 2854 | "dependencies": { 2855 | "call-bind": "^1.0.2", 2856 | "define-properties": "^1.2.0", 2857 | "es-abstract": "^1.22.1", 2858 | "functions-have-names": "^1.2.3" 2859 | }, 2860 | "engines": { 2861 | "node": ">= 0.4" 2862 | }, 2863 | "funding": { 2864 | "url": "https://github.com/sponsors/ljharb" 2865 | } 2866 | }, 2867 | "node_modules/functions-have-names": { 2868 | "version": "1.2.3", 2869 | "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", 2870 | "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", 2871 | "dev": true, 2872 | "funding": { 2873 | "url": "https://github.com/sponsors/ljharb" 2874 | } 2875 | }, 2876 | "node_modules/gensync": { 2877 | "version": "1.0.0-beta.2", 2878 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2879 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2880 | "dev": true, 2881 | "engines": { 2882 | "node": ">=6.9.0" 2883 | } 2884 | }, 2885 | "node_modules/get-caller-file": { 2886 | "version": "2.0.5", 2887 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2888 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2889 | "engines": { 2890 | "node": "6.* || 8.* || >= 10.*" 2891 | } 2892 | }, 2893 | "node_modules/get-intrinsic": { 2894 | "version": "1.2.2", 2895 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz", 2896 | "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==", 2897 | "dev": true, 2898 | "dependencies": { 2899 | "function-bind": "^1.1.2", 2900 | "has-proto": "^1.0.1", 2901 | "has-symbols": "^1.0.3", 2902 | "hasown": "^2.0.0" 2903 | }, 2904 | "funding": { 2905 | "url": "https://github.com/sponsors/ljharb" 2906 | } 2907 | }, 2908 | "node_modules/get-symbol-description": { 2909 | "version": "1.0.0", 2910 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 2911 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 2912 | "dev": true, 2913 | "dependencies": { 2914 | "call-bind": "^1.0.2", 2915 | "get-intrinsic": "^1.1.1" 2916 | }, 2917 | "engines": { 2918 | "node": ">= 0.4" 2919 | }, 2920 | "funding": { 2921 | "url": "https://github.com/sponsors/ljharb" 2922 | } 2923 | }, 2924 | "node_modules/glob": { 2925 | "version": "7.2.3", 2926 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2927 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2928 | "dev": true, 2929 | "dependencies": { 2930 | "fs.realpath": "^1.0.0", 2931 | "inflight": "^1.0.4", 2932 | "inherits": "2", 2933 | "minimatch": "^3.1.1", 2934 | "once": "^1.3.0", 2935 | "path-is-absolute": "^1.0.0" 2936 | }, 2937 | "engines": { 2938 | "node": "*" 2939 | }, 2940 | "funding": { 2941 | "url": "https://github.com/sponsors/isaacs" 2942 | } 2943 | }, 2944 | "node_modules/glob-parent": { 2945 | "version": "6.0.2", 2946 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2947 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2948 | "dev": true, 2949 | "dependencies": { 2950 | "is-glob": "^4.0.3" 2951 | }, 2952 | "engines": { 2953 | "node": ">=10.13.0" 2954 | } 2955 | }, 2956 | "node_modules/globals": { 2957 | "version": "11.12.0", 2958 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2959 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2960 | "dev": true, 2961 | "engines": { 2962 | "node": ">=4" 2963 | } 2964 | }, 2965 | "node_modules/globalthis": { 2966 | "version": "1.0.3", 2967 | "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", 2968 | "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", 2969 | "dev": true, 2970 | "dependencies": { 2971 | "define-properties": "^1.1.3" 2972 | }, 2973 | "engines": { 2974 | "node": ">= 0.4" 2975 | }, 2976 | "funding": { 2977 | "url": "https://github.com/sponsors/ljharb" 2978 | } 2979 | }, 2980 | "node_modules/gopd": { 2981 | "version": "1.0.1", 2982 | "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", 2983 | "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", 2984 | "dev": true, 2985 | "dependencies": { 2986 | "get-intrinsic": "^1.1.3" 2987 | }, 2988 | "funding": { 2989 | "url": "https://github.com/sponsors/ljharb" 2990 | } 2991 | }, 2992 | "node_modules/graphemer": { 2993 | "version": "1.4.0", 2994 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2995 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2996 | "dev": true 2997 | }, 2998 | "node_modules/has-bigints": { 2999 | "version": "1.0.2", 3000 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", 3001 | "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", 3002 | "dev": true, 3003 | "funding": { 3004 | "url": "https://github.com/sponsors/ljharb" 3005 | } 3006 | }, 3007 | "node_modules/has-flag": { 3008 | "version": "3.0.0", 3009 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 3010 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 3011 | "dev": true, 3012 | "engines": { 3013 | "node": ">=4" 3014 | } 3015 | }, 3016 | "node_modules/has-property-descriptors": { 3017 | "version": "1.0.1", 3018 | "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz", 3019 | "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==", 3020 | "dev": true, 3021 | "dependencies": { 3022 | "get-intrinsic": "^1.2.2" 3023 | }, 3024 | "funding": { 3025 | "url": "https://github.com/sponsors/ljharb" 3026 | } 3027 | }, 3028 | "node_modules/has-proto": { 3029 | "version": "1.0.1", 3030 | "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", 3031 | "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", 3032 | "dev": true, 3033 | "engines": { 3034 | "node": ">= 0.4" 3035 | }, 3036 | "funding": { 3037 | "url": "https://github.com/sponsors/ljharb" 3038 | } 3039 | }, 3040 | "node_modules/has-symbols": { 3041 | "version": "1.0.3", 3042 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", 3043 | "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", 3044 | "dev": true, 3045 | "engines": { 3046 | "node": ">= 0.4" 3047 | }, 3048 | "funding": { 3049 | "url": "https://github.com/sponsors/ljharb" 3050 | } 3051 | }, 3052 | "node_modules/has-tostringtag": { 3053 | "version": "1.0.0", 3054 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 3055 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 3056 | "dev": true, 3057 | "dependencies": { 3058 | "has-symbols": "^1.0.2" 3059 | }, 3060 | "engines": { 3061 | "node": ">= 0.4" 3062 | }, 3063 | "funding": { 3064 | "url": "https://github.com/sponsors/ljharb" 3065 | } 3066 | }, 3067 | "node_modules/hasown": { 3068 | "version": "2.0.0", 3069 | "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", 3070 | "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", 3071 | "dev": true, 3072 | "dependencies": { 3073 | "function-bind": "^1.1.2" 3074 | }, 3075 | "engines": { 3076 | "node": ">= 0.4" 3077 | } 3078 | }, 3079 | "node_modules/http-parser-js": { 3080 | "version": "0.5.8", 3081 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz", 3082 | "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==" 3083 | }, 3084 | "node_modules/idb": { 3085 | "version": "7.1.1", 3086 | "resolved": "https://registry.npmjs.org/idb/-/idb-7.1.1.tgz", 3087 | "integrity": "sha512-gchesWBzyvGHRO9W8tzUWFDycow5gwjvFKfyV9FF32Y7F50yZMp7mP+T2mJIWFx49zicqyC4uefHM17o6xKIVQ==" 3088 | }, 3089 | "node_modules/ignore": { 3090 | "version": "5.3.0", 3091 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", 3092 | "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", 3093 | "dev": true, 3094 | "engines": { 3095 | "node": ">= 4" 3096 | } 3097 | }, 3098 | "node_modules/import-fresh": { 3099 | "version": "3.3.0", 3100 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 3101 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 3102 | "dev": true, 3103 | "dependencies": { 3104 | "parent-module": "^1.0.0", 3105 | "resolve-from": "^4.0.0" 3106 | }, 3107 | "engines": { 3108 | "node": ">=6" 3109 | }, 3110 | "funding": { 3111 | "url": "https://github.com/sponsors/sindresorhus" 3112 | } 3113 | }, 3114 | "node_modules/imurmurhash": { 3115 | "version": "0.1.4", 3116 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 3117 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 3118 | "dev": true, 3119 | "engines": { 3120 | "node": ">=0.8.19" 3121 | } 3122 | }, 3123 | "node_modules/inflight": { 3124 | "version": "1.0.6", 3125 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3126 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 3127 | "dev": true, 3128 | "dependencies": { 3129 | "once": "^1.3.0", 3130 | "wrappy": "1" 3131 | } 3132 | }, 3133 | "node_modules/inherits": { 3134 | "version": "2.0.4", 3135 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3136 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 3137 | "dev": true 3138 | }, 3139 | "node_modules/internal-slot": { 3140 | "version": "1.0.6", 3141 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", 3142 | "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==", 3143 | "dev": true, 3144 | "dependencies": { 3145 | "get-intrinsic": "^1.2.2", 3146 | "hasown": "^2.0.0", 3147 | "side-channel": "^1.0.4" 3148 | }, 3149 | "engines": { 3150 | "node": ">= 0.4" 3151 | } 3152 | }, 3153 | "node_modules/is-array-buffer": { 3154 | "version": "3.0.2", 3155 | "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", 3156 | "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", 3157 | "dev": true, 3158 | "dependencies": { 3159 | "call-bind": "^1.0.2", 3160 | "get-intrinsic": "^1.2.0", 3161 | "is-typed-array": "^1.1.10" 3162 | }, 3163 | "funding": { 3164 | "url": "https://github.com/sponsors/ljharb" 3165 | } 3166 | }, 3167 | "node_modules/is-async-function": { 3168 | "version": "2.0.0", 3169 | "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", 3170 | "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", 3171 | "dev": true, 3172 | "dependencies": { 3173 | "has-tostringtag": "^1.0.0" 3174 | }, 3175 | "engines": { 3176 | "node": ">= 0.4" 3177 | }, 3178 | "funding": { 3179 | "url": "https://github.com/sponsors/ljharb" 3180 | } 3181 | }, 3182 | "node_modules/is-bigint": { 3183 | "version": "1.0.4", 3184 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 3185 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 3186 | "dev": true, 3187 | "dependencies": { 3188 | "has-bigints": "^1.0.1" 3189 | }, 3190 | "funding": { 3191 | "url": "https://github.com/sponsors/ljharb" 3192 | } 3193 | }, 3194 | "node_modules/is-boolean-object": { 3195 | "version": "1.1.2", 3196 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 3197 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 3198 | "dev": true, 3199 | "dependencies": { 3200 | "call-bind": "^1.0.2", 3201 | "has-tostringtag": "^1.0.0" 3202 | }, 3203 | "engines": { 3204 | "node": ">= 0.4" 3205 | }, 3206 | "funding": { 3207 | "url": "https://github.com/sponsors/ljharb" 3208 | } 3209 | }, 3210 | "node_modules/is-callable": { 3211 | "version": "1.2.7", 3212 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", 3213 | "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", 3214 | "dev": true, 3215 | "engines": { 3216 | "node": ">= 0.4" 3217 | }, 3218 | "funding": { 3219 | "url": "https://github.com/sponsors/ljharb" 3220 | } 3221 | }, 3222 | "node_modules/is-core-module": { 3223 | "version": "2.13.1", 3224 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", 3225 | "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", 3226 | "dev": true, 3227 | "dependencies": { 3228 | "hasown": "^2.0.0" 3229 | }, 3230 | "funding": { 3231 | "url": "https://github.com/sponsors/ljharb" 3232 | } 3233 | }, 3234 | "node_modules/is-date-object": { 3235 | "version": "1.0.5", 3236 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 3237 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 3238 | "dev": true, 3239 | "dependencies": { 3240 | "has-tostringtag": "^1.0.0" 3241 | }, 3242 | "engines": { 3243 | "node": ">= 0.4" 3244 | }, 3245 | "funding": { 3246 | "url": "https://github.com/sponsors/ljharb" 3247 | } 3248 | }, 3249 | "node_modules/is-extglob": { 3250 | "version": "2.1.1", 3251 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3252 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 3253 | "dev": true, 3254 | "engines": { 3255 | "node": ">=0.10.0" 3256 | } 3257 | }, 3258 | "node_modules/is-finalizationregistry": { 3259 | "version": "1.0.2", 3260 | "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", 3261 | "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", 3262 | "dev": true, 3263 | "dependencies": { 3264 | "call-bind": "^1.0.2" 3265 | }, 3266 | "funding": { 3267 | "url": "https://github.com/sponsors/ljharb" 3268 | } 3269 | }, 3270 | "node_modules/is-fullwidth-code-point": { 3271 | "version": "3.0.0", 3272 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3273 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3274 | "engines": { 3275 | "node": ">=8" 3276 | } 3277 | }, 3278 | "node_modules/is-generator-function": { 3279 | "version": "1.0.10", 3280 | "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", 3281 | "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", 3282 | "dev": true, 3283 | "dependencies": { 3284 | "has-tostringtag": "^1.0.0" 3285 | }, 3286 | "engines": { 3287 | "node": ">= 0.4" 3288 | }, 3289 | "funding": { 3290 | "url": "https://github.com/sponsors/ljharb" 3291 | } 3292 | }, 3293 | "node_modules/is-glob": { 3294 | "version": "4.0.3", 3295 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3296 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3297 | "dev": true, 3298 | "dependencies": { 3299 | "is-extglob": "^2.1.1" 3300 | }, 3301 | "engines": { 3302 | "node": ">=0.10.0" 3303 | } 3304 | }, 3305 | "node_modules/is-map": { 3306 | "version": "2.0.2", 3307 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.2.tgz", 3308 | "integrity": "sha512-cOZFQQozTha1f4MxLFzlgKYPTyj26picdZTx82hbc/Xf4K/tZOOXSCkMvU4pKioRXGDLJRn0GM7Upe7kR721yg==", 3309 | "dev": true, 3310 | "funding": { 3311 | "url": "https://github.com/sponsors/ljharb" 3312 | } 3313 | }, 3314 | "node_modules/is-negative-zero": { 3315 | "version": "2.0.2", 3316 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 3317 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 3318 | "dev": true, 3319 | "engines": { 3320 | "node": ">= 0.4" 3321 | }, 3322 | "funding": { 3323 | "url": "https://github.com/sponsors/ljharb" 3324 | } 3325 | }, 3326 | "node_modules/is-number-object": { 3327 | "version": "1.0.7", 3328 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", 3329 | "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", 3330 | "dev": true, 3331 | "dependencies": { 3332 | "has-tostringtag": "^1.0.0" 3333 | }, 3334 | "engines": { 3335 | "node": ">= 0.4" 3336 | }, 3337 | "funding": { 3338 | "url": "https://github.com/sponsors/ljharb" 3339 | } 3340 | }, 3341 | "node_modules/is-path-inside": { 3342 | "version": "3.0.3", 3343 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 3344 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 3345 | "dev": true, 3346 | "engines": { 3347 | "node": ">=8" 3348 | } 3349 | }, 3350 | "node_modules/is-regex": { 3351 | "version": "1.1.4", 3352 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 3353 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 3354 | "dev": true, 3355 | "dependencies": { 3356 | "call-bind": "^1.0.2", 3357 | "has-tostringtag": "^1.0.0" 3358 | }, 3359 | "engines": { 3360 | "node": ">= 0.4" 3361 | }, 3362 | "funding": { 3363 | "url": "https://github.com/sponsors/ljharb" 3364 | } 3365 | }, 3366 | "node_modules/is-set": { 3367 | "version": "2.0.2", 3368 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.2.tgz", 3369 | "integrity": "sha512-+2cnTEZeY5z/iXGbLhPrOAaK/Mau5k5eXq9j14CpRTftq0pAJu2MwVRSZhyZWBzx3o6X795Lz6Bpb6R0GKf37g==", 3370 | "dev": true, 3371 | "funding": { 3372 | "url": "https://github.com/sponsors/ljharb" 3373 | } 3374 | }, 3375 | "node_modules/is-shared-array-buffer": { 3376 | "version": "1.0.2", 3377 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", 3378 | "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", 3379 | "dev": true, 3380 | "dependencies": { 3381 | "call-bind": "^1.0.2" 3382 | }, 3383 | "funding": { 3384 | "url": "https://github.com/sponsors/ljharb" 3385 | } 3386 | }, 3387 | "node_modules/is-string": { 3388 | "version": "1.0.7", 3389 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 3390 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 3391 | "dev": true, 3392 | "dependencies": { 3393 | "has-tostringtag": "^1.0.0" 3394 | }, 3395 | "engines": { 3396 | "node": ">= 0.4" 3397 | }, 3398 | "funding": { 3399 | "url": "https://github.com/sponsors/ljharb" 3400 | } 3401 | }, 3402 | "node_modules/is-symbol": { 3403 | "version": "1.0.4", 3404 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 3405 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 3406 | "dev": true, 3407 | "dependencies": { 3408 | "has-symbols": "^1.0.2" 3409 | }, 3410 | "engines": { 3411 | "node": ">= 0.4" 3412 | }, 3413 | "funding": { 3414 | "url": "https://github.com/sponsors/ljharb" 3415 | } 3416 | }, 3417 | "node_modules/is-typed-array": { 3418 | "version": "1.1.12", 3419 | "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", 3420 | "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", 3421 | "dev": true, 3422 | "dependencies": { 3423 | "which-typed-array": "^1.1.11" 3424 | }, 3425 | "engines": { 3426 | "node": ">= 0.4" 3427 | }, 3428 | "funding": { 3429 | "url": "https://github.com/sponsors/ljharb" 3430 | } 3431 | }, 3432 | "node_modules/is-weakmap": { 3433 | "version": "2.0.1", 3434 | "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.1.tgz", 3435 | "integrity": "sha512-NSBR4kH5oVj1Uwvv970ruUkCV7O1mzgVFO4/rev2cLRda9Tm9HrL70ZPut4rOHgY0FNrUu9BCbXA2sdQ+x0chA==", 3436 | "dev": true, 3437 | "funding": { 3438 | "url": "https://github.com/sponsors/ljharb" 3439 | } 3440 | }, 3441 | "node_modules/is-weakref": { 3442 | "version": "1.0.2", 3443 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 3444 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 3445 | "dev": true, 3446 | "dependencies": { 3447 | "call-bind": "^1.0.2" 3448 | }, 3449 | "funding": { 3450 | "url": "https://github.com/sponsors/ljharb" 3451 | } 3452 | }, 3453 | "node_modules/is-weakset": { 3454 | "version": "2.0.2", 3455 | "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.2.tgz", 3456 | "integrity": "sha512-t2yVvttHkQktwnNNmBQ98AhENLdPUTDTE21uPqAQ0ARwQfGeQKRVS0NNurH7bTf7RrvcVn1OOge45CnBeHCSmg==", 3457 | "dev": true, 3458 | "dependencies": { 3459 | "call-bind": "^1.0.2", 3460 | "get-intrinsic": "^1.1.1" 3461 | }, 3462 | "funding": { 3463 | "url": "https://github.com/sponsors/ljharb" 3464 | } 3465 | }, 3466 | "node_modules/isarray": { 3467 | "version": "2.0.5", 3468 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 3469 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 3470 | "dev": true 3471 | }, 3472 | "node_modules/isexe": { 3473 | "version": "2.0.0", 3474 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3475 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 3476 | "dev": true 3477 | }, 3478 | "node_modules/iterator.prototype": { 3479 | "version": "1.1.2", 3480 | "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.2.tgz", 3481 | "integrity": "sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==", 3482 | "dev": true, 3483 | "dependencies": { 3484 | "define-properties": "^1.2.1", 3485 | "get-intrinsic": "^1.2.1", 3486 | "has-symbols": "^1.0.3", 3487 | "reflect.getprototypeof": "^1.0.4", 3488 | "set-function-name": "^2.0.1" 3489 | } 3490 | }, 3491 | "node_modules/js-tokens": { 3492 | "version": "4.0.0", 3493 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 3494 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 3495 | }, 3496 | "node_modules/js-yaml": { 3497 | "version": "4.1.0", 3498 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 3499 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 3500 | "dev": true, 3501 | "dependencies": { 3502 | "argparse": "^2.0.1" 3503 | }, 3504 | "bin": { 3505 | "js-yaml": "bin/js-yaml.js" 3506 | } 3507 | }, 3508 | "node_modules/jsesc": { 3509 | "version": "2.5.2", 3510 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 3511 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 3512 | "dev": true, 3513 | "bin": { 3514 | "jsesc": "bin/jsesc" 3515 | }, 3516 | "engines": { 3517 | "node": ">=4" 3518 | } 3519 | }, 3520 | "node_modules/json-buffer": { 3521 | "version": "3.0.1", 3522 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 3523 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 3524 | "dev": true 3525 | }, 3526 | "node_modules/json-schema-traverse": { 3527 | "version": "0.4.1", 3528 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 3529 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 3530 | "dev": true 3531 | }, 3532 | "node_modules/json-stable-stringify-without-jsonify": { 3533 | "version": "1.0.1", 3534 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 3535 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 3536 | "dev": true 3537 | }, 3538 | "node_modules/json5": { 3539 | "version": "2.2.3", 3540 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 3541 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 3542 | "dev": true, 3543 | "bin": { 3544 | "json5": "lib/cli.js" 3545 | }, 3546 | "engines": { 3547 | "node": ">=6" 3548 | } 3549 | }, 3550 | "node_modules/jsx-ast-utils": { 3551 | "version": "3.3.5", 3552 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", 3553 | "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", 3554 | "dev": true, 3555 | "dependencies": { 3556 | "array-includes": "^3.1.6", 3557 | "array.prototype.flat": "^1.3.1", 3558 | "object.assign": "^4.1.4", 3559 | "object.values": "^1.1.6" 3560 | }, 3561 | "engines": { 3562 | "node": ">=4.0" 3563 | } 3564 | }, 3565 | "node_modules/keyv": { 3566 | "version": "4.5.4", 3567 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 3568 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 3569 | "dev": true, 3570 | "dependencies": { 3571 | "json-buffer": "3.0.1" 3572 | } 3573 | }, 3574 | "node_modules/levn": { 3575 | "version": "0.4.1", 3576 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 3577 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3578 | "dev": true, 3579 | "dependencies": { 3580 | "prelude-ls": "^1.2.1", 3581 | "type-check": "~0.4.0" 3582 | }, 3583 | "engines": { 3584 | "node": ">= 0.8.0" 3585 | } 3586 | }, 3587 | "node_modules/locate-path": { 3588 | "version": "6.0.0", 3589 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 3590 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 3591 | "dev": true, 3592 | "dependencies": { 3593 | "p-locate": "^5.0.0" 3594 | }, 3595 | "engines": { 3596 | "node": ">=10" 3597 | }, 3598 | "funding": { 3599 | "url": "https://github.com/sponsors/sindresorhus" 3600 | } 3601 | }, 3602 | "node_modules/lodash.camelcase": { 3603 | "version": "4.3.0", 3604 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 3605 | "integrity": "sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==" 3606 | }, 3607 | "node_modules/lodash.merge": { 3608 | "version": "4.6.2", 3609 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3610 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 3611 | "dev": true 3612 | }, 3613 | "node_modules/long": { 3614 | "version": "5.2.3", 3615 | "resolved": "https://registry.npmjs.org/long/-/long-5.2.3.tgz", 3616 | "integrity": "sha512-lcHwpNoggQTObv5apGNCTdJrO69eHOZMi4BNC+rTLER8iHAqGrUVeLh/irVIM7zTw2bOXA8T6uNPeujwOLg/2Q==" 3617 | }, 3618 | "node_modules/loose-envify": { 3619 | "version": "1.4.0", 3620 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 3621 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 3622 | "dependencies": { 3623 | "js-tokens": "^3.0.0 || ^4.0.0" 3624 | }, 3625 | "bin": { 3626 | "loose-envify": "cli.js" 3627 | } 3628 | }, 3629 | "node_modules/lru-cache": { 3630 | "version": "5.1.1", 3631 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 3632 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 3633 | "dev": true, 3634 | "dependencies": { 3635 | "yallist": "^3.0.2" 3636 | } 3637 | }, 3638 | "node_modules/minimatch": { 3639 | "version": "3.1.2", 3640 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3641 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3642 | "dev": true, 3643 | "dependencies": { 3644 | "brace-expansion": "^1.1.7" 3645 | }, 3646 | "engines": { 3647 | "node": "*" 3648 | } 3649 | }, 3650 | "node_modules/ms": { 3651 | "version": "2.1.2", 3652 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3653 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3654 | "dev": true 3655 | }, 3656 | "node_modules/nanoid": { 3657 | "version": "3.3.7", 3658 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 3659 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 3660 | "dev": true, 3661 | "funding": [ 3662 | { 3663 | "type": "github", 3664 | "url": "https://github.com/sponsors/ai" 3665 | } 3666 | ], 3667 | "bin": { 3668 | "nanoid": "bin/nanoid.cjs" 3669 | }, 3670 | "engines": { 3671 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 3672 | } 3673 | }, 3674 | "node_modules/natural-compare": { 3675 | "version": "1.4.0", 3676 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3677 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3678 | "dev": true 3679 | }, 3680 | "node_modules/node-releases": { 3681 | "version": "2.0.14", 3682 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", 3683 | "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", 3684 | "dev": true 3685 | }, 3686 | "node_modules/object-assign": { 3687 | "version": "4.1.1", 3688 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 3689 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 3690 | "dev": true, 3691 | "engines": { 3692 | "node": ">=0.10.0" 3693 | } 3694 | }, 3695 | "node_modules/object-inspect": { 3696 | "version": "1.13.1", 3697 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", 3698 | "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", 3699 | "dev": true, 3700 | "funding": { 3701 | "url": "https://github.com/sponsors/ljharb" 3702 | } 3703 | }, 3704 | "node_modules/object-keys": { 3705 | "version": "1.1.1", 3706 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 3707 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 3708 | "dev": true, 3709 | "engines": { 3710 | "node": ">= 0.4" 3711 | } 3712 | }, 3713 | "node_modules/object.assign": { 3714 | "version": "4.1.5", 3715 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", 3716 | "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", 3717 | "dev": true, 3718 | "dependencies": { 3719 | "call-bind": "^1.0.5", 3720 | "define-properties": "^1.2.1", 3721 | "has-symbols": "^1.0.3", 3722 | "object-keys": "^1.1.1" 3723 | }, 3724 | "engines": { 3725 | "node": ">= 0.4" 3726 | }, 3727 | "funding": { 3728 | "url": "https://github.com/sponsors/ljharb" 3729 | } 3730 | }, 3731 | "node_modules/object.entries": { 3732 | "version": "1.1.7", 3733 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.7.tgz", 3734 | "integrity": "sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA==", 3735 | "dev": true, 3736 | "dependencies": { 3737 | "call-bind": "^1.0.2", 3738 | "define-properties": "^1.2.0", 3739 | "es-abstract": "^1.22.1" 3740 | }, 3741 | "engines": { 3742 | "node": ">= 0.4" 3743 | } 3744 | }, 3745 | "node_modules/object.fromentries": { 3746 | "version": "2.0.7", 3747 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz", 3748 | "integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==", 3749 | "dev": true, 3750 | "dependencies": { 3751 | "call-bind": "^1.0.2", 3752 | "define-properties": "^1.2.0", 3753 | "es-abstract": "^1.22.1" 3754 | }, 3755 | "engines": { 3756 | "node": ">= 0.4" 3757 | }, 3758 | "funding": { 3759 | "url": "https://github.com/sponsors/ljharb" 3760 | } 3761 | }, 3762 | "node_modules/object.hasown": { 3763 | "version": "1.1.3", 3764 | "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.3.tgz", 3765 | "integrity": "sha512-fFI4VcYpRHvSLXxP7yiZOMAd331cPfd2p7PFDVbgUsYOfCT3tICVqXWngbjr4m49OvsBwUBQ6O2uQoJvy3RexA==", 3766 | "dev": true, 3767 | "dependencies": { 3768 | "define-properties": "^1.2.0", 3769 | "es-abstract": "^1.22.1" 3770 | }, 3771 | "funding": { 3772 | "url": "https://github.com/sponsors/ljharb" 3773 | } 3774 | }, 3775 | "node_modules/object.values": { 3776 | "version": "1.1.7", 3777 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz", 3778 | "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==", 3779 | "dev": true, 3780 | "dependencies": { 3781 | "call-bind": "^1.0.2", 3782 | "define-properties": "^1.2.0", 3783 | "es-abstract": "^1.22.1" 3784 | }, 3785 | "engines": { 3786 | "node": ">= 0.4" 3787 | }, 3788 | "funding": { 3789 | "url": "https://github.com/sponsors/ljharb" 3790 | } 3791 | }, 3792 | "node_modules/once": { 3793 | "version": "1.4.0", 3794 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3795 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3796 | "dev": true, 3797 | "dependencies": { 3798 | "wrappy": "1" 3799 | } 3800 | }, 3801 | "node_modules/optionator": { 3802 | "version": "0.9.3", 3803 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 3804 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 3805 | "dev": true, 3806 | "dependencies": { 3807 | "@aashutoshrathi/word-wrap": "^1.2.3", 3808 | "deep-is": "^0.1.3", 3809 | "fast-levenshtein": "^2.0.6", 3810 | "levn": "^0.4.1", 3811 | "prelude-ls": "^1.2.1", 3812 | "type-check": "^0.4.0" 3813 | }, 3814 | "engines": { 3815 | "node": ">= 0.8.0" 3816 | } 3817 | }, 3818 | "node_modules/p-limit": { 3819 | "version": "3.1.0", 3820 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3821 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3822 | "dev": true, 3823 | "dependencies": { 3824 | "yocto-queue": "^0.1.0" 3825 | }, 3826 | "engines": { 3827 | "node": ">=10" 3828 | }, 3829 | "funding": { 3830 | "url": "https://github.com/sponsors/sindresorhus" 3831 | } 3832 | }, 3833 | "node_modules/p-locate": { 3834 | "version": "5.0.0", 3835 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3836 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3837 | "dev": true, 3838 | "dependencies": { 3839 | "p-limit": "^3.0.2" 3840 | }, 3841 | "engines": { 3842 | "node": ">=10" 3843 | }, 3844 | "funding": { 3845 | "url": "https://github.com/sponsors/sindresorhus" 3846 | } 3847 | }, 3848 | "node_modules/parent-module": { 3849 | "version": "1.0.1", 3850 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3851 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3852 | "dev": true, 3853 | "dependencies": { 3854 | "callsites": "^3.0.0" 3855 | }, 3856 | "engines": { 3857 | "node": ">=6" 3858 | } 3859 | }, 3860 | "node_modules/path-exists": { 3861 | "version": "4.0.0", 3862 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3863 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3864 | "dev": true, 3865 | "engines": { 3866 | "node": ">=8" 3867 | } 3868 | }, 3869 | "node_modules/path-is-absolute": { 3870 | "version": "1.0.1", 3871 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3872 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3873 | "dev": true, 3874 | "engines": { 3875 | "node": ">=0.10.0" 3876 | } 3877 | }, 3878 | "node_modules/path-key": { 3879 | "version": "3.1.1", 3880 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3881 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3882 | "dev": true, 3883 | "engines": { 3884 | "node": ">=8" 3885 | } 3886 | }, 3887 | "node_modules/path-parse": { 3888 | "version": "1.0.7", 3889 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3890 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3891 | "dev": true 3892 | }, 3893 | "node_modules/picocolors": { 3894 | "version": "1.0.0", 3895 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 3896 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 3897 | "dev": true 3898 | }, 3899 | "node_modules/postcss": { 3900 | "version": "8.4.33", 3901 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.33.tgz", 3902 | "integrity": "sha512-Kkpbhhdjw2qQs2O2DGX+8m5OVqEcbB9HRBvuYM9pgrjEFUg30A9LmXNlTAUj4S9kgtGyrMbTzVjH7E+s5Re2yg==", 3903 | "dev": true, 3904 | "funding": [ 3905 | { 3906 | "type": "opencollective", 3907 | "url": "https://opencollective.com/postcss/" 3908 | }, 3909 | { 3910 | "type": "tidelift", 3911 | "url": "https://tidelift.com/funding/github/npm/postcss" 3912 | }, 3913 | { 3914 | "type": "github", 3915 | "url": "https://github.com/sponsors/ai" 3916 | } 3917 | ], 3918 | "dependencies": { 3919 | "nanoid": "^3.3.7", 3920 | "picocolors": "^1.0.0", 3921 | "source-map-js": "^1.0.2" 3922 | }, 3923 | "engines": { 3924 | "node": "^10 || ^12 || >=14" 3925 | } 3926 | }, 3927 | "node_modules/prelude-ls": { 3928 | "version": "1.2.1", 3929 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3930 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3931 | "dev": true, 3932 | "engines": { 3933 | "node": ">= 0.8.0" 3934 | } 3935 | }, 3936 | "node_modules/prop-types": { 3937 | "version": "15.8.1", 3938 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", 3939 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", 3940 | "dev": true, 3941 | "dependencies": { 3942 | "loose-envify": "^1.4.0", 3943 | "object-assign": "^4.1.1", 3944 | "react-is": "^16.13.1" 3945 | } 3946 | }, 3947 | "node_modules/protobufjs": { 3948 | "version": "7.2.5", 3949 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-7.2.5.tgz", 3950 | "integrity": "sha512-gGXRSXvxQ7UiPgfw8gevrfRWcTlSbOFg+p/N+JVJEK5VhueL2miT6qTymqAmjr1Q5WbOCyJbyrk6JfWKwlFn6A==", 3951 | "hasInstallScript": true, 3952 | "dependencies": { 3953 | "@protobufjs/aspromise": "^1.1.2", 3954 | "@protobufjs/base64": "^1.1.2", 3955 | "@protobufjs/codegen": "^2.0.4", 3956 | "@protobufjs/eventemitter": "^1.1.0", 3957 | "@protobufjs/fetch": "^1.1.0", 3958 | "@protobufjs/float": "^1.0.2", 3959 | "@protobufjs/inquire": "^1.1.0", 3960 | "@protobufjs/path": "^1.1.2", 3961 | "@protobufjs/pool": "^1.1.0", 3962 | "@protobufjs/utf8": "^1.1.0", 3963 | "@types/node": ">=13.7.0", 3964 | "long": "^5.0.0" 3965 | }, 3966 | "engines": { 3967 | "node": ">=12.0.0" 3968 | } 3969 | }, 3970 | "node_modules/punycode": { 3971 | "version": "2.3.1", 3972 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 3973 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 3974 | "dev": true, 3975 | "engines": { 3976 | "node": ">=6" 3977 | } 3978 | }, 3979 | "node_modules/queue-microtask": { 3980 | "version": "1.2.3", 3981 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3982 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3983 | "dev": true, 3984 | "funding": [ 3985 | { 3986 | "type": "github", 3987 | "url": "https://github.com/sponsors/feross" 3988 | }, 3989 | { 3990 | "type": "patreon", 3991 | "url": "https://www.patreon.com/feross" 3992 | }, 3993 | { 3994 | "type": "consulting", 3995 | "url": "https://feross.org/support" 3996 | } 3997 | ] 3998 | }, 3999 | "node_modules/react": { 4000 | "version": "18.2.0", 4001 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 4002 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 4003 | "dependencies": { 4004 | "loose-envify": "^1.1.0" 4005 | }, 4006 | "engines": { 4007 | "node": ">=0.10.0" 4008 | } 4009 | }, 4010 | "node_modules/react-dom": { 4011 | "version": "18.2.0", 4012 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 4013 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 4014 | "dependencies": { 4015 | "loose-envify": "^1.1.0", 4016 | "scheduler": "^0.23.0" 4017 | }, 4018 | "peerDependencies": { 4019 | "react": "^18.2.0" 4020 | } 4021 | }, 4022 | "node_modules/react-is": { 4023 | "version": "16.13.1", 4024 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 4025 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", 4026 | "dev": true 4027 | }, 4028 | "node_modules/react-refresh": { 4029 | "version": "0.14.0", 4030 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 4031 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 4032 | "dev": true, 4033 | "engines": { 4034 | "node": ">=0.10.0" 4035 | } 4036 | }, 4037 | "node_modules/reflect.getprototypeof": { 4038 | "version": "1.0.4", 4039 | "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.4.tgz", 4040 | "integrity": "sha512-ECkTw8TmJwW60lOTR+ZkODISW6RQ8+2CL3COqtiJKLd6MmB45hN51HprHFziKLGkAuTGQhBb91V8cy+KHlaCjw==", 4041 | "dev": true, 4042 | "dependencies": { 4043 | "call-bind": "^1.0.2", 4044 | "define-properties": "^1.2.0", 4045 | "es-abstract": "^1.22.1", 4046 | "get-intrinsic": "^1.2.1", 4047 | "globalthis": "^1.0.3", 4048 | "which-builtin-type": "^1.1.3" 4049 | }, 4050 | "engines": { 4051 | "node": ">= 0.4" 4052 | }, 4053 | "funding": { 4054 | "url": "https://github.com/sponsors/ljharb" 4055 | } 4056 | }, 4057 | "node_modules/regexp.prototype.flags": { 4058 | "version": "1.5.1", 4059 | "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", 4060 | "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", 4061 | "dev": true, 4062 | "dependencies": { 4063 | "call-bind": "^1.0.2", 4064 | "define-properties": "^1.2.0", 4065 | "set-function-name": "^2.0.0" 4066 | }, 4067 | "engines": { 4068 | "node": ">= 0.4" 4069 | }, 4070 | "funding": { 4071 | "url": "https://github.com/sponsors/ljharb" 4072 | } 4073 | }, 4074 | "node_modules/require-directory": { 4075 | "version": "2.1.1", 4076 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 4077 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 4078 | "engines": { 4079 | "node": ">=0.10.0" 4080 | } 4081 | }, 4082 | "node_modules/resolve": { 4083 | "version": "2.0.0-next.5", 4084 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", 4085 | "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", 4086 | "dev": true, 4087 | "dependencies": { 4088 | "is-core-module": "^2.13.0", 4089 | "path-parse": "^1.0.7", 4090 | "supports-preserve-symlinks-flag": "^1.0.0" 4091 | }, 4092 | "bin": { 4093 | "resolve": "bin/resolve" 4094 | }, 4095 | "funding": { 4096 | "url": "https://github.com/sponsors/ljharb" 4097 | } 4098 | }, 4099 | "node_modules/resolve-from": { 4100 | "version": "4.0.0", 4101 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 4102 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 4103 | "dev": true, 4104 | "engines": { 4105 | "node": ">=4" 4106 | } 4107 | }, 4108 | "node_modules/reusify": { 4109 | "version": "1.0.4", 4110 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 4111 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 4112 | "dev": true, 4113 | "engines": { 4114 | "iojs": ">=1.0.0", 4115 | "node": ">=0.10.0" 4116 | } 4117 | }, 4118 | "node_modules/rimraf": { 4119 | "version": "3.0.2", 4120 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 4121 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 4122 | "dev": true, 4123 | "dependencies": { 4124 | "glob": "^7.1.3" 4125 | }, 4126 | "bin": { 4127 | "rimraf": "bin.js" 4128 | }, 4129 | "funding": { 4130 | "url": "https://github.com/sponsors/isaacs" 4131 | } 4132 | }, 4133 | "node_modules/rollup": { 4134 | "version": "4.9.5", 4135 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.5.tgz", 4136 | "integrity": "sha512-E4vQW0H/mbNMw2yLSqJyjtkHY9dslf/p0zuT1xehNRqUTBOFMqEjguDvqhXr7N7r/4ttb2jr4T41d3dncmIgbQ==", 4137 | "dev": true, 4138 | "dependencies": { 4139 | "@types/estree": "1.0.5" 4140 | }, 4141 | "bin": { 4142 | "rollup": "dist/bin/rollup" 4143 | }, 4144 | "engines": { 4145 | "node": ">=18.0.0", 4146 | "npm": ">=8.0.0" 4147 | }, 4148 | "optionalDependencies": { 4149 | "@rollup/rollup-android-arm-eabi": "4.9.5", 4150 | "@rollup/rollup-android-arm64": "4.9.5", 4151 | "@rollup/rollup-darwin-arm64": "4.9.5", 4152 | "@rollup/rollup-darwin-x64": "4.9.5", 4153 | "@rollup/rollup-linux-arm-gnueabihf": "4.9.5", 4154 | "@rollup/rollup-linux-arm64-gnu": "4.9.5", 4155 | "@rollup/rollup-linux-arm64-musl": "4.9.5", 4156 | "@rollup/rollup-linux-riscv64-gnu": "4.9.5", 4157 | "@rollup/rollup-linux-x64-gnu": "4.9.5", 4158 | "@rollup/rollup-linux-x64-musl": "4.9.5", 4159 | "@rollup/rollup-win32-arm64-msvc": "4.9.5", 4160 | "@rollup/rollup-win32-ia32-msvc": "4.9.5", 4161 | "@rollup/rollup-win32-x64-msvc": "4.9.5", 4162 | "fsevents": "~2.3.2" 4163 | } 4164 | }, 4165 | "node_modules/run-parallel": { 4166 | "version": "1.2.0", 4167 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 4168 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 4169 | "dev": true, 4170 | "funding": [ 4171 | { 4172 | "type": "github", 4173 | "url": "https://github.com/sponsors/feross" 4174 | }, 4175 | { 4176 | "type": "patreon", 4177 | "url": "https://www.patreon.com/feross" 4178 | }, 4179 | { 4180 | "type": "consulting", 4181 | "url": "https://feross.org/support" 4182 | } 4183 | ], 4184 | "dependencies": { 4185 | "queue-microtask": "^1.2.2" 4186 | } 4187 | }, 4188 | "node_modules/safe-array-concat": { 4189 | "version": "1.1.0", 4190 | "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.0.tgz", 4191 | "integrity": "sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==", 4192 | "dev": true, 4193 | "dependencies": { 4194 | "call-bind": "^1.0.5", 4195 | "get-intrinsic": "^1.2.2", 4196 | "has-symbols": "^1.0.3", 4197 | "isarray": "^2.0.5" 4198 | }, 4199 | "engines": { 4200 | "node": ">=0.4" 4201 | }, 4202 | "funding": { 4203 | "url": "https://github.com/sponsors/ljharb" 4204 | } 4205 | }, 4206 | "node_modules/safe-buffer": { 4207 | "version": "5.2.1", 4208 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 4209 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 4210 | "funding": [ 4211 | { 4212 | "type": "github", 4213 | "url": "https://github.com/sponsors/feross" 4214 | }, 4215 | { 4216 | "type": "patreon", 4217 | "url": "https://www.patreon.com/feross" 4218 | }, 4219 | { 4220 | "type": "consulting", 4221 | "url": "https://feross.org/support" 4222 | } 4223 | ] 4224 | }, 4225 | "node_modules/safe-regex-test": { 4226 | "version": "1.0.2", 4227 | "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.2.tgz", 4228 | "integrity": "sha512-83S9w6eFq12BBIJYvjMux6/dkirb8+4zJRA9cxNBVb7Wq5fJBW+Xze48WqR8pxua7bDuAaaAxtVVd4Idjp1dBQ==", 4229 | "dev": true, 4230 | "dependencies": { 4231 | "call-bind": "^1.0.5", 4232 | "get-intrinsic": "^1.2.2", 4233 | "is-regex": "^1.1.4" 4234 | }, 4235 | "engines": { 4236 | "node": ">= 0.4" 4237 | }, 4238 | "funding": { 4239 | "url": "https://github.com/sponsors/ljharb" 4240 | } 4241 | }, 4242 | "node_modules/scheduler": { 4243 | "version": "0.23.0", 4244 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 4245 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 4246 | "dependencies": { 4247 | "loose-envify": "^1.1.0" 4248 | } 4249 | }, 4250 | "node_modules/semver": { 4251 | "version": "6.3.1", 4252 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 4253 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 4254 | "dev": true, 4255 | "bin": { 4256 | "semver": "bin/semver.js" 4257 | } 4258 | }, 4259 | "node_modules/set-function-length": { 4260 | "version": "1.2.0", 4261 | "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.0.tgz", 4262 | "integrity": "sha512-4DBHDoyHlM1IRPGYcoxexgh67y4ueR53FKV1yyxwFMY7aCqcN/38M1+SwZ/qJQ8iLv7+ck385ot4CcisOAPT9w==", 4263 | "dev": true, 4264 | "dependencies": { 4265 | "define-data-property": "^1.1.1", 4266 | "function-bind": "^1.1.2", 4267 | "get-intrinsic": "^1.2.2", 4268 | "gopd": "^1.0.1", 4269 | "has-property-descriptors": "^1.0.1" 4270 | }, 4271 | "engines": { 4272 | "node": ">= 0.4" 4273 | } 4274 | }, 4275 | "node_modules/set-function-name": { 4276 | "version": "2.0.1", 4277 | "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", 4278 | "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", 4279 | "dev": true, 4280 | "dependencies": { 4281 | "define-data-property": "^1.0.1", 4282 | "functions-have-names": "^1.2.3", 4283 | "has-property-descriptors": "^1.0.0" 4284 | }, 4285 | "engines": { 4286 | "node": ">= 0.4" 4287 | } 4288 | }, 4289 | "node_modules/shebang-command": { 4290 | "version": "2.0.0", 4291 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 4292 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 4293 | "dev": true, 4294 | "dependencies": { 4295 | "shebang-regex": "^3.0.0" 4296 | }, 4297 | "engines": { 4298 | "node": ">=8" 4299 | } 4300 | }, 4301 | "node_modules/shebang-regex": { 4302 | "version": "3.0.0", 4303 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 4304 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 4305 | "dev": true, 4306 | "engines": { 4307 | "node": ">=8" 4308 | } 4309 | }, 4310 | "node_modules/side-channel": { 4311 | "version": "1.0.4", 4312 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 4313 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 4314 | "dev": true, 4315 | "dependencies": { 4316 | "call-bind": "^1.0.0", 4317 | "get-intrinsic": "^1.0.2", 4318 | "object-inspect": "^1.9.0" 4319 | }, 4320 | "funding": { 4321 | "url": "https://github.com/sponsors/ljharb" 4322 | } 4323 | }, 4324 | "node_modules/source-map-js": { 4325 | "version": "1.0.2", 4326 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 4327 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 4328 | "dev": true, 4329 | "engines": { 4330 | "node": ">=0.10.0" 4331 | } 4332 | }, 4333 | "node_modules/string-width": { 4334 | "version": "4.2.3", 4335 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 4336 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 4337 | "dependencies": { 4338 | "emoji-regex": "^8.0.0", 4339 | "is-fullwidth-code-point": "^3.0.0", 4340 | "strip-ansi": "^6.0.1" 4341 | }, 4342 | "engines": { 4343 | "node": ">=8" 4344 | } 4345 | }, 4346 | "node_modules/string.prototype.matchall": { 4347 | "version": "4.0.10", 4348 | "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.10.tgz", 4349 | "integrity": "sha512-rGXbGmOEosIQi6Qva94HUjgPs9vKW+dkG7Y8Q5O2OYkWL6wFaTRZO8zM4mhP94uX55wgyrXzfS2aGtGzUL7EJQ==", 4350 | "dev": true, 4351 | "dependencies": { 4352 | "call-bind": "^1.0.2", 4353 | "define-properties": "^1.2.0", 4354 | "es-abstract": "^1.22.1", 4355 | "get-intrinsic": "^1.2.1", 4356 | "has-symbols": "^1.0.3", 4357 | "internal-slot": "^1.0.5", 4358 | "regexp.prototype.flags": "^1.5.0", 4359 | "set-function-name": "^2.0.0", 4360 | "side-channel": "^1.0.4" 4361 | }, 4362 | "funding": { 4363 | "url": "https://github.com/sponsors/ljharb" 4364 | } 4365 | }, 4366 | "node_modules/string.prototype.trim": { 4367 | "version": "1.2.8", 4368 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", 4369 | "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", 4370 | "dev": true, 4371 | "dependencies": { 4372 | "call-bind": "^1.0.2", 4373 | "define-properties": "^1.2.0", 4374 | "es-abstract": "^1.22.1" 4375 | }, 4376 | "engines": { 4377 | "node": ">= 0.4" 4378 | }, 4379 | "funding": { 4380 | "url": "https://github.com/sponsors/ljharb" 4381 | } 4382 | }, 4383 | "node_modules/string.prototype.trimend": { 4384 | "version": "1.0.7", 4385 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", 4386 | "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", 4387 | "dev": true, 4388 | "dependencies": { 4389 | "call-bind": "^1.0.2", 4390 | "define-properties": "^1.2.0", 4391 | "es-abstract": "^1.22.1" 4392 | }, 4393 | "funding": { 4394 | "url": "https://github.com/sponsors/ljharb" 4395 | } 4396 | }, 4397 | "node_modules/string.prototype.trimstart": { 4398 | "version": "1.0.7", 4399 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", 4400 | "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", 4401 | "dev": true, 4402 | "dependencies": { 4403 | "call-bind": "^1.0.2", 4404 | "define-properties": "^1.2.0", 4405 | "es-abstract": "^1.22.1" 4406 | }, 4407 | "funding": { 4408 | "url": "https://github.com/sponsors/ljharb" 4409 | } 4410 | }, 4411 | "node_modules/strip-ansi": { 4412 | "version": "6.0.1", 4413 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 4414 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 4415 | "dependencies": { 4416 | "ansi-regex": "^5.0.1" 4417 | }, 4418 | "engines": { 4419 | "node": ">=8" 4420 | } 4421 | }, 4422 | "node_modules/strip-json-comments": { 4423 | "version": "3.1.1", 4424 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 4425 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 4426 | "dev": true, 4427 | "engines": { 4428 | "node": ">=8" 4429 | }, 4430 | "funding": { 4431 | "url": "https://github.com/sponsors/sindresorhus" 4432 | } 4433 | }, 4434 | "node_modules/supports-color": { 4435 | "version": "5.5.0", 4436 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 4437 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 4438 | "dev": true, 4439 | "dependencies": { 4440 | "has-flag": "^3.0.0" 4441 | }, 4442 | "engines": { 4443 | "node": ">=4" 4444 | } 4445 | }, 4446 | "node_modules/supports-preserve-symlinks-flag": { 4447 | "version": "1.0.0", 4448 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 4449 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 4450 | "dev": true, 4451 | "engines": { 4452 | "node": ">= 0.4" 4453 | }, 4454 | "funding": { 4455 | "url": "https://github.com/sponsors/ljharb" 4456 | } 4457 | }, 4458 | "node_modules/text-table": { 4459 | "version": "0.2.0", 4460 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 4461 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 4462 | "dev": true 4463 | }, 4464 | "node_modules/to-fast-properties": { 4465 | "version": "2.0.0", 4466 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 4467 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 4468 | "dev": true, 4469 | "engines": { 4470 | "node": ">=4" 4471 | } 4472 | }, 4473 | "node_modules/tslib": { 4474 | "version": "2.6.2", 4475 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 4476 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" 4477 | }, 4478 | "node_modules/type-check": { 4479 | "version": "0.4.0", 4480 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 4481 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 4482 | "dev": true, 4483 | "dependencies": { 4484 | "prelude-ls": "^1.2.1" 4485 | }, 4486 | "engines": { 4487 | "node": ">= 0.8.0" 4488 | } 4489 | }, 4490 | "node_modules/type-fest": { 4491 | "version": "0.20.2", 4492 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 4493 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 4494 | "dev": true, 4495 | "engines": { 4496 | "node": ">=10" 4497 | }, 4498 | "funding": { 4499 | "url": "https://github.com/sponsors/sindresorhus" 4500 | } 4501 | }, 4502 | "node_modules/typed-array-buffer": { 4503 | "version": "1.0.0", 4504 | "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", 4505 | "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", 4506 | "dev": true, 4507 | "dependencies": { 4508 | "call-bind": "^1.0.2", 4509 | "get-intrinsic": "^1.2.1", 4510 | "is-typed-array": "^1.1.10" 4511 | }, 4512 | "engines": { 4513 | "node": ">= 0.4" 4514 | } 4515 | }, 4516 | "node_modules/typed-array-byte-length": { 4517 | "version": "1.0.0", 4518 | "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", 4519 | "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", 4520 | "dev": true, 4521 | "dependencies": { 4522 | "call-bind": "^1.0.2", 4523 | "for-each": "^0.3.3", 4524 | "has-proto": "^1.0.1", 4525 | "is-typed-array": "^1.1.10" 4526 | }, 4527 | "engines": { 4528 | "node": ">= 0.4" 4529 | }, 4530 | "funding": { 4531 | "url": "https://github.com/sponsors/ljharb" 4532 | } 4533 | }, 4534 | "node_modules/typed-array-byte-offset": { 4535 | "version": "1.0.0", 4536 | "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", 4537 | "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", 4538 | "dev": true, 4539 | "dependencies": { 4540 | "available-typed-arrays": "^1.0.5", 4541 | "call-bind": "^1.0.2", 4542 | "for-each": "^0.3.3", 4543 | "has-proto": "^1.0.1", 4544 | "is-typed-array": "^1.1.10" 4545 | }, 4546 | "engines": { 4547 | "node": ">= 0.4" 4548 | }, 4549 | "funding": { 4550 | "url": "https://github.com/sponsors/ljharb" 4551 | } 4552 | }, 4553 | "node_modules/typed-array-length": { 4554 | "version": "1.0.4", 4555 | "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", 4556 | "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", 4557 | "dev": true, 4558 | "dependencies": { 4559 | "call-bind": "^1.0.2", 4560 | "for-each": "^0.3.3", 4561 | "is-typed-array": "^1.1.9" 4562 | }, 4563 | "funding": { 4564 | "url": "https://github.com/sponsors/ljharb" 4565 | } 4566 | }, 4567 | "node_modules/unbox-primitive": { 4568 | "version": "1.0.2", 4569 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", 4570 | "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", 4571 | "dev": true, 4572 | "dependencies": { 4573 | "call-bind": "^1.0.2", 4574 | "has-bigints": "^1.0.2", 4575 | "has-symbols": "^1.0.3", 4576 | "which-boxed-primitive": "^1.0.2" 4577 | }, 4578 | "funding": { 4579 | "url": "https://github.com/sponsors/ljharb" 4580 | } 4581 | }, 4582 | "node_modules/undici": { 4583 | "version": "5.26.5", 4584 | "resolved": "https://registry.npmjs.org/undici/-/undici-5.26.5.tgz", 4585 | "integrity": "sha512-cSb4bPFd5qgR7qr2jYAi0hlX9n5YKK2ONKkLFkxl+v/9BvC0sOpZjBHDBSXc5lWAf5ty9oZdRXytBIHzgUcerw==", 4586 | "dependencies": { 4587 | "@fastify/busboy": "^2.0.0" 4588 | }, 4589 | "engines": { 4590 | "node": ">=14.0" 4591 | } 4592 | }, 4593 | "node_modules/undici-types": { 4594 | "version": "5.26.5", 4595 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 4596 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==" 4597 | }, 4598 | "node_modules/update-browserslist-db": { 4599 | "version": "1.0.13", 4600 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", 4601 | "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", 4602 | "dev": true, 4603 | "funding": [ 4604 | { 4605 | "type": "opencollective", 4606 | "url": "https://opencollective.com/browserslist" 4607 | }, 4608 | { 4609 | "type": "tidelift", 4610 | "url": "https://tidelift.com/funding/github/npm/browserslist" 4611 | }, 4612 | { 4613 | "type": "github", 4614 | "url": "https://github.com/sponsors/ai" 4615 | } 4616 | ], 4617 | "dependencies": { 4618 | "escalade": "^3.1.1", 4619 | "picocolors": "^1.0.0" 4620 | }, 4621 | "bin": { 4622 | "update-browserslist-db": "cli.js" 4623 | }, 4624 | "peerDependencies": { 4625 | "browserslist": ">= 4.21.0" 4626 | } 4627 | }, 4628 | "node_modules/uri-js": { 4629 | "version": "4.4.1", 4630 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 4631 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 4632 | "dev": true, 4633 | "dependencies": { 4634 | "punycode": "^2.1.0" 4635 | } 4636 | }, 4637 | "node_modules/vite": { 4638 | "version": "5.0.11", 4639 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.0.11.tgz", 4640 | "integrity": "sha512-XBMnDjZcNAw/G1gEiskiM1v6yzM4GE5aMGvhWTlHAYYhxb7S3/V1s3m2LDHa8Vh6yIWYYB0iJwsEaS523c4oYA==", 4641 | "dev": true, 4642 | "dependencies": { 4643 | "esbuild": "^0.19.3", 4644 | "postcss": "^8.4.32", 4645 | "rollup": "^4.2.0" 4646 | }, 4647 | "bin": { 4648 | "vite": "bin/vite.js" 4649 | }, 4650 | "engines": { 4651 | "node": "^18.0.0 || >=20.0.0" 4652 | }, 4653 | "funding": { 4654 | "url": "https://github.com/vitejs/vite?sponsor=1" 4655 | }, 4656 | "optionalDependencies": { 4657 | "fsevents": "~2.3.3" 4658 | }, 4659 | "peerDependencies": { 4660 | "@types/node": "^18.0.0 || >=20.0.0", 4661 | "less": "*", 4662 | "lightningcss": "^1.21.0", 4663 | "sass": "*", 4664 | "stylus": "*", 4665 | "sugarss": "*", 4666 | "terser": "^5.4.0" 4667 | }, 4668 | "peerDependenciesMeta": { 4669 | "@types/node": { 4670 | "optional": true 4671 | }, 4672 | "less": { 4673 | "optional": true 4674 | }, 4675 | "lightningcss": { 4676 | "optional": true 4677 | }, 4678 | "sass": { 4679 | "optional": true 4680 | }, 4681 | "stylus": { 4682 | "optional": true 4683 | }, 4684 | "sugarss": { 4685 | "optional": true 4686 | }, 4687 | "terser": { 4688 | "optional": true 4689 | } 4690 | } 4691 | }, 4692 | "node_modules/websocket-driver": { 4693 | "version": "0.7.4", 4694 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 4695 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 4696 | "dependencies": { 4697 | "http-parser-js": ">=0.5.1", 4698 | "safe-buffer": ">=5.1.0", 4699 | "websocket-extensions": ">=0.1.1" 4700 | }, 4701 | "engines": { 4702 | "node": ">=0.8.0" 4703 | } 4704 | }, 4705 | "node_modules/websocket-extensions": { 4706 | "version": "0.1.4", 4707 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 4708 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", 4709 | "engines": { 4710 | "node": ">=0.8.0" 4711 | } 4712 | }, 4713 | "node_modules/which": { 4714 | "version": "2.0.2", 4715 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 4716 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 4717 | "dev": true, 4718 | "dependencies": { 4719 | "isexe": "^2.0.0" 4720 | }, 4721 | "bin": { 4722 | "node-which": "bin/node-which" 4723 | }, 4724 | "engines": { 4725 | "node": ">= 8" 4726 | } 4727 | }, 4728 | "node_modules/which-boxed-primitive": { 4729 | "version": "1.0.2", 4730 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 4731 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 4732 | "dev": true, 4733 | "dependencies": { 4734 | "is-bigint": "^1.0.1", 4735 | "is-boolean-object": "^1.1.0", 4736 | "is-number-object": "^1.0.4", 4737 | "is-string": "^1.0.5", 4738 | "is-symbol": "^1.0.3" 4739 | }, 4740 | "funding": { 4741 | "url": "https://github.com/sponsors/ljharb" 4742 | } 4743 | }, 4744 | "node_modules/which-builtin-type": { 4745 | "version": "1.1.3", 4746 | "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.3.tgz", 4747 | "integrity": "sha512-YmjsSMDBYsM1CaFiayOVT06+KJeXf0o5M/CAd4o1lTadFAtacTUM49zoYxr/oroopFDfhvN6iEcBxUyc3gvKmw==", 4748 | "dev": true, 4749 | "dependencies": { 4750 | "function.prototype.name": "^1.1.5", 4751 | "has-tostringtag": "^1.0.0", 4752 | "is-async-function": "^2.0.0", 4753 | "is-date-object": "^1.0.5", 4754 | "is-finalizationregistry": "^1.0.2", 4755 | "is-generator-function": "^1.0.10", 4756 | "is-regex": "^1.1.4", 4757 | "is-weakref": "^1.0.2", 4758 | "isarray": "^2.0.5", 4759 | "which-boxed-primitive": "^1.0.2", 4760 | "which-collection": "^1.0.1", 4761 | "which-typed-array": "^1.1.9" 4762 | }, 4763 | "engines": { 4764 | "node": ">= 0.4" 4765 | }, 4766 | "funding": { 4767 | "url": "https://github.com/sponsors/ljharb" 4768 | } 4769 | }, 4770 | "node_modules/which-collection": { 4771 | "version": "1.0.1", 4772 | "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.1.tgz", 4773 | "integrity": "sha512-W8xeTUwaln8i3K/cY1nGXzdnVZlidBcagyNFtBdD5kxnb4TvGKR7FfSIS3mYpwWS1QUCutfKz8IY8RjftB0+1A==", 4774 | "dev": true, 4775 | "dependencies": { 4776 | "is-map": "^2.0.1", 4777 | "is-set": "^2.0.1", 4778 | "is-weakmap": "^2.0.1", 4779 | "is-weakset": "^2.0.1" 4780 | }, 4781 | "funding": { 4782 | "url": "https://github.com/sponsors/ljharb" 4783 | } 4784 | }, 4785 | "node_modules/which-typed-array": { 4786 | "version": "1.1.13", 4787 | "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz", 4788 | "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==", 4789 | "dev": true, 4790 | "dependencies": { 4791 | "available-typed-arrays": "^1.0.5", 4792 | "call-bind": "^1.0.4", 4793 | "for-each": "^0.3.3", 4794 | "gopd": "^1.0.1", 4795 | "has-tostringtag": "^1.0.0" 4796 | }, 4797 | "engines": { 4798 | "node": ">= 0.4" 4799 | }, 4800 | "funding": { 4801 | "url": "https://github.com/sponsors/ljharb" 4802 | } 4803 | }, 4804 | "node_modules/wrap-ansi": { 4805 | "version": "7.0.0", 4806 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 4807 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 4808 | "dependencies": { 4809 | "ansi-styles": "^4.0.0", 4810 | "string-width": "^4.1.0", 4811 | "strip-ansi": "^6.0.0" 4812 | }, 4813 | "engines": { 4814 | "node": ">=10" 4815 | }, 4816 | "funding": { 4817 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 4818 | } 4819 | }, 4820 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 4821 | "version": "4.3.0", 4822 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 4823 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 4824 | "dependencies": { 4825 | "color-convert": "^2.0.1" 4826 | }, 4827 | "engines": { 4828 | "node": ">=8" 4829 | }, 4830 | "funding": { 4831 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 4832 | } 4833 | }, 4834 | "node_modules/wrap-ansi/node_modules/color-convert": { 4835 | "version": "2.0.1", 4836 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 4837 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 4838 | "dependencies": { 4839 | "color-name": "~1.1.4" 4840 | }, 4841 | "engines": { 4842 | "node": ">=7.0.0" 4843 | } 4844 | }, 4845 | "node_modules/wrap-ansi/node_modules/color-name": { 4846 | "version": "1.1.4", 4847 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 4848 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 4849 | }, 4850 | "node_modules/wrappy": { 4851 | "version": "1.0.2", 4852 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4853 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 4854 | "dev": true 4855 | }, 4856 | "node_modules/y18n": { 4857 | "version": "5.0.8", 4858 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 4859 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 4860 | "engines": { 4861 | "node": ">=10" 4862 | } 4863 | }, 4864 | "node_modules/yallist": { 4865 | "version": "3.1.1", 4866 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 4867 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 4868 | "dev": true 4869 | }, 4870 | "node_modules/yargs": { 4871 | "version": "17.7.2", 4872 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 4873 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 4874 | "dependencies": { 4875 | "cliui": "^8.0.1", 4876 | "escalade": "^3.1.1", 4877 | "get-caller-file": "^2.0.5", 4878 | "require-directory": "^2.1.1", 4879 | "string-width": "^4.2.3", 4880 | "y18n": "^5.0.5", 4881 | "yargs-parser": "^21.1.1" 4882 | }, 4883 | "engines": { 4884 | "node": ">=12" 4885 | } 4886 | }, 4887 | "node_modules/yargs-parser": { 4888 | "version": "21.1.1", 4889 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 4890 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 4891 | "engines": { 4892 | "node": ">=12" 4893 | } 4894 | }, 4895 | "node_modules/yocto-queue": { 4896 | "version": "0.1.0", 4897 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4898 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4899 | "dev": true, 4900 | "engines": { 4901 | "node": ">=10" 4902 | }, 4903 | "funding": { 4904 | "url": "https://github.com/sponsors/sindresorhus" 4905 | } 4906 | } 4907 | } 4908 | } 4909 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-firebase-auth-db-template", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "lint": "eslint . --ext js,jsx --report-unused-disable-directives --max-warnings 0", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "firebase": "^10.7.1", 14 | "react": "^18.2.0", 15 | "react-dom": "^18.2.0" 16 | }, 17 | "devDependencies": { 18 | "@types/react": "^18.2.43", 19 | "@types/react-dom": "^18.2.17", 20 | "@vitejs/plugin-react": "^4.2.1", 21 | "eslint": "^8.55.0", 22 | "eslint-plugin-react": "^7.33.2", 23 | "eslint-plugin-react-hooks": "^4.6.0", 24 | "eslint-plugin-react-refresh": "^0.4.5", 25 | "vite": "^5.0.8" 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/jamezmca/react-firebase-auth-db-template/0661665315aeeaa845950316ba8871380c5b6d7c/src/App.css -------------------------------------------------------------------------------- /src/App.jsx: -------------------------------------------------------------------------------- 1 | import { useAuth } from './context/AuthContext' 2 | import Login from './components/Login' 3 | import Dashboard from './components/Dashboard' 4 | 5 | function App() { 6 | const { currentUser } = useAuth() 7 | return ( 8 |
9 | {currentUser ? ( 10 | 11 | ) : ( 12 | 13 | )} 14 |
15 | ) 16 | } 17 | 18 | export default App 19 | -------------------------------------------------------------------------------- /src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/components/Dashboard.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react' 2 | import { doc, increment, serverTimestamp, setDoc } from "firebase/firestore"; 3 | import { useAuth } from '../context/AuthContext' 4 | import { db } from '../../firebase'; 5 | 6 | export default function Dashboard() { 7 | const { logout, currentUser } = useAuth() 8 | 9 | async function handleIncrement() { 10 | const userRef = doc(db, 'users', currentUser.uid); 11 | await setDoc(userRef, { counter: increment(1), timestamp: serverTimestamp() }, { merge: true }); 12 | } 13 | 14 | return ( 15 |
16 |

hello world & welcome to the dashboard

17 | 18 | 19 |
20 | ) 21 | } 22 | -------------------------------------------------------------------------------- /src/components/Login.jsx: -------------------------------------------------------------------------------- 1 | import React, { useState } from 'react' 2 | import { useAuth } from '../context/AuthContext' 3 | 4 | export default function Login() { 5 | const [createAccount, setCreateAccount] = useState(false) 6 | const [userCreds, setUserCreds] = useState({ email: '', password: '' }) 7 | 8 | const { signUp, login } = useAuth() 9 | 10 | function updateEmail(e) { 11 | setUserCreds({ ...userCreds, email: e.target.value }) 12 | } 13 | 14 | function updatePassword(e) { 15 | setUserCreds({ ...userCreds, password: e.target.value }) 16 | } 17 | 18 | function handleSubmit(e) { 19 | e.preventDefault() 20 | // prevents signup if form not completed 21 | if (!userCreds.email || !userCreds.password) { return } 22 | 23 | if (createAccount) { 24 | // recommended to add password regex check in here 25 | console.log('Registering') 26 | signUp(userCreds.email, userCreds.password) 27 | } else { 28 | console.log('Logging in') 29 | login(userCreds.email, userCreds.password) 30 | } 31 | } 32 | 33 | return ( 34 |
35 | { 36 | updateEmail(e) 37 | }}> 38 | { 39 | updatePassword(e) 40 | }}> 41 | 44 | 47 |
48 | ) 49 | } 50 | -------------------------------------------------------------------------------- /src/context/AuthContext.jsx: -------------------------------------------------------------------------------- 1 | import React, { useContext, useState, useEffect } from 'react' 2 | import { auth, db } from '../../firebase' 3 | import { signInWithEmailAndPassword, createUserWithEmailAndPassword, signOut, onAuthStateChanged } from 'firebase/auth' 4 | 5 | const AuthContext = React.createContext() 6 | 7 | export function useAuth() { 8 | return useContext(AuthContext) 9 | } 10 | 11 | export function AuthProvider({ children }) { 12 | 13 | const [currentUser, setCurrentUser] = useState(null) 14 | 15 | function signUp(email, password) { 16 | return createUserWithEmailAndPassword(auth, email, password) 17 | } 18 | 19 | function login(email, password) { 20 | return signInWithEmailAndPassword(auth, email, password) 21 | } 22 | 23 | function logout() { 24 | return signOut(auth) 25 | } 26 | 27 | useEffect(() => { 28 | const unsubscribe = onAuthStateChanged(auth, user => { 29 | setCurrentUser(user) 30 | }) 31 | return unsubscribe 32 | }, []) 33 | 34 | const value = { 35 | currentUser, 36 | signUp, 37 | logout, 38 | login 39 | } 40 | 41 | return ( 42 | 43 | {children} 44 | 45 | ) 46 | 47 | } -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/jamezmca/react-firebase-auth-db-template/0661665315aeeaa845950316ba8871380c5b6d7c/src/index.css -------------------------------------------------------------------------------- /src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react' 2 | import ReactDOM from 'react-dom/client' 3 | import App from './App.jsx' 4 | import { AuthProvider } from './context/AuthContext.jsx' 5 | 6 | ReactDOM.createRoot(document.getElementById('root')).render( 7 | 8 | 9 | 10 | 11 | , 12 | ) 13 | -------------------------------------------------------------------------------- /vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()], 7 | }) 8 | --------------------------------------------------------------------------------