├── .firebaserc ├── .gitignore ├── README.md ├── firebase.json ├── firestore.indexes.json ├── firestore.rules ├── functions ├── .gitignore ├── index.js ├── package-lock.json └── package.json ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.jsx ├── assets │ └── logo.svg ├── components │ ├── layout │ │ ├── AppLoader.jsx │ │ ├── ModalHeader.jsx │ │ └── SnackbarManager.jsx │ └── utils │ │ ├── ImageEl.jsx │ │ ├── PrivateRoute.jsx │ │ ├── PublicOnlyRoute.jsx │ │ └── StrictModeDroppable.jsx ├── firebase.js ├── hooks │ └── useApp.js ├── index.css ├── main.jsx ├── screens │ ├── AuthScreen │ │ └── index.jsx │ ├── BoardScreen │ │ ├── AddTaskModal.jsx │ │ ├── BoardInterface.jsx │ │ ├── BoardNotReady.jsx │ │ ├── BoardTab.jsx │ │ ├── BoardTopbar.jsx │ │ ├── ShiftTaskModal.jsx │ │ ├── Task.jsx │ │ └── index.jsx │ └── BoardsScreen │ │ ├── BoardCard.jsx │ │ ├── CreateBoardModal.jsx │ │ ├── NoBoards.jsx │ │ ├── Topbar.jsx │ │ └── index.jsx ├── store.js └── theme.js ├── vite.config.js └── vite.config.js.timestamp-1685895866945-f33c910a0ddf2.mjs /.firebaserc: -------------------------------------------------------------------------------- 1 | { 2 | "projects": { 3 | "default": "flowboard-b0f9e" 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /.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 | fb-emulator 19 | .idea 20 | .DS_Store 21 | *.suo 22 | *.ntvs* 23 | *.njsproj 24 | *.sln 25 | *.sw? 26 | .firebase -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## Build and Deploy Kanban Web App (React.js, Firebase, Drag & Drop, MUI v5, Zustand, Security Rules) 2 | 3 | ![Video Thumbnail](https://i3.ytimg.com/vi/5H0I97Pe9YY/maxresdefault.jpg) 4 | 5 | Link - https://www.youtube.com/watch?v=5H0I97Pe9YY 6 | -------------------------------------------------------------------------------- /firebase.json: -------------------------------------------------------------------------------- 1 | { 2 | "firestore": { 3 | "rules": "firestore.rules", 4 | "indexes": "firestore.indexes.json" 5 | }, 6 | "functions": [ 7 | { 8 | "source": "functions", 9 | "codebase": "default", 10 | "ignore": [ 11 | "node_modules", 12 | ".git", 13 | "firebase-debug.log", 14 | "firebase-debug.*.log" 15 | ] 16 | } 17 | ], 18 | "emulators": { 19 | "auth": { 20 | "port": 9098 21 | }, 22 | "functions": { 23 | "port": 5002 24 | }, 25 | "firestore": { 26 | "port": 8082 27 | }, 28 | "ui": { 29 | "enabled": true 30 | }, 31 | "singleProjectMode": true 32 | }, 33 | "hosting": { 34 | "public": "dist", 35 | "ignore": [ 36 | "firebase.json", 37 | "**/.*", 38 | "**/node_modules/**" 39 | ], 40 | "rewrites": [ 41 | { 42 | "source": "**", 43 | "destination": "/index.html" 44 | } 45 | ] 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /firestore.indexes.json: -------------------------------------------------------------------------------- 1 | { 2 | "indexes": [], 3 | "fieldOverrides": [] 4 | } 5 | -------------------------------------------------------------------------------- /firestore.rules: -------------------------------------------------------------------------------- 1 | rules_version = '2'; 2 | service cloud.firestore { 3 | match /databases/{database}/documents { 4 | 5 | // FUNCTIONS // 6 | 7 | function isOwner(userId) { 8 | return request.auth != null && request.auth.uid == userId 9 | } 10 | 11 | function docOnlyHasRequiredFields(requiredFields) { 12 | let incomingData = request.resource.data; 13 | return incomingData.keys().hasAll(requiredFields) && incomingData.keys().hasOnly(requiredFields); 14 | } 15 | 16 | //// 17 | 18 | 19 | match /users/{userId}/boards/{boardId} { 20 | 21 | function verifyDocFields() { 22 | let incomingData = request.resource.data; 23 | return incomingData.name is string && incomingData.name.matches('^[a-zA-Z0-9 \t]{1,20}$') 24 | && incomingData.color is number && incomingData.color >= 0 && incomingData.color <= 5 25 | && incomingData.createdAt is timestamp && incomingData.createdAt == request.time; 26 | } 27 | 28 | allow read: if isOwner(userId); 29 | allow delete: if isOwner(userId); 30 | allow create: if isOwner(userId) && docOnlyHasRequiredFields(['color', 'createdAt', 'name']) && verifyDocFields(); 31 | } 32 | 33 | 34 | match /users/{userId}/boardsData/{boardId} { 35 | 36 | function verifyDocFields() { 37 | let incomingData = request.resource.data; 38 | return incomingData.tabs is map 39 | && incomingData.tabs.keys().hasAll(['todos', 'inProgress', 'completed']) 40 | && incomingData.tabs.keys().hasOnly(['todos', 'inProgress', 'completed']) 41 | && incomingData.lastUpdated is timestamp && incomingData.lastUpdated == request.time 42 | } 43 | 44 | allow get: if isOwner(userId) 45 | allow update: if isOwner(userId) && docOnlyHasRequiredFields(['tabs', 'lastUpdated']) && verifyDocFields() 46 | } 47 | 48 | } 49 | 50 | 51 | 52 | } -------------------------------------------------------------------------------- /functions/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ -------------------------------------------------------------------------------- /functions/index.js: -------------------------------------------------------------------------------- 1 | const { 2 | onDocumentCreated, 3 | onDocumentDeleted, 4 | } = require("firebase-functions/v2/firestore"); 5 | const { initializeApp } = require("firebase-admin/app"); 6 | const { getFirestore, FieldValue } = require("firebase-admin/firestore"); 7 | 8 | initializeApp(); 9 | 10 | exports.createBoardData = onDocumentCreated( 11 | "users/{uid}/boards/{boardId}", 12 | async (event) => { 13 | const { uid, boardId } = event.params; 14 | const firestore = getFirestore(); 15 | 16 | return await firestore.doc(`users/${uid}/boardsData/${boardId}`).set({ 17 | tabs: { 18 | todos: [], 19 | inProgress: [], 20 | completed: [], 21 | }, 22 | lastUpdated: FieldValue.serverTimestamp(), 23 | }); 24 | } 25 | ); 26 | 27 | exports.deleteBoardData = onDocumentDeleted( 28 | "users/{uid}/boards/{boardId}", 29 | async (event) => { 30 | const { uid, boardId } = event.params; 31 | const firestore = getFirestore(); 32 | 33 | return await firestore.doc(`users/${uid}/boardsData/${boardId}`).delete(); 34 | } 35 | ); 36 | -------------------------------------------------------------------------------- /functions/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "functions", 3 | "description": "Cloud Functions for Firebase", 4 | "scripts": { 5 | "serve": "firebase emulators:start --only functions", 6 | "shell": "firebase functions:shell", 7 | "start": "npm run shell", 8 | "deploy": "firebase deploy --only functions", 9 | "logs": "firebase functions:log" 10 | }, 11 | "engines": { 12 | "node": "16" 13 | }, 14 | "main": "index.js", 15 | "dependencies": { 16 | "firebase-admin": "^11.5.0", 17 | "firebase-functions": "^4.2.0" 18 | }, 19 | "devDependencies": { 20 | "firebase-functions-test": "^3.0.0" 21 | }, 22 | "private": true 23 | } 24 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | FlowBoard 8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "flowboard-tutorial", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "flowboard-tutorial", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "@emotion/react": "^11.10.8", 12 | "@emotion/styled": "^11.10.8", 13 | "@mui/icons-material": "^5.11.16", 14 | "@mui/material": "^5.12.3", 15 | "firebase": "^9.21.0", 16 | "react": "^18.2.0", 17 | "react-beautiful-dnd": "^13.1.1", 18 | "react-dom": "^18.2.0", 19 | "react-router-dom": "^6.11.1", 20 | "zustand": "^4.3.8" 21 | }, 22 | "devDependencies": { 23 | "@types/react": "^18.0.28", 24 | "@types/react-dom": "^18.0.11", 25 | "@vitejs/plugin-react": "^4.0.0", 26 | "vite": "^4.3.2" 27 | } 28 | }, 29 | "node_modules/@ampproject/remapping": { 30 | "version": "2.2.1", 31 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", 32 | "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", 33 | "dev": true, 34 | "dependencies": { 35 | "@jridgewell/gen-mapping": "^0.3.0", 36 | "@jridgewell/trace-mapping": "^0.3.9" 37 | }, 38 | "engines": { 39 | "node": ">=6.0.0" 40 | } 41 | }, 42 | "node_modules/@babel/code-frame": { 43 | "version": "7.21.4", 44 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.21.4.tgz", 45 | "integrity": "sha512-LYvhNKfwWSPpocw8GI7gpK2nq3HSDuEPC/uSYaALSJu9xjsalaaYFOq0Pwt5KmVqwEbZlDu81aLXwBOmD/Fv9g==", 46 | "dependencies": { 47 | "@babel/highlight": "^7.18.6" 48 | }, 49 | "engines": { 50 | "node": ">=6.9.0" 51 | } 52 | }, 53 | "node_modules/@babel/compat-data": { 54 | "version": "7.21.7", 55 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.21.7.tgz", 56 | "integrity": "sha512-KYMqFYTaenzMK4yUtf4EW9wc4N9ef80FsbMtkwool5zpwl4YrT1SdWYSTRcT94KO4hannogdS+LxY7L+arP3gA==", 57 | "dev": true, 58 | "engines": { 59 | "node": ">=6.9.0" 60 | } 61 | }, 62 | "node_modules/@babel/core": { 63 | "version": "7.21.8", 64 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.21.8.tgz", 65 | "integrity": "sha512-YeM22Sondbo523Sz0+CirSPnbj9bG3P0CdHcBZdqUuaeOaYEFbOLoGU7lebvGP6P5J/WE9wOn7u7C4J9HvS1xQ==", 66 | "dev": true, 67 | "dependencies": { 68 | "@ampproject/remapping": "^2.2.0", 69 | "@babel/code-frame": "^7.21.4", 70 | "@babel/generator": "^7.21.5", 71 | "@babel/helper-compilation-targets": "^7.21.5", 72 | "@babel/helper-module-transforms": "^7.21.5", 73 | "@babel/helpers": "^7.21.5", 74 | "@babel/parser": "^7.21.8", 75 | "@babel/template": "^7.20.7", 76 | "@babel/traverse": "^7.21.5", 77 | "@babel/types": "^7.21.5", 78 | "convert-source-map": "^1.7.0", 79 | "debug": "^4.1.0", 80 | "gensync": "^1.0.0-beta.2", 81 | "json5": "^2.2.2", 82 | "semver": "^6.3.0" 83 | }, 84 | "engines": { 85 | "node": ">=6.9.0" 86 | }, 87 | "funding": { 88 | "type": "opencollective", 89 | "url": "https://opencollective.com/babel" 90 | } 91 | }, 92 | "node_modules/@babel/generator": { 93 | "version": "7.21.5", 94 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.21.5.tgz", 95 | "integrity": "sha512-SrKK/sRv8GesIW1bDagf9cCG38IOMYZusoe1dfg0D8aiUe3Amvoj1QtjTPAWcfrZFvIwlleLb0gxzQidL9w14w==", 96 | "dev": true, 97 | "dependencies": { 98 | "@babel/types": "^7.21.5", 99 | "@jridgewell/gen-mapping": "^0.3.2", 100 | "@jridgewell/trace-mapping": "^0.3.17", 101 | "jsesc": "^2.5.1" 102 | }, 103 | "engines": { 104 | "node": ">=6.9.0" 105 | } 106 | }, 107 | "node_modules/@babel/helper-compilation-targets": { 108 | "version": "7.21.5", 109 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.21.5.tgz", 110 | "integrity": "sha512-1RkbFGUKex4lvsB9yhIfWltJM5cZKUftB2eNajaDv3dCMEp49iBG0K14uH8NnX9IPux2+mK7JGEOB0jn48/J6w==", 111 | "dev": true, 112 | "dependencies": { 113 | "@babel/compat-data": "^7.21.5", 114 | "@babel/helper-validator-option": "^7.21.0", 115 | "browserslist": "^4.21.3", 116 | "lru-cache": "^5.1.1", 117 | "semver": "^6.3.0" 118 | }, 119 | "engines": { 120 | "node": ">=6.9.0" 121 | }, 122 | "peerDependencies": { 123 | "@babel/core": "^7.0.0" 124 | } 125 | }, 126 | "node_modules/@babel/helper-environment-visitor": { 127 | "version": "7.21.5", 128 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.21.5.tgz", 129 | "integrity": "sha512-IYl4gZ3ETsWocUWgsFZLM5i1BYx9SoemminVEXadgLBa9TdeorzgLKm8wWLA6J1N/kT3Kch8XIk1laNzYoHKvQ==", 130 | "dev": true, 131 | "engines": { 132 | "node": ">=6.9.0" 133 | } 134 | }, 135 | "node_modules/@babel/helper-function-name": { 136 | "version": "7.21.0", 137 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.21.0.tgz", 138 | "integrity": "sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg==", 139 | "dev": true, 140 | "dependencies": { 141 | "@babel/template": "^7.20.7", 142 | "@babel/types": "^7.21.0" 143 | }, 144 | "engines": { 145 | "node": ">=6.9.0" 146 | } 147 | }, 148 | "node_modules/@babel/helper-hoist-variables": { 149 | "version": "7.18.6", 150 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", 151 | "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", 152 | "dev": true, 153 | "dependencies": { 154 | "@babel/types": "^7.18.6" 155 | }, 156 | "engines": { 157 | "node": ">=6.9.0" 158 | } 159 | }, 160 | "node_modules/@babel/helper-module-imports": { 161 | "version": "7.21.4", 162 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.21.4.tgz", 163 | "integrity": "sha512-orajc5T2PsRYUN3ZryCEFeMDYwyw09c/pZeaQEZPH0MpKzSvn3e0uXsDBu3k03VI+9DBiRo+l22BfKTpKwa/Wg==", 164 | "dependencies": { 165 | "@babel/types": "^7.21.4" 166 | }, 167 | "engines": { 168 | "node": ">=6.9.0" 169 | } 170 | }, 171 | "node_modules/@babel/helper-module-transforms": { 172 | "version": "7.21.5", 173 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.21.5.tgz", 174 | "integrity": "sha512-bI2Z9zBGY2q5yMHoBvJ2a9iX3ZOAzJPm7Q8Yz6YeoUjU/Cvhmi2G4QyTNyPBqqXSgTjUxRg3L0xV45HvkNWWBw==", 175 | "dev": true, 176 | "dependencies": { 177 | "@babel/helper-environment-visitor": "^7.21.5", 178 | "@babel/helper-module-imports": "^7.21.4", 179 | "@babel/helper-simple-access": "^7.21.5", 180 | "@babel/helper-split-export-declaration": "^7.18.6", 181 | "@babel/helper-validator-identifier": "^7.19.1", 182 | "@babel/template": "^7.20.7", 183 | "@babel/traverse": "^7.21.5", 184 | "@babel/types": "^7.21.5" 185 | }, 186 | "engines": { 187 | "node": ">=6.9.0" 188 | } 189 | }, 190 | "node_modules/@babel/helper-plugin-utils": { 191 | "version": "7.21.5", 192 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.21.5.tgz", 193 | "integrity": "sha512-0WDaIlXKOX/3KfBK/dwP1oQGiPh6rjMkT7HIRv7i5RR2VUMwrx5ZL0dwBkKx7+SW1zwNdgjHd34IMk5ZjTeHVg==", 194 | "dev": true, 195 | "engines": { 196 | "node": ">=6.9.0" 197 | } 198 | }, 199 | "node_modules/@babel/helper-simple-access": { 200 | "version": "7.21.5", 201 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.21.5.tgz", 202 | "integrity": "sha512-ENPDAMC1wAjR0uaCUwliBdiSl1KBJAVnMTzXqi64c2MG8MPR6ii4qf7bSXDqSFbr4W6W028/rf5ivoHop5/mkg==", 203 | "dev": true, 204 | "dependencies": { 205 | "@babel/types": "^7.21.5" 206 | }, 207 | "engines": { 208 | "node": ">=6.9.0" 209 | } 210 | }, 211 | "node_modules/@babel/helper-split-export-declaration": { 212 | "version": "7.18.6", 213 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", 214 | "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", 215 | "dev": true, 216 | "dependencies": { 217 | "@babel/types": "^7.18.6" 218 | }, 219 | "engines": { 220 | "node": ">=6.9.0" 221 | } 222 | }, 223 | "node_modules/@babel/helper-string-parser": { 224 | "version": "7.21.5", 225 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.21.5.tgz", 226 | "integrity": "sha512-5pTUx3hAJaZIdW99sJ6ZUUgWq/Y+Hja7TowEnLNMm1VivRgZQL3vpBY3qUACVsvw+yQU6+YgfBVmcbLaZtrA1w==", 227 | "engines": { 228 | "node": ">=6.9.0" 229 | } 230 | }, 231 | "node_modules/@babel/helper-validator-identifier": { 232 | "version": "7.19.1", 233 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 234 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 235 | "engines": { 236 | "node": ">=6.9.0" 237 | } 238 | }, 239 | "node_modules/@babel/helper-validator-option": { 240 | "version": "7.21.0", 241 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.21.0.tgz", 242 | "integrity": "sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ==", 243 | "dev": true, 244 | "engines": { 245 | "node": ">=6.9.0" 246 | } 247 | }, 248 | "node_modules/@babel/helpers": { 249 | "version": "7.21.5", 250 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.21.5.tgz", 251 | "integrity": "sha512-BSY+JSlHxOmGsPTydUkPf1MdMQ3M81x5xGCOVgWM3G8XH77sJ292Y2oqcp0CbbgxhqBuI46iUz1tT7hqP7EfgA==", 252 | "dev": true, 253 | "dependencies": { 254 | "@babel/template": "^7.20.7", 255 | "@babel/traverse": "^7.21.5", 256 | "@babel/types": "^7.21.5" 257 | }, 258 | "engines": { 259 | "node": ">=6.9.0" 260 | } 261 | }, 262 | "node_modules/@babel/highlight": { 263 | "version": "7.18.6", 264 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 265 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 266 | "dependencies": { 267 | "@babel/helper-validator-identifier": "^7.18.6", 268 | "chalk": "^2.0.0", 269 | "js-tokens": "^4.0.0" 270 | }, 271 | "engines": { 272 | "node": ">=6.9.0" 273 | } 274 | }, 275 | "node_modules/@babel/parser": { 276 | "version": "7.21.8", 277 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.8.tgz", 278 | "integrity": "sha512-6zavDGdzG3gUqAdWvlLFfk+36RilI+Pwyuuh7HItyeScCWP3k6i8vKclAQ0bM/0y/Kz/xiwvxhMv9MgTJP5gmA==", 279 | "dev": true, 280 | "bin": { 281 | "parser": "bin/babel-parser.js" 282 | }, 283 | "engines": { 284 | "node": ">=6.0.0" 285 | } 286 | }, 287 | "node_modules/@babel/plugin-transform-react-jsx-self": { 288 | "version": "7.21.0", 289 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.21.0.tgz", 290 | "integrity": "sha512-f/Eq+79JEu+KUANFks9UZCcvydOOGMgF7jBrcwjHa5jTZD8JivnhCJYvmlhR/WTXBWonDExPoW0eO/CR4QJirA==", 291 | "dev": true, 292 | "dependencies": { 293 | "@babel/helper-plugin-utils": "^7.20.2" 294 | }, 295 | "engines": { 296 | "node": ">=6.9.0" 297 | }, 298 | "peerDependencies": { 299 | "@babel/core": "^7.0.0-0" 300 | } 301 | }, 302 | "node_modules/@babel/plugin-transform-react-jsx-source": { 303 | "version": "7.19.6", 304 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.19.6.tgz", 305 | "integrity": "sha512-RpAi004QyMNisst/pvSanoRdJ4q+jMCWyk9zdw/CyLB9j8RXEahodR6l2GyttDRyEVWZtbN+TpLiHJ3t34LbsQ==", 306 | "dev": true, 307 | "dependencies": { 308 | "@babel/helper-plugin-utils": "^7.19.0" 309 | }, 310 | "engines": { 311 | "node": ">=6.9.0" 312 | }, 313 | "peerDependencies": { 314 | "@babel/core": "^7.0.0-0" 315 | } 316 | }, 317 | "node_modules/@babel/runtime": { 318 | "version": "7.21.5", 319 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.21.5.tgz", 320 | "integrity": "sha512-8jI69toZqqcsnqGGqwGS4Qb1VwLOEp4hz+CXPywcvjs60u3B4Pom/U/7rm4W8tMOYEB+E9wgD0mW1l3r8qlI9Q==", 321 | "dependencies": { 322 | "regenerator-runtime": "^0.13.11" 323 | }, 324 | "engines": { 325 | "node": ">=6.9.0" 326 | } 327 | }, 328 | "node_modules/@babel/template": { 329 | "version": "7.20.7", 330 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz", 331 | "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==", 332 | "dev": true, 333 | "dependencies": { 334 | "@babel/code-frame": "^7.18.6", 335 | "@babel/parser": "^7.20.7", 336 | "@babel/types": "^7.20.7" 337 | }, 338 | "engines": { 339 | "node": ">=6.9.0" 340 | } 341 | }, 342 | "node_modules/@babel/traverse": { 343 | "version": "7.21.5", 344 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.21.5.tgz", 345 | "integrity": "sha512-AhQoI3YjWi6u/y/ntv7k48mcrCXmus0t79J9qPNlk/lAsFlCiJ047RmbfMOawySTHtywXhbXgpx/8nXMYd+oFw==", 346 | "dev": true, 347 | "dependencies": { 348 | "@babel/code-frame": "^7.21.4", 349 | "@babel/generator": "^7.21.5", 350 | "@babel/helper-environment-visitor": "^7.21.5", 351 | "@babel/helper-function-name": "^7.21.0", 352 | "@babel/helper-hoist-variables": "^7.18.6", 353 | "@babel/helper-split-export-declaration": "^7.18.6", 354 | "@babel/parser": "^7.21.5", 355 | "@babel/types": "^7.21.5", 356 | "debug": "^4.1.0", 357 | "globals": "^11.1.0" 358 | }, 359 | "engines": { 360 | "node": ">=6.9.0" 361 | } 362 | }, 363 | "node_modules/@babel/types": { 364 | "version": "7.21.5", 365 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.21.5.tgz", 366 | "integrity": "sha512-m4AfNvVF2mVC/F7fDEdH2El3HzUg9It/XsCxZiOTTA3m3qYfcSVSbTfM6Q9xG+hYDniZssYhlXKKUMD5m8tF4Q==", 367 | "dependencies": { 368 | "@babel/helper-string-parser": "^7.21.5", 369 | "@babel/helper-validator-identifier": "^7.19.1", 370 | "to-fast-properties": "^2.0.0" 371 | }, 372 | "engines": { 373 | "node": ">=6.9.0" 374 | } 375 | }, 376 | "node_modules/@emotion/babel-plugin": { 377 | "version": "11.10.8", 378 | "resolved": "https://registry.npmjs.org/@emotion/babel-plugin/-/babel-plugin-11.10.8.tgz", 379 | "integrity": "sha512-gxNky50AJL3AlkbjvTARiwAqei6/tNUxDZPSKd+3jqWVM3AmdVTTdpjHorR/an/M0VJqdsuq5oGcFH+rjtyujQ==", 380 | "dependencies": { 381 | "@babel/helper-module-imports": "^7.16.7", 382 | "@babel/runtime": "^7.18.3", 383 | "@emotion/hash": "^0.9.0", 384 | "@emotion/memoize": "^0.8.0", 385 | "@emotion/serialize": "^1.1.1", 386 | "babel-plugin-macros": "^3.1.0", 387 | "convert-source-map": "^1.5.0", 388 | "escape-string-regexp": "^4.0.0", 389 | "find-root": "^1.1.0", 390 | "source-map": "^0.5.7", 391 | "stylis": "4.1.4" 392 | } 393 | }, 394 | "node_modules/@emotion/babel-plugin/node_modules/escape-string-regexp": { 395 | "version": "4.0.0", 396 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 397 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 398 | "engines": { 399 | "node": ">=10" 400 | }, 401 | "funding": { 402 | "url": "https://github.com/sponsors/sindresorhus" 403 | } 404 | }, 405 | "node_modules/@emotion/cache": { 406 | "version": "11.10.8", 407 | "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-11.10.8.tgz", 408 | "integrity": "sha512-5fyqGHi51LU95o7qQ/vD1jyvC4uCY5GcBT+UgP4LHdpO9jPDlXqhrRr9/wCKmfoAvh5G/F7aOh4MwQa+8uEqhA==", 409 | "dependencies": { 410 | "@emotion/memoize": "^0.8.0", 411 | "@emotion/sheet": "^1.2.1", 412 | "@emotion/utils": "^1.2.0", 413 | "@emotion/weak-memoize": "^0.3.0", 414 | "stylis": "4.1.4" 415 | } 416 | }, 417 | "node_modules/@emotion/hash": { 418 | "version": "0.9.0", 419 | "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.0.tgz", 420 | "integrity": "sha512-14FtKiHhy2QoPIzdTcvh//8OyBlknNs2nXRwIhG904opCby3l+9Xaf/wuPvICBF0rc1ZCNBd3nKe9cd2mecVkQ==" 421 | }, 422 | "node_modules/@emotion/is-prop-valid": { 423 | "version": "1.2.0", 424 | "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.2.0.tgz", 425 | "integrity": "sha512-3aDpDprjM0AwaxGE09bOPkNxHpBd+kA6jty3RnaEXdweX1DF1U3VQpPYb0g1IStAuK7SVQ1cy+bNBBKp4W3Fjg==", 426 | "dependencies": { 427 | "@emotion/memoize": "^0.8.0" 428 | } 429 | }, 430 | "node_modules/@emotion/memoize": { 431 | "version": "0.8.0", 432 | "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.0.tgz", 433 | "integrity": "sha512-G/YwXTkv7Den9mXDO7AhLWkE3q+I92B+VqAE+dYG4NGPaHZGvt3G8Q0p9vmE+sq7rTGphUbAvmQ9YpbfMQGGlA==" 434 | }, 435 | "node_modules/@emotion/react": { 436 | "version": "11.10.8", 437 | "resolved": "https://registry.npmjs.org/@emotion/react/-/react-11.10.8.tgz", 438 | "integrity": "sha512-ZfGfiABtJ1P1OXqOBsW08EgCDp5fK6C5I8hUJauc/VcJBGSzqAirMnFslhFWnZJ/w5HxPI36XbvMV0l4KZHl+w==", 439 | "dependencies": { 440 | "@babel/runtime": "^7.18.3", 441 | "@emotion/babel-plugin": "^11.10.8", 442 | "@emotion/cache": "^11.10.8", 443 | "@emotion/serialize": "^1.1.1", 444 | "@emotion/use-insertion-effect-with-fallbacks": "^1.0.0", 445 | "@emotion/utils": "^1.2.0", 446 | "@emotion/weak-memoize": "^0.3.0", 447 | "hoist-non-react-statics": "^3.3.1" 448 | }, 449 | "peerDependencies": { 450 | "react": ">=16.8.0" 451 | }, 452 | "peerDependenciesMeta": { 453 | "@types/react": { 454 | "optional": true 455 | } 456 | } 457 | }, 458 | "node_modules/@emotion/serialize": { 459 | "version": "1.1.1", 460 | "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.1.1.tgz", 461 | "integrity": "sha512-Zl/0LFggN7+L1liljxXdsVSVlg6E/Z/olVWpfxUTxOAmi8NU7YoeWeLfi1RmnB2TATHoaWwIBRoL+FvAJiTUQA==", 462 | "dependencies": { 463 | "@emotion/hash": "^0.9.0", 464 | "@emotion/memoize": "^0.8.0", 465 | "@emotion/unitless": "^0.8.0", 466 | "@emotion/utils": "^1.2.0", 467 | "csstype": "^3.0.2" 468 | } 469 | }, 470 | "node_modules/@emotion/sheet": { 471 | "version": "1.2.1", 472 | "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.2.1.tgz", 473 | "integrity": "sha512-zxRBwl93sHMsOj4zs+OslQKg/uhF38MB+OMKoCrVuS0nyTkqnau+BM3WGEoOptg9Oz45T/aIGs1qbVAsEFo3nA==" 474 | }, 475 | "node_modules/@emotion/styled": { 476 | "version": "11.10.8", 477 | "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-11.10.8.tgz", 478 | "integrity": "sha512-gow0lF4Uw/QEdX2REMhI8v6wLOabPKJ+4HKNF0xdJ2DJdznN6fxaXpQOx6sNkyBhSUL558Rmcu1Lq/MYlVo4vw==", 479 | "dependencies": { 480 | "@babel/runtime": "^7.18.3", 481 | "@emotion/babel-plugin": "^11.10.8", 482 | "@emotion/is-prop-valid": "^1.2.0", 483 | "@emotion/serialize": "^1.1.1", 484 | "@emotion/use-insertion-effect-with-fallbacks": "^1.0.0", 485 | "@emotion/utils": "^1.2.0" 486 | }, 487 | "peerDependencies": { 488 | "@emotion/react": "^11.0.0-rc.0", 489 | "react": ">=16.8.0" 490 | }, 491 | "peerDependenciesMeta": { 492 | "@types/react": { 493 | "optional": true 494 | } 495 | } 496 | }, 497 | "node_modules/@emotion/unitless": { 498 | "version": "0.8.0", 499 | "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.0.tgz", 500 | "integrity": "sha512-VINS5vEYAscRl2ZUDiT3uMPlrFQupiKgHz5AA4bCH1miKBg4qtwkim1qPmJj/4WG6TreYMY111rEFsjupcOKHw==" 501 | }, 502 | "node_modules/@emotion/use-insertion-effect-with-fallbacks": { 503 | "version": "1.0.0", 504 | "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.0.0.tgz", 505 | "integrity": "sha512-1eEgUGmkaljiBnRMTdksDV1W4kUnmwgp7X9G8B++9GYwl1lUdqSndSriIrTJ0N7LQaoauY9JJ2yhiOYK5+NI4A==", 506 | "peerDependencies": { 507 | "react": ">=16.8.0" 508 | } 509 | }, 510 | "node_modules/@emotion/utils": { 511 | "version": "1.2.0", 512 | "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-1.2.0.tgz", 513 | "integrity": "sha512-sn3WH53Kzpw8oQ5mgMmIzzyAaH2ZqFEbozVVBSYp538E06OSE6ytOp7pRAjNQR+Q/orwqdQYJSe2m3hCOeznkw==" 514 | }, 515 | "node_modules/@emotion/weak-memoize": { 516 | "version": "0.3.0", 517 | "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.3.0.tgz", 518 | "integrity": "sha512-AHPmaAx+RYfZz0eYu6Gviiagpmiyw98ySSlQvCUhVGDRtDFe4DBS0x1bSjdF3gqUDYOczB+yYvBTtEylYSdRhg==" 519 | }, 520 | "node_modules/@esbuild/android-arm": { 521 | "version": "0.17.18", 522 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.18.tgz", 523 | "integrity": "sha512-EmwL+vUBZJ7mhFCs5lA4ZimpUH3WMAoqvOIYhVQwdIgSpHC8ImHdsRyhHAVxpDYUSm0lWvd63z0XH1IlImS2Qw==", 524 | "cpu": [ 525 | "arm" 526 | ], 527 | "dev": true, 528 | "optional": true, 529 | "os": [ 530 | "android" 531 | ], 532 | "engines": { 533 | "node": ">=12" 534 | } 535 | }, 536 | "node_modules/@esbuild/android-arm64": { 537 | "version": "0.17.18", 538 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.18.tgz", 539 | "integrity": "sha512-/iq0aK0eeHgSC3z55ucMAHO05OIqmQehiGay8eP5l/5l+iEr4EIbh4/MI8xD9qRFjqzgkc0JkX0LculNC9mXBw==", 540 | "cpu": [ 541 | "arm64" 542 | ], 543 | "dev": true, 544 | "optional": true, 545 | "os": [ 546 | "android" 547 | ], 548 | "engines": { 549 | "node": ">=12" 550 | } 551 | }, 552 | "node_modules/@esbuild/android-x64": { 553 | "version": "0.17.18", 554 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.18.tgz", 555 | "integrity": "sha512-x+0efYNBF3NPW2Xc5bFOSFW7tTXdAcpfEg2nXmxegm4mJuVeS+i109m/7HMiOQ6M12aVGGFlqJX3RhNdYM2lWg==", 556 | "cpu": [ 557 | "x64" 558 | ], 559 | "dev": true, 560 | "optional": true, 561 | "os": [ 562 | "android" 563 | ], 564 | "engines": { 565 | "node": ">=12" 566 | } 567 | }, 568 | "node_modules/@esbuild/darwin-arm64": { 569 | "version": "0.17.18", 570 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.18.tgz", 571 | "integrity": "sha512-6tY+djEAdF48M1ONWnQb1C+6LiXrKjmqjzPNPWXhu/GzOHTHX2nh8Mo2ZAmBFg0kIodHhciEgUBtcYCAIjGbjQ==", 572 | "cpu": [ 573 | "arm64" 574 | ], 575 | "dev": true, 576 | "optional": true, 577 | "os": [ 578 | "darwin" 579 | ], 580 | "engines": { 581 | "node": ">=12" 582 | } 583 | }, 584 | "node_modules/@esbuild/darwin-x64": { 585 | "version": "0.17.18", 586 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.18.tgz", 587 | "integrity": "sha512-Qq84ykvLvya3dO49wVC9FFCNUfSrQJLbxhoQk/TE1r6MjHo3sFF2tlJCwMjhkBVq3/ahUisj7+EpRSz0/+8+9A==", 588 | "cpu": [ 589 | "x64" 590 | ], 591 | "dev": true, 592 | "optional": true, 593 | "os": [ 594 | "darwin" 595 | ], 596 | "engines": { 597 | "node": ">=12" 598 | } 599 | }, 600 | "node_modules/@esbuild/freebsd-arm64": { 601 | "version": "0.17.18", 602 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.18.tgz", 603 | "integrity": "sha512-fw/ZfxfAzuHfaQeMDhbzxp9mc+mHn1Y94VDHFHjGvt2Uxl10mT4CDavHm+/L9KG441t1QdABqkVYwakMUeyLRA==", 604 | "cpu": [ 605 | "arm64" 606 | ], 607 | "dev": true, 608 | "optional": true, 609 | "os": [ 610 | "freebsd" 611 | ], 612 | "engines": { 613 | "node": ">=12" 614 | } 615 | }, 616 | "node_modules/@esbuild/freebsd-x64": { 617 | "version": "0.17.18", 618 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.18.tgz", 619 | "integrity": "sha512-FQFbRtTaEi8ZBi/A6kxOC0V0E9B/97vPdYjY9NdawyLd4Qk5VD5g2pbWN2VR1c0xhzcJm74HWpObPszWC+qTew==", 620 | "cpu": [ 621 | "x64" 622 | ], 623 | "dev": true, 624 | "optional": true, 625 | "os": [ 626 | "freebsd" 627 | ], 628 | "engines": { 629 | "node": ">=12" 630 | } 631 | }, 632 | "node_modules/@esbuild/linux-arm": { 633 | "version": "0.17.18", 634 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.18.tgz", 635 | "integrity": "sha512-jW+UCM40LzHcouIaqv3e/oRs0JM76JfhHjCavPxMUti7VAPh8CaGSlS7cmyrdpzSk7A+8f0hiedHqr/LMnfijg==", 636 | "cpu": [ 637 | "arm" 638 | ], 639 | "dev": true, 640 | "optional": true, 641 | "os": [ 642 | "linux" 643 | ], 644 | "engines": { 645 | "node": ">=12" 646 | } 647 | }, 648 | "node_modules/@esbuild/linux-arm64": { 649 | "version": "0.17.18", 650 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.18.tgz", 651 | "integrity": "sha512-R7pZvQZFOY2sxUG8P6A21eq6q+eBv7JPQYIybHVf1XkQYC+lT7nDBdC7wWKTrbvMXKRaGudp/dzZCwL/863mZQ==", 652 | "cpu": [ 653 | "arm64" 654 | ], 655 | "dev": true, 656 | "optional": true, 657 | "os": [ 658 | "linux" 659 | ], 660 | "engines": { 661 | "node": ">=12" 662 | } 663 | }, 664 | "node_modules/@esbuild/linux-ia32": { 665 | "version": "0.17.18", 666 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.18.tgz", 667 | "integrity": "sha512-ygIMc3I7wxgXIxk6j3V00VlABIjq260i967Cp9BNAk5pOOpIXmd1RFQJQX9Io7KRsthDrQYrtcx7QCof4o3ZoQ==", 668 | "cpu": [ 669 | "ia32" 670 | ], 671 | "dev": true, 672 | "optional": true, 673 | "os": [ 674 | "linux" 675 | ], 676 | "engines": { 677 | "node": ">=12" 678 | } 679 | }, 680 | "node_modules/@esbuild/linux-loong64": { 681 | "version": "0.17.18", 682 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.18.tgz", 683 | "integrity": "sha512-bvPG+MyFs5ZlwYclCG1D744oHk1Pv7j8psF5TfYx7otCVmcJsEXgFEhQkbhNW8otDHL1a2KDINW20cfCgnzgMQ==", 684 | "cpu": [ 685 | "loong64" 686 | ], 687 | "dev": true, 688 | "optional": true, 689 | "os": [ 690 | "linux" 691 | ], 692 | "engines": { 693 | "node": ">=12" 694 | } 695 | }, 696 | "node_modules/@esbuild/linux-mips64el": { 697 | "version": "0.17.18", 698 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.18.tgz", 699 | "integrity": "sha512-oVqckATOAGuiUOa6wr8TXaVPSa+6IwVJrGidmNZS1cZVx0HqkTMkqFGD2HIx9H1RvOwFeWYdaYbdY6B89KUMxA==", 700 | "cpu": [ 701 | "mips64el" 702 | ], 703 | "dev": true, 704 | "optional": true, 705 | "os": [ 706 | "linux" 707 | ], 708 | "engines": { 709 | "node": ">=12" 710 | } 711 | }, 712 | "node_modules/@esbuild/linux-ppc64": { 713 | "version": "0.17.18", 714 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.18.tgz", 715 | "integrity": "sha512-3dLlQO+b/LnQNxgH4l9rqa2/IwRJVN9u/bK63FhOPB4xqiRqlQAU0qDU3JJuf0BmaH0yytTBdoSBHrb2jqc5qQ==", 716 | "cpu": [ 717 | "ppc64" 718 | ], 719 | "dev": true, 720 | "optional": true, 721 | "os": [ 722 | "linux" 723 | ], 724 | "engines": { 725 | "node": ">=12" 726 | } 727 | }, 728 | "node_modules/@esbuild/linux-riscv64": { 729 | "version": "0.17.18", 730 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.18.tgz", 731 | "integrity": "sha512-/x7leOyDPjZV3TcsdfrSI107zItVnsX1q2nho7hbbQoKnmoeUWjs+08rKKt4AUXju7+3aRZSsKrJtaRmsdL1xA==", 732 | "cpu": [ 733 | "riscv64" 734 | ], 735 | "dev": true, 736 | "optional": true, 737 | "os": [ 738 | "linux" 739 | ], 740 | "engines": { 741 | "node": ">=12" 742 | } 743 | }, 744 | "node_modules/@esbuild/linux-s390x": { 745 | "version": "0.17.18", 746 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.18.tgz", 747 | "integrity": "sha512-cX0I8Q9xQkL/6F5zWdYmVf5JSQt+ZfZD2bJudZrWD+4mnUvoZ3TDDXtDX2mUaq6upMFv9FlfIh4Gfun0tbGzuw==", 748 | "cpu": [ 749 | "s390x" 750 | ], 751 | "dev": true, 752 | "optional": true, 753 | "os": [ 754 | "linux" 755 | ], 756 | "engines": { 757 | "node": ">=12" 758 | } 759 | }, 760 | "node_modules/@esbuild/linux-x64": { 761 | "version": "0.17.18", 762 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.18.tgz", 763 | "integrity": "sha512-66RmRsPlYy4jFl0vG80GcNRdirx4nVWAzJmXkevgphP1qf4dsLQCpSKGM3DUQCojwU1hnepI63gNZdrr02wHUA==", 764 | "cpu": [ 765 | "x64" 766 | ], 767 | "dev": true, 768 | "optional": true, 769 | "os": [ 770 | "linux" 771 | ], 772 | "engines": { 773 | "node": ">=12" 774 | } 775 | }, 776 | "node_modules/@esbuild/netbsd-x64": { 777 | "version": "0.17.18", 778 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.18.tgz", 779 | "integrity": "sha512-95IRY7mI2yrkLlTLb1gpDxdC5WLC5mZDi+kA9dmM5XAGxCME0F8i4bYH4jZreaJ6lIZ0B8hTrweqG1fUyW7jbg==", 780 | "cpu": [ 781 | "x64" 782 | ], 783 | "dev": true, 784 | "optional": true, 785 | "os": [ 786 | "netbsd" 787 | ], 788 | "engines": { 789 | "node": ">=12" 790 | } 791 | }, 792 | "node_modules/@esbuild/openbsd-x64": { 793 | "version": "0.17.18", 794 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.18.tgz", 795 | "integrity": "sha512-WevVOgcng+8hSZ4Q3BKL3n1xTv5H6Nb53cBrtzzEjDbbnOmucEVcZeGCsCOi9bAOcDYEeBZbD2SJNBxlfP3qiA==", 796 | "cpu": [ 797 | "x64" 798 | ], 799 | "dev": true, 800 | "optional": true, 801 | "os": [ 802 | "openbsd" 803 | ], 804 | "engines": { 805 | "node": ">=12" 806 | } 807 | }, 808 | "node_modules/@esbuild/sunos-x64": { 809 | "version": "0.17.18", 810 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.18.tgz", 811 | "integrity": "sha512-Rzf4QfQagnwhQXVBS3BYUlxmEbcV7MY+BH5vfDZekU5eYpcffHSyjU8T0xucKVuOcdCsMo+Ur5wmgQJH2GfNrg==", 812 | "cpu": [ 813 | "x64" 814 | ], 815 | "dev": true, 816 | "optional": true, 817 | "os": [ 818 | "sunos" 819 | ], 820 | "engines": { 821 | "node": ">=12" 822 | } 823 | }, 824 | "node_modules/@esbuild/win32-arm64": { 825 | "version": "0.17.18", 826 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.18.tgz", 827 | "integrity": "sha512-Kb3Ko/KKaWhjeAm2YoT/cNZaHaD1Yk/pa3FTsmqo9uFh1D1Rfco7BBLIPdDOozrObj2sahslFuAQGvWbgWldAg==", 828 | "cpu": [ 829 | "arm64" 830 | ], 831 | "dev": true, 832 | "optional": true, 833 | "os": [ 834 | "win32" 835 | ], 836 | "engines": { 837 | "node": ">=12" 838 | } 839 | }, 840 | "node_modules/@esbuild/win32-ia32": { 841 | "version": "0.17.18", 842 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.18.tgz", 843 | "integrity": "sha512-0/xUMIdkVHwkvxfbd5+lfG7mHOf2FRrxNbPiKWg9C4fFrB8H0guClmaM3BFiRUYrznVoyxTIyC/Ou2B7QQSwmw==", 844 | "cpu": [ 845 | "ia32" 846 | ], 847 | "dev": true, 848 | "optional": true, 849 | "os": [ 850 | "win32" 851 | ], 852 | "engines": { 853 | "node": ">=12" 854 | } 855 | }, 856 | "node_modules/@esbuild/win32-x64": { 857 | "version": "0.17.18", 858 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.18.tgz", 859 | "integrity": "sha512-qU25Ma1I3NqTSHJUOKi9sAH1/Mzuvlke0ioMJRthLXKm7JiSKVwFghlGbDLOO2sARECGhja4xYfRAZNPAkooYg==", 860 | "cpu": [ 861 | "x64" 862 | ], 863 | "dev": true, 864 | "optional": true, 865 | "os": [ 866 | "win32" 867 | ], 868 | "engines": { 869 | "node": ">=12" 870 | } 871 | }, 872 | "node_modules/@firebase/analytics": { 873 | "version": "0.10.0", 874 | "resolved": "https://registry.npmjs.org/@firebase/analytics/-/analytics-0.10.0.tgz", 875 | "integrity": "sha512-Locv8gAqx0e+GX/0SI3dzmBY5e9kjVDtD+3zCFLJ0tH2hJwuCAiL+5WkHuxKj92rqQj/rvkBUCfA1ewlX2hehg==", 876 | "dependencies": { 877 | "@firebase/component": "0.6.4", 878 | "@firebase/installations": "0.6.4", 879 | "@firebase/logger": "0.4.0", 880 | "@firebase/util": "1.9.3", 881 | "tslib": "^2.1.0" 882 | }, 883 | "peerDependencies": { 884 | "@firebase/app": "0.x" 885 | } 886 | }, 887 | "node_modules/@firebase/analytics-compat": { 888 | "version": "0.2.6", 889 | "resolved": "https://registry.npmjs.org/@firebase/analytics-compat/-/analytics-compat-0.2.6.tgz", 890 | "integrity": "sha512-4MqpVLFkGK7NJf/5wPEEP7ePBJatwYpyjgJ+wQHQGHfzaCDgntOnl9rL2vbVGGKCnRqWtZDIWhctB86UWXaX2Q==", 891 | "dependencies": { 892 | "@firebase/analytics": "0.10.0", 893 | "@firebase/analytics-types": "0.8.0", 894 | "@firebase/component": "0.6.4", 895 | "@firebase/util": "1.9.3", 896 | "tslib": "^2.1.0" 897 | }, 898 | "peerDependencies": { 899 | "@firebase/app-compat": "0.x" 900 | } 901 | }, 902 | "node_modules/@firebase/analytics-types": { 903 | "version": "0.8.0", 904 | "resolved": "https://registry.npmjs.org/@firebase/analytics-types/-/analytics-types-0.8.0.tgz", 905 | "integrity": "sha512-iRP+QKI2+oz3UAh4nPEq14CsEjrjD6a5+fuypjScisAh9kXKFvdJOZJDwk7kikLvWVLGEs9+kIUS4LPQV7VZVw==" 906 | }, 907 | "node_modules/@firebase/app": { 908 | "version": "0.9.9", 909 | "resolved": "https://registry.npmjs.org/@firebase/app/-/app-0.9.9.tgz", 910 | "integrity": "sha512-8jzuHtQ/t9XqK+0IAQ/lpylVYzXGKIUKm6U3v7LWor+MGIm+9Ucn+hbrd2iBjH8qfmNrjnQnmf7sWBbdSa54oA==", 911 | "dependencies": { 912 | "@firebase/component": "0.6.4", 913 | "@firebase/logger": "0.4.0", 914 | "@firebase/util": "1.9.3", 915 | "idb": "7.1.1", 916 | "tslib": "^2.1.0" 917 | } 918 | }, 919 | "node_modules/@firebase/app-check": { 920 | "version": "0.7.0", 921 | "resolved": "https://registry.npmjs.org/@firebase/app-check/-/app-check-0.7.0.tgz", 922 | "integrity": "sha512-y0raLJpEtiL+wonfInFMaSfBV/EDvr356ZHMWbpr5F7fR0/I3cC0h7U6SKpKhrbSHJ0fOYIe0xbih20KTlpcnA==", 923 | "dependencies": { 924 | "@firebase/component": "0.6.4", 925 | "@firebase/logger": "0.4.0", 926 | "@firebase/util": "1.9.3", 927 | "tslib": "^2.1.0" 928 | }, 929 | "peerDependencies": { 930 | "@firebase/app": "0.x" 931 | } 932 | }, 933 | "node_modules/@firebase/app-check-compat": { 934 | "version": "0.3.6", 935 | "resolved": "https://registry.npmjs.org/@firebase/app-check-compat/-/app-check-compat-0.3.6.tgz", 936 | "integrity": "sha512-azHAeHi9igoaIo04E6Yfuc7aIbWoWuBXuqjyYyWbeCc8Zz/NfJvIAgmXugN4LdxsHJ7XGlZTvwJ6YaYROdSa7A==", 937 | "dependencies": { 938 | "@firebase/app-check": "0.7.0", 939 | "@firebase/app-check-types": "0.5.0", 940 | "@firebase/component": "0.6.4", 941 | "@firebase/logger": "0.4.0", 942 | "@firebase/util": "1.9.3", 943 | "tslib": "^2.1.0" 944 | }, 945 | "peerDependencies": { 946 | "@firebase/app-compat": "0.x" 947 | } 948 | }, 949 | "node_modules/@firebase/app-check-interop-types": { 950 | "version": "0.2.0", 951 | "resolved": "https://registry.npmjs.org/@firebase/app-check-interop-types/-/app-check-interop-types-0.2.0.tgz", 952 | "integrity": "sha512-+3PQIeX6/eiVK+x/yg8r6xTNR97fN7MahFDm+jiQmDjcyvSefoGuTTNQuuMScGyx3vYUBeZn+Cp9kC0yY/9uxQ==" 953 | }, 954 | "node_modules/@firebase/app-check-types": { 955 | "version": "0.5.0", 956 | "resolved": "https://registry.npmjs.org/@firebase/app-check-types/-/app-check-types-0.5.0.tgz", 957 | "integrity": "sha512-uwSUj32Mlubybw7tedRzR24RP8M8JUVR3NPiMk3/Z4bCmgEKTlQBwMXrehDAZ2wF+TsBq0SN1c6ema71U/JPyQ==" 958 | }, 959 | "node_modules/@firebase/app-compat": { 960 | "version": "0.2.9", 961 | "resolved": "https://registry.npmjs.org/@firebase/app-compat/-/app-compat-0.2.9.tgz", 962 | "integrity": "sha512-XdnkHNK3XdPrwChmuSJHDA6eYmo2KLAtaAG1SJLGMQ+n+S5/UcufmDkw9GvPh93H1xhPRAwd/vKdjHmE7xp3Zw==", 963 | "dependencies": { 964 | "@firebase/app": "0.9.9", 965 | "@firebase/component": "0.6.4", 966 | "@firebase/logger": "0.4.0", 967 | "@firebase/util": "1.9.3", 968 | "tslib": "^2.1.0" 969 | } 970 | }, 971 | "node_modules/@firebase/app-types": { 972 | "version": "0.9.0", 973 | "resolved": "https://registry.npmjs.org/@firebase/app-types/-/app-types-0.9.0.tgz", 974 | "integrity": "sha512-AeweANOIo0Mb8GiYm3xhTEBVCmPwTYAu9Hcd2qSkLuga/6+j9b1Jskl5bpiSQWy9eJ/j5pavxj6eYogmnuzm+Q==" 975 | }, 976 | "node_modules/@firebase/auth": { 977 | "version": "0.23.1", 978 | "resolved": "https://registry.npmjs.org/@firebase/auth/-/auth-0.23.1.tgz", 979 | "integrity": "sha512-QubckPA5Ad92HiY20szjdH7EnFxL8gsZzRLyNCmO2oqebVAVuh9pJp6Zb8EA+P/AuMQYMBo6rQ3oIHi9gUCstg==", 980 | "dependencies": { 981 | "@firebase/component": "0.6.4", 982 | "@firebase/logger": "0.4.0", 983 | "@firebase/util": "1.9.3", 984 | "node-fetch": "2.6.7", 985 | "tslib": "^2.1.0" 986 | }, 987 | "peerDependencies": { 988 | "@firebase/app": "0.x" 989 | } 990 | }, 991 | "node_modules/@firebase/auth-compat": { 992 | "version": "0.4.1", 993 | "resolved": "https://registry.npmjs.org/@firebase/auth-compat/-/auth-compat-0.4.1.tgz", 994 | "integrity": "sha512-wCw+6Jz7zCWzMA2bN8vphqEUmxuIFxHfBJiF3rKFTCEFPPXG4ulIcmMT98uuZVVq4xDPk/hxm105xwHBFAwBng==", 995 | "dependencies": { 996 | "@firebase/auth": "0.23.1", 997 | "@firebase/auth-types": "0.12.0", 998 | "@firebase/component": "0.6.4", 999 | "@firebase/util": "1.9.3", 1000 | "node-fetch": "2.6.7", 1001 | "tslib": "^2.1.0" 1002 | }, 1003 | "peerDependencies": { 1004 | "@firebase/app-compat": "0.x" 1005 | } 1006 | }, 1007 | "node_modules/@firebase/auth-interop-types": { 1008 | "version": "0.2.1", 1009 | "resolved": "https://registry.npmjs.org/@firebase/auth-interop-types/-/auth-interop-types-0.2.1.tgz", 1010 | "integrity": "sha512-VOaGzKp65MY6P5FI84TfYKBXEPi6LmOCSMMzys6o2BN2LOsqy7pCuZCup7NYnfbk5OkkQKzvIfHOzTm0UDpkyg==" 1011 | }, 1012 | "node_modules/@firebase/auth-types": { 1013 | "version": "0.12.0", 1014 | "resolved": "https://registry.npmjs.org/@firebase/auth-types/-/auth-types-0.12.0.tgz", 1015 | "integrity": "sha512-pPwaZt+SPOshK8xNoiQlK5XIrS97kFYc3Rc7xmy373QsOJ9MmqXxLaYssP5Kcds4wd2qK//amx/c+A8O2fVeZA==", 1016 | "peerDependencies": { 1017 | "@firebase/app-types": "0.x", 1018 | "@firebase/util": "1.x" 1019 | } 1020 | }, 1021 | "node_modules/@firebase/component": { 1022 | "version": "0.6.4", 1023 | "resolved": "https://registry.npmjs.org/@firebase/component/-/component-0.6.4.tgz", 1024 | "integrity": "sha512-rLMyrXuO9jcAUCaQXCMjCMUsWrba5fzHlNK24xz5j2W6A/SRmK8mZJ/hn7V0fViLbxC0lPMtrK1eYzk6Fg03jA==", 1025 | "dependencies": { 1026 | "@firebase/util": "1.9.3", 1027 | "tslib": "^2.1.0" 1028 | } 1029 | }, 1030 | "node_modules/@firebase/database": { 1031 | "version": "0.14.4", 1032 | "resolved": "https://registry.npmjs.org/@firebase/database/-/database-0.14.4.tgz", 1033 | "integrity": "sha512-+Ea/IKGwh42jwdjCyzTmeZeLM3oy1h0mFPsTy6OqCWzcu/KFqRAr5Tt1HRCOBlNOdbh84JPZC47WLU18n2VbxQ==", 1034 | "dependencies": { 1035 | "@firebase/auth-interop-types": "0.2.1", 1036 | "@firebase/component": "0.6.4", 1037 | "@firebase/logger": "0.4.0", 1038 | "@firebase/util": "1.9.3", 1039 | "faye-websocket": "0.11.4", 1040 | "tslib": "^2.1.0" 1041 | } 1042 | }, 1043 | "node_modules/@firebase/database-compat": { 1044 | "version": "0.3.4", 1045 | "resolved": "https://registry.npmjs.org/@firebase/database-compat/-/database-compat-0.3.4.tgz", 1046 | "integrity": "sha512-kuAW+l+sLMUKBThnvxvUZ+Q1ZrF/vFJ58iUY9kAcbX48U03nVzIF6Tmkf0p3WVQwMqiXguSgtOPIB6ZCeF+5Gg==", 1047 | "dependencies": { 1048 | "@firebase/component": "0.6.4", 1049 | "@firebase/database": "0.14.4", 1050 | "@firebase/database-types": "0.10.4", 1051 | "@firebase/logger": "0.4.0", 1052 | "@firebase/util": "1.9.3", 1053 | "tslib": "^2.1.0" 1054 | } 1055 | }, 1056 | "node_modules/@firebase/database-types": { 1057 | "version": "0.10.4", 1058 | "resolved": "https://registry.npmjs.org/@firebase/database-types/-/database-types-0.10.4.tgz", 1059 | "integrity": "sha512-dPySn0vJ/89ZeBac70T+2tWWPiJXWbmRygYv0smT5TfE3hDrQ09eKMF3Y+vMlTdrMWq7mUdYW5REWPSGH4kAZQ==", 1060 | "dependencies": { 1061 | "@firebase/app-types": "0.9.0", 1062 | "@firebase/util": "1.9.3" 1063 | } 1064 | }, 1065 | "node_modules/@firebase/firestore": { 1066 | "version": "3.11.0", 1067 | "resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-3.11.0.tgz", 1068 | "integrity": "sha512-r9qUbjuIKOXAVYwqZaamgXuUJBuV8I2X0Kao5PUxQAPueV2mRapdIlby6awYgjknE8kq1Tlys5Nf5/TV6WtnAg==", 1069 | "dependencies": { 1070 | "@firebase/component": "0.6.4", 1071 | "@firebase/logger": "0.4.0", 1072 | "@firebase/util": "1.9.3", 1073 | "@firebase/webchannel-wrapper": "0.10.0", 1074 | "@grpc/grpc-js": "~1.7.0", 1075 | "@grpc/proto-loader": "^0.6.13", 1076 | "node-fetch": "2.6.7", 1077 | "tslib": "^2.1.0" 1078 | }, 1079 | "engines": { 1080 | "node": ">=10.10.0" 1081 | }, 1082 | "peerDependencies": { 1083 | "@firebase/app": "0.x" 1084 | } 1085 | }, 1086 | "node_modules/@firebase/firestore-compat": { 1087 | "version": "0.3.8", 1088 | "resolved": "https://registry.npmjs.org/@firebase/firestore-compat/-/firestore-compat-0.3.8.tgz", 1089 | "integrity": "sha512-VrTckDEVBqFWFsHGVdQgCb0Tht/Rrg/nKFp2aat0FaIjr8A9t4Pfcuu32Py25SbiCnr98pyh3RmVYs0kbF/lCA==", 1090 | "dependencies": { 1091 | "@firebase/component": "0.6.4", 1092 | "@firebase/firestore": "3.11.0", 1093 | "@firebase/firestore-types": "2.5.1", 1094 | "@firebase/util": "1.9.3", 1095 | "tslib": "^2.1.0" 1096 | }, 1097 | "peerDependencies": { 1098 | "@firebase/app-compat": "0.x" 1099 | } 1100 | }, 1101 | "node_modules/@firebase/firestore-types": { 1102 | "version": "2.5.1", 1103 | "resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-2.5.1.tgz", 1104 | "integrity": "sha512-xG0CA6EMfYo8YeUxC8FeDzf6W3FX1cLlcAGBYV6Cku12sZRI81oWcu61RSKM66K6kUENP+78Qm8mvroBcm1whw==", 1105 | "peerDependencies": { 1106 | "@firebase/app-types": "0.x", 1107 | "@firebase/util": "1.x" 1108 | } 1109 | }, 1110 | "node_modules/@firebase/functions": { 1111 | "version": "0.9.4", 1112 | "resolved": "https://registry.npmjs.org/@firebase/functions/-/functions-0.9.4.tgz", 1113 | "integrity": "sha512-3H2qh6U+q+nepO5Hds+Ddl6J0pS+zisuBLqqQMRBHv9XpWfu0PnDHklNmE8rZ+ccTEXvBj6zjkPfdxt6NisvlQ==", 1114 | "dependencies": { 1115 | "@firebase/app-check-interop-types": "0.2.0", 1116 | "@firebase/auth-interop-types": "0.2.1", 1117 | "@firebase/component": "0.6.4", 1118 | "@firebase/messaging-interop-types": "0.2.0", 1119 | "@firebase/util": "1.9.3", 1120 | "node-fetch": "2.6.7", 1121 | "tslib": "^2.1.0" 1122 | }, 1123 | "peerDependencies": { 1124 | "@firebase/app": "0.x" 1125 | } 1126 | }, 1127 | "node_modules/@firebase/functions-compat": { 1128 | "version": "0.3.4", 1129 | "resolved": "https://registry.npmjs.org/@firebase/functions-compat/-/functions-compat-0.3.4.tgz", 1130 | "integrity": "sha512-kxVxTGyLV1MBR3sp3mI+eQ6JBqz0G5bk310F8eX4HzDFk4xjk5xY0KdHktMH+edM2xs1BOg0vwvvsAHczIjB+w==", 1131 | "dependencies": { 1132 | "@firebase/component": "0.6.4", 1133 | "@firebase/functions": "0.9.4", 1134 | "@firebase/functions-types": "0.6.0", 1135 | "@firebase/util": "1.9.3", 1136 | "tslib": "^2.1.0" 1137 | }, 1138 | "peerDependencies": { 1139 | "@firebase/app-compat": "0.x" 1140 | } 1141 | }, 1142 | "node_modules/@firebase/functions-types": { 1143 | "version": "0.6.0", 1144 | "resolved": "https://registry.npmjs.org/@firebase/functions-types/-/functions-types-0.6.0.tgz", 1145 | "integrity": "sha512-hfEw5VJtgWXIRf92ImLkgENqpL6IWpYaXVYiRkFY1jJ9+6tIhWM7IzzwbevwIIud/jaxKVdRzD7QBWfPmkwCYw==" 1146 | }, 1147 | "node_modules/@firebase/installations": { 1148 | "version": "0.6.4", 1149 | "resolved": "https://registry.npmjs.org/@firebase/installations/-/installations-0.6.4.tgz", 1150 | "integrity": "sha512-u5y88rtsp7NYkCHC3ElbFBrPtieUybZluXyzl7+4BsIz4sqb4vSAuwHEUgCgCeaQhvsnxDEU6icly8U9zsJigA==", 1151 | "dependencies": { 1152 | "@firebase/component": "0.6.4", 1153 | "@firebase/util": "1.9.3", 1154 | "idb": "7.0.1", 1155 | "tslib": "^2.1.0" 1156 | }, 1157 | "peerDependencies": { 1158 | "@firebase/app": "0.x" 1159 | } 1160 | }, 1161 | "node_modules/@firebase/installations-compat": { 1162 | "version": "0.2.4", 1163 | "resolved": "https://registry.npmjs.org/@firebase/installations-compat/-/installations-compat-0.2.4.tgz", 1164 | "integrity": "sha512-LI9dYjp0aT9Njkn9U4JRrDqQ6KXeAmFbRC0E7jI7+hxl5YmRWysq5qgQl22hcWpTk+cm3es66d/apoDU/A9n6Q==", 1165 | "dependencies": { 1166 | "@firebase/component": "0.6.4", 1167 | "@firebase/installations": "0.6.4", 1168 | "@firebase/installations-types": "0.5.0", 1169 | "@firebase/util": "1.9.3", 1170 | "tslib": "^2.1.0" 1171 | }, 1172 | "peerDependencies": { 1173 | "@firebase/app-compat": "0.x" 1174 | } 1175 | }, 1176 | "node_modules/@firebase/installations-types": { 1177 | "version": "0.5.0", 1178 | "resolved": "https://registry.npmjs.org/@firebase/installations-types/-/installations-types-0.5.0.tgz", 1179 | "integrity": "sha512-9DP+RGfzoI2jH7gY4SlzqvZ+hr7gYzPODrbzVD82Y12kScZ6ZpRg/i3j6rleto8vTFC8n6Len4560FnV1w2IRg==", 1180 | "peerDependencies": { 1181 | "@firebase/app-types": "0.x" 1182 | } 1183 | }, 1184 | "node_modules/@firebase/installations/node_modules/idb": { 1185 | "version": "7.0.1", 1186 | "resolved": "https://registry.npmjs.org/idb/-/idb-7.0.1.tgz", 1187 | "integrity": "sha512-UUxlE7vGWK5RfB/fDwEGgRf84DY/ieqNha6msMV99UsEMQhJ1RwbCd8AYBj3QMgnE3VZnfQvm4oKVCJTYlqIgg==" 1188 | }, 1189 | "node_modules/@firebase/logger": { 1190 | "version": "0.4.0", 1191 | "resolved": "https://registry.npmjs.org/@firebase/logger/-/logger-0.4.0.tgz", 1192 | "integrity": "sha512-eRKSeykumZ5+cJPdxxJRgAC3G5NknY2GwEbKfymdnXtnT0Ucm4pspfR6GT4MUQEDuJwRVbVcSx85kgJulMoFFA==", 1193 | "dependencies": { 1194 | "tslib": "^2.1.0" 1195 | } 1196 | }, 1197 | "node_modules/@firebase/messaging": { 1198 | "version": "0.12.4", 1199 | "resolved": "https://registry.npmjs.org/@firebase/messaging/-/messaging-0.12.4.tgz", 1200 | "integrity": "sha512-6JLZct6zUaex4g7HI3QbzeUrg9xcnmDAPTWpkoMpd/GoSVWH98zDoWXMGrcvHeCAIsLpFMe4MPoZkJbrPhaASw==", 1201 | "dependencies": { 1202 | "@firebase/component": "0.6.4", 1203 | "@firebase/installations": "0.6.4", 1204 | "@firebase/messaging-interop-types": "0.2.0", 1205 | "@firebase/util": "1.9.3", 1206 | "idb": "7.0.1", 1207 | "tslib": "^2.1.0" 1208 | }, 1209 | "peerDependencies": { 1210 | "@firebase/app": "0.x" 1211 | } 1212 | }, 1213 | "node_modules/@firebase/messaging-compat": { 1214 | "version": "0.2.4", 1215 | "resolved": "https://registry.npmjs.org/@firebase/messaging-compat/-/messaging-compat-0.2.4.tgz", 1216 | "integrity": "sha512-lyFjeUhIsPRYDPNIkYX1LcZMpoVbBWXX4rPl7c/rqc7G+EUea7IEtSt4MxTvh6fDfPuzLn7+FZADfscC+tNMfg==", 1217 | "dependencies": { 1218 | "@firebase/component": "0.6.4", 1219 | "@firebase/messaging": "0.12.4", 1220 | "@firebase/util": "1.9.3", 1221 | "tslib": "^2.1.0" 1222 | }, 1223 | "peerDependencies": { 1224 | "@firebase/app-compat": "0.x" 1225 | } 1226 | }, 1227 | "node_modules/@firebase/messaging-interop-types": { 1228 | "version": "0.2.0", 1229 | "resolved": "https://registry.npmjs.org/@firebase/messaging-interop-types/-/messaging-interop-types-0.2.0.tgz", 1230 | "integrity": "sha512-ujA8dcRuVeBixGR9CtegfpU4YmZf3Lt7QYkcj693FFannwNuZgfAYaTmbJ40dtjB81SAu6tbFPL9YLNT15KmOQ==" 1231 | }, 1232 | "node_modules/@firebase/messaging/node_modules/idb": { 1233 | "version": "7.0.1", 1234 | "resolved": "https://registry.npmjs.org/idb/-/idb-7.0.1.tgz", 1235 | "integrity": "sha512-UUxlE7vGWK5RfB/fDwEGgRf84DY/ieqNha6msMV99UsEMQhJ1RwbCd8AYBj3QMgnE3VZnfQvm4oKVCJTYlqIgg==" 1236 | }, 1237 | "node_modules/@firebase/performance": { 1238 | "version": "0.6.4", 1239 | "resolved": "https://registry.npmjs.org/@firebase/performance/-/performance-0.6.4.tgz", 1240 | "integrity": "sha512-HfTn/bd8mfy/61vEqaBelNiNnvAbUtME2S25A67Nb34zVuCSCRIX4SseXY6zBnOFj3oLisaEqhVcJmVPAej67g==", 1241 | "dependencies": { 1242 | "@firebase/component": "0.6.4", 1243 | "@firebase/installations": "0.6.4", 1244 | "@firebase/logger": "0.4.0", 1245 | "@firebase/util": "1.9.3", 1246 | "tslib": "^2.1.0" 1247 | }, 1248 | "peerDependencies": { 1249 | "@firebase/app": "0.x" 1250 | } 1251 | }, 1252 | "node_modules/@firebase/performance-compat": { 1253 | "version": "0.2.4", 1254 | "resolved": "https://registry.npmjs.org/@firebase/performance-compat/-/performance-compat-0.2.4.tgz", 1255 | "integrity": "sha512-nnHUb8uP9G8islzcld/k6Bg5RhX62VpbAb/Anj7IXs/hp32Eb2LqFPZK4sy3pKkBUO5wcrlRWQa6wKOxqlUqsg==", 1256 | "dependencies": { 1257 | "@firebase/component": "0.6.4", 1258 | "@firebase/logger": "0.4.0", 1259 | "@firebase/performance": "0.6.4", 1260 | "@firebase/performance-types": "0.2.0", 1261 | "@firebase/util": "1.9.3", 1262 | "tslib": "^2.1.0" 1263 | }, 1264 | "peerDependencies": { 1265 | "@firebase/app-compat": "0.x" 1266 | } 1267 | }, 1268 | "node_modules/@firebase/performance-types": { 1269 | "version": "0.2.0", 1270 | "resolved": "https://registry.npmjs.org/@firebase/performance-types/-/performance-types-0.2.0.tgz", 1271 | "integrity": "sha512-kYrbr8e/CYr1KLrLYZZt2noNnf+pRwDq2KK9Au9jHrBMnb0/C9X9yWSXmZkFt4UIdsQknBq8uBB7fsybZdOBTA==" 1272 | }, 1273 | "node_modules/@firebase/remote-config": { 1274 | "version": "0.4.4", 1275 | "resolved": "https://registry.npmjs.org/@firebase/remote-config/-/remote-config-0.4.4.tgz", 1276 | "integrity": "sha512-x1ioTHGX8ZwDSTOVp8PBLv2/wfwKzb4pxi0gFezS5GCJwbLlloUH4YYZHHS83IPxnua8b6l0IXUaWd0RgbWwzQ==", 1277 | "dependencies": { 1278 | "@firebase/component": "0.6.4", 1279 | "@firebase/installations": "0.6.4", 1280 | "@firebase/logger": "0.4.0", 1281 | "@firebase/util": "1.9.3", 1282 | "tslib": "^2.1.0" 1283 | }, 1284 | "peerDependencies": { 1285 | "@firebase/app": "0.x" 1286 | } 1287 | }, 1288 | "node_modules/@firebase/remote-config-compat": { 1289 | "version": "0.2.4", 1290 | "resolved": "https://registry.npmjs.org/@firebase/remote-config-compat/-/remote-config-compat-0.2.4.tgz", 1291 | "integrity": "sha512-FKiki53jZirrDFkBHglB3C07j5wBpitAaj8kLME6g8Mx+aq7u9P7qfmuSRytiOItADhWUj7O1JIv7n9q87SuwA==", 1292 | "dependencies": { 1293 | "@firebase/component": "0.6.4", 1294 | "@firebase/logger": "0.4.0", 1295 | "@firebase/remote-config": "0.4.4", 1296 | "@firebase/remote-config-types": "0.3.0", 1297 | "@firebase/util": "1.9.3", 1298 | "tslib": "^2.1.0" 1299 | }, 1300 | "peerDependencies": { 1301 | "@firebase/app-compat": "0.x" 1302 | } 1303 | }, 1304 | "node_modules/@firebase/remote-config-types": { 1305 | "version": "0.3.0", 1306 | "resolved": "https://registry.npmjs.org/@firebase/remote-config-types/-/remote-config-types-0.3.0.tgz", 1307 | "integrity": "sha512-RtEH4vdcbXZuZWRZbIRmQVBNsE7VDQpet2qFvq6vwKLBIQRQR5Kh58M4ok3A3US8Sr3rubYnaGqZSurCwI8uMA==" 1308 | }, 1309 | "node_modules/@firebase/storage": { 1310 | "version": "0.11.2", 1311 | "resolved": "https://registry.npmjs.org/@firebase/storage/-/storage-0.11.2.tgz", 1312 | "integrity": "sha512-CtvoFaBI4hGXlXbaCHf8humajkbXhs39Nbh6MbNxtwJiCqxPy9iH3D3CCfXAvP0QvAAwmJUTK3+z9a++Kc4nkA==", 1313 | "dependencies": { 1314 | "@firebase/component": "0.6.4", 1315 | "@firebase/util": "1.9.3", 1316 | "node-fetch": "2.6.7", 1317 | "tslib": "^2.1.0" 1318 | }, 1319 | "peerDependencies": { 1320 | "@firebase/app": "0.x" 1321 | } 1322 | }, 1323 | "node_modules/@firebase/storage-compat": { 1324 | "version": "0.3.2", 1325 | "resolved": "https://registry.npmjs.org/@firebase/storage-compat/-/storage-compat-0.3.2.tgz", 1326 | "integrity": "sha512-wvsXlLa9DVOMQJckbDNhXKKxRNNewyUhhbXev3t8kSgoCotd1v3MmqhKKz93ePhDnhHnDs7bYHy+Qa8dRY6BXw==", 1327 | "dependencies": { 1328 | "@firebase/component": "0.6.4", 1329 | "@firebase/storage": "0.11.2", 1330 | "@firebase/storage-types": "0.8.0", 1331 | "@firebase/util": "1.9.3", 1332 | "tslib": "^2.1.0" 1333 | }, 1334 | "peerDependencies": { 1335 | "@firebase/app-compat": "0.x" 1336 | } 1337 | }, 1338 | "node_modules/@firebase/storage-types": { 1339 | "version": "0.8.0", 1340 | "resolved": "https://registry.npmjs.org/@firebase/storage-types/-/storage-types-0.8.0.tgz", 1341 | "integrity": "sha512-isRHcGrTs9kITJC0AVehHfpraWFui39MPaU7Eo8QfWlqW7YPymBmRgjDrlOgFdURh6Cdeg07zmkLP5tzTKRSpg==", 1342 | "peerDependencies": { 1343 | "@firebase/app-types": "0.x", 1344 | "@firebase/util": "1.x" 1345 | } 1346 | }, 1347 | "node_modules/@firebase/util": { 1348 | "version": "1.9.3", 1349 | "resolved": "https://registry.npmjs.org/@firebase/util/-/util-1.9.3.tgz", 1350 | "integrity": "sha512-DY02CRhOZwpzO36fHpuVysz6JZrscPiBXD0fXp6qSrL9oNOx5KWICKdR95C0lSITzxp0TZosVyHqzatE8JbcjA==", 1351 | "dependencies": { 1352 | "tslib": "^2.1.0" 1353 | } 1354 | }, 1355 | "node_modules/@firebase/webchannel-wrapper": { 1356 | "version": "0.10.0", 1357 | "resolved": "https://registry.npmjs.org/@firebase/webchannel-wrapper/-/webchannel-wrapper-0.10.0.tgz", 1358 | "integrity": "sha512-2I8y+vJVrPfPFJrnRGpao1Qc2Gu7wmYoo5ed2s5zK/DUGgcyY1Yr/xC0YdnKM4pi7rG3HqwW9ehAKUXoTMLdoA==" 1359 | }, 1360 | "node_modules/@grpc/grpc-js": { 1361 | "version": "1.7.3", 1362 | "resolved": "https://registry.npmjs.org/@grpc/grpc-js/-/grpc-js-1.7.3.tgz", 1363 | "integrity": "sha512-H9l79u4kJ2PVSxUNA08HMYAnUBLj9v6KjYQ7SQ71hOZcEXhShE/y5iQCesP8+6/Ik/7i2O0a10bPquIcYfufog==", 1364 | "dependencies": { 1365 | "@grpc/proto-loader": "^0.7.0", 1366 | "@types/node": ">=12.12.47" 1367 | }, 1368 | "engines": { 1369 | "node": "^8.13.0 || >=10.10.0" 1370 | } 1371 | }, 1372 | "node_modules/@grpc/grpc-js/node_modules/@grpc/proto-loader": { 1373 | "version": "0.7.7", 1374 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.7.7.tgz", 1375 | "integrity": "sha512-1TIeXOi8TuSCQprPItwoMymZXxWT0CPxUhkrkeCUH+D8U7QDwQ6b7SUz2MaLuWM2llT+J/TVFLmQI5KtML3BhQ==", 1376 | "dependencies": { 1377 | "@types/long": "^4.0.1", 1378 | "lodash.camelcase": "^4.3.0", 1379 | "long": "^4.0.0", 1380 | "protobufjs": "^7.0.0", 1381 | "yargs": "^17.7.2" 1382 | }, 1383 | "bin": { 1384 | "proto-loader-gen-types": "build/bin/proto-loader-gen-types.js" 1385 | }, 1386 | "engines": { 1387 | "node": ">=6" 1388 | } 1389 | }, 1390 | "node_modules/@grpc/grpc-js/node_modules/cliui": { 1391 | "version": "8.0.1", 1392 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", 1393 | "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", 1394 | "dependencies": { 1395 | "string-width": "^4.2.0", 1396 | "strip-ansi": "^6.0.1", 1397 | "wrap-ansi": "^7.0.0" 1398 | }, 1399 | "engines": { 1400 | "node": ">=12" 1401 | } 1402 | }, 1403 | "node_modules/@grpc/grpc-js/node_modules/protobufjs": { 1404 | "version": "7.2.3", 1405 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-7.2.3.tgz", 1406 | "integrity": "sha512-TtpvOqwB5Gdz/PQmOjgsrGH1nHjAQVCN7JG4A6r1sXRWESL5rNMAiRcBQlCAdKxZcAbstExQePYG8xof/JVRgg==", 1407 | "hasInstallScript": true, 1408 | "dependencies": { 1409 | "@protobufjs/aspromise": "^1.1.2", 1410 | "@protobufjs/base64": "^1.1.2", 1411 | "@protobufjs/codegen": "^2.0.4", 1412 | "@protobufjs/eventemitter": "^1.1.0", 1413 | "@protobufjs/fetch": "^1.1.0", 1414 | "@protobufjs/float": "^1.0.2", 1415 | "@protobufjs/inquire": "^1.1.0", 1416 | "@protobufjs/path": "^1.1.2", 1417 | "@protobufjs/pool": "^1.1.0", 1418 | "@protobufjs/utf8": "^1.1.0", 1419 | "@types/node": ">=13.7.0", 1420 | "long": "^5.0.0" 1421 | }, 1422 | "engines": { 1423 | "node": ">=12.0.0" 1424 | } 1425 | }, 1426 | "node_modules/@grpc/grpc-js/node_modules/protobufjs/node_modules/long": { 1427 | "version": "5.2.3", 1428 | "resolved": "https://registry.npmjs.org/long/-/long-5.2.3.tgz", 1429 | "integrity": "sha512-lcHwpNoggQTObv5apGNCTdJrO69eHOZMi4BNC+rTLER8iHAqGrUVeLh/irVIM7zTw2bOXA8T6uNPeujwOLg/2Q==" 1430 | }, 1431 | "node_modules/@grpc/grpc-js/node_modules/yargs": { 1432 | "version": "17.7.2", 1433 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", 1434 | "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", 1435 | "dependencies": { 1436 | "cliui": "^8.0.1", 1437 | "escalade": "^3.1.1", 1438 | "get-caller-file": "^2.0.5", 1439 | "require-directory": "^2.1.1", 1440 | "string-width": "^4.2.3", 1441 | "y18n": "^5.0.5", 1442 | "yargs-parser": "^21.1.1" 1443 | }, 1444 | "engines": { 1445 | "node": ">=12" 1446 | } 1447 | }, 1448 | "node_modules/@grpc/grpc-js/node_modules/yargs-parser": { 1449 | "version": "21.1.1", 1450 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", 1451 | "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", 1452 | "engines": { 1453 | "node": ">=12" 1454 | } 1455 | }, 1456 | "node_modules/@grpc/proto-loader": { 1457 | "version": "0.6.13", 1458 | "resolved": "https://registry.npmjs.org/@grpc/proto-loader/-/proto-loader-0.6.13.tgz", 1459 | "integrity": "sha512-FjxPYDRTn6Ec3V0arm1FtSpmP6V50wuph2yILpyvTKzjc76oDdoihXqM1DzOW5ubvCC8GivfCnNtfaRE8myJ7g==", 1460 | "dependencies": { 1461 | "@types/long": "^4.0.1", 1462 | "lodash.camelcase": "^4.3.0", 1463 | "long": "^4.0.0", 1464 | "protobufjs": "^6.11.3", 1465 | "yargs": "^16.2.0" 1466 | }, 1467 | "bin": { 1468 | "proto-loader-gen-types": "build/bin/proto-loader-gen-types.js" 1469 | }, 1470 | "engines": { 1471 | "node": ">=6" 1472 | } 1473 | }, 1474 | "node_modules/@jridgewell/gen-mapping": { 1475 | "version": "0.3.3", 1476 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", 1477 | "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", 1478 | "dev": true, 1479 | "dependencies": { 1480 | "@jridgewell/set-array": "^1.0.1", 1481 | "@jridgewell/sourcemap-codec": "^1.4.10", 1482 | "@jridgewell/trace-mapping": "^0.3.9" 1483 | }, 1484 | "engines": { 1485 | "node": ">=6.0.0" 1486 | } 1487 | }, 1488 | "node_modules/@jridgewell/resolve-uri": { 1489 | "version": "3.1.0", 1490 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 1491 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 1492 | "dev": true, 1493 | "engines": { 1494 | "node": ">=6.0.0" 1495 | } 1496 | }, 1497 | "node_modules/@jridgewell/set-array": { 1498 | "version": "1.1.2", 1499 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 1500 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 1501 | "dev": true, 1502 | "engines": { 1503 | "node": ">=6.0.0" 1504 | } 1505 | }, 1506 | "node_modules/@jridgewell/sourcemap-codec": { 1507 | "version": "1.4.15", 1508 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 1509 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 1510 | "dev": true 1511 | }, 1512 | "node_modules/@jridgewell/trace-mapping": { 1513 | "version": "0.3.18", 1514 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", 1515 | "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", 1516 | "dev": true, 1517 | "dependencies": { 1518 | "@jridgewell/resolve-uri": "3.1.0", 1519 | "@jridgewell/sourcemap-codec": "1.4.14" 1520 | } 1521 | }, 1522 | "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { 1523 | "version": "1.4.14", 1524 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 1525 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 1526 | "dev": true 1527 | }, 1528 | "node_modules/@mui/base": { 1529 | "version": "5.0.0-alpha.128", 1530 | "resolved": "https://registry.npmjs.org/@mui/base/-/base-5.0.0-alpha.128.tgz", 1531 | "integrity": "sha512-wub3wxNN+hUp8hzilMlXX3sZrPo75vsy1cXEQpqdTfIFlE9HprP1jlulFiPg5tfPst2OKmygXr2hhmgvAKRrzQ==", 1532 | "dependencies": { 1533 | "@babel/runtime": "^7.21.0", 1534 | "@emotion/is-prop-valid": "^1.2.0", 1535 | "@mui/types": "^7.2.4", 1536 | "@mui/utils": "^5.12.3", 1537 | "@popperjs/core": "^2.11.7", 1538 | "clsx": "^1.2.1", 1539 | "prop-types": "^15.8.1", 1540 | "react-is": "^18.2.0" 1541 | }, 1542 | "engines": { 1543 | "node": ">=12.0.0" 1544 | }, 1545 | "funding": { 1546 | "type": "opencollective", 1547 | "url": "https://opencollective.com/mui" 1548 | }, 1549 | "peerDependencies": { 1550 | "@types/react": "^17.0.0 || ^18.0.0", 1551 | "react": "^17.0.0 || ^18.0.0", 1552 | "react-dom": "^17.0.0 || ^18.0.0" 1553 | }, 1554 | "peerDependenciesMeta": { 1555 | "@types/react": { 1556 | "optional": true 1557 | } 1558 | } 1559 | }, 1560 | "node_modules/@mui/base/node_modules/react-is": { 1561 | "version": "18.2.0", 1562 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", 1563 | "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==" 1564 | }, 1565 | "node_modules/@mui/core-downloads-tracker": { 1566 | "version": "5.12.3", 1567 | "resolved": "https://registry.npmjs.org/@mui/core-downloads-tracker/-/core-downloads-tracker-5.12.3.tgz", 1568 | "integrity": "sha512-yiJZ+knaknPHuRKhRk4L6XiwppwkAahVal3LuYpvBH7GkA2g+D9WLEXOEnNYtVFUggyKf6fWGLGnx0iqzkU5YA==", 1569 | "funding": { 1570 | "type": "opencollective", 1571 | "url": "https://opencollective.com/mui" 1572 | } 1573 | }, 1574 | "node_modules/@mui/icons-material": { 1575 | "version": "5.11.16", 1576 | "resolved": "https://registry.npmjs.org/@mui/icons-material/-/icons-material-5.11.16.tgz", 1577 | "integrity": "sha512-oKkx9z9Kwg40NtcIajF9uOXhxiyTZrrm9nmIJ4UjkU2IdHpd4QVLbCc/5hZN/y0C6qzi2Zlxyr9TGddQx2vx2A==", 1578 | "dependencies": { 1579 | "@babel/runtime": "^7.21.0" 1580 | }, 1581 | "engines": { 1582 | "node": ">=12.0.0" 1583 | }, 1584 | "funding": { 1585 | "type": "opencollective", 1586 | "url": "https://opencollective.com/mui" 1587 | }, 1588 | "peerDependencies": { 1589 | "@mui/material": "^5.0.0", 1590 | "@types/react": "^17.0.0 || ^18.0.0", 1591 | "react": "^17.0.0 || ^18.0.0" 1592 | }, 1593 | "peerDependenciesMeta": { 1594 | "@types/react": { 1595 | "optional": true 1596 | } 1597 | } 1598 | }, 1599 | "node_modules/@mui/material": { 1600 | "version": "5.12.3", 1601 | "resolved": "https://registry.npmjs.org/@mui/material/-/material-5.12.3.tgz", 1602 | "integrity": "sha512-xNmKlrEN4HsTaKFNLZfc7ie7CXx2YqEeO//hsXZx2p3MGtDdeMr2sV3jC4hsFs57RhQlF79weY7uVvC8xSuVbg==", 1603 | "dependencies": { 1604 | "@babel/runtime": "^7.21.0", 1605 | "@mui/base": "5.0.0-alpha.128", 1606 | "@mui/core-downloads-tracker": "^5.12.3", 1607 | "@mui/system": "^5.12.3", 1608 | "@mui/types": "^7.2.4", 1609 | "@mui/utils": "^5.12.3", 1610 | "@types/react-transition-group": "^4.4.5", 1611 | "clsx": "^1.2.1", 1612 | "csstype": "^3.1.2", 1613 | "prop-types": "^15.8.1", 1614 | "react-is": "^18.2.0", 1615 | "react-transition-group": "^4.4.5" 1616 | }, 1617 | "engines": { 1618 | "node": ">=12.0.0" 1619 | }, 1620 | "funding": { 1621 | "type": "opencollective", 1622 | "url": "https://opencollective.com/mui" 1623 | }, 1624 | "peerDependencies": { 1625 | "@emotion/react": "^11.5.0", 1626 | "@emotion/styled": "^11.3.0", 1627 | "@types/react": "^17.0.0 || ^18.0.0", 1628 | "react": "^17.0.0 || ^18.0.0", 1629 | "react-dom": "^17.0.0 || ^18.0.0" 1630 | }, 1631 | "peerDependenciesMeta": { 1632 | "@emotion/react": { 1633 | "optional": true 1634 | }, 1635 | "@emotion/styled": { 1636 | "optional": true 1637 | }, 1638 | "@types/react": { 1639 | "optional": true 1640 | } 1641 | } 1642 | }, 1643 | "node_modules/@mui/material/node_modules/react-is": { 1644 | "version": "18.2.0", 1645 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", 1646 | "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==" 1647 | }, 1648 | "node_modules/@mui/private-theming": { 1649 | "version": "5.12.3", 1650 | "resolved": "https://registry.npmjs.org/@mui/private-theming/-/private-theming-5.12.3.tgz", 1651 | "integrity": "sha512-o1e7Z1Bp27n4x2iUHhegV4/Jp6H3T6iBKHJdLivS5GbwsuAE/5l4SnZ+7+K+e5u9TuhwcAKZLkjvqzkDe8zqfA==", 1652 | "dependencies": { 1653 | "@babel/runtime": "^7.21.0", 1654 | "@mui/utils": "^5.12.3", 1655 | "prop-types": "^15.8.1" 1656 | }, 1657 | "engines": { 1658 | "node": ">=12.0.0" 1659 | }, 1660 | "funding": { 1661 | "type": "opencollective", 1662 | "url": "https://opencollective.com/mui" 1663 | }, 1664 | "peerDependencies": { 1665 | "@types/react": "^17.0.0 || ^18.0.0", 1666 | "react": "^17.0.0 || ^18.0.0" 1667 | }, 1668 | "peerDependenciesMeta": { 1669 | "@types/react": { 1670 | "optional": true 1671 | } 1672 | } 1673 | }, 1674 | "node_modules/@mui/styled-engine": { 1675 | "version": "5.12.3", 1676 | "resolved": "https://registry.npmjs.org/@mui/styled-engine/-/styled-engine-5.12.3.tgz", 1677 | "integrity": "sha512-AhZtiRyT8Bjr7fufxE/mLS+QJ3LxwX1kghIcM2B2dvJzSSg9rnIuXDXM959QfUVIM3C8U4x3mgVoPFMQJvc4/g==", 1678 | "dependencies": { 1679 | "@babel/runtime": "^7.21.0", 1680 | "@emotion/cache": "^11.10.8", 1681 | "csstype": "^3.1.2", 1682 | "prop-types": "^15.8.1" 1683 | }, 1684 | "engines": { 1685 | "node": ">=12.0.0" 1686 | }, 1687 | "funding": { 1688 | "type": "opencollective", 1689 | "url": "https://opencollective.com/mui" 1690 | }, 1691 | "peerDependencies": { 1692 | "@emotion/react": "^11.4.1", 1693 | "@emotion/styled": "^11.3.0", 1694 | "react": "^17.0.0 || ^18.0.0" 1695 | }, 1696 | "peerDependenciesMeta": { 1697 | "@emotion/react": { 1698 | "optional": true 1699 | }, 1700 | "@emotion/styled": { 1701 | "optional": true 1702 | } 1703 | } 1704 | }, 1705 | "node_modules/@mui/system": { 1706 | "version": "5.12.3", 1707 | "resolved": "https://registry.npmjs.org/@mui/system/-/system-5.12.3.tgz", 1708 | "integrity": "sha512-JB/6sypHqeJCqwldWeQ1MKkijH829EcZAKKizxbU2MJdxGG5KSwZvTBa5D9qiJUA1hJFYYupjiuy9ZdJt6rV6w==", 1709 | "dependencies": { 1710 | "@babel/runtime": "^7.21.0", 1711 | "@mui/private-theming": "^5.12.3", 1712 | "@mui/styled-engine": "^5.12.3", 1713 | "@mui/types": "^7.2.4", 1714 | "@mui/utils": "^5.12.3", 1715 | "clsx": "^1.2.1", 1716 | "csstype": "^3.1.2", 1717 | "prop-types": "^15.8.1" 1718 | }, 1719 | "engines": { 1720 | "node": ">=12.0.0" 1721 | }, 1722 | "funding": { 1723 | "type": "opencollective", 1724 | "url": "https://opencollective.com/mui" 1725 | }, 1726 | "peerDependencies": { 1727 | "@emotion/react": "^11.5.0", 1728 | "@emotion/styled": "^11.3.0", 1729 | "@types/react": "^17.0.0 || ^18.0.0", 1730 | "react": "^17.0.0 || ^18.0.0" 1731 | }, 1732 | "peerDependenciesMeta": { 1733 | "@emotion/react": { 1734 | "optional": true 1735 | }, 1736 | "@emotion/styled": { 1737 | "optional": true 1738 | }, 1739 | "@types/react": { 1740 | "optional": true 1741 | } 1742 | } 1743 | }, 1744 | "node_modules/@mui/types": { 1745 | "version": "7.2.4", 1746 | "resolved": "https://registry.npmjs.org/@mui/types/-/types-7.2.4.tgz", 1747 | "integrity": "sha512-LBcwa8rN84bKF+f5sDyku42w1NTxaPgPyYKODsh01U1fVstTClbUoSA96oyRBnSNyEiAVjKm6Gwx9vjR+xyqHA==", 1748 | "peerDependencies": { 1749 | "@types/react": "*" 1750 | }, 1751 | "peerDependenciesMeta": { 1752 | "@types/react": { 1753 | "optional": true 1754 | } 1755 | } 1756 | }, 1757 | "node_modules/@mui/utils": { 1758 | "version": "5.12.3", 1759 | "resolved": "https://registry.npmjs.org/@mui/utils/-/utils-5.12.3.tgz", 1760 | "integrity": "sha512-D/Z4Ub3MRl7HiUccid7sQYclTr24TqUAQFFlxHQF8FR177BrCTQ0JJZom7EqYjZCdXhwnSkOj2ph685MSKNtIA==", 1761 | "dependencies": { 1762 | "@babel/runtime": "^7.21.0", 1763 | "@types/prop-types": "^15.7.5", 1764 | "@types/react-is": "^16.7.1 || ^17.0.0", 1765 | "prop-types": "^15.8.1", 1766 | "react-is": "^18.2.0" 1767 | }, 1768 | "engines": { 1769 | "node": ">=12.0.0" 1770 | }, 1771 | "funding": { 1772 | "type": "opencollective", 1773 | "url": "https://opencollective.com/mui" 1774 | }, 1775 | "peerDependencies": { 1776 | "react": "^17.0.0 || ^18.0.0" 1777 | } 1778 | }, 1779 | "node_modules/@mui/utils/node_modules/react-is": { 1780 | "version": "18.2.0", 1781 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz", 1782 | "integrity": "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==" 1783 | }, 1784 | "node_modules/@popperjs/core": { 1785 | "version": "2.11.7", 1786 | "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.7.tgz", 1787 | "integrity": "sha512-Cr4OjIkipTtcXKjAsm8agyleBuDHvxzeBoa1v543lbv1YaIwQjESsVcmjiWiPEbC1FIeHOG/Op9kdCmAmiS3Kw==", 1788 | "funding": { 1789 | "type": "opencollective", 1790 | "url": "https://opencollective.com/popperjs" 1791 | } 1792 | }, 1793 | "node_modules/@protobufjs/aspromise": { 1794 | "version": "1.1.2", 1795 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 1796 | "integrity": "sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ==" 1797 | }, 1798 | "node_modules/@protobufjs/base64": { 1799 | "version": "1.1.2", 1800 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 1801 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 1802 | }, 1803 | "node_modules/@protobufjs/codegen": { 1804 | "version": "2.0.4", 1805 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 1806 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 1807 | }, 1808 | "node_modules/@protobufjs/eventemitter": { 1809 | "version": "1.1.0", 1810 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 1811 | "integrity": "sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q==" 1812 | }, 1813 | "node_modules/@protobufjs/fetch": { 1814 | "version": "1.1.0", 1815 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 1816 | "integrity": "sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ==", 1817 | "dependencies": { 1818 | "@protobufjs/aspromise": "^1.1.1", 1819 | "@protobufjs/inquire": "^1.1.0" 1820 | } 1821 | }, 1822 | "node_modules/@protobufjs/float": { 1823 | "version": "1.0.2", 1824 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 1825 | "integrity": "sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ==" 1826 | }, 1827 | "node_modules/@protobufjs/inquire": { 1828 | "version": "1.1.0", 1829 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 1830 | "integrity": "sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q==" 1831 | }, 1832 | "node_modules/@protobufjs/path": { 1833 | "version": "1.1.2", 1834 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 1835 | "integrity": "sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA==" 1836 | }, 1837 | "node_modules/@protobufjs/pool": { 1838 | "version": "1.1.0", 1839 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 1840 | "integrity": "sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw==" 1841 | }, 1842 | "node_modules/@protobufjs/utf8": { 1843 | "version": "1.1.0", 1844 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 1845 | "integrity": "sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw==" 1846 | }, 1847 | "node_modules/@remix-run/router": { 1848 | "version": "1.6.1", 1849 | "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.6.1.tgz", 1850 | "integrity": "sha512-YUkWj+xs0oOzBe74OgErsuR3wVn+efrFhXBWrit50kOiED+pvQe2r6MWY0iJMQU/mSVKxvNzL4ZaYvjdX+G7ZA==", 1851 | "engines": { 1852 | "node": ">=14" 1853 | } 1854 | }, 1855 | "node_modules/@types/hoist-non-react-statics": { 1856 | "version": "3.3.1", 1857 | "resolved": "https://registry.npmjs.org/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.1.tgz", 1858 | "integrity": "sha512-iMIqiko6ooLrTh1joXodJK5X9xeEALT1kM5G3ZLhD3hszxBdIEd5C75U834D9mLcINgD4OyZf5uQXjkuYydWvA==", 1859 | "dependencies": { 1860 | "@types/react": "*", 1861 | "hoist-non-react-statics": "^3.3.0" 1862 | } 1863 | }, 1864 | "node_modules/@types/long": { 1865 | "version": "4.0.2", 1866 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.2.tgz", 1867 | "integrity": "sha512-MqTGEo5bj5t157U6fA/BiDynNkn0YknVdh48CMPkTSpFTVmvao5UQmm7uEF6xBEo7qIMAlY/JSleYaE6VOdpaA==" 1868 | }, 1869 | "node_modules/@types/node": { 1870 | "version": "20.0.0", 1871 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.0.0.tgz", 1872 | "integrity": "sha512-cD2uPTDnQQCVpmRefonO98/PPijuOnnEy5oytWJFPY1N9aJCz2wJ5kSGWO+zJoed2cY2JxQh6yBuUq4vIn61hw==" 1873 | }, 1874 | "node_modules/@types/parse-json": { 1875 | "version": "4.0.0", 1876 | "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", 1877 | "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" 1878 | }, 1879 | "node_modules/@types/prop-types": { 1880 | "version": "15.7.5", 1881 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", 1882 | "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==" 1883 | }, 1884 | "node_modules/@types/react": { 1885 | "version": "18.2.4", 1886 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.4.tgz", 1887 | "integrity": "sha512-IvAIhJTmKAAJmCIcaa6+5uagjyh+9GvcJ/thPZcw+i+vx+22eHlTy2Q1bJg/prES57jehjebq9DnIhOTtIhmLw==", 1888 | "dependencies": { 1889 | "@types/prop-types": "*", 1890 | "@types/scheduler": "*", 1891 | "csstype": "^3.0.2" 1892 | } 1893 | }, 1894 | "node_modules/@types/react-dom": { 1895 | "version": "18.2.3", 1896 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.3.tgz", 1897 | "integrity": "sha512-hxXEXWxFJXbY0LMj/T69mznqOZJXNtQMqVxIiirVAZnnpeYiD4zt+lPsgcr/cfWg2VLsxZ1y26vigG03prYB+Q==", 1898 | "dev": true, 1899 | "dependencies": { 1900 | "@types/react": "*" 1901 | } 1902 | }, 1903 | "node_modules/@types/react-is": { 1904 | "version": "17.0.4", 1905 | "resolved": "https://registry.npmjs.org/@types/react-is/-/react-is-17.0.4.tgz", 1906 | "integrity": "sha512-FLzd0K9pnaEvKz4D1vYxK9JmgQPiGk1lu23o1kqGsLeT0iPbRSF7b76+S5T9fD8aRa0B8bY7I/3DebEj+1ysBA==", 1907 | "dependencies": { 1908 | "@types/react": "^17" 1909 | } 1910 | }, 1911 | "node_modules/@types/react-is/node_modules/@types/react": { 1912 | "version": "17.0.58", 1913 | "resolved": "https://registry.npmjs.org/@types/react/-/react-17.0.58.tgz", 1914 | "integrity": "sha512-c1GzVY97P0fGxwGxhYq989j4XwlcHQoto6wQISOC2v6wm3h0PORRWJFHlkRjfGsiG3y1609WdQ+J+tKxvrEd6A==", 1915 | "dependencies": { 1916 | "@types/prop-types": "*", 1917 | "@types/scheduler": "*", 1918 | "csstype": "^3.0.2" 1919 | } 1920 | }, 1921 | "node_modules/@types/react-redux": { 1922 | "version": "7.1.25", 1923 | "resolved": "https://registry.npmjs.org/@types/react-redux/-/react-redux-7.1.25.tgz", 1924 | "integrity": "sha512-bAGh4e+w5D8dajd6InASVIyCo4pZLJ66oLb80F9OBLO1gKESbZcRCJpTT6uLXX+HAB57zw1WTdwJdAsewuTweg==", 1925 | "dependencies": { 1926 | "@types/hoist-non-react-statics": "^3.3.0", 1927 | "@types/react": "*", 1928 | "hoist-non-react-statics": "^3.3.0", 1929 | "redux": "^4.0.0" 1930 | } 1931 | }, 1932 | "node_modules/@types/react-transition-group": { 1933 | "version": "4.4.5", 1934 | "resolved": "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.5.tgz", 1935 | "integrity": "sha512-juKD/eiSM3/xZYzjuzH6ZwpP+/lejltmiS3QEzV/vmb/Q8+HfDmxu+Baga8UEMGBqV88Nbg4l2hY/K2DkyaLLA==", 1936 | "dependencies": { 1937 | "@types/react": "*" 1938 | } 1939 | }, 1940 | "node_modules/@types/scheduler": { 1941 | "version": "0.16.3", 1942 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.3.tgz", 1943 | "integrity": "sha512-5cJ8CB4yAx7BH1oMvdU0Jh9lrEXyPkar6F9G/ERswkCuvP4KQZfZkSjcMbAICCpQTN4OuZn8tz0HiKv9TGZgrQ==" 1944 | }, 1945 | "node_modules/@vitejs/plugin-react": { 1946 | "version": "4.0.0", 1947 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.0.0.tgz", 1948 | "integrity": "sha512-HX0XzMjL3hhOYm+0s95pb0Z7F8O81G7joUHgfDd/9J/ZZf5k4xX6QAMFkKsHFxaHlf6X7GD7+XuaZ66ULiJuhQ==", 1949 | "dev": true, 1950 | "dependencies": { 1951 | "@babel/core": "^7.21.4", 1952 | "@babel/plugin-transform-react-jsx-self": "^7.21.0", 1953 | "@babel/plugin-transform-react-jsx-source": "^7.19.6", 1954 | "react-refresh": "^0.14.0" 1955 | }, 1956 | "engines": { 1957 | "node": "^14.18.0 || >=16.0.0" 1958 | }, 1959 | "peerDependencies": { 1960 | "vite": "^4.2.0" 1961 | } 1962 | }, 1963 | "node_modules/ansi-regex": { 1964 | "version": "5.0.1", 1965 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1966 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1967 | "engines": { 1968 | "node": ">=8" 1969 | } 1970 | }, 1971 | "node_modules/ansi-styles": { 1972 | "version": "3.2.1", 1973 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1974 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1975 | "dependencies": { 1976 | "color-convert": "^1.9.0" 1977 | }, 1978 | "engines": { 1979 | "node": ">=4" 1980 | } 1981 | }, 1982 | "node_modules/babel-plugin-macros": { 1983 | "version": "3.1.0", 1984 | "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz", 1985 | "integrity": "sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg==", 1986 | "dependencies": { 1987 | "@babel/runtime": "^7.12.5", 1988 | "cosmiconfig": "^7.0.0", 1989 | "resolve": "^1.19.0" 1990 | }, 1991 | "engines": { 1992 | "node": ">=10", 1993 | "npm": ">=6" 1994 | } 1995 | }, 1996 | "node_modules/babel-plugin-macros/node_modules/resolve": { 1997 | "version": "1.22.2", 1998 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", 1999 | "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", 2000 | "dependencies": { 2001 | "is-core-module": "^2.11.0", 2002 | "path-parse": "^1.0.7", 2003 | "supports-preserve-symlinks-flag": "^1.0.0" 2004 | }, 2005 | "bin": { 2006 | "resolve": "bin/resolve" 2007 | }, 2008 | "funding": { 2009 | "url": "https://github.com/sponsors/ljharb" 2010 | } 2011 | }, 2012 | "node_modules/browserslist": { 2013 | "version": "4.21.5", 2014 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.5.tgz", 2015 | "integrity": "sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==", 2016 | "dev": true, 2017 | "funding": [ 2018 | { 2019 | "type": "opencollective", 2020 | "url": "https://opencollective.com/browserslist" 2021 | }, 2022 | { 2023 | "type": "tidelift", 2024 | "url": "https://tidelift.com/funding/github/npm/browserslist" 2025 | } 2026 | ], 2027 | "dependencies": { 2028 | "caniuse-lite": "^1.0.30001449", 2029 | "electron-to-chromium": "^1.4.284", 2030 | "node-releases": "^2.0.8", 2031 | "update-browserslist-db": "^1.0.10" 2032 | }, 2033 | "bin": { 2034 | "browserslist": "cli.js" 2035 | }, 2036 | "engines": { 2037 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 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 | "engines": { 2045 | "node": ">=6" 2046 | } 2047 | }, 2048 | "node_modules/caniuse-lite": { 2049 | "version": "1.0.30001482", 2050 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001482.tgz", 2051 | "integrity": "sha512-F1ZInsg53cegyjroxLNW9DmrEQ1SuGRTO1QlpA0o2/6OpQ0gFeDRoq1yFmnr8Sakn9qwwt9DmbxHB6w167OSuQ==", 2052 | "dev": true, 2053 | "funding": [ 2054 | { 2055 | "type": "opencollective", 2056 | "url": "https://opencollective.com/browserslist" 2057 | }, 2058 | { 2059 | "type": "tidelift", 2060 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 2061 | }, 2062 | { 2063 | "type": "github", 2064 | "url": "https://github.com/sponsors/ai" 2065 | } 2066 | ] 2067 | }, 2068 | "node_modules/chalk": { 2069 | "version": "2.4.2", 2070 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2071 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2072 | "dependencies": { 2073 | "ansi-styles": "^3.2.1", 2074 | "escape-string-regexp": "^1.0.5", 2075 | "supports-color": "^5.3.0" 2076 | }, 2077 | "engines": { 2078 | "node": ">=4" 2079 | } 2080 | }, 2081 | "node_modules/cliui": { 2082 | "version": "7.0.4", 2083 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 2084 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 2085 | "dependencies": { 2086 | "string-width": "^4.2.0", 2087 | "strip-ansi": "^6.0.0", 2088 | "wrap-ansi": "^7.0.0" 2089 | } 2090 | }, 2091 | "node_modules/clsx": { 2092 | "version": "1.2.1", 2093 | "resolved": "https://registry.npmjs.org/clsx/-/clsx-1.2.1.tgz", 2094 | "integrity": "sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg==", 2095 | "engines": { 2096 | "node": ">=6" 2097 | } 2098 | }, 2099 | "node_modules/color-convert": { 2100 | "version": "1.9.3", 2101 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2102 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2103 | "dependencies": { 2104 | "color-name": "1.1.3" 2105 | } 2106 | }, 2107 | "node_modules/color-name": { 2108 | "version": "1.1.3", 2109 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2110 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" 2111 | }, 2112 | "node_modules/convert-source-map": { 2113 | "version": "1.9.0", 2114 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", 2115 | "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" 2116 | }, 2117 | "node_modules/cosmiconfig": { 2118 | "version": "7.1.0", 2119 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz", 2120 | "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==", 2121 | "dependencies": { 2122 | "@types/parse-json": "^4.0.0", 2123 | "import-fresh": "^3.2.1", 2124 | "parse-json": "^5.0.0", 2125 | "path-type": "^4.0.0", 2126 | "yaml": "^1.10.0" 2127 | }, 2128 | "engines": { 2129 | "node": ">=10" 2130 | } 2131 | }, 2132 | "node_modules/css-box-model": { 2133 | "version": "1.2.1", 2134 | "resolved": "https://registry.npmjs.org/css-box-model/-/css-box-model-1.2.1.tgz", 2135 | "integrity": "sha512-a7Vr4Q/kd/aw96bnJG332W9V9LkJO69JRcaCYDUqjp6/z0w6VcZjgAcTbgFxEPfBgdnAwlh3iwu+hLopa+flJw==", 2136 | "dependencies": { 2137 | "tiny-invariant": "^1.0.6" 2138 | } 2139 | }, 2140 | "node_modules/csstype": { 2141 | "version": "3.1.2", 2142 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.2.tgz", 2143 | "integrity": "sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ==" 2144 | }, 2145 | "node_modules/debug": { 2146 | "version": "4.3.4", 2147 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2148 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2149 | "dev": true, 2150 | "dependencies": { 2151 | "ms": "2.1.2" 2152 | }, 2153 | "engines": { 2154 | "node": ">=6.0" 2155 | }, 2156 | "peerDependenciesMeta": { 2157 | "supports-color": { 2158 | "optional": true 2159 | } 2160 | } 2161 | }, 2162 | "node_modules/dom-helpers": { 2163 | "version": "5.2.1", 2164 | "resolved": "https://registry.npmjs.org/dom-helpers/-/dom-helpers-5.2.1.tgz", 2165 | "integrity": "sha512-nRCa7CK3VTrM2NmGkIy4cbK7IZlgBE/PYMn55rrXefr5xXDP0LdtfPnblFDoVdcAfslJ7or6iqAUnx0CCGIWQA==", 2166 | "dependencies": { 2167 | "@babel/runtime": "^7.8.7", 2168 | "csstype": "^3.0.2" 2169 | } 2170 | }, 2171 | "node_modules/electron-to-chromium": { 2172 | "version": "1.4.382", 2173 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.382.tgz", 2174 | "integrity": "sha512-czMavlW52VIPgutbVL9JnZIZuFijzsG1ww/1z2Otu1r1q+9Qe2bTsH3My3sZarlvwyqHM6+mnZfEnt2Vr4dsIg==", 2175 | "dev": true 2176 | }, 2177 | "node_modules/emoji-regex": { 2178 | "version": "8.0.0", 2179 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2180 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" 2181 | }, 2182 | "node_modules/error-ex": { 2183 | "version": "1.3.2", 2184 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 2185 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 2186 | "dependencies": { 2187 | "is-arrayish": "^0.2.1" 2188 | } 2189 | }, 2190 | "node_modules/esbuild": { 2191 | "version": "0.17.18", 2192 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.18.tgz", 2193 | "integrity": "sha512-z1lix43jBs6UKjcZVKOw2xx69ffE2aG0PygLL5qJ9OS/gy0Ewd1gW/PUQIOIQGXBHWNywSc0floSKoMFF8aK2w==", 2194 | "dev": true, 2195 | "hasInstallScript": true, 2196 | "bin": { 2197 | "esbuild": "bin/esbuild" 2198 | }, 2199 | "engines": { 2200 | "node": ">=12" 2201 | }, 2202 | "optionalDependencies": { 2203 | "@esbuild/android-arm": "0.17.18", 2204 | "@esbuild/android-arm64": "0.17.18", 2205 | "@esbuild/android-x64": "0.17.18", 2206 | "@esbuild/darwin-arm64": "0.17.18", 2207 | "@esbuild/darwin-x64": "0.17.18", 2208 | "@esbuild/freebsd-arm64": "0.17.18", 2209 | "@esbuild/freebsd-x64": "0.17.18", 2210 | "@esbuild/linux-arm": "0.17.18", 2211 | "@esbuild/linux-arm64": "0.17.18", 2212 | "@esbuild/linux-ia32": "0.17.18", 2213 | "@esbuild/linux-loong64": "0.17.18", 2214 | "@esbuild/linux-mips64el": "0.17.18", 2215 | "@esbuild/linux-ppc64": "0.17.18", 2216 | "@esbuild/linux-riscv64": "0.17.18", 2217 | "@esbuild/linux-s390x": "0.17.18", 2218 | "@esbuild/linux-x64": "0.17.18", 2219 | "@esbuild/netbsd-x64": "0.17.18", 2220 | "@esbuild/openbsd-x64": "0.17.18", 2221 | "@esbuild/sunos-x64": "0.17.18", 2222 | "@esbuild/win32-arm64": "0.17.18", 2223 | "@esbuild/win32-ia32": "0.17.18", 2224 | "@esbuild/win32-x64": "0.17.18" 2225 | } 2226 | }, 2227 | "node_modules/escalade": { 2228 | "version": "3.1.1", 2229 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2230 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2231 | "engines": { 2232 | "node": ">=6" 2233 | } 2234 | }, 2235 | "node_modules/escape-string-regexp": { 2236 | "version": "1.0.5", 2237 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2238 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 2239 | "engines": { 2240 | "node": ">=0.8.0" 2241 | } 2242 | }, 2243 | "node_modules/faye-websocket": { 2244 | "version": "0.11.4", 2245 | "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", 2246 | "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", 2247 | "dependencies": { 2248 | "websocket-driver": ">=0.5.1" 2249 | }, 2250 | "engines": { 2251 | "node": ">=0.8.0" 2252 | } 2253 | }, 2254 | "node_modules/find-root": { 2255 | "version": "1.1.0", 2256 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", 2257 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==" 2258 | }, 2259 | "node_modules/firebase": { 2260 | "version": "9.21.0", 2261 | "resolved": "https://registry.npmjs.org/firebase/-/firebase-9.21.0.tgz", 2262 | "integrity": "sha512-kQpT+YjusVhqj8feSmb+9Fpmyfy7ayGSd6GVk2k0qJjt+AwYgHZ9tuHuIgFdEHGsvqxYRZJpu067ck9ZQwbqQw==", 2263 | "dependencies": { 2264 | "@firebase/analytics": "0.10.0", 2265 | "@firebase/analytics-compat": "0.2.6", 2266 | "@firebase/app": "0.9.9", 2267 | "@firebase/app-check": "0.7.0", 2268 | "@firebase/app-check-compat": "0.3.6", 2269 | "@firebase/app-compat": "0.2.9", 2270 | "@firebase/app-types": "0.9.0", 2271 | "@firebase/auth": "0.23.1", 2272 | "@firebase/auth-compat": "0.4.1", 2273 | "@firebase/database": "0.14.4", 2274 | "@firebase/database-compat": "0.3.4", 2275 | "@firebase/firestore": "3.11.0", 2276 | "@firebase/firestore-compat": "0.3.8", 2277 | "@firebase/functions": "0.9.4", 2278 | "@firebase/functions-compat": "0.3.4", 2279 | "@firebase/installations": "0.6.4", 2280 | "@firebase/installations-compat": "0.2.4", 2281 | "@firebase/messaging": "0.12.4", 2282 | "@firebase/messaging-compat": "0.2.4", 2283 | "@firebase/performance": "0.6.4", 2284 | "@firebase/performance-compat": "0.2.4", 2285 | "@firebase/remote-config": "0.4.4", 2286 | "@firebase/remote-config-compat": "0.2.4", 2287 | "@firebase/storage": "0.11.2", 2288 | "@firebase/storage-compat": "0.3.2", 2289 | "@firebase/util": "1.9.3" 2290 | } 2291 | }, 2292 | "node_modules/fsevents": { 2293 | "version": "2.3.2", 2294 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2295 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2296 | "dev": true, 2297 | "hasInstallScript": true, 2298 | "optional": true, 2299 | "os": [ 2300 | "darwin" 2301 | ], 2302 | "engines": { 2303 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2304 | } 2305 | }, 2306 | "node_modules/function-bind": { 2307 | "version": "1.1.1", 2308 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2309 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2310 | }, 2311 | "node_modules/gensync": { 2312 | "version": "1.0.0-beta.2", 2313 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2314 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2315 | "dev": true, 2316 | "engines": { 2317 | "node": ">=6.9.0" 2318 | } 2319 | }, 2320 | "node_modules/get-caller-file": { 2321 | "version": "2.0.5", 2322 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 2323 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 2324 | "engines": { 2325 | "node": "6.* || 8.* || >= 10.*" 2326 | } 2327 | }, 2328 | "node_modules/globals": { 2329 | "version": "11.12.0", 2330 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2331 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2332 | "dev": true, 2333 | "engines": { 2334 | "node": ">=4" 2335 | } 2336 | }, 2337 | "node_modules/has": { 2338 | "version": "1.0.3", 2339 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2340 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2341 | "dependencies": { 2342 | "function-bind": "^1.1.1" 2343 | }, 2344 | "engines": { 2345 | "node": ">= 0.4.0" 2346 | } 2347 | }, 2348 | "node_modules/has-flag": { 2349 | "version": "3.0.0", 2350 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2351 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2352 | "engines": { 2353 | "node": ">=4" 2354 | } 2355 | }, 2356 | "node_modules/hoist-non-react-statics": { 2357 | "version": "3.3.2", 2358 | "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz", 2359 | "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==", 2360 | "dependencies": { 2361 | "react-is": "^16.7.0" 2362 | } 2363 | }, 2364 | "node_modules/http-parser-js": { 2365 | "version": "0.5.8", 2366 | "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz", 2367 | "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==" 2368 | }, 2369 | "node_modules/idb": { 2370 | "version": "7.1.1", 2371 | "resolved": "https://registry.npmjs.org/idb/-/idb-7.1.1.tgz", 2372 | "integrity": "sha512-gchesWBzyvGHRO9W8tzUWFDycow5gwjvFKfyV9FF32Y7F50yZMp7mP+T2mJIWFx49zicqyC4uefHM17o6xKIVQ==" 2373 | }, 2374 | "node_modules/import-fresh": { 2375 | "version": "3.3.0", 2376 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2377 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2378 | "dependencies": { 2379 | "parent-module": "^1.0.0", 2380 | "resolve-from": "^4.0.0" 2381 | }, 2382 | "engines": { 2383 | "node": ">=6" 2384 | }, 2385 | "funding": { 2386 | "url": "https://github.com/sponsors/sindresorhus" 2387 | } 2388 | }, 2389 | "node_modules/is-arrayish": { 2390 | "version": "0.2.1", 2391 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2392 | "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" 2393 | }, 2394 | "node_modules/is-core-module": { 2395 | "version": "2.12.0", 2396 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.0.tgz", 2397 | "integrity": "sha512-RECHCBCd/viahWmwj6enj19sKbHfJrddi/6cBDsNTKbNq0f7VeaUkBo60BqzvPqo/W54ChS62Z5qyun7cfOMqQ==", 2398 | "dependencies": { 2399 | "has": "^1.0.3" 2400 | }, 2401 | "funding": { 2402 | "url": "https://github.com/sponsors/ljharb" 2403 | } 2404 | }, 2405 | "node_modules/is-fullwidth-code-point": { 2406 | "version": "3.0.0", 2407 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2408 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2409 | "engines": { 2410 | "node": ">=8" 2411 | } 2412 | }, 2413 | "node_modules/js-tokens": { 2414 | "version": "4.0.0", 2415 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2416 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2417 | }, 2418 | "node_modules/jsesc": { 2419 | "version": "2.5.2", 2420 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2421 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2422 | "dev": true, 2423 | "bin": { 2424 | "jsesc": "bin/jsesc" 2425 | }, 2426 | "engines": { 2427 | "node": ">=4" 2428 | } 2429 | }, 2430 | "node_modules/json-parse-even-better-errors": { 2431 | "version": "2.3.1", 2432 | "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", 2433 | "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" 2434 | }, 2435 | "node_modules/json5": { 2436 | "version": "2.2.3", 2437 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2438 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2439 | "dev": true, 2440 | "bin": { 2441 | "json5": "lib/cli.js" 2442 | }, 2443 | "engines": { 2444 | "node": ">=6" 2445 | } 2446 | }, 2447 | "node_modules/lines-and-columns": { 2448 | "version": "1.2.4", 2449 | "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", 2450 | "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" 2451 | }, 2452 | "node_modules/lodash.camelcase": { 2453 | "version": "4.3.0", 2454 | "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", 2455 | "integrity": "sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==" 2456 | }, 2457 | "node_modules/long": { 2458 | "version": "4.0.0", 2459 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 2460 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 2461 | }, 2462 | "node_modules/loose-envify": { 2463 | "version": "1.4.0", 2464 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2465 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2466 | "dependencies": { 2467 | "js-tokens": "^3.0.0 || ^4.0.0" 2468 | }, 2469 | "bin": { 2470 | "loose-envify": "cli.js" 2471 | } 2472 | }, 2473 | "node_modules/lru-cache": { 2474 | "version": "5.1.1", 2475 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2476 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2477 | "dev": true, 2478 | "dependencies": { 2479 | "yallist": "^3.0.2" 2480 | } 2481 | }, 2482 | "node_modules/memoize-one": { 2483 | "version": "5.2.1", 2484 | "resolved": "https://registry.npmjs.org/memoize-one/-/memoize-one-5.2.1.tgz", 2485 | "integrity": "sha512-zYiwtZUcYyXKo/np96AGZAckk+FWWsUdJ3cHGGmld7+AhvcWmQyGCYUh1hc4Q/pkOhb65dQR/pqCyK0cOaHz4Q==" 2486 | }, 2487 | "node_modules/ms": { 2488 | "version": "2.1.2", 2489 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2490 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2491 | "dev": true 2492 | }, 2493 | "node_modules/nanoid": { 2494 | "version": "3.3.6", 2495 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", 2496 | "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", 2497 | "dev": true, 2498 | "funding": [ 2499 | { 2500 | "type": "github", 2501 | "url": "https://github.com/sponsors/ai" 2502 | } 2503 | ], 2504 | "bin": { 2505 | "nanoid": "bin/nanoid.cjs" 2506 | }, 2507 | "engines": { 2508 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2509 | } 2510 | }, 2511 | "node_modules/node-fetch": { 2512 | "version": "2.6.7", 2513 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", 2514 | "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", 2515 | "dependencies": { 2516 | "whatwg-url": "^5.0.0" 2517 | }, 2518 | "engines": { 2519 | "node": "4.x || >=6.0.0" 2520 | }, 2521 | "peerDependencies": { 2522 | "encoding": "^0.1.0" 2523 | }, 2524 | "peerDependenciesMeta": { 2525 | "encoding": { 2526 | "optional": true 2527 | } 2528 | } 2529 | }, 2530 | "node_modules/node-releases": { 2531 | "version": "2.0.10", 2532 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.10.tgz", 2533 | "integrity": "sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==", 2534 | "dev": true 2535 | }, 2536 | "node_modules/object-assign": { 2537 | "version": "4.1.1", 2538 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2539 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 2540 | "engines": { 2541 | "node": ">=0.10.0" 2542 | } 2543 | }, 2544 | "node_modules/parent-module": { 2545 | "version": "1.0.1", 2546 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2547 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2548 | "dependencies": { 2549 | "callsites": "^3.0.0" 2550 | }, 2551 | "engines": { 2552 | "node": ">=6" 2553 | } 2554 | }, 2555 | "node_modules/parse-json": { 2556 | "version": "5.2.0", 2557 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", 2558 | "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", 2559 | "dependencies": { 2560 | "@babel/code-frame": "^7.0.0", 2561 | "error-ex": "^1.3.1", 2562 | "json-parse-even-better-errors": "^2.3.0", 2563 | "lines-and-columns": "^1.1.6" 2564 | }, 2565 | "engines": { 2566 | "node": ">=8" 2567 | }, 2568 | "funding": { 2569 | "url": "https://github.com/sponsors/sindresorhus" 2570 | } 2571 | }, 2572 | "node_modules/path-parse": { 2573 | "version": "1.0.7", 2574 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2575 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 2576 | }, 2577 | "node_modules/path-type": { 2578 | "version": "4.0.0", 2579 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2580 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2581 | "engines": { 2582 | "node": ">=8" 2583 | } 2584 | }, 2585 | "node_modules/picocolors": { 2586 | "version": "1.0.0", 2587 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2588 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2589 | "dev": true 2590 | }, 2591 | "node_modules/postcss": { 2592 | "version": "8.4.23", 2593 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.23.tgz", 2594 | "integrity": "sha512-bQ3qMcpF6A/YjR55xtoTr0jGOlnPOKAIMdOWiv0EIT6HVPEaJiJB4NLljSbiHoC2RX7DN5Uvjtpbg1NPdwv1oA==", 2595 | "dev": true, 2596 | "funding": [ 2597 | { 2598 | "type": "opencollective", 2599 | "url": "https://opencollective.com/postcss/" 2600 | }, 2601 | { 2602 | "type": "tidelift", 2603 | "url": "https://tidelift.com/funding/github/npm/postcss" 2604 | }, 2605 | { 2606 | "type": "github", 2607 | "url": "https://github.com/sponsors/ai" 2608 | } 2609 | ], 2610 | "dependencies": { 2611 | "nanoid": "^3.3.6", 2612 | "picocolors": "^1.0.0", 2613 | "source-map-js": "^1.0.2" 2614 | }, 2615 | "engines": { 2616 | "node": "^10 || ^12 || >=14" 2617 | } 2618 | }, 2619 | "node_modules/prop-types": { 2620 | "version": "15.8.1", 2621 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", 2622 | "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", 2623 | "dependencies": { 2624 | "loose-envify": "^1.4.0", 2625 | "object-assign": "^4.1.1", 2626 | "react-is": "^16.13.1" 2627 | } 2628 | }, 2629 | "node_modules/protobufjs": { 2630 | "version": "6.11.3", 2631 | "resolved": "https://registry.npmjs.org/protobufjs/-/protobufjs-6.11.3.tgz", 2632 | "integrity": "sha512-xL96WDdCZYdU7Slin569tFX712BxsxslWwAfAhCYjQKGTq7dAU91Lomy6nLLhh/dyGhk/YH4TwTSRxTzhuHyZg==", 2633 | "hasInstallScript": true, 2634 | "dependencies": { 2635 | "@protobufjs/aspromise": "^1.1.2", 2636 | "@protobufjs/base64": "^1.1.2", 2637 | "@protobufjs/codegen": "^2.0.4", 2638 | "@protobufjs/eventemitter": "^1.1.0", 2639 | "@protobufjs/fetch": "^1.1.0", 2640 | "@protobufjs/float": "^1.0.2", 2641 | "@protobufjs/inquire": "^1.1.0", 2642 | "@protobufjs/path": "^1.1.2", 2643 | "@protobufjs/pool": "^1.1.0", 2644 | "@protobufjs/utf8": "^1.1.0", 2645 | "@types/long": "^4.0.1", 2646 | "@types/node": ">=13.7.0", 2647 | "long": "^4.0.0" 2648 | }, 2649 | "bin": { 2650 | "pbjs": "bin/pbjs", 2651 | "pbts": "bin/pbts" 2652 | } 2653 | }, 2654 | "node_modules/raf-schd": { 2655 | "version": "4.0.3", 2656 | "resolved": "https://registry.npmjs.org/raf-schd/-/raf-schd-4.0.3.tgz", 2657 | "integrity": "sha512-tQkJl2GRWh83ui2DiPTJz9wEiMN20syf+5oKfB03yYP7ioZcJwsIK8FjrtLwH1m7C7e+Tt2yYBlrOpdT+dyeIQ==" 2658 | }, 2659 | "node_modules/react": { 2660 | "version": "18.2.0", 2661 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 2662 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 2663 | "dependencies": { 2664 | "loose-envify": "^1.1.0" 2665 | }, 2666 | "engines": { 2667 | "node": ">=0.10.0" 2668 | } 2669 | }, 2670 | "node_modules/react-beautiful-dnd": { 2671 | "version": "13.1.1", 2672 | "resolved": "https://registry.npmjs.org/react-beautiful-dnd/-/react-beautiful-dnd-13.1.1.tgz", 2673 | "integrity": "sha512-0Lvs4tq2VcrEjEgDXHjT98r+63drkKEgqyxdA7qD3mvKwga6a5SscbdLPO2IExotU1jW8L0Ksdl0Cj2AF67nPQ==", 2674 | "dependencies": { 2675 | "@babel/runtime": "^7.9.2", 2676 | "css-box-model": "^1.2.0", 2677 | "memoize-one": "^5.1.1", 2678 | "raf-schd": "^4.0.2", 2679 | "react-redux": "^7.2.0", 2680 | "redux": "^4.0.4", 2681 | "use-memo-one": "^1.1.1" 2682 | }, 2683 | "peerDependencies": { 2684 | "react": "^16.8.5 || ^17.0.0 || ^18.0.0", 2685 | "react-dom": "^16.8.5 || ^17.0.0 || ^18.0.0" 2686 | } 2687 | }, 2688 | "node_modules/react-dom": { 2689 | "version": "18.2.0", 2690 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 2691 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 2692 | "dependencies": { 2693 | "loose-envify": "^1.1.0", 2694 | "scheduler": "^0.23.0" 2695 | }, 2696 | "peerDependencies": { 2697 | "react": "^18.2.0" 2698 | } 2699 | }, 2700 | "node_modules/react-is": { 2701 | "version": "16.13.1", 2702 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2703 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" 2704 | }, 2705 | "node_modules/react-redux": { 2706 | "version": "7.2.9", 2707 | "resolved": "https://registry.npmjs.org/react-redux/-/react-redux-7.2.9.tgz", 2708 | "integrity": "sha512-Gx4L3uM182jEEayZfRbI/G11ZpYdNAnBs70lFVMNdHJI76XYtR+7m0MN+eAs7UHBPhWXcnFPaS+9owSCJQHNpQ==", 2709 | "dependencies": { 2710 | "@babel/runtime": "^7.15.4", 2711 | "@types/react-redux": "^7.1.20", 2712 | "hoist-non-react-statics": "^3.3.2", 2713 | "loose-envify": "^1.4.0", 2714 | "prop-types": "^15.7.2", 2715 | "react-is": "^17.0.2" 2716 | }, 2717 | "peerDependencies": { 2718 | "react": "^16.8.3 || ^17 || ^18" 2719 | }, 2720 | "peerDependenciesMeta": { 2721 | "react-dom": { 2722 | "optional": true 2723 | }, 2724 | "react-native": { 2725 | "optional": true 2726 | } 2727 | } 2728 | }, 2729 | "node_modules/react-redux/node_modules/react-is": { 2730 | "version": "17.0.2", 2731 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 2732 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==" 2733 | }, 2734 | "node_modules/react-refresh": { 2735 | "version": "0.14.0", 2736 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 2737 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 2738 | "dev": true, 2739 | "engines": { 2740 | "node": ">=0.10.0" 2741 | } 2742 | }, 2743 | "node_modules/react-router": { 2744 | "version": "6.11.1", 2745 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.11.1.tgz", 2746 | "integrity": "sha512-OZINSdjJ2WgvAi7hgNLazrEV8SGn6xrKA+MkJe9wVDMZ3zQ6fdJocUjpCUCI0cNrelWjcvon0S/QK/j0NzL3KA==", 2747 | "dependencies": { 2748 | "@remix-run/router": "1.6.1" 2749 | }, 2750 | "engines": { 2751 | "node": ">=14" 2752 | }, 2753 | "peerDependencies": { 2754 | "react": ">=16.8" 2755 | } 2756 | }, 2757 | "node_modules/react-router-dom": { 2758 | "version": "6.11.1", 2759 | "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.11.1.tgz", 2760 | "integrity": "sha512-dPC2MhoPeTQ1YUOt5uIK376SMNWbwUxYRWk2ZmTT4fZfwlOvabF8uduRKKJIyfkCZvMgiF0GSCQckmkGGijIrg==", 2761 | "dependencies": { 2762 | "@remix-run/router": "1.6.1", 2763 | "react-router": "6.11.1" 2764 | }, 2765 | "engines": { 2766 | "node": ">=14" 2767 | }, 2768 | "peerDependencies": { 2769 | "react": ">=16.8", 2770 | "react-dom": ">=16.8" 2771 | } 2772 | }, 2773 | "node_modules/react-transition-group": { 2774 | "version": "4.4.5", 2775 | "resolved": "https://registry.npmjs.org/react-transition-group/-/react-transition-group-4.4.5.tgz", 2776 | "integrity": "sha512-pZcd1MCJoiKiBR2NRxeCRg13uCXbydPnmB4EOeRrY7480qNWO8IIgQG6zlDkm6uRMsURXPuKq0GWtiM59a5Q6g==", 2777 | "dependencies": { 2778 | "@babel/runtime": "^7.5.5", 2779 | "dom-helpers": "^5.0.1", 2780 | "loose-envify": "^1.4.0", 2781 | "prop-types": "^15.6.2" 2782 | }, 2783 | "peerDependencies": { 2784 | "react": ">=16.6.0", 2785 | "react-dom": ">=16.6.0" 2786 | } 2787 | }, 2788 | "node_modules/redux": { 2789 | "version": "4.2.1", 2790 | "resolved": "https://registry.npmjs.org/redux/-/redux-4.2.1.tgz", 2791 | "integrity": "sha512-LAUYz4lc+Do8/g7aeRa8JkyDErK6ekstQaqWQrNRW//MY1TvCEpMtpTWvlQ+FPbWCx+Xixu/6SHt5N0HR+SB4w==", 2792 | "dependencies": { 2793 | "@babel/runtime": "^7.9.2" 2794 | } 2795 | }, 2796 | "node_modules/regenerator-runtime": { 2797 | "version": "0.13.11", 2798 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", 2799 | "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==" 2800 | }, 2801 | "node_modules/require-directory": { 2802 | "version": "2.1.1", 2803 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2804 | "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", 2805 | "engines": { 2806 | "node": ">=0.10.0" 2807 | } 2808 | }, 2809 | "node_modules/resolve-from": { 2810 | "version": "4.0.0", 2811 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2812 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2813 | "engines": { 2814 | "node": ">=4" 2815 | } 2816 | }, 2817 | "node_modules/rollup": { 2818 | "version": "3.21.4", 2819 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.21.4.tgz", 2820 | "integrity": "sha512-N5LxpvDolOm9ueiCp4NfB80omMDqb45ShtsQw2+OT3f11uJ197dv703NZvznYHP6RWR85wfxanXurXKG3ux2GQ==", 2821 | "dev": true, 2822 | "bin": { 2823 | "rollup": "dist/bin/rollup" 2824 | }, 2825 | "engines": { 2826 | "node": ">=14.18.0", 2827 | "npm": ">=8.0.0" 2828 | }, 2829 | "optionalDependencies": { 2830 | "fsevents": "~2.3.2" 2831 | } 2832 | }, 2833 | "node_modules/safe-buffer": { 2834 | "version": "5.2.1", 2835 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2836 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 2837 | "funding": [ 2838 | { 2839 | "type": "github", 2840 | "url": "https://github.com/sponsors/feross" 2841 | }, 2842 | { 2843 | "type": "patreon", 2844 | "url": "https://www.patreon.com/feross" 2845 | }, 2846 | { 2847 | "type": "consulting", 2848 | "url": "https://feross.org/support" 2849 | } 2850 | ] 2851 | }, 2852 | "node_modules/scheduler": { 2853 | "version": "0.23.0", 2854 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 2855 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 2856 | "dependencies": { 2857 | "loose-envify": "^1.1.0" 2858 | } 2859 | }, 2860 | "node_modules/semver": { 2861 | "version": "6.3.0", 2862 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2863 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2864 | "dev": true, 2865 | "bin": { 2866 | "semver": "bin/semver.js" 2867 | } 2868 | }, 2869 | "node_modules/source-map": { 2870 | "version": "0.5.7", 2871 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2872 | "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", 2873 | "engines": { 2874 | "node": ">=0.10.0" 2875 | } 2876 | }, 2877 | "node_modules/source-map-js": { 2878 | "version": "1.0.2", 2879 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 2880 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 2881 | "dev": true, 2882 | "engines": { 2883 | "node": ">=0.10.0" 2884 | } 2885 | }, 2886 | "node_modules/string-width": { 2887 | "version": "4.2.3", 2888 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2889 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2890 | "dependencies": { 2891 | "emoji-regex": "^8.0.0", 2892 | "is-fullwidth-code-point": "^3.0.0", 2893 | "strip-ansi": "^6.0.1" 2894 | }, 2895 | "engines": { 2896 | "node": ">=8" 2897 | } 2898 | }, 2899 | "node_modules/strip-ansi": { 2900 | "version": "6.0.1", 2901 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2902 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2903 | "dependencies": { 2904 | "ansi-regex": "^5.0.1" 2905 | }, 2906 | "engines": { 2907 | "node": ">=8" 2908 | } 2909 | }, 2910 | "node_modules/stylis": { 2911 | "version": "4.1.4", 2912 | "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.1.4.tgz", 2913 | "integrity": "sha512-USf5pszRYwuE6hg9by0OkKChkQYEXfkeTtm0xKw+jqQhwyjCVLdYyMBK7R+n7dhzsblAWJnGxju4vxq5eH20GQ==" 2914 | }, 2915 | "node_modules/supports-color": { 2916 | "version": "5.5.0", 2917 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2918 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2919 | "dependencies": { 2920 | "has-flag": "^3.0.0" 2921 | }, 2922 | "engines": { 2923 | "node": ">=4" 2924 | } 2925 | }, 2926 | "node_modules/supports-preserve-symlinks-flag": { 2927 | "version": "1.0.0", 2928 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2929 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2930 | "engines": { 2931 | "node": ">= 0.4" 2932 | }, 2933 | "funding": { 2934 | "url": "https://github.com/sponsors/ljharb" 2935 | } 2936 | }, 2937 | "node_modules/tiny-invariant": { 2938 | "version": "1.3.1", 2939 | "resolved": "https://registry.npmjs.org/tiny-invariant/-/tiny-invariant-1.3.1.tgz", 2940 | "integrity": "sha512-AD5ih2NlSssTCwsMznbvwMZpJ1cbhkGd2uueNxzv2jDlEeZdU04JQfRnggJQ8DrcVBGjAsCKwFBbDlVNtEMlzw==" 2941 | }, 2942 | "node_modules/to-fast-properties": { 2943 | "version": "2.0.0", 2944 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2945 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 2946 | "engines": { 2947 | "node": ">=4" 2948 | } 2949 | }, 2950 | "node_modules/tr46": { 2951 | "version": "0.0.3", 2952 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 2953 | "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" 2954 | }, 2955 | "node_modules/tslib": { 2956 | "version": "2.5.0", 2957 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.5.0.tgz", 2958 | "integrity": "sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==" 2959 | }, 2960 | "node_modules/update-browserslist-db": { 2961 | "version": "1.0.11", 2962 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", 2963 | "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", 2964 | "dev": true, 2965 | "funding": [ 2966 | { 2967 | "type": "opencollective", 2968 | "url": "https://opencollective.com/browserslist" 2969 | }, 2970 | { 2971 | "type": "tidelift", 2972 | "url": "https://tidelift.com/funding/github/npm/browserslist" 2973 | }, 2974 | { 2975 | "type": "github", 2976 | "url": "https://github.com/sponsors/ai" 2977 | } 2978 | ], 2979 | "dependencies": { 2980 | "escalade": "^3.1.1", 2981 | "picocolors": "^1.0.0" 2982 | }, 2983 | "bin": { 2984 | "update-browserslist-db": "cli.js" 2985 | }, 2986 | "peerDependencies": { 2987 | "browserslist": ">= 4.21.0" 2988 | } 2989 | }, 2990 | "node_modules/use-memo-one": { 2991 | "version": "1.1.3", 2992 | "resolved": "https://registry.npmjs.org/use-memo-one/-/use-memo-one-1.1.3.tgz", 2993 | "integrity": "sha512-g66/K7ZQGYrI6dy8GLpVcMsBp4s17xNkYJVSMvTEevGy3nDxHOfE6z8BVE22+5G5x7t3+bhzrlTDB7ObrEE0cQ==", 2994 | "peerDependencies": { 2995 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 2996 | } 2997 | }, 2998 | "node_modules/use-sync-external-store": { 2999 | "version": "1.2.0", 3000 | "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", 3001 | "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", 3002 | "peerDependencies": { 3003 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 3004 | } 3005 | }, 3006 | "node_modules/vite": { 3007 | "version": "4.3.4", 3008 | "resolved": "https://registry.npmjs.org/vite/-/vite-4.3.4.tgz", 3009 | "integrity": "sha512-f90aqGBoxSFxWph2b39ae2uHAxm5jFBBdnfueNxZAT1FTpM13ccFQExCaKbR2xFW5atowjleRniQ7onjJ22QEg==", 3010 | "dev": true, 3011 | "dependencies": { 3012 | "esbuild": "^0.17.5", 3013 | "postcss": "^8.4.23", 3014 | "rollup": "^3.21.0" 3015 | }, 3016 | "bin": { 3017 | "vite": "bin/vite.js" 3018 | }, 3019 | "engines": { 3020 | "node": "^14.18.0 || >=16.0.0" 3021 | }, 3022 | "optionalDependencies": { 3023 | "fsevents": "~2.3.2" 3024 | }, 3025 | "peerDependencies": { 3026 | "@types/node": ">= 14", 3027 | "less": "*", 3028 | "sass": "*", 3029 | "stylus": "*", 3030 | "sugarss": "*", 3031 | "terser": "^5.4.0" 3032 | }, 3033 | "peerDependenciesMeta": { 3034 | "@types/node": { 3035 | "optional": true 3036 | }, 3037 | "less": { 3038 | "optional": true 3039 | }, 3040 | "sass": { 3041 | "optional": true 3042 | }, 3043 | "stylus": { 3044 | "optional": true 3045 | }, 3046 | "sugarss": { 3047 | "optional": true 3048 | }, 3049 | "terser": { 3050 | "optional": true 3051 | } 3052 | } 3053 | }, 3054 | "node_modules/webidl-conversions": { 3055 | "version": "3.0.1", 3056 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 3057 | "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" 3058 | }, 3059 | "node_modules/websocket-driver": { 3060 | "version": "0.7.4", 3061 | "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", 3062 | "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", 3063 | "dependencies": { 3064 | "http-parser-js": ">=0.5.1", 3065 | "safe-buffer": ">=5.1.0", 3066 | "websocket-extensions": ">=0.1.1" 3067 | }, 3068 | "engines": { 3069 | "node": ">=0.8.0" 3070 | } 3071 | }, 3072 | "node_modules/websocket-extensions": { 3073 | "version": "0.1.4", 3074 | "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", 3075 | "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", 3076 | "engines": { 3077 | "node": ">=0.8.0" 3078 | } 3079 | }, 3080 | "node_modules/whatwg-url": { 3081 | "version": "5.0.0", 3082 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", 3083 | "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", 3084 | "dependencies": { 3085 | "tr46": "~0.0.3", 3086 | "webidl-conversions": "^3.0.0" 3087 | } 3088 | }, 3089 | "node_modules/wrap-ansi": { 3090 | "version": "7.0.0", 3091 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3092 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3093 | "dependencies": { 3094 | "ansi-styles": "^4.0.0", 3095 | "string-width": "^4.1.0", 3096 | "strip-ansi": "^6.0.0" 3097 | }, 3098 | "engines": { 3099 | "node": ">=10" 3100 | }, 3101 | "funding": { 3102 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 3103 | } 3104 | }, 3105 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 3106 | "version": "4.3.0", 3107 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3108 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3109 | "dependencies": { 3110 | "color-convert": "^2.0.1" 3111 | }, 3112 | "engines": { 3113 | "node": ">=8" 3114 | }, 3115 | "funding": { 3116 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 3117 | } 3118 | }, 3119 | "node_modules/wrap-ansi/node_modules/color-convert": { 3120 | "version": "2.0.1", 3121 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 3122 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 3123 | "dependencies": { 3124 | "color-name": "~1.1.4" 3125 | }, 3126 | "engines": { 3127 | "node": ">=7.0.0" 3128 | } 3129 | }, 3130 | "node_modules/wrap-ansi/node_modules/color-name": { 3131 | "version": "1.1.4", 3132 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 3133 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 3134 | }, 3135 | "node_modules/y18n": { 3136 | "version": "5.0.8", 3137 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3138 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3139 | "engines": { 3140 | "node": ">=10" 3141 | } 3142 | }, 3143 | "node_modules/yallist": { 3144 | "version": "3.1.1", 3145 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 3146 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 3147 | "dev": true 3148 | }, 3149 | "node_modules/yaml": { 3150 | "version": "1.10.2", 3151 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 3152 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 3153 | "engines": { 3154 | "node": ">= 6" 3155 | } 3156 | }, 3157 | "node_modules/yargs": { 3158 | "version": "16.2.0", 3159 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3160 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3161 | "dependencies": { 3162 | "cliui": "^7.0.2", 3163 | "escalade": "^3.1.1", 3164 | "get-caller-file": "^2.0.5", 3165 | "require-directory": "^2.1.1", 3166 | "string-width": "^4.2.0", 3167 | "y18n": "^5.0.5", 3168 | "yargs-parser": "^20.2.2" 3169 | }, 3170 | "engines": { 3171 | "node": ">=10" 3172 | } 3173 | }, 3174 | "node_modules/yargs-parser": { 3175 | "version": "20.2.9", 3176 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3177 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3178 | "engines": { 3179 | "node": ">=10" 3180 | } 3181 | }, 3182 | "node_modules/zustand": { 3183 | "version": "4.3.8", 3184 | "resolved": "https://registry.npmjs.org/zustand/-/zustand-4.3.8.tgz", 3185 | "integrity": "sha512-4h28KCkHg5ii/wcFFJ5Fp+k1J3gJoasaIbppdgZFO4BPJnsNxL0mQXBSFgOgAdCdBj35aDTPvdAJReTMntFPGg==", 3186 | "dependencies": { 3187 | "use-sync-external-store": "1.2.0" 3188 | }, 3189 | "engines": { 3190 | "node": ">=12.7.0" 3191 | }, 3192 | "peerDependencies": { 3193 | "immer": ">=9.0", 3194 | "react": ">=16.8" 3195 | }, 3196 | "peerDependenciesMeta": { 3197 | "immer": { 3198 | "optional": true 3199 | }, 3200 | "react": { 3201 | "optional": true 3202 | } 3203 | } 3204 | } 3205 | } 3206 | } 3207 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "flowboard-tutorial", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "fb-emulators": "firebase emulators:start --import=./fb-emulator --export-on-exit", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "@emotion/react": "^11.10.8", 14 | "@emotion/styled": "^11.10.8", 15 | "@mui/icons-material": "^5.11.16", 16 | "@mui/material": "^5.12.3", 17 | "firebase": "^9.21.0", 18 | "react": "^18.2.0", 19 | "react-beautiful-dnd": "^13.1.1", 20 | "react-dom": "^18.2.0", 21 | "react-router-dom": "^6.11.1", 22 | "zustand": "^4.3.8" 23 | }, 24 | "devDependencies": { 25 | "@types/react": "^18.0.28", 26 | "@types/react-dom": "^18.0.11", 27 | "@vitejs/plugin-react": "^4.0.0", 28 | "vite": "^4.3.2" 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.jsx: -------------------------------------------------------------------------------- 1 | import { useEffect } from "react"; 2 | import { CssBaseline, ThemeProvider } from "@mui/material"; 3 | import theme from "./theme"; 4 | import { BrowserRouter, Routes, Route, Navigate } from "react-router-dom"; 5 | import { auth } from "./firebase"; 6 | import { onAuthStateChanged } from "firebase/auth"; 7 | import useStore from "./store"; 8 | import AppLoader from "./components/layout/AppLoader"; 9 | 10 | // screens 11 | import AuthScreen from "./screens/AuthScreen"; 12 | import BoardsScreen from "./screens/BoardsScreen"; 13 | import BoardScreen from "./screens/BoardScreen"; 14 | 15 | // 16 | import PublicOnlyRoute from "./components/utils/PublicOnlyRoute"; 17 | import PrivateRoute from "./components/utils/PrivateRoute"; 18 | import SnackbarManager from "./components/layout/SnackbarManager"; 19 | 20 | const App = () => { 21 | const { loader, setLoginStatus } = useStore(); 22 | 23 | useEffect(() => { 24 | const unsub = onAuthStateChanged(auth, (user) => { 25 | setLoginStatus(!!user); 26 | }); 27 | 28 | return () => unsub(); 29 | }, []); 30 | 31 | if (loader) return ; 32 | 33 | return ( 34 | 35 | 36 | 37 | 38 | 39 | } 42 | /> 43 | } 46 | /> 47 | } 50 | /> 51 | } /> 52 | 53 | 54 | 55 | ); 56 | }; 57 | 58 | export default App; 59 | -------------------------------------------------------------------------------- /src/assets/logo.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | -------------------------------------------------------------------------------- /src/components/layout/AppLoader.jsx: -------------------------------------------------------------------------------- 1 | import { Stack, CircularProgress } from "@mui/material"; 2 | const AppLoader = () => { 3 | return ( 4 | 5 | 6 | 7 | ); 8 | }; 9 | 10 | export default AppLoader; 11 | -------------------------------------------------------------------------------- /src/components/layout/ModalHeader.jsx: -------------------------------------------------------------------------------- 1 | import { Stack, Typography, IconButton } from "@mui/material"; 2 | import CloseIcon from "@mui/icons-material/Close"; 3 | 4 | const ModalHeader = ({ title, onClose }) => { 5 | return ( 6 | 7 | {title} 8 | 9 | 10 | 11 | 12 | ); 13 | }; 14 | 15 | export default ModalHeader; 16 | -------------------------------------------------------------------------------- /src/components/layout/SnackbarManager.jsx: -------------------------------------------------------------------------------- 1 | import { Snackbar } from "@mui/material"; 2 | import useStore from "../../store"; 3 | 4 | const SnackbarManager = () => { 5 | const { toastrMsg, setToastr } = useStore(); 6 | return ( 7 | setToastr("")} 12 | /> 13 | ); 14 | }; 15 | 16 | export default SnackbarManager; 17 | -------------------------------------------------------------------------------- /src/components/utils/ImageEl.jsx: -------------------------------------------------------------------------------- 1 | import { styled } from "@mui/material"; 2 | 3 | export default styled("img")``; 4 | -------------------------------------------------------------------------------- /src/components/utils/PrivateRoute.jsx: -------------------------------------------------------------------------------- 1 | import { Navigate } from "react-router-dom"; 2 | import useStore from "../../store"; 3 | 4 | const PrivateRoute = ({ Component }) => { 5 | const { isLoggedIn } = useStore(); 6 | return !isLoggedIn ? : ; 7 | }; 8 | 9 | export default PrivateRoute; 10 | -------------------------------------------------------------------------------- /src/components/utils/PublicOnlyRoute.jsx: -------------------------------------------------------------------------------- 1 | import { Navigate } from "react-router-dom"; 2 | import useStore from "../../store"; 3 | 4 | const PublicOnlyRoute = ({ Component }) => { 5 | const { isLoggedIn } = useStore(); 6 | return isLoggedIn ? : ; 7 | }; 8 | 9 | export default PublicOnlyRoute; 10 | -------------------------------------------------------------------------------- /src/components/utils/StrictModeDroppable.jsx: -------------------------------------------------------------------------------- 1 | import { useEffect, useState } from "react"; 2 | import { Droppable } from "react-beautiful-dnd"; 3 | 4 | const StrictModeDroppable = ({ children, ...props }) => { 5 | const [enabled, setEnabled] = useState(false); 6 | useEffect(() => { 7 | const animation = requestAnimationFrame(() => setEnabled(true)); 8 | 9 | return () => { 10 | cancelAnimationFrame(animation); 11 | setEnabled(false); 12 | }; 13 | }, []); 14 | 15 | if (!enabled) return null; 16 | return {children}; 17 | }; 18 | 19 | export default StrictModeDroppable; 20 | -------------------------------------------------------------------------------- /src/firebase.js: -------------------------------------------------------------------------------- 1 | import { initializeApp } from "firebase/app"; 2 | import { getAuth, connectAuthEmulator } from "firebase/auth"; 3 | import { getFirestore, connectFirestoreEmulator } from "firebase/firestore"; 4 | import { getFunctions, connectFunctionsEmulator } from "firebase/functions"; 5 | 6 | const firebaseConfig = { 7 | apiKey: "", 8 | authDomain: "", 9 | projectId: "", 10 | storageBucket: "", 11 | messagingSenderId: "", 12 | appId: "", 13 | }; 14 | 15 | // Initialize Firebase 16 | export const app = initializeApp(firebaseConfig); 17 | export const db = getFirestore(app); 18 | export const auth = getAuth(app); 19 | export const fbFunctions = getFunctions(app); 20 | 21 | if (process.env.NODE_ENV === "development") { 22 | connectAuthEmulator(auth, "http://localhost:9098"); 23 | connectFirestoreEmulator(db, "localhost", 8082); 24 | connectFunctionsEmulator(fbFunctions, "localhost", 5002); 25 | } 26 | -------------------------------------------------------------------------------- /src/hooks/useApp.js: -------------------------------------------------------------------------------- 1 | import { 2 | collection, 3 | addDoc, 4 | serverTimestamp, 5 | getDocs, 6 | query, 7 | orderBy, 8 | doc, 9 | getDoc, 10 | updateDoc, 11 | deleteDoc, 12 | } from "firebase/firestore"; 13 | import { db } from "../firebase"; 14 | import { getAuth } from "firebase/auth"; 15 | import useStore from "../store"; 16 | import { useNavigate } from "react-router-dom"; 17 | 18 | const useApp = () => { 19 | const navigate = useNavigate(); 20 | const { 21 | currentUser: { uid }, 22 | } = getAuth(); 23 | const boardsColRef = collection(db, `users/${uid}/boards`); 24 | const { boards, setBoards, addBoard, setToastr } = useStore(); 25 | 26 | const deleteBoard = async (boardId) => { 27 | try { 28 | // delete the doc from the DB 29 | const docRef = doc(db, `users/${uid}/boards/${boardId}`); 30 | await deleteDoc(docRef); 31 | 32 | // update the boards in the store 33 | const tBoards = boards.filter((board) => board.id !== boardId); 34 | setBoards(tBoards); 35 | 36 | // navigate to the boards screen 37 | navigate("/boards"); 38 | } catch (err) { 39 | setToastr("Error deleting the board"); 40 | throw err; 41 | } 42 | }; 43 | 44 | const updateBoardData = async (boardId, tabs) => { 45 | const docRef = doc(db, `users/${uid}/boardsData/${boardId}`); 46 | try { 47 | await updateDoc(docRef, { tabs, lastUpdated: serverTimestamp() }); 48 | } catch (err) { 49 | setToastr("Error updating board"); 50 | throw err; 51 | } 52 | }; 53 | 54 | const fetchBoard = async (boardId) => { 55 | const docRef = doc(db, `users/${uid}/boardsData/${boardId}`); 56 | try { 57 | const doc = await getDoc(docRef); 58 | if (doc.exists) { 59 | return doc.data(); 60 | } else return null; 61 | } catch (err) { 62 | setToastr("Error fetching board"); 63 | throw err; 64 | } 65 | }; 66 | 67 | const createBoard = async ({ name, color }) => { 68 | try { 69 | const doc = await addDoc(boardsColRef, { 70 | name, 71 | color, 72 | createdAt: serverTimestamp(), 73 | }); 74 | 75 | addBoard({ 76 | name, 77 | color, 78 | createdAt: new Date().toLocaleString("en-US"), 79 | id: doc.id, 80 | }); 81 | } catch (err) { 82 | setToastr("Error creating board"); 83 | throw err; 84 | } 85 | }; 86 | 87 | const fetchBoards = async (setLoading) => { 88 | try { 89 | const q = query(boardsColRef, orderBy("createdAt", "desc")); 90 | const querySnapshot = await getDocs(q); 91 | const boards = querySnapshot.docs.map((doc) => ({ 92 | ...doc.data(), 93 | id: doc.id, 94 | createdAt: doc.data().createdAt.toDate().toLocaleString("en-US"), 95 | })); 96 | 97 | setBoards(boards); 98 | } catch (err) { 99 | setToastr("Error fetching boards"); 100 | } finally { 101 | if (setLoading) setLoading(false); 102 | } 103 | }; 104 | 105 | return { createBoard, fetchBoards, fetchBoard, updateBoardData, deleteBoard }; 106 | }; 107 | 108 | export default useApp; 109 | -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- 1 | body { 2 | margin: 0; 3 | padding: 0; 4 | } 5 | -------------------------------------------------------------------------------- /src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import ReactDOM from "react-dom/client"; 3 | import App from "./App.jsx"; 4 | import "./index.css"; 5 | 6 | ReactDOM.createRoot(document.getElementById("root")).render( 7 | 8 | 9 | 10 | ); 11 | -------------------------------------------------------------------------------- /src/screens/AuthScreen/index.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import { Container, Stack, TextField, Button, Typography } from "@mui/material"; 3 | import LogoImg from "../../assets/logo.svg"; 4 | import ImageEl from "../../components/utils/ImageEl"; 5 | import { auth } from "../../firebase"; 6 | import { 7 | signInWithEmailAndPassword, 8 | createUserWithEmailAndPassword, 9 | } from "firebase/auth"; 10 | import useStore from "../../store"; 11 | 12 | const initForm = { 13 | email: "", 14 | password: "", 15 | }; 16 | const AuthScreen = () => { 17 | const [loading, setLoading] = useState(false); 18 | const [isLogin, setIsLogin] = useState(true); 19 | const [form, setForm] = useState(initForm); 20 | const { setToastr } = useStore(); 21 | 22 | const authText = isLogin 23 | ? "Do not have an account?" 24 | : "Already have an account?"; 25 | 26 | const handleChange = (event) => 27 | setForm((oldForm) => ({ 28 | ...oldForm, 29 | [event.target.name]: event.target.value, 30 | })); 31 | 32 | const handleAuth = async () => { 33 | try { 34 | setLoading(true); 35 | if (isLogin) { 36 | await signInWithEmailAndPassword(auth, form.email, form.password); 37 | } else { 38 | await createUserWithEmailAndPassword(auth, form.email, form.password); 39 | } 40 | } catch (err) { 41 | const msg = err.code.split("auth/")[1].split("-").join(" "); 42 | setToastr(msg); 43 | setLoading(false); 44 | } 45 | }; 46 | 47 | return ( 48 | 54 | 55 | 56 | 57 | Visualize Your Workflow for Increased Productivity. 58 |
59 | Access Your Tasks Anytime, Anywhere 60 |
61 |
62 | 63 | 69 | 76 | 84 | 85 | setIsLogin((o) => !o)} 90 | mt={3} 91 | textAlign="center" 92 | > 93 | {authText} 94 | 95 |
96 | ); 97 | }; 98 | 99 | export default AuthScreen; 100 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/AddTaskModal.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import { 3 | Dialog, 4 | Typography, 5 | Stack, 6 | IconButton, 7 | Chip, 8 | OutlinedInput, 9 | Button, 10 | } from "@mui/material"; 11 | import CloseIcon from "@mui/icons-material/Close"; 12 | import ModalHeader from "../../components/layout/ModalHeader"; 13 | 14 | const AddTaskModal = ({ tabName, onClose, addTask }) => { 15 | const [text, setText] = useState(""); 16 | 17 | return ( 18 | 19 | 20 | 21 | 22 | 23 | Status: 24 | 25 | 26 | setText(e.target.value)} 29 | placeholder="Task" 30 | /> 31 | 34 | 35 | 36 | 37 | ); 38 | }; 39 | 40 | export default AddTaskModal; 41 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/BoardInterface.jsx: -------------------------------------------------------------------------------- 1 | import { useState, useCallback } from "react"; 2 | import { Grid } from "@mui/material"; 3 | import AddTaskModal from "./AddTaskModal"; 4 | 5 | import BoardTab from "./BoardTab"; 6 | import useApp from "../../hooks/useApp"; 7 | import useStore from "../../store"; 8 | import { DragDropContext } from "react-beautiful-dnd"; 9 | import AppLoader from "../../components/layout/AppLoader"; 10 | import ShiftTaskModal from "./ShiftTaskModal"; 11 | 12 | export const statusMap = { 13 | todos: "Todos", 14 | inProgress: "In Progress", 15 | completed: "Completed", 16 | }; 17 | 18 | const sleep = (ms = 1000) => new Promise((r) => setTimeout(r, ms)); 19 | 20 | const BoardInterface = ({ boardData, boardId, updateLastUpdated }) => { 21 | const [loading, setLoading] = useState(false); 22 | const [shiftTask, setShiftTask] = useState(null); 23 | const [addTaskTo, setAddTaskTo] = useState(""); 24 | const [tabs, setTabs] = useState(structuredClone(boardData)); 25 | const { updateBoardData } = useApp(); 26 | const { setToastr } = useStore(); 27 | 28 | const handleOpenAddTaskModal = useCallback( 29 | (status) => setAddTaskTo(status), 30 | [] 31 | ); 32 | 33 | const handleOpenShiftTaskModal = useCallback( 34 | (task) => setShiftTask(task), 35 | [] 36 | ); 37 | 38 | console.log({ shiftTask }); 39 | 40 | const handleShiftTask = async (newStatus) => { 41 | const oldStatus = shiftTask.status; 42 | if (newStatus === oldStatus) return setShiftTask(null); 43 | const dClone = structuredClone(tabs); 44 | 45 | // remove the el from arr 1 46 | const [task] = dClone[oldStatus].splice(shiftTask.index, 1); 47 | 48 | // add it to the arr 2 49 | dClone[newStatus].unshift(task); 50 | 51 | try { 52 | await handleUpdateBoardData(dClone); 53 | setShiftTask(null); 54 | } catch (err) { 55 | console.log(err); 56 | } finally { 57 | setLoading(false); 58 | } 59 | }; 60 | 61 | const handleUpdateBoardData = async (dClone) => { 62 | setLoading(true); 63 | await updateBoardData(boardId, dClone); 64 | setTabs(dClone); 65 | updateLastUpdated(); 66 | setToastr("Board updated!"); 67 | }; 68 | 69 | const handleRemoveTask = useCallback( 70 | async (tab, taskId) => { 71 | const dClone = structuredClone(tabs); 72 | const taskIdx = dClone[tab].findIndex((t) => t.id === taskId); 73 | dClone[tab].splice(taskIdx, 1); 74 | 75 | try { 76 | await handleUpdateBoardData(dClone); 77 | } catch (err) { 78 | console.log(err); 79 | } finally { 80 | setLoading(false); 81 | } 82 | }, 83 | [tabs] 84 | ); 85 | 86 | const handleAddTask = async (text) => { 87 | if (!text.trim()) return setToastr("Task cannot be empty!"); 88 | const dClone = structuredClone(tabs); 89 | dClone[addTaskTo].unshift({ text, id: crypto.randomUUID() }); 90 | try { 91 | await handleUpdateBoardData(dClone); 92 | setAddTaskTo(""); 93 | } catch (err) { 94 | console.log(err); 95 | } finally { 96 | setLoading(false); 97 | } 98 | }; 99 | 100 | const handleDnd = async ({ source, destination }) => { 101 | if (!destination) return; 102 | if ( 103 | source.droppableId === destination.droppableId && 104 | source.index === destination.index 105 | ) 106 | return; 107 | 108 | const dClone = structuredClone(tabs); 109 | 110 | // remove the task from tab 1 111 | const [draggedTask] = dClone[source.droppableId].splice(source.index, 1); 112 | 113 | // add it to the tab 2 114 | dClone[destination.droppableId].splice(destination.index, 0, draggedTask); 115 | 116 | try { 117 | await handleUpdateBoardData(dClone); 118 | } catch (err) { 119 | console.log(err); 120 | } finally { 121 | setLoading(false); 122 | } 123 | }; 124 | 125 | if (loading) return ; 126 | return ( 127 | <> 128 | {!!shiftTask && ( 129 | setShiftTask(null)} 133 | /> 134 | )} 135 | {!!addTaskTo && ( 136 | setAddTaskTo("")} 139 | addTask={handleAddTask} 140 | loading={loading} 141 | /> 142 | )} 143 | 144 | 145 | 146 | {Object.keys(statusMap).map((status) => ( 147 | 156 | ))} 157 | 158 | 159 | 160 | ); 161 | }; 162 | 163 | export default BoardInterface; 164 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/BoardNotReady.jsx: -------------------------------------------------------------------------------- 1 | import { Button, Stack, Typography } from "@mui/material"; 2 | import BackIcon from "@mui/icons-material/ArrowBack"; 3 | import { useNavigate } from "react-router-dom"; 4 | 5 | const BoardNotReady = () => { 6 | const navigate = useNavigate(); 7 | return ( 8 | 9 | Seems like your board is not ready 10 | 11 | Sometime it may take a few seconds for the board to be ready for use. 12 |
Try again in a few seconds 13 |
14 | 21 |
22 | ); 23 | }; 24 | 25 | export default BoardNotReady; 26 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/BoardTab.jsx: -------------------------------------------------------------------------------- 1 | import { memo } from "react"; 2 | import { 3 | Grid, 4 | Stack, 5 | Typography, 6 | IconButton, 7 | useMediaQuery, 8 | } from "@mui/material"; 9 | import AddIcon from "@mui/icons-material/AddCircleOutline"; 10 | import Task from "./Task"; 11 | import Droppable from "../../components/utils/StrictModeDroppable"; 12 | 13 | const BoardTab = ({ 14 | name, 15 | status, 16 | openAddTaskModal, 17 | tasks, 18 | removeTask, 19 | openShiftTaskModal, 20 | }) => { 21 | console.log("Tab: ", name); 22 | const isXs = useMediaQuery((theme) => theme.breakpoints.only("xs")); 23 | return ( 24 | 25 | {(provided) => ( 26 | 33 | 34 | 39 | 40 | {name} 41 | 42 | openAddTaskModal(status)}> 43 | 44 | 45 | 46 | 47 | {tasks.map((task, index) => ( 48 | 52 | openShiftTaskModal({ 53 | text: task.text, 54 | index: index, 55 | status: status, 56 | }) 57 | : null 58 | } 59 | key={task.id} 60 | text={task.text} 61 | id={task.id} 62 | removeTask={() => removeTask(status, task.id)} 63 | index={index} 64 | /> 65 | ))} 66 | 67 | {provided.placeholder} 68 | 69 | 70 | )} 71 | 72 | ); 73 | }; 74 | 75 | export default memo(BoardTab); 76 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/BoardTopbar.jsx: -------------------------------------------------------------------------------- 1 | import { memo } from "react"; 2 | import { Toolbar, Stack, Typography, IconButton, AppBar } from "@mui/material"; 3 | import BackIcon from "@mui/icons-material/ArrowBack"; 4 | import DeleteIcon from "@mui/icons-material/Delete"; 5 | import { useNavigate } from "react-router-dom"; 6 | import { colors } from "../../theme"; 7 | 8 | const BoardTopbar = ({ name, lastUpdated, color, deleteBoard }) => { 9 | const navigate = useNavigate(); 10 | return ( 11 | 18 | 19 | 20 | navigate("/boards")}> 21 | 22 | 23 | {name} 24 | 25 | 26 | 33 | Last updated: {lastUpdated} 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | ); 42 | }; 43 | 44 | export default memo(BoardTopbar); 45 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/ShiftTaskModal.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import { Dialog, Button, Typography, Stack, Chip } from "@mui/material"; 3 | import ModalHeader from "../../components/layout/ModalHeader"; 4 | import { statusMap } from "./BoardInterface"; 5 | 6 | const ShiftTaskModal = ({ onClose, task, shiftTask }) => { 7 | const [taskStatus, setTaskStatus] = useState(task.status); 8 | return ( 9 | 10 | 11 | 12 | 13 | 14 | Task: 15 | 16 | {task.text} 17 | 18 | 19 | 20 | Status 21 | 22 | {Object.entries(statusMap).map(([status, label]) => ( 23 | setTaskStatus(status)} 25 | variant={taskStatus === status ? "filled" : "outlined"} 26 | key={status} 27 | label={label} 28 | /> 29 | ))} 30 | 31 | 32 | 33 | 36 | 37 | 38 | ); 39 | }; 40 | 41 | export default ShiftTaskModal; 42 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/Task.jsx: -------------------------------------------------------------------------------- 1 | import { Stack, Typography, IconButton } from "@mui/material"; 2 | import DeleteIcon from "@mui/icons-material/Delete"; 3 | import { Draggable } from "react-beautiful-dnd"; 4 | 5 | const Task = ({ id, text, index, removeTask, onClick }) => { 6 | return ( 7 | 8 | {(provided) => ( 9 | 17 | 25 | {text} 26 | 27 | 28 | 29 | 30 | 31 | )} 32 | 33 | ); 34 | }; 35 | 36 | export default Task; 37 | -------------------------------------------------------------------------------- /src/screens/BoardScreen/index.jsx: -------------------------------------------------------------------------------- 1 | import { useCallback, useState } from "react"; 2 | import { useMemo, useEffect } from "react"; 3 | import { useNavigate, useParams } from "react-router-dom"; 4 | import AppLoader from "../../components/layout/AppLoader"; 5 | import useApp from "../../hooks/useApp"; 6 | import useStore from "../../store"; 7 | import BoardInterface from "./BoardInterface"; 8 | import BoardNotReady from "./BoardNotReady"; 9 | import BoardTopbar from "./BoardTopbar"; 10 | 11 | const BoardScreen = () => { 12 | const navigate = useNavigate(); 13 | const [data, setData] = useState(null); 14 | const [lastUpdated, setLastUpdated] = useState(null); 15 | const [loading, setLoading] = useState(true); 16 | const { boards, areBoardsFetched } = useStore(); 17 | const { boardId } = useParams(); 18 | const { fetchBoard, deleteBoard } = useApp(); 19 | const board = useMemo(() => boards.find((b) => b.id === boardId), []); 20 | 21 | const boardData = useMemo(() => data, [data]); 22 | 23 | const handleDeleteBoard = useCallback(async () => { 24 | if (!window.confirm("Do you want to delete this board?")) return; 25 | try { 26 | setLoading(true); 27 | await deleteBoard(boardId); 28 | } catch (err) { 29 | console.log(err); 30 | setLoading(false); 31 | } 32 | }, []); 33 | 34 | const handleUpdateLastUpdated = useCallback( 35 | () => setLastUpdated(new Date().toLocaleString("en-US")), 36 | [] 37 | ); 38 | 39 | const handleFetchBoard = async () => { 40 | try { 41 | const boardData = await fetchBoard(boardId); 42 | if (boardData) { 43 | const { lastUpdated, tabs } = boardData; 44 | setData(tabs); 45 | setLastUpdated(lastUpdated.toDate().toLocaleString("en-US")); 46 | } 47 | setLoading(false); 48 | } catch (err) { 49 | console.log(err); 50 | } 51 | }; 52 | 53 | useEffect(() => { 54 | if (!areBoardsFetched || !board) navigate("/boards"); 55 | else handleFetchBoard(); 56 | }, []); 57 | 58 | if (!board) return null; 59 | if (loading) return ; 60 | if (!data) return ; 61 | 62 | return ( 63 | <> 64 | 70 | 75 | 76 | ); 77 | }; 78 | 79 | export default BoardScreen; 80 | -------------------------------------------------------------------------------- /src/screens/BoardsScreen/BoardCard.jsx: -------------------------------------------------------------------------------- 1 | import OpenIcon from "@mui/icons-material/Launch"; 2 | import { Box, Grid, IconButton, Stack, Typography } from "@mui/material"; 3 | import { useNavigate } from "react-router-dom"; 4 | import { colors } from "../../theme"; 5 | 6 | const BoardCard = ({ name, color, createdAt, id }) => { 7 | const navigate = useNavigate(); 8 | return ( 9 | 10 | 16 | 21 | 22 | 29 | {name} 30 | 31 | 32 | 33 | navigate(`/boards/${id}`)} size="small"> 34 | 35 | 36 | 37 | Created at: {createdAt} 38 | 39 | 40 | ); 41 | }; 42 | 43 | export default BoardCard; 44 | -------------------------------------------------------------------------------- /src/screens/BoardsScreen/CreateBoardModal.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from "react"; 2 | import { 3 | Dialog, 4 | Stack, 5 | Typography, 6 | Box, 7 | TextField, 8 | Button, 9 | } from "@mui/material"; 10 | import ModalHeader from "../../components/layout/ModalHeader"; 11 | import { colors } from "../../theme"; 12 | import useApp from "../../hooks/useApp"; 13 | import useStore from "../../store"; 14 | 15 | const CreateBoardModal = ({ closeModal }) => { 16 | const { createBoard } = useApp(); 17 | const [name, setName] = useState(""); 18 | const [color, setColor] = useState(0); 19 | const [loading, setLoading] = useState(false); 20 | const { setToastr } = useStore(); 21 | 22 | const handleCreate = async () => { 23 | const tName = name.trim(); 24 | if (!tName) return setToastr("You need to enter board name"); 25 | if (!/^[a-zA-Z0-9\s]{1,20}$/.test(tName)) 26 | return setToastr( 27 | "Board name cannot contain special characters and should not be more than 20 chars" 28 | ); 29 | try { 30 | setLoading(true); 31 | await createBoard({ name: tName, color }); 32 | closeModal(); 33 | } catch (err) { 34 | setLoading(false); 35 | console.log(err); 36 | } 37 | }; 38 | 39 | return ( 40 | 41 | 42 | 43 | 44 | setName(e.target.value)} 47 | label="Board name" 48 | /> 49 | 50 | Color: 51 | 52 | {colors.map((clr, idx) => ( 53 | setColor(idx)} 60 | key={clr} 61 | height={25} 62 | width={25} 63 | backgroundColor={clr} 64 | borderRadius="50%" 65 | /> 66 | ))} 67 | 68 | 69 | 77 | 78 | 79 | ); 80 | }; 81 | 82 | export default CreateBoardModal; 83 | -------------------------------------------------------------------------------- /src/screens/BoardsScreen/NoBoards.jsx: -------------------------------------------------------------------------------- 1 | import { Stack, Typography } from "@mui/material"; 2 | 3 | const NoBoards = () => { 4 | return ( 5 | 6 | No boards created 7 | Create your first board today! 8 | 9 | ); 10 | }; 11 | 12 | export default NoBoards; 13 | -------------------------------------------------------------------------------- /src/screens/BoardsScreen/Topbar.jsx: -------------------------------------------------------------------------------- 1 | import { 2 | AppBar, 3 | Toolbar, 4 | Button, 5 | Stack, 6 | useMediaQuery, 7 | IconButton, 8 | } from "@mui/material"; 9 | import ImageEl from "../../components/utils/ImageEl"; 10 | import LogoImg from "../../assets/logo.svg"; 11 | import LogoutIcon from "@mui/icons-material/ExitToApp"; 12 | import CreateBoardIcon from "@mui/icons-material/AddCircle"; 13 | import { signOut } from "firebase/auth"; 14 | import { auth } from "../../firebase"; 15 | 16 | const Topbar = ({ openModal }) => { 17 | const isXs = useMediaQuery((theme) => theme.breakpoints.only("xs")); 18 | 19 | return ( 20 | 21 | 26 | 33 | 34 | {isXs ? ( 35 | <> 36 | 37 | 38 | 39 | signOut(auth)}> 40 | 41 | 42 | 43 | ) : ( 44 | <> 45 | 48 | 55 | 56 | )} 57 | 58 | 59 | 60 | ); 61 | }; 62 | 63 | export default Topbar; 64 | -------------------------------------------------------------------------------- /src/screens/BoardsScreen/index.jsx: -------------------------------------------------------------------------------- 1 | import { Grid, Stack } from "@mui/material"; 2 | import { useState, useEffect } from "react"; 3 | import AppLoader from "../../components/layout/AppLoader"; 4 | import useApp from "../../hooks/useApp"; 5 | import useStore from "../../store"; 6 | import BoardCard from "./BoardCard"; 7 | import CreateBoardModal from "./CreateBoardModal"; 8 | import Topbar from "./Topbar"; 9 | import NoBoards from "./NoBoards"; 10 | 11 | const BoardsScreen = () => { 12 | const [loading, setLoading] = useState(true); 13 | const [showModal, setShowModal] = useState(false); 14 | const { fetchBoards } = useApp(); 15 | const { boards, areBoardsFetched } = useStore(); 16 | 17 | useEffect(() => { 18 | if (!areBoardsFetched) fetchBoards(setLoading); 19 | else setLoading(false); 20 | }, []); 21 | 22 | if (loading) return ; 23 | return ( 24 | <> 25 | setShowModal(true)} /> 26 | {showModal && setShowModal(false)} />} 27 | {/* */} 28 | 29 | {!boards.length ? ( 30 | 31 | ) : ( 32 | 33 | 34 | {boards.map((board) => ( 35 | 36 | ))} 37 | 38 | 39 | )} 40 | 41 | ); 42 | }; 43 | 44 | export default BoardsScreen; 45 | -------------------------------------------------------------------------------- /src/store.js: -------------------------------------------------------------------------------- 1 | import { create } from "zustand"; 2 | import { devtools } from "zustand/middleware"; 3 | 4 | const store = (set) => ({ 5 | loader: true, 6 | toastrMsg: "", 7 | isLoggedIn: false, 8 | boards: [], 9 | areBoardsFetched: false, 10 | setToastr: (toastrMsg) => set({ toastrMsg }, false, "setToastr"), 11 | setBoards: (boards) => 12 | set({ boards, areBoardsFetched: true }, false, "setBoards"), 13 | addBoard: (board) => 14 | set((old) => ({ boards: [board, ...old.boards] }), false, "addBoard"), 15 | setLoginStatus: (status) => 16 | set( 17 | { 18 | isLoggedIn: status, 19 | loader: false, 20 | boards: [], 21 | areBoardsFetched: false, 22 | }, 23 | false, 24 | "setLoginStatus" 25 | ), 26 | }); 27 | 28 | const useStore = create(devtools(store)); 29 | 30 | export default useStore; 31 | -------------------------------------------------------------------------------- /src/theme.js: -------------------------------------------------------------------------------- 1 | import { createTheme } from "@mui/material"; 2 | 3 | export const colors = [ 4 | "#F49D6E", 5 | "#E85A4F", 6 | "#FFD166", 7 | "#8ABEB7", 8 | "#247BA0", 9 | "#D3D3D3", 10 | ]; 11 | 12 | const theme = createTheme({ 13 | palette: { 14 | mode: "dark", 15 | background: { 16 | default: "#1D1F26", 17 | }, 18 | primary: { 19 | main: "#BEA4FF", 20 | }, 21 | }, 22 | components: { 23 | MuiIconButton: { 24 | defaultProps: { 25 | size: "small", 26 | }, 27 | }, 28 | MuiSnackbar: { 29 | defaultProps: { 30 | anchorOrigin: { 31 | vertical: "top", 32 | horizontal: "center", 33 | }, 34 | }, 35 | }, 36 | MuiSnackbarContent: { 37 | styleOverrides: { 38 | message: { 39 | fontWeight: 600, 40 | textTransform: "capitalize", 41 | }, 42 | }, 43 | }, 44 | }, 45 | typography: { 46 | fontFamily: "Lato, sans-serif", 47 | button: { 48 | textTransform: "unset", 49 | fontWeight: 700, 50 | }, 51 | 52 | h5: { 53 | fontWeight: 700, 54 | }, 55 | h6: { 56 | fontWeight: 700, 57 | }, 58 | }, 59 | shape: { 60 | borderRadius: 0, 61 | }, 62 | }); 63 | 64 | export default theme; 65 | -------------------------------------------------------------------------------- /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 | -------------------------------------------------------------------------------- /vite.config.js.timestamp-1685895866945-f33c910a0ddf2.mjs: -------------------------------------------------------------------------------- 1 | // vite.config.js 2 | import { defineConfig } from "file:///Users/dependarsethi/Documents/flowboard-tutorial/node_modules/vite/dist/node/index.js"; 3 | import react from "file:///Users/dependarsethi/Documents/flowboard-tutorial/node_modules/@vitejs/plugin-react/dist/index.mjs"; 4 | var vite_config_default = defineConfig({ 5 | plugins: [react()] 6 | }); 7 | export { 8 | vite_config_default as default 9 | }; 10 | //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsidml0ZS5jb25maWcuanMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImNvbnN0IF9fdml0ZV9pbmplY3RlZF9vcmlnaW5hbF9kaXJuYW1lID0gXCIvVXNlcnMvZGVwZW5kYXJzZXRoaS9Eb2N1bWVudHMvZmxvd2JvYXJkLXR1dG9yaWFsXCI7Y29uc3QgX192aXRlX2luamVjdGVkX29yaWdpbmFsX2ZpbGVuYW1lID0gXCIvVXNlcnMvZGVwZW5kYXJzZXRoaS9Eb2N1bWVudHMvZmxvd2JvYXJkLXR1dG9yaWFsL3ZpdGUuY29uZmlnLmpzXCI7Y29uc3QgX192aXRlX2luamVjdGVkX29yaWdpbmFsX2ltcG9ydF9tZXRhX3VybCA9IFwiZmlsZTovLy9Vc2Vycy9kZXBlbmRhcnNldGhpL0RvY3VtZW50cy9mbG93Ym9hcmQtdHV0b3JpYWwvdml0ZS5jb25maWcuanNcIjtpbXBvcnQgeyBkZWZpbmVDb25maWcgfSBmcm9tICd2aXRlJ1xuaW1wb3J0IHJlYWN0IGZyb20gJ0B2aXRlanMvcGx1Z2luLXJlYWN0J1xuXG4vLyBodHRwczovL3ZpdGVqcy5kZXYvY29uZmlnL1xuZXhwb3J0IGRlZmF1bHQgZGVmaW5lQ29uZmlnKHtcbiAgcGx1Z2luczogW3JlYWN0KCldLFxufSlcbiJdLAogICJtYXBwaW5ncyI6ICI7QUFBcVUsU0FBUyxvQkFBb0I7QUFDbFcsT0FBTyxXQUFXO0FBR2xCLElBQU8sc0JBQVEsYUFBYTtBQUFBLEVBQzFCLFNBQVMsQ0FBQyxNQUFNLENBQUM7QUFDbkIsQ0FBQzsiLAogICJuYW1lcyI6IFtdCn0K 11 | --------------------------------------------------------------------------------