├── .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 | 
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 |
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 |
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 | }
16 | onClick={() => navigate("/boards")}
17 | variant="contained"
18 | >
19 | Go back
20 |
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 |
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 |
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 |
--------------------------------------------------------------------------------