├── .eslintrc.cjs ├── .gitignore ├── README.md ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.tsx ├── assets │ └── react.svg ├── components │ ├── AppHeader.tsx │ ├── RemoveCompletedBtn.tsx │ ├── Task.tsx │ ├── TaskCompletionToggle.tsx │ ├── TaskDeleteBtn.tsx │ ├── TaskFilterBar.tsx │ ├── TaskFilterBtn.tsx │ ├── TaskForm.tsx │ ├── TaskList.tsx │ ├── ThemeToggle.tsx │ └── index.ts ├── features │ ├── task │ │ └── taskSlice.ts │ └── theme │ │ └── themeSlice.ts ├── hooks.ts ├── index.css ├── main.tsx ├── store.ts ├── utils │ ├── taskUtils.ts │ ├── themeUtils.ts │ └── types.ts └── vite-env.d.ts ├── tsconfig.json ├── tsconfig.node.json └── vite.config.ts /.eslintrc.cjs: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | env: { browser: true, es2020: true }, 4 | extends: [ 5 | 'eslint:recommended', 6 | 'plugin:@typescript-eslint/recommended', 7 | 'plugin:react-hooks/recommended', 8 | ], 9 | ignorePatterns: ['dist', '.eslintrc.cjs'], 10 | parser: '@typescript-eslint/parser', 11 | plugins: ['react-refresh'], 12 | rules: { 13 | 'react-refresh/only-export-components': [ 14 | 'warn', 15 | { allowConstantExport: true }, 16 | ], 17 | }, 18 | } 19 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | pnpm-debug.log* 8 | lerna-debug.log* 9 | 10 | node_modules 11 | dist 12 | dist-ssr 13 | *.local 14 | 15 | # Editor directories and files 16 | .vscode/* 17 | !.vscode/extensions.json 18 | .idea 19 | .DS_Store 20 | *.suo 21 | *.ntvs* 22 | *.njsproj 23 | *.sln 24 | *.sw? 25 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Task Manager App 2 | 3 | Task Manager APP with React, Typescript and Redux Toolkit 4 | [Live Demo](https://task-manager-app-react-typescript.netlify.app/) 5 | 6 | ## Setup 7 | 8 | - install dependencies 9 | 10 | ```sh 11 | npm install 12 | ``` 13 | 14 | - spin up the development server 15 | 16 | ```sh 17 | npm run dev 18 | ``` 19 | 20 | - working app on http://localhost:5173/ 21 | 22 | ## Development Choices/Technology Stack 23 | 24 | ### React 25 | 26 | For this project, I selected React due to its component-based architecture and efficient reactivity system. This choice enabled me to add more features faster and streamline the development process. Nevertheless, I'm still comfortable and proficient in building similar applications with just Vanilla JS, ensuring a strong foundation in the fundamentals of JavaScript. 27 | 28 | ### TypeScript 29 | 30 | In this project, I utilized TypeScript because it provided strong typing and compile-time error checking. This enhanced the code's reliability and maintainability. 31 | 32 | ### CSS 33 | 34 | For this project, I chose vanilla CSS to showcase my familiarity and skill with CSS fundamentals. Additionally, I am adept and well-versed in using Tailwind CSS for utility-centric strategies. 35 | 36 | ### Redux Toolkit 37 | 38 | In this project, I opted for Redux Toolkit due to its longer-standing presence in the industry. However, at this point, a library like Zustand would be a suitable alternative. 39 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Task Manager 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "task-manager", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "task-manager", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "@reduxjs/toolkit": "^2.2.1", 12 | "react": "^18.2.0", 13 | "react-dom": "^18.2.0", 14 | "react-hot-toast": "^2.4.1", 15 | "react-icons": "^5.0.1", 16 | "react-redux": "^9.1.0" 17 | }, 18 | "devDependencies": { 19 | "@types/react": "^18.2.56", 20 | "@types/react-dom": "^18.2.19", 21 | "@typescript-eslint/eslint-plugin": "^7.0.2", 22 | "@typescript-eslint/parser": "^7.0.2", 23 | "@vitejs/plugin-react": "^4.2.1", 24 | "eslint": "^8.56.0", 25 | "eslint-plugin-react-hooks": "^4.6.0", 26 | "eslint-plugin-react-refresh": "^0.4.5", 27 | "typescript": "^5.2.2", 28 | "vite": "^5.1.4" 29 | } 30 | }, 31 | "node_modules/@aashutoshrathi/word-wrap": { 32 | "version": "1.2.6", 33 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 34 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 35 | "dev": true, 36 | "engines": { 37 | "node": ">=0.10.0" 38 | } 39 | }, 40 | "node_modules/@ampproject/remapping": { 41 | "version": "2.3.0", 42 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", 43 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", 44 | "dev": true, 45 | "dependencies": { 46 | "@jridgewell/gen-mapping": "^0.3.5", 47 | "@jridgewell/trace-mapping": "^0.3.24" 48 | }, 49 | "engines": { 50 | "node": ">=6.0.0" 51 | } 52 | }, 53 | "node_modules/@babel/code-frame": { 54 | "version": "7.23.5", 55 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", 56 | "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", 57 | "dev": true, 58 | "dependencies": { 59 | "@babel/highlight": "^7.23.4", 60 | "chalk": "^2.4.2" 61 | }, 62 | "engines": { 63 | "node": ">=6.9.0" 64 | } 65 | }, 66 | "node_modules/@babel/compat-data": { 67 | "version": "7.23.5", 68 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", 69 | "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", 70 | "dev": true, 71 | "engines": { 72 | "node": ">=6.9.0" 73 | } 74 | }, 75 | "node_modules/@babel/core": { 76 | "version": "7.24.0", 77 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.0.tgz", 78 | "integrity": "sha512-fQfkg0Gjkza3nf0c7/w6Xf34BW4YvzNfACRLmmb7XRLa6XHdR+K9AlJlxneFfWYf6uhOzuzZVTjF/8KfndZANw==", 79 | "dev": true, 80 | "dependencies": { 81 | "@ampproject/remapping": "^2.2.0", 82 | "@babel/code-frame": "^7.23.5", 83 | "@babel/generator": "^7.23.6", 84 | "@babel/helper-compilation-targets": "^7.23.6", 85 | "@babel/helper-module-transforms": "^7.23.3", 86 | "@babel/helpers": "^7.24.0", 87 | "@babel/parser": "^7.24.0", 88 | "@babel/template": "^7.24.0", 89 | "@babel/traverse": "^7.24.0", 90 | "@babel/types": "^7.24.0", 91 | "convert-source-map": "^2.0.0", 92 | "debug": "^4.1.0", 93 | "gensync": "^1.0.0-beta.2", 94 | "json5": "^2.2.3", 95 | "semver": "^6.3.1" 96 | }, 97 | "engines": { 98 | "node": ">=6.9.0" 99 | }, 100 | "funding": { 101 | "type": "opencollective", 102 | "url": "https://opencollective.com/babel" 103 | } 104 | }, 105 | "node_modules/@babel/core/node_modules/semver": { 106 | "version": "6.3.1", 107 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 108 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 109 | "dev": true, 110 | "bin": { 111 | "semver": "bin/semver.js" 112 | } 113 | }, 114 | "node_modules/@babel/generator": { 115 | "version": "7.23.6", 116 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", 117 | "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", 118 | "dev": true, 119 | "dependencies": { 120 | "@babel/types": "^7.23.6", 121 | "@jridgewell/gen-mapping": "^0.3.2", 122 | "@jridgewell/trace-mapping": "^0.3.17", 123 | "jsesc": "^2.5.1" 124 | }, 125 | "engines": { 126 | "node": ">=6.9.0" 127 | } 128 | }, 129 | "node_modules/@babel/helper-compilation-targets": { 130 | "version": "7.23.6", 131 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", 132 | "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", 133 | "dev": true, 134 | "dependencies": { 135 | "@babel/compat-data": "^7.23.5", 136 | "@babel/helper-validator-option": "^7.23.5", 137 | "browserslist": "^4.22.2", 138 | "lru-cache": "^5.1.1", 139 | "semver": "^6.3.1" 140 | }, 141 | "engines": { 142 | "node": ">=6.9.0" 143 | } 144 | }, 145 | "node_modules/@babel/helper-compilation-targets/node_modules/semver": { 146 | "version": "6.3.1", 147 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", 148 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", 149 | "dev": true, 150 | "bin": { 151 | "semver": "bin/semver.js" 152 | } 153 | }, 154 | "node_modules/@babel/helper-environment-visitor": { 155 | "version": "7.22.20", 156 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", 157 | "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", 158 | "dev": true, 159 | "engines": { 160 | "node": ">=6.9.0" 161 | } 162 | }, 163 | "node_modules/@babel/helper-function-name": { 164 | "version": "7.23.0", 165 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", 166 | "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", 167 | "dev": true, 168 | "dependencies": { 169 | "@babel/template": "^7.22.15", 170 | "@babel/types": "^7.23.0" 171 | }, 172 | "engines": { 173 | "node": ">=6.9.0" 174 | } 175 | }, 176 | "node_modules/@babel/helper-hoist-variables": { 177 | "version": "7.22.5", 178 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", 179 | "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", 180 | "dev": true, 181 | "dependencies": { 182 | "@babel/types": "^7.22.5" 183 | }, 184 | "engines": { 185 | "node": ">=6.9.0" 186 | } 187 | }, 188 | "node_modules/@babel/helper-module-imports": { 189 | "version": "7.22.15", 190 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", 191 | "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", 192 | "dev": true, 193 | "dependencies": { 194 | "@babel/types": "^7.22.15" 195 | }, 196 | "engines": { 197 | "node": ">=6.9.0" 198 | } 199 | }, 200 | "node_modules/@babel/helper-module-transforms": { 201 | "version": "7.23.3", 202 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz", 203 | "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==", 204 | "dev": true, 205 | "dependencies": { 206 | "@babel/helper-environment-visitor": "^7.22.20", 207 | "@babel/helper-module-imports": "^7.22.15", 208 | "@babel/helper-simple-access": "^7.22.5", 209 | "@babel/helper-split-export-declaration": "^7.22.6", 210 | "@babel/helper-validator-identifier": "^7.22.20" 211 | }, 212 | "engines": { 213 | "node": ">=6.9.0" 214 | }, 215 | "peerDependencies": { 216 | "@babel/core": "^7.0.0" 217 | } 218 | }, 219 | "node_modules/@babel/helper-plugin-utils": { 220 | "version": "7.24.0", 221 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.0.tgz", 222 | "integrity": "sha512-9cUznXMG0+FxRuJfvL82QlTqIzhVW9sL0KjMPHhAOOvpQGL8QtdxnBKILjBqxlHyliz0yCa1G903ZXI/FuHy2w==", 223 | "dev": true, 224 | "engines": { 225 | "node": ">=6.9.0" 226 | } 227 | }, 228 | "node_modules/@babel/helper-simple-access": { 229 | "version": "7.22.5", 230 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", 231 | "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", 232 | "dev": true, 233 | "dependencies": { 234 | "@babel/types": "^7.22.5" 235 | }, 236 | "engines": { 237 | "node": ">=6.9.0" 238 | } 239 | }, 240 | "node_modules/@babel/helper-split-export-declaration": { 241 | "version": "7.22.6", 242 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", 243 | "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", 244 | "dev": true, 245 | "dependencies": { 246 | "@babel/types": "^7.22.5" 247 | }, 248 | "engines": { 249 | "node": ">=6.9.0" 250 | } 251 | }, 252 | "node_modules/@babel/helper-string-parser": { 253 | "version": "7.23.4", 254 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", 255 | "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", 256 | "dev": true, 257 | "engines": { 258 | "node": ">=6.9.0" 259 | } 260 | }, 261 | "node_modules/@babel/helper-validator-identifier": { 262 | "version": "7.22.20", 263 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", 264 | "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", 265 | "dev": true, 266 | "engines": { 267 | "node": ">=6.9.0" 268 | } 269 | }, 270 | "node_modules/@babel/helper-validator-option": { 271 | "version": "7.23.5", 272 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz", 273 | "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==", 274 | "dev": true, 275 | "engines": { 276 | "node": ">=6.9.0" 277 | } 278 | }, 279 | "node_modules/@babel/helpers": { 280 | "version": "7.24.0", 281 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.0.tgz", 282 | "integrity": "sha512-ulDZdc0Aj5uLc5nETsa7EPx2L7rM0YJM8r7ck7U73AXi7qOV44IHHRAYZHY6iU1rr3C5N4NtTmMRUJP6kwCWeA==", 283 | "dev": true, 284 | "dependencies": { 285 | "@babel/template": "^7.24.0", 286 | "@babel/traverse": "^7.24.0", 287 | "@babel/types": "^7.24.0" 288 | }, 289 | "engines": { 290 | "node": ">=6.9.0" 291 | } 292 | }, 293 | "node_modules/@babel/highlight": { 294 | "version": "7.23.4", 295 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", 296 | "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", 297 | "dev": true, 298 | "dependencies": { 299 | "@babel/helper-validator-identifier": "^7.22.20", 300 | "chalk": "^2.4.2", 301 | "js-tokens": "^4.0.0" 302 | }, 303 | "engines": { 304 | "node": ">=6.9.0" 305 | } 306 | }, 307 | "node_modules/@babel/parser": { 308 | "version": "7.24.0", 309 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.0.tgz", 310 | "integrity": "sha512-QuP/FxEAzMSjXygs8v4N9dvdXzEHN4W1oF3PxuWAtPo08UdM17u89RDMgjLn/mlc56iM0HlLmVkO/wgR+rDgHg==", 311 | "dev": true, 312 | "bin": { 313 | "parser": "bin/babel-parser.js" 314 | }, 315 | "engines": { 316 | "node": ">=6.0.0" 317 | } 318 | }, 319 | "node_modules/@babel/plugin-transform-react-jsx-self": { 320 | "version": "7.23.3", 321 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.23.3.tgz", 322 | "integrity": "sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==", 323 | "dev": true, 324 | "dependencies": { 325 | "@babel/helper-plugin-utils": "^7.22.5" 326 | }, 327 | "engines": { 328 | "node": ">=6.9.0" 329 | }, 330 | "peerDependencies": { 331 | "@babel/core": "^7.0.0-0" 332 | } 333 | }, 334 | "node_modules/@babel/plugin-transform-react-jsx-source": { 335 | "version": "7.23.3", 336 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.23.3.tgz", 337 | "integrity": "sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==", 338 | "dev": true, 339 | "dependencies": { 340 | "@babel/helper-plugin-utils": "^7.22.5" 341 | }, 342 | "engines": { 343 | "node": ">=6.9.0" 344 | }, 345 | "peerDependencies": { 346 | "@babel/core": "^7.0.0-0" 347 | } 348 | }, 349 | "node_modules/@babel/template": { 350 | "version": "7.24.0", 351 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.0.tgz", 352 | "integrity": "sha512-Bkf2q8lMB0AFpX0NFEqSbx1OkTHf0f+0j82mkw+ZpzBnkk7e9Ql0891vlfgi+kHwOk8tQjiQHpqh4LaSa0fKEA==", 353 | "dev": true, 354 | "dependencies": { 355 | "@babel/code-frame": "^7.23.5", 356 | "@babel/parser": "^7.24.0", 357 | "@babel/types": "^7.24.0" 358 | }, 359 | "engines": { 360 | "node": ">=6.9.0" 361 | } 362 | }, 363 | "node_modules/@babel/traverse": { 364 | "version": "7.24.0", 365 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.0.tgz", 366 | "integrity": "sha512-HfuJlI8qq3dEDmNU5ChzzpZRWq+oxCZQyMzIMEqLho+AQnhMnKQUzH6ydo3RBl/YjPCuk68Y6s0Gx0AeyULiWw==", 367 | "dev": true, 368 | "dependencies": { 369 | "@babel/code-frame": "^7.23.5", 370 | "@babel/generator": "^7.23.6", 371 | "@babel/helper-environment-visitor": "^7.22.20", 372 | "@babel/helper-function-name": "^7.23.0", 373 | "@babel/helper-hoist-variables": "^7.22.5", 374 | "@babel/helper-split-export-declaration": "^7.22.6", 375 | "@babel/parser": "^7.24.0", 376 | "@babel/types": "^7.24.0", 377 | "debug": "^4.3.1", 378 | "globals": "^11.1.0" 379 | }, 380 | "engines": { 381 | "node": ">=6.9.0" 382 | } 383 | }, 384 | "node_modules/@babel/types": { 385 | "version": "7.24.0", 386 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.0.tgz", 387 | "integrity": "sha512-+j7a5c253RfKh8iABBhywc8NSfP5LURe7Uh4qpsh6jc+aLJguvmIUBdjSdEMQv2bENrCR5MfRdjGo7vzS/ob7w==", 388 | "dev": true, 389 | "dependencies": { 390 | "@babel/helper-string-parser": "^7.23.4", 391 | "@babel/helper-validator-identifier": "^7.22.20", 392 | "to-fast-properties": "^2.0.0" 393 | }, 394 | "engines": { 395 | "node": ">=6.9.0" 396 | } 397 | }, 398 | "node_modules/@esbuild/aix-ppc64": { 399 | "version": "0.19.12", 400 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.19.12.tgz", 401 | "integrity": "sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA==", 402 | "cpu": [ 403 | "ppc64" 404 | ], 405 | "dev": true, 406 | "optional": true, 407 | "os": [ 408 | "aix" 409 | ], 410 | "engines": { 411 | "node": ">=12" 412 | } 413 | }, 414 | "node_modules/@esbuild/android-arm": { 415 | "version": "0.19.12", 416 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.19.12.tgz", 417 | "integrity": "sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w==", 418 | "cpu": [ 419 | "arm" 420 | ], 421 | "dev": true, 422 | "optional": true, 423 | "os": [ 424 | "android" 425 | ], 426 | "engines": { 427 | "node": ">=12" 428 | } 429 | }, 430 | "node_modules/@esbuild/android-arm64": { 431 | "version": "0.19.12", 432 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.19.12.tgz", 433 | "integrity": "sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA==", 434 | "cpu": [ 435 | "arm64" 436 | ], 437 | "dev": true, 438 | "optional": true, 439 | "os": [ 440 | "android" 441 | ], 442 | "engines": { 443 | "node": ">=12" 444 | } 445 | }, 446 | "node_modules/@esbuild/android-x64": { 447 | "version": "0.19.12", 448 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.19.12.tgz", 449 | "integrity": "sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew==", 450 | "cpu": [ 451 | "x64" 452 | ], 453 | "dev": true, 454 | "optional": true, 455 | "os": [ 456 | "android" 457 | ], 458 | "engines": { 459 | "node": ">=12" 460 | } 461 | }, 462 | "node_modules/@esbuild/darwin-arm64": { 463 | "version": "0.19.12", 464 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.19.12.tgz", 465 | "integrity": "sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g==", 466 | "cpu": [ 467 | "arm64" 468 | ], 469 | "dev": true, 470 | "optional": true, 471 | "os": [ 472 | "darwin" 473 | ], 474 | "engines": { 475 | "node": ">=12" 476 | } 477 | }, 478 | "node_modules/@esbuild/darwin-x64": { 479 | "version": "0.19.12", 480 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.19.12.tgz", 481 | "integrity": "sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A==", 482 | "cpu": [ 483 | "x64" 484 | ], 485 | "dev": true, 486 | "optional": true, 487 | "os": [ 488 | "darwin" 489 | ], 490 | "engines": { 491 | "node": ">=12" 492 | } 493 | }, 494 | "node_modules/@esbuild/freebsd-arm64": { 495 | "version": "0.19.12", 496 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.19.12.tgz", 497 | "integrity": "sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA==", 498 | "cpu": [ 499 | "arm64" 500 | ], 501 | "dev": true, 502 | "optional": true, 503 | "os": [ 504 | "freebsd" 505 | ], 506 | "engines": { 507 | "node": ">=12" 508 | } 509 | }, 510 | "node_modules/@esbuild/freebsd-x64": { 511 | "version": "0.19.12", 512 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.19.12.tgz", 513 | "integrity": "sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg==", 514 | "cpu": [ 515 | "x64" 516 | ], 517 | "dev": true, 518 | "optional": true, 519 | "os": [ 520 | "freebsd" 521 | ], 522 | "engines": { 523 | "node": ">=12" 524 | } 525 | }, 526 | "node_modules/@esbuild/linux-arm": { 527 | "version": "0.19.12", 528 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.19.12.tgz", 529 | "integrity": "sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w==", 530 | "cpu": [ 531 | "arm" 532 | ], 533 | "dev": true, 534 | "optional": true, 535 | "os": [ 536 | "linux" 537 | ], 538 | "engines": { 539 | "node": ">=12" 540 | } 541 | }, 542 | "node_modules/@esbuild/linux-arm64": { 543 | "version": "0.19.12", 544 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.19.12.tgz", 545 | "integrity": "sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA==", 546 | "cpu": [ 547 | "arm64" 548 | ], 549 | "dev": true, 550 | "optional": true, 551 | "os": [ 552 | "linux" 553 | ], 554 | "engines": { 555 | "node": ">=12" 556 | } 557 | }, 558 | "node_modules/@esbuild/linux-ia32": { 559 | "version": "0.19.12", 560 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.19.12.tgz", 561 | "integrity": "sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA==", 562 | "cpu": [ 563 | "ia32" 564 | ], 565 | "dev": true, 566 | "optional": true, 567 | "os": [ 568 | "linux" 569 | ], 570 | "engines": { 571 | "node": ">=12" 572 | } 573 | }, 574 | "node_modules/@esbuild/linux-loong64": { 575 | "version": "0.19.12", 576 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.19.12.tgz", 577 | "integrity": "sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA==", 578 | "cpu": [ 579 | "loong64" 580 | ], 581 | "dev": true, 582 | "optional": true, 583 | "os": [ 584 | "linux" 585 | ], 586 | "engines": { 587 | "node": ">=12" 588 | } 589 | }, 590 | "node_modules/@esbuild/linux-mips64el": { 591 | "version": "0.19.12", 592 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.19.12.tgz", 593 | "integrity": "sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w==", 594 | "cpu": [ 595 | "mips64el" 596 | ], 597 | "dev": true, 598 | "optional": true, 599 | "os": [ 600 | "linux" 601 | ], 602 | "engines": { 603 | "node": ">=12" 604 | } 605 | }, 606 | "node_modules/@esbuild/linux-ppc64": { 607 | "version": "0.19.12", 608 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.19.12.tgz", 609 | "integrity": "sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg==", 610 | "cpu": [ 611 | "ppc64" 612 | ], 613 | "dev": true, 614 | "optional": true, 615 | "os": [ 616 | "linux" 617 | ], 618 | "engines": { 619 | "node": ">=12" 620 | } 621 | }, 622 | "node_modules/@esbuild/linux-riscv64": { 623 | "version": "0.19.12", 624 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.19.12.tgz", 625 | "integrity": "sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg==", 626 | "cpu": [ 627 | "riscv64" 628 | ], 629 | "dev": true, 630 | "optional": true, 631 | "os": [ 632 | "linux" 633 | ], 634 | "engines": { 635 | "node": ">=12" 636 | } 637 | }, 638 | "node_modules/@esbuild/linux-s390x": { 639 | "version": "0.19.12", 640 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.19.12.tgz", 641 | "integrity": "sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg==", 642 | "cpu": [ 643 | "s390x" 644 | ], 645 | "dev": true, 646 | "optional": true, 647 | "os": [ 648 | "linux" 649 | ], 650 | "engines": { 651 | "node": ">=12" 652 | } 653 | }, 654 | "node_modules/@esbuild/linux-x64": { 655 | "version": "0.19.12", 656 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.19.12.tgz", 657 | "integrity": "sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg==", 658 | "cpu": [ 659 | "x64" 660 | ], 661 | "dev": true, 662 | "optional": true, 663 | "os": [ 664 | "linux" 665 | ], 666 | "engines": { 667 | "node": ">=12" 668 | } 669 | }, 670 | "node_modules/@esbuild/netbsd-x64": { 671 | "version": "0.19.12", 672 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.19.12.tgz", 673 | "integrity": "sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA==", 674 | "cpu": [ 675 | "x64" 676 | ], 677 | "dev": true, 678 | "optional": true, 679 | "os": [ 680 | "netbsd" 681 | ], 682 | "engines": { 683 | "node": ">=12" 684 | } 685 | }, 686 | "node_modules/@esbuild/openbsd-x64": { 687 | "version": "0.19.12", 688 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.19.12.tgz", 689 | "integrity": "sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw==", 690 | "cpu": [ 691 | "x64" 692 | ], 693 | "dev": true, 694 | "optional": true, 695 | "os": [ 696 | "openbsd" 697 | ], 698 | "engines": { 699 | "node": ">=12" 700 | } 701 | }, 702 | "node_modules/@esbuild/sunos-x64": { 703 | "version": "0.19.12", 704 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.19.12.tgz", 705 | "integrity": "sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA==", 706 | "cpu": [ 707 | "x64" 708 | ], 709 | "dev": true, 710 | "optional": true, 711 | "os": [ 712 | "sunos" 713 | ], 714 | "engines": { 715 | "node": ">=12" 716 | } 717 | }, 718 | "node_modules/@esbuild/win32-arm64": { 719 | "version": "0.19.12", 720 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.19.12.tgz", 721 | "integrity": "sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A==", 722 | "cpu": [ 723 | "arm64" 724 | ], 725 | "dev": true, 726 | "optional": true, 727 | "os": [ 728 | "win32" 729 | ], 730 | "engines": { 731 | "node": ">=12" 732 | } 733 | }, 734 | "node_modules/@esbuild/win32-ia32": { 735 | "version": "0.19.12", 736 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.19.12.tgz", 737 | "integrity": "sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ==", 738 | "cpu": [ 739 | "ia32" 740 | ], 741 | "dev": true, 742 | "optional": true, 743 | "os": [ 744 | "win32" 745 | ], 746 | "engines": { 747 | "node": ">=12" 748 | } 749 | }, 750 | "node_modules/@esbuild/win32-x64": { 751 | "version": "0.19.12", 752 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.19.12.tgz", 753 | "integrity": "sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA==", 754 | "cpu": [ 755 | "x64" 756 | ], 757 | "dev": true, 758 | "optional": true, 759 | "os": [ 760 | "win32" 761 | ], 762 | "engines": { 763 | "node": ">=12" 764 | } 765 | }, 766 | "node_modules/@eslint-community/eslint-utils": { 767 | "version": "4.4.0", 768 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 769 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 770 | "dev": true, 771 | "dependencies": { 772 | "eslint-visitor-keys": "^3.3.0" 773 | }, 774 | "engines": { 775 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 776 | }, 777 | "peerDependencies": { 778 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 779 | } 780 | }, 781 | "node_modules/@eslint-community/regexpp": { 782 | "version": "4.10.0", 783 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 784 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 785 | "dev": true, 786 | "engines": { 787 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 788 | } 789 | }, 790 | "node_modules/@eslint/eslintrc": { 791 | "version": "2.1.4", 792 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 793 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 794 | "dev": true, 795 | "dependencies": { 796 | "ajv": "^6.12.4", 797 | "debug": "^4.3.2", 798 | "espree": "^9.6.0", 799 | "globals": "^13.19.0", 800 | "ignore": "^5.2.0", 801 | "import-fresh": "^3.2.1", 802 | "js-yaml": "^4.1.0", 803 | "minimatch": "^3.1.2", 804 | "strip-json-comments": "^3.1.1" 805 | }, 806 | "engines": { 807 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 808 | }, 809 | "funding": { 810 | "url": "https://opencollective.com/eslint" 811 | } 812 | }, 813 | "node_modules/@eslint/eslintrc/node_modules/brace-expansion": { 814 | "version": "1.1.11", 815 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 816 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 817 | "dev": true, 818 | "dependencies": { 819 | "balanced-match": "^1.0.0", 820 | "concat-map": "0.0.1" 821 | } 822 | }, 823 | "node_modules/@eslint/eslintrc/node_modules/globals": { 824 | "version": "13.24.0", 825 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 826 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 827 | "dev": true, 828 | "dependencies": { 829 | "type-fest": "^0.20.2" 830 | }, 831 | "engines": { 832 | "node": ">=8" 833 | }, 834 | "funding": { 835 | "url": "https://github.com/sponsors/sindresorhus" 836 | } 837 | }, 838 | "node_modules/@eslint/eslintrc/node_modules/minimatch": { 839 | "version": "3.1.2", 840 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 841 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 842 | "dev": true, 843 | "dependencies": { 844 | "brace-expansion": "^1.1.7" 845 | }, 846 | "engines": { 847 | "node": "*" 848 | } 849 | }, 850 | "node_modules/@eslint/js": { 851 | "version": "8.57.0", 852 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", 853 | "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", 854 | "dev": true, 855 | "engines": { 856 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 857 | } 858 | }, 859 | "node_modules/@humanwhocodes/config-array": { 860 | "version": "0.11.14", 861 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", 862 | "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", 863 | "dev": true, 864 | "dependencies": { 865 | "@humanwhocodes/object-schema": "^2.0.2", 866 | "debug": "^4.3.1", 867 | "minimatch": "^3.0.5" 868 | }, 869 | "engines": { 870 | "node": ">=10.10.0" 871 | } 872 | }, 873 | "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": { 874 | "version": "1.1.11", 875 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 876 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 877 | "dev": true, 878 | "dependencies": { 879 | "balanced-match": "^1.0.0", 880 | "concat-map": "0.0.1" 881 | } 882 | }, 883 | "node_modules/@humanwhocodes/config-array/node_modules/minimatch": { 884 | "version": "3.1.2", 885 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 886 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 887 | "dev": true, 888 | "dependencies": { 889 | "brace-expansion": "^1.1.7" 890 | }, 891 | "engines": { 892 | "node": "*" 893 | } 894 | }, 895 | "node_modules/@humanwhocodes/module-importer": { 896 | "version": "1.0.1", 897 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 898 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 899 | "dev": true, 900 | "engines": { 901 | "node": ">=12.22" 902 | }, 903 | "funding": { 904 | "type": "github", 905 | "url": "https://github.com/sponsors/nzakas" 906 | } 907 | }, 908 | "node_modules/@humanwhocodes/object-schema": { 909 | "version": "2.0.2", 910 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", 911 | "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", 912 | "dev": true 913 | }, 914 | "node_modules/@jridgewell/gen-mapping": { 915 | "version": "0.3.5", 916 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 917 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 918 | "dev": true, 919 | "dependencies": { 920 | "@jridgewell/set-array": "^1.2.1", 921 | "@jridgewell/sourcemap-codec": "^1.4.10", 922 | "@jridgewell/trace-mapping": "^0.3.24" 923 | }, 924 | "engines": { 925 | "node": ">=6.0.0" 926 | } 927 | }, 928 | "node_modules/@jridgewell/resolve-uri": { 929 | "version": "3.1.2", 930 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 931 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 932 | "dev": true, 933 | "engines": { 934 | "node": ">=6.0.0" 935 | } 936 | }, 937 | "node_modules/@jridgewell/set-array": { 938 | "version": "1.2.1", 939 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 940 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 941 | "dev": true, 942 | "engines": { 943 | "node": ">=6.0.0" 944 | } 945 | }, 946 | "node_modules/@jridgewell/sourcemap-codec": { 947 | "version": "1.4.15", 948 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 949 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 950 | "dev": true 951 | }, 952 | "node_modules/@jridgewell/trace-mapping": { 953 | "version": "0.3.25", 954 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 955 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 956 | "dev": true, 957 | "dependencies": { 958 | "@jridgewell/resolve-uri": "^3.1.0", 959 | "@jridgewell/sourcemap-codec": "^1.4.14" 960 | } 961 | }, 962 | "node_modules/@nodelib/fs.scandir": { 963 | "version": "2.1.5", 964 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 965 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 966 | "dev": true, 967 | "dependencies": { 968 | "@nodelib/fs.stat": "2.0.5", 969 | "run-parallel": "^1.1.9" 970 | }, 971 | "engines": { 972 | "node": ">= 8" 973 | } 974 | }, 975 | "node_modules/@nodelib/fs.stat": { 976 | "version": "2.0.5", 977 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 978 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 979 | "dev": true, 980 | "engines": { 981 | "node": ">= 8" 982 | } 983 | }, 984 | "node_modules/@nodelib/fs.walk": { 985 | "version": "1.2.8", 986 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 987 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 988 | "dev": true, 989 | "dependencies": { 990 | "@nodelib/fs.scandir": "2.1.5", 991 | "fastq": "^1.6.0" 992 | }, 993 | "engines": { 994 | "node": ">= 8" 995 | } 996 | }, 997 | "node_modules/@reduxjs/toolkit": { 998 | "version": "2.2.1", 999 | "resolved": "https://registry.npmjs.org/@reduxjs/toolkit/-/toolkit-2.2.1.tgz", 1000 | "integrity": "sha512-8CREoqJovQW/5I4yvvijm/emUiCCmcs4Ev4XPWd4mizSO+dD3g5G6w34QK5AGeNrSH7qM8Fl66j4vuV7dpOdkw==", 1001 | "dependencies": { 1002 | "immer": "^10.0.3", 1003 | "redux": "^5.0.1", 1004 | "redux-thunk": "^3.1.0", 1005 | "reselect": "^5.0.1" 1006 | }, 1007 | "peerDependencies": { 1008 | "react": "^16.9.0 || ^17.0.0 || ^18", 1009 | "react-redux": "^7.2.1 || ^8.1.3 || ^9.0.0" 1010 | }, 1011 | "peerDependenciesMeta": { 1012 | "react": { 1013 | "optional": true 1014 | }, 1015 | "react-redux": { 1016 | "optional": true 1017 | } 1018 | } 1019 | }, 1020 | "node_modules/@rollup/rollup-android-arm-eabi": { 1021 | "version": "4.12.0", 1022 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.12.0.tgz", 1023 | "integrity": "sha512-+ac02NL/2TCKRrJu2wffk1kZ+RyqxVUlbjSagNgPm94frxtr+XDL12E5Ll1enWskLrtrZ2r8L3wED1orIibV/w==", 1024 | "cpu": [ 1025 | "arm" 1026 | ], 1027 | "dev": true, 1028 | "optional": true, 1029 | "os": [ 1030 | "android" 1031 | ] 1032 | }, 1033 | "node_modules/@rollup/rollup-android-arm64": { 1034 | "version": "4.12.0", 1035 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.12.0.tgz", 1036 | "integrity": "sha512-OBqcX2BMe6nvjQ0Nyp7cC90cnumt8PXmO7Dp3gfAju/6YwG0Tj74z1vKrfRz7qAv23nBcYM8BCbhrsWqO7PzQQ==", 1037 | "cpu": [ 1038 | "arm64" 1039 | ], 1040 | "dev": true, 1041 | "optional": true, 1042 | "os": [ 1043 | "android" 1044 | ] 1045 | }, 1046 | "node_modules/@rollup/rollup-darwin-arm64": { 1047 | "version": "4.12.0", 1048 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.12.0.tgz", 1049 | "integrity": "sha512-X64tZd8dRE/QTrBIEs63kaOBG0b5GVEd3ccoLtyf6IdXtHdh8h+I56C2yC3PtC9Ucnv0CpNFJLqKFVgCYe0lOQ==", 1050 | "cpu": [ 1051 | "arm64" 1052 | ], 1053 | "dev": true, 1054 | "optional": true, 1055 | "os": [ 1056 | "darwin" 1057 | ] 1058 | }, 1059 | "node_modules/@rollup/rollup-darwin-x64": { 1060 | "version": "4.12.0", 1061 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.12.0.tgz", 1062 | "integrity": "sha512-cc71KUZoVbUJmGP2cOuiZ9HSOP14AzBAThn3OU+9LcA1+IUqswJyR1cAJj3Mg55HbjZP6OLAIscbQsQLrpgTOg==", 1063 | "cpu": [ 1064 | "x64" 1065 | ], 1066 | "dev": true, 1067 | "optional": true, 1068 | "os": [ 1069 | "darwin" 1070 | ] 1071 | }, 1072 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 1073 | "version": "4.12.0", 1074 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.12.0.tgz", 1075 | "integrity": "sha512-a6w/Y3hyyO6GlpKL2xJ4IOh/7d+APaqLYdMf86xnczU3nurFTaVN9s9jOXQg97BE4nYm/7Ga51rjec5nfRdrvA==", 1076 | "cpu": [ 1077 | "arm" 1078 | ], 1079 | "dev": true, 1080 | "optional": true, 1081 | "os": [ 1082 | "linux" 1083 | ] 1084 | }, 1085 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 1086 | "version": "4.12.0", 1087 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.12.0.tgz", 1088 | "integrity": "sha512-0fZBq27b+D7Ar5CQMofVN8sggOVhEtzFUwOwPppQt0k+VR+7UHMZZY4y+64WJ06XOhBTKXtQB/Sv0NwQMXyNAA==", 1089 | "cpu": [ 1090 | "arm64" 1091 | ], 1092 | "dev": true, 1093 | "optional": true, 1094 | "os": [ 1095 | "linux" 1096 | ] 1097 | }, 1098 | "node_modules/@rollup/rollup-linux-arm64-musl": { 1099 | "version": "4.12.0", 1100 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.12.0.tgz", 1101 | "integrity": "sha512-eTvzUS3hhhlgeAv6bfigekzWZjaEX9xP9HhxB0Dvrdbkk5w/b+1Sxct2ZuDxNJKzsRStSq1EaEkVSEe7A7ipgQ==", 1102 | "cpu": [ 1103 | "arm64" 1104 | ], 1105 | "dev": true, 1106 | "optional": true, 1107 | "os": [ 1108 | "linux" 1109 | ] 1110 | }, 1111 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 1112 | "version": "4.12.0", 1113 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.12.0.tgz", 1114 | "integrity": "sha512-ix+qAB9qmrCRiaO71VFfY8rkiAZJL8zQRXveS27HS+pKdjwUfEhqo2+YF2oI+H/22Xsiski+qqwIBxVewLK7sw==", 1115 | "cpu": [ 1116 | "riscv64" 1117 | ], 1118 | "dev": true, 1119 | "optional": true, 1120 | "os": [ 1121 | "linux" 1122 | ] 1123 | }, 1124 | "node_modules/@rollup/rollup-linux-x64-gnu": { 1125 | "version": "4.12.0", 1126 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.12.0.tgz", 1127 | "integrity": "sha512-TenQhZVOtw/3qKOPa7d+QgkeM6xY0LtwzR8OplmyL5LrgTWIXpTQg2Q2ycBf8jm+SFW2Wt/DTn1gf7nFp3ssVA==", 1128 | "cpu": [ 1129 | "x64" 1130 | ], 1131 | "dev": true, 1132 | "optional": true, 1133 | "os": [ 1134 | "linux" 1135 | ] 1136 | }, 1137 | "node_modules/@rollup/rollup-linux-x64-musl": { 1138 | "version": "4.12.0", 1139 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.12.0.tgz", 1140 | "integrity": "sha512-LfFdRhNnW0zdMvdCb5FNuWlls2WbbSridJvxOvYWgSBOYZtgBfW9UGNJG//rwMqTX1xQE9BAodvMH9tAusKDUw==", 1141 | "cpu": [ 1142 | "x64" 1143 | ], 1144 | "dev": true, 1145 | "optional": true, 1146 | "os": [ 1147 | "linux" 1148 | ] 1149 | }, 1150 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 1151 | "version": "4.12.0", 1152 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.12.0.tgz", 1153 | "integrity": "sha512-JPDxovheWNp6d7AHCgsUlkuCKvtu3RB55iNEkaQcf0ttsDU/JZF+iQnYcQJSk/7PtT4mjjVG8N1kpwnI9SLYaw==", 1154 | "cpu": [ 1155 | "arm64" 1156 | ], 1157 | "dev": true, 1158 | "optional": true, 1159 | "os": [ 1160 | "win32" 1161 | ] 1162 | }, 1163 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 1164 | "version": "4.12.0", 1165 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.12.0.tgz", 1166 | "integrity": "sha512-fjtuvMWRGJn1oZacG8IPnzIV6GF2/XG+h71FKn76OYFqySXInJtseAqdprVTDTyqPxQOG9Exak5/E9Z3+EJ8ZA==", 1167 | "cpu": [ 1168 | "ia32" 1169 | ], 1170 | "dev": true, 1171 | "optional": true, 1172 | "os": [ 1173 | "win32" 1174 | ] 1175 | }, 1176 | "node_modules/@rollup/rollup-win32-x64-msvc": { 1177 | "version": "4.12.0", 1178 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.12.0.tgz", 1179 | "integrity": "sha512-ZYmr5mS2wd4Dew/JjT0Fqi2NPB/ZhZ2VvPp7SmvPZb4Y1CG/LRcS6tcRo2cYU7zLK5A7cdbhWnnWmUjoI4qapg==", 1180 | "cpu": [ 1181 | "x64" 1182 | ], 1183 | "dev": true, 1184 | "optional": true, 1185 | "os": [ 1186 | "win32" 1187 | ] 1188 | }, 1189 | "node_modules/@types/babel__core": { 1190 | "version": "7.20.5", 1191 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", 1192 | "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", 1193 | "dev": true, 1194 | "dependencies": { 1195 | "@babel/parser": "^7.20.7", 1196 | "@babel/types": "^7.20.7", 1197 | "@types/babel__generator": "*", 1198 | "@types/babel__template": "*", 1199 | "@types/babel__traverse": "*" 1200 | } 1201 | }, 1202 | "node_modules/@types/babel__generator": { 1203 | "version": "7.6.8", 1204 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", 1205 | "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", 1206 | "dev": true, 1207 | "dependencies": { 1208 | "@babel/types": "^7.0.0" 1209 | } 1210 | }, 1211 | "node_modules/@types/babel__template": { 1212 | "version": "7.4.4", 1213 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", 1214 | "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", 1215 | "dev": true, 1216 | "dependencies": { 1217 | "@babel/parser": "^7.1.0", 1218 | "@babel/types": "^7.0.0" 1219 | } 1220 | }, 1221 | "node_modules/@types/babel__traverse": { 1222 | "version": "7.20.5", 1223 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.5.tgz", 1224 | "integrity": "sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==", 1225 | "dev": true, 1226 | "dependencies": { 1227 | "@babel/types": "^7.20.7" 1228 | } 1229 | }, 1230 | "node_modules/@types/estree": { 1231 | "version": "1.0.5", 1232 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", 1233 | "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", 1234 | "dev": true 1235 | }, 1236 | "node_modules/@types/json-schema": { 1237 | "version": "7.0.15", 1238 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 1239 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 1240 | "dev": true 1241 | }, 1242 | "node_modules/@types/prop-types": { 1243 | "version": "15.7.11", 1244 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.11.tgz", 1245 | "integrity": "sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==", 1246 | "devOptional": true 1247 | }, 1248 | "node_modules/@types/react": { 1249 | "version": "18.2.61", 1250 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.2.61.tgz", 1251 | "integrity": "sha512-NURTN0qNnJa7O/k4XUkEW2yfygA+NxS0V5h1+kp9jPwhzZy95q3ADoGMP0+JypMhrZBTTgjKAUlTctde1zzeQA==", 1252 | "devOptional": true, 1253 | "dependencies": { 1254 | "@types/prop-types": "*", 1255 | "@types/scheduler": "*", 1256 | "csstype": "^3.0.2" 1257 | } 1258 | }, 1259 | "node_modules/@types/react-dom": { 1260 | "version": "18.2.19", 1261 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.2.19.tgz", 1262 | "integrity": "sha512-aZvQL6uUbIJpjZk4U8JZGbau9KDeAwMfmhyWorxgBkqDIEf6ROjRozcmPIicqsUwPUjbkDfHKgGee1Lq65APcA==", 1263 | "dev": true, 1264 | "dependencies": { 1265 | "@types/react": "*" 1266 | } 1267 | }, 1268 | "node_modules/@types/scheduler": { 1269 | "version": "0.16.8", 1270 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.8.tgz", 1271 | "integrity": "sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==", 1272 | "devOptional": true 1273 | }, 1274 | "node_modules/@types/semver": { 1275 | "version": "7.5.8", 1276 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", 1277 | "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==", 1278 | "dev": true 1279 | }, 1280 | "node_modules/@types/use-sync-external-store": { 1281 | "version": "0.0.3", 1282 | "resolved": "https://registry.npmjs.org/@types/use-sync-external-store/-/use-sync-external-store-0.0.3.tgz", 1283 | "integrity": "sha512-EwmlvuaxPNej9+T4v5AuBPJa2x2UOJVdjCtDHgcDqitUeOtjnJKJ+apYjVcAoBEMjKW1VVFGZLUb5+qqa09XFA==" 1284 | }, 1285 | "node_modules/@typescript-eslint/eslint-plugin": { 1286 | "version": "7.1.0", 1287 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.1.0.tgz", 1288 | "integrity": "sha512-j6vT/kCulhG5wBmGtstKeiVr1rdXE4nk+DT1k6trYkwlrvW9eOF5ZbgKnd/YR6PcM4uTEXa0h6Fcvf6X7Dxl0w==", 1289 | "dev": true, 1290 | "dependencies": { 1291 | "@eslint-community/regexpp": "^4.5.1", 1292 | "@typescript-eslint/scope-manager": "7.1.0", 1293 | "@typescript-eslint/type-utils": "7.1.0", 1294 | "@typescript-eslint/utils": "7.1.0", 1295 | "@typescript-eslint/visitor-keys": "7.1.0", 1296 | "debug": "^4.3.4", 1297 | "graphemer": "^1.4.0", 1298 | "ignore": "^5.2.4", 1299 | "natural-compare": "^1.4.0", 1300 | "semver": "^7.5.4", 1301 | "ts-api-utils": "^1.0.1" 1302 | }, 1303 | "engines": { 1304 | "node": "^16.0.0 || >=18.0.0" 1305 | }, 1306 | "funding": { 1307 | "type": "opencollective", 1308 | "url": "https://opencollective.com/typescript-eslint" 1309 | }, 1310 | "peerDependencies": { 1311 | "@typescript-eslint/parser": "^7.0.0", 1312 | "eslint": "^8.56.0" 1313 | }, 1314 | "peerDependenciesMeta": { 1315 | "typescript": { 1316 | "optional": true 1317 | } 1318 | } 1319 | }, 1320 | "node_modules/@typescript-eslint/parser": { 1321 | "version": "7.1.0", 1322 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.1.0.tgz", 1323 | "integrity": "sha512-V1EknKUubZ1gWFjiOZhDSNToOjs63/9O0puCgGS8aDOgpZY326fzFu15QAUjwaXzRZjf/qdsdBrckYdv9YxB8w==", 1324 | "dev": true, 1325 | "dependencies": { 1326 | "@typescript-eslint/scope-manager": "7.1.0", 1327 | "@typescript-eslint/types": "7.1.0", 1328 | "@typescript-eslint/typescript-estree": "7.1.0", 1329 | "@typescript-eslint/visitor-keys": "7.1.0", 1330 | "debug": "^4.3.4" 1331 | }, 1332 | "engines": { 1333 | "node": "^16.0.0 || >=18.0.0" 1334 | }, 1335 | "funding": { 1336 | "type": "opencollective", 1337 | "url": "https://opencollective.com/typescript-eslint" 1338 | }, 1339 | "peerDependencies": { 1340 | "eslint": "^8.56.0" 1341 | }, 1342 | "peerDependenciesMeta": { 1343 | "typescript": { 1344 | "optional": true 1345 | } 1346 | } 1347 | }, 1348 | "node_modules/@typescript-eslint/scope-manager": { 1349 | "version": "7.1.0", 1350 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.1.0.tgz", 1351 | "integrity": "sha512-6TmN4OJiohHfoOdGZ3huuLhpiUgOGTpgXNUPJgeZOZR3DnIpdSgtt83RS35OYNNXxM4TScVlpVKC9jyQSETR1A==", 1352 | "dev": true, 1353 | "dependencies": { 1354 | "@typescript-eslint/types": "7.1.0", 1355 | "@typescript-eslint/visitor-keys": "7.1.0" 1356 | }, 1357 | "engines": { 1358 | "node": "^16.0.0 || >=18.0.0" 1359 | }, 1360 | "funding": { 1361 | "type": "opencollective", 1362 | "url": "https://opencollective.com/typescript-eslint" 1363 | } 1364 | }, 1365 | "node_modules/@typescript-eslint/type-utils": { 1366 | "version": "7.1.0", 1367 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.1.0.tgz", 1368 | "integrity": "sha512-UZIhv8G+5b5skkcuhgvxYWHjk7FW7/JP5lPASMEUoliAPwIH/rxoUSQPia2cuOj9AmDZmwUl1usKm85t5VUMew==", 1369 | "dev": true, 1370 | "dependencies": { 1371 | "@typescript-eslint/typescript-estree": "7.1.0", 1372 | "@typescript-eslint/utils": "7.1.0", 1373 | "debug": "^4.3.4", 1374 | "ts-api-utils": "^1.0.1" 1375 | }, 1376 | "engines": { 1377 | "node": "^16.0.0 || >=18.0.0" 1378 | }, 1379 | "funding": { 1380 | "type": "opencollective", 1381 | "url": "https://opencollective.com/typescript-eslint" 1382 | }, 1383 | "peerDependencies": { 1384 | "eslint": "^8.56.0" 1385 | }, 1386 | "peerDependenciesMeta": { 1387 | "typescript": { 1388 | "optional": true 1389 | } 1390 | } 1391 | }, 1392 | "node_modules/@typescript-eslint/types": { 1393 | "version": "7.1.0", 1394 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.1.0.tgz", 1395 | "integrity": "sha512-qTWjWieJ1tRJkxgZYXx6WUYtWlBc48YRxgY2JN1aGeVpkhmnopq+SUC8UEVGNXIvWH7XyuTjwALfG6bFEgCkQA==", 1396 | "dev": true, 1397 | "engines": { 1398 | "node": "^16.0.0 || >=18.0.0" 1399 | }, 1400 | "funding": { 1401 | "type": "opencollective", 1402 | "url": "https://opencollective.com/typescript-eslint" 1403 | } 1404 | }, 1405 | "node_modules/@typescript-eslint/typescript-estree": { 1406 | "version": "7.1.0", 1407 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.1.0.tgz", 1408 | "integrity": "sha512-k7MyrbD6E463CBbSpcOnwa8oXRdHzH1WiVzOipK3L5KSML92ZKgUBrTlehdi7PEIMT8k0bQixHUGXggPAlKnOQ==", 1409 | "dev": true, 1410 | "dependencies": { 1411 | "@typescript-eslint/types": "7.1.0", 1412 | "@typescript-eslint/visitor-keys": "7.1.0", 1413 | "debug": "^4.3.4", 1414 | "globby": "^11.1.0", 1415 | "is-glob": "^4.0.3", 1416 | "minimatch": "9.0.3", 1417 | "semver": "^7.5.4", 1418 | "ts-api-utils": "^1.0.1" 1419 | }, 1420 | "engines": { 1421 | "node": "^16.0.0 || >=18.0.0" 1422 | }, 1423 | "funding": { 1424 | "type": "opencollective", 1425 | "url": "https://opencollective.com/typescript-eslint" 1426 | }, 1427 | "peerDependenciesMeta": { 1428 | "typescript": { 1429 | "optional": true 1430 | } 1431 | } 1432 | }, 1433 | "node_modules/@typescript-eslint/utils": { 1434 | "version": "7.1.0", 1435 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.1.0.tgz", 1436 | "integrity": "sha512-WUFba6PZC5OCGEmbweGpnNJytJiLG7ZvDBJJoUcX4qZYf1mGZ97mO2Mps6O2efxJcJdRNpqweCistDbZMwIVHw==", 1437 | "dev": true, 1438 | "dependencies": { 1439 | "@eslint-community/eslint-utils": "^4.4.0", 1440 | "@types/json-schema": "^7.0.12", 1441 | "@types/semver": "^7.5.0", 1442 | "@typescript-eslint/scope-manager": "7.1.0", 1443 | "@typescript-eslint/types": "7.1.0", 1444 | "@typescript-eslint/typescript-estree": "7.1.0", 1445 | "semver": "^7.5.4" 1446 | }, 1447 | "engines": { 1448 | "node": "^16.0.0 || >=18.0.0" 1449 | }, 1450 | "funding": { 1451 | "type": "opencollective", 1452 | "url": "https://opencollective.com/typescript-eslint" 1453 | }, 1454 | "peerDependencies": { 1455 | "eslint": "^8.56.0" 1456 | } 1457 | }, 1458 | "node_modules/@typescript-eslint/visitor-keys": { 1459 | "version": "7.1.0", 1460 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.1.0.tgz", 1461 | "integrity": "sha512-FhUqNWluiGNzlvnDZiXad4mZRhtghdoKW6e98GoEOYSu5cND+E39rG5KwJMUzeENwm1ztYBRqof8wMLP+wNPIA==", 1462 | "dev": true, 1463 | "dependencies": { 1464 | "@typescript-eslint/types": "7.1.0", 1465 | "eslint-visitor-keys": "^3.4.1" 1466 | }, 1467 | "engines": { 1468 | "node": "^16.0.0 || >=18.0.0" 1469 | }, 1470 | "funding": { 1471 | "type": "opencollective", 1472 | "url": "https://opencollective.com/typescript-eslint" 1473 | } 1474 | }, 1475 | "node_modules/@ungap/structured-clone": { 1476 | "version": "1.2.0", 1477 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 1478 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 1479 | "dev": true 1480 | }, 1481 | "node_modules/@vitejs/plugin-react": { 1482 | "version": "4.2.1", 1483 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.2.1.tgz", 1484 | "integrity": "sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==", 1485 | "dev": true, 1486 | "dependencies": { 1487 | "@babel/core": "^7.23.5", 1488 | "@babel/plugin-transform-react-jsx-self": "^7.23.3", 1489 | "@babel/plugin-transform-react-jsx-source": "^7.23.3", 1490 | "@types/babel__core": "^7.20.5", 1491 | "react-refresh": "^0.14.0" 1492 | }, 1493 | "engines": { 1494 | "node": "^14.18.0 || >=16.0.0" 1495 | }, 1496 | "peerDependencies": { 1497 | "vite": "^4.2.0 || ^5.0.0" 1498 | } 1499 | }, 1500 | "node_modules/acorn": { 1501 | "version": "8.11.3", 1502 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1503 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1504 | "dev": true, 1505 | "bin": { 1506 | "acorn": "bin/acorn" 1507 | }, 1508 | "engines": { 1509 | "node": ">=0.4.0" 1510 | } 1511 | }, 1512 | "node_modules/acorn-jsx": { 1513 | "version": "5.3.2", 1514 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 1515 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 1516 | "dev": true, 1517 | "peerDependencies": { 1518 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 1519 | } 1520 | }, 1521 | "node_modules/ajv": { 1522 | "version": "6.12.6", 1523 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 1524 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 1525 | "dev": true, 1526 | "dependencies": { 1527 | "fast-deep-equal": "^3.1.1", 1528 | "fast-json-stable-stringify": "^2.0.0", 1529 | "json-schema-traverse": "^0.4.1", 1530 | "uri-js": "^4.2.2" 1531 | }, 1532 | "funding": { 1533 | "type": "github", 1534 | "url": "https://github.com/sponsors/epoberezkin" 1535 | } 1536 | }, 1537 | "node_modules/ansi-regex": { 1538 | "version": "5.0.1", 1539 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1540 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1541 | "dev": true, 1542 | "engines": { 1543 | "node": ">=8" 1544 | } 1545 | }, 1546 | "node_modules/ansi-styles": { 1547 | "version": "3.2.1", 1548 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1549 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1550 | "dev": true, 1551 | "dependencies": { 1552 | "color-convert": "^1.9.0" 1553 | }, 1554 | "engines": { 1555 | "node": ">=4" 1556 | } 1557 | }, 1558 | "node_modules/argparse": { 1559 | "version": "2.0.1", 1560 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 1561 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 1562 | "dev": true 1563 | }, 1564 | "node_modules/array-union": { 1565 | "version": "2.1.0", 1566 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 1567 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 1568 | "dev": true, 1569 | "engines": { 1570 | "node": ">=8" 1571 | } 1572 | }, 1573 | "node_modules/balanced-match": { 1574 | "version": "1.0.2", 1575 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1576 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1577 | "dev": true 1578 | }, 1579 | "node_modules/brace-expansion": { 1580 | "version": "2.0.1", 1581 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1582 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1583 | "dev": true, 1584 | "dependencies": { 1585 | "balanced-match": "^1.0.0" 1586 | } 1587 | }, 1588 | "node_modules/braces": { 1589 | "version": "3.0.2", 1590 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1591 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1592 | "dev": true, 1593 | "dependencies": { 1594 | "fill-range": "^7.0.1" 1595 | }, 1596 | "engines": { 1597 | "node": ">=8" 1598 | } 1599 | }, 1600 | "node_modules/browserslist": { 1601 | "version": "4.23.0", 1602 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", 1603 | "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", 1604 | "dev": true, 1605 | "funding": [ 1606 | { 1607 | "type": "opencollective", 1608 | "url": "https://opencollective.com/browserslist" 1609 | }, 1610 | { 1611 | "type": "tidelift", 1612 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1613 | }, 1614 | { 1615 | "type": "github", 1616 | "url": "https://github.com/sponsors/ai" 1617 | } 1618 | ], 1619 | "dependencies": { 1620 | "caniuse-lite": "^1.0.30001587", 1621 | "electron-to-chromium": "^1.4.668", 1622 | "node-releases": "^2.0.14", 1623 | "update-browserslist-db": "^1.0.13" 1624 | }, 1625 | "bin": { 1626 | "browserslist": "cli.js" 1627 | }, 1628 | "engines": { 1629 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 1630 | } 1631 | }, 1632 | "node_modules/callsites": { 1633 | "version": "3.1.0", 1634 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1635 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1636 | "dev": true, 1637 | "engines": { 1638 | "node": ">=6" 1639 | } 1640 | }, 1641 | "node_modules/caniuse-lite": { 1642 | "version": "1.0.30001593", 1643 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001593.tgz", 1644 | "integrity": "sha512-UWM1zlo3cZfkpBysd7AS+z+v007q9G1+fLTUU42rQnY6t2axoogPW/xol6T7juU5EUoOhML4WgBIdG+9yYqAjQ==", 1645 | "dev": true, 1646 | "funding": [ 1647 | { 1648 | "type": "opencollective", 1649 | "url": "https://opencollective.com/browserslist" 1650 | }, 1651 | { 1652 | "type": "tidelift", 1653 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 1654 | }, 1655 | { 1656 | "type": "github", 1657 | "url": "https://github.com/sponsors/ai" 1658 | } 1659 | ] 1660 | }, 1661 | "node_modules/chalk": { 1662 | "version": "2.4.2", 1663 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1664 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1665 | "dev": true, 1666 | "dependencies": { 1667 | "ansi-styles": "^3.2.1", 1668 | "escape-string-regexp": "^1.0.5", 1669 | "supports-color": "^5.3.0" 1670 | }, 1671 | "engines": { 1672 | "node": ">=4" 1673 | } 1674 | }, 1675 | "node_modules/color-convert": { 1676 | "version": "1.9.3", 1677 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1678 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1679 | "dev": true, 1680 | "dependencies": { 1681 | "color-name": "1.1.3" 1682 | } 1683 | }, 1684 | "node_modules/color-name": { 1685 | "version": "1.1.3", 1686 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1687 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1688 | "dev": true 1689 | }, 1690 | "node_modules/concat-map": { 1691 | "version": "0.0.1", 1692 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1693 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1694 | "dev": true 1695 | }, 1696 | "node_modules/convert-source-map": { 1697 | "version": "2.0.0", 1698 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", 1699 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", 1700 | "dev": true 1701 | }, 1702 | "node_modules/cross-spawn": { 1703 | "version": "7.0.3", 1704 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1705 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1706 | "dev": true, 1707 | "dependencies": { 1708 | "path-key": "^3.1.0", 1709 | "shebang-command": "^2.0.0", 1710 | "which": "^2.0.1" 1711 | }, 1712 | "engines": { 1713 | "node": ">= 8" 1714 | } 1715 | }, 1716 | "node_modules/csstype": { 1717 | "version": "3.1.3", 1718 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", 1719 | "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==" 1720 | }, 1721 | "node_modules/debug": { 1722 | "version": "4.3.4", 1723 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1724 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1725 | "dev": true, 1726 | "dependencies": { 1727 | "ms": "2.1.2" 1728 | }, 1729 | "engines": { 1730 | "node": ">=6.0" 1731 | }, 1732 | "peerDependenciesMeta": { 1733 | "supports-color": { 1734 | "optional": true 1735 | } 1736 | } 1737 | }, 1738 | "node_modules/deep-is": { 1739 | "version": "0.1.4", 1740 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1741 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1742 | "dev": true 1743 | }, 1744 | "node_modules/dir-glob": { 1745 | "version": "3.0.1", 1746 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 1747 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 1748 | "dev": true, 1749 | "dependencies": { 1750 | "path-type": "^4.0.0" 1751 | }, 1752 | "engines": { 1753 | "node": ">=8" 1754 | } 1755 | }, 1756 | "node_modules/doctrine": { 1757 | "version": "3.0.0", 1758 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 1759 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 1760 | "dev": true, 1761 | "dependencies": { 1762 | "esutils": "^2.0.2" 1763 | }, 1764 | "engines": { 1765 | "node": ">=6.0.0" 1766 | } 1767 | }, 1768 | "node_modules/electron-to-chromium": { 1769 | "version": "1.4.690", 1770 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.690.tgz", 1771 | "integrity": "sha512-+2OAGjUx68xElQhydpcbqH50hE8Vs2K6TkAeLhICYfndb67CVH0UsZaijmRUE3rHlIxU1u0jxwhgVe6fK3YANA==", 1772 | "dev": true 1773 | }, 1774 | "node_modules/esbuild": { 1775 | "version": "0.19.12", 1776 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.19.12.tgz", 1777 | "integrity": "sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg==", 1778 | "dev": true, 1779 | "hasInstallScript": true, 1780 | "bin": { 1781 | "esbuild": "bin/esbuild" 1782 | }, 1783 | "engines": { 1784 | "node": ">=12" 1785 | }, 1786 | "optionalDependencies": { 1787 | "@esbuild/aix-ppc64": "0.19.12", 1788 | "@esbuild/android-arm": "0.19.12", 1789 | "@esbuild/android-arm64": "0.19.12", 1790 | "@esbuild/android-x64": "0.19.12", 1791 | "@esbuild/darwin-arm64": "0.19.12", 1792 | "@esbuild/darwin-x64": "0.19.12", 1793 | "@esbuild/freebsd-arm64": "0.19.12", 1794 | "@esbuild/freebsd-x64": "0.19.12", 1795 | "@esbuild/linux-arm": "0.19.12", 1796 | "@esbuild/linux-arm64": "0.19.12", 1797 | "@esbuild/linux-ia32": "0.19.12", 1798 | "@esbuild/linux-loong64": "0.19.12", 1799 | "@esbuild/linux-mips64el": "0.19.12", 1800 | "@esbuild/linux-ppc64": "0.19.12", 1801 | "@esbuild/linux-riscv64": "0.19.12", 1802 | "@esbuild/linux-s390x": "0.19.12", 1803 | "@esbuild/linux-x64": "0.19.12", 1804 | "@esbuild/netbsd-x64": "0.19.12", 1805 | "@esbuild/openbsd-x64": "0.19.12", 1806 | "@esbuild/sunos-x64": "0.19.12", 1807 | "@esbuild/win32-arm64": "0.19.12", 1808 | "@esbuild/win32-ia32": "0.19.12", 1809 | "@esbuild/win32-x64": "0.19.12" 1810 | } 1811 | }, 1812 | "node_modules/escalade": { 1813 | "version": "3.1.2", 1814 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", 1815 | "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", 1816 | "dev": true, 1817 | "engines": { 1818 | "node": ">=6" 1819 | } 1820 | }, 1821 | "node_modules/escape-string-regexp": { 1822 | "version": "1.0.5", 1823 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1824 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1825 | "dev": true, 1826 | "engines": { 1827 | "node": ">=0.8.0" 1828 | } 1829 | }, 1830 | "node_modules/eslint": { 1831 | "version": "8.57.0", 1832 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", 1833 | "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", 1834 | "dev": true, 1835 | "dependencies": { 1836 | "@eslint-community/eslint-utils": "^4.2.0", 1837 | "@eslint-community/regexpp": "^4.6.1", 1838 | "@eslint/eslintrc": "^2.1.4", 1839 | "@eslint/js": "8.57.0", 1840 | "@humanwhocodes/config-array": "^0.11.14", 1841 | "@humanwhocodes/module-importer": "^1.0.1", 1842 | "@nodelib/fs.walk": "^1.2.8", 1843 | "@ungap/structured-clone": "^1.2.0", 1844 | "ajv": "^6.12.4", 1845 | "chalk": "^4.0.0", 1846 | "cross-spawn": "^7.0.2", 1847 | "debug": "^4.3.2", 1848 | "doctrine": "^3.0.0", 1849 | "escape-string-regexp": "^4.0.0", 1850 | "eslint-scope": "^7.2.2", 1851 | "eslint-visitor-keys": "^3.4.3", 1852 | "espree": "^9.6.1", 1853 | "esquery": "^1.4.2", 1854 | "esutils": "^2.0.2", 1855 | "fast-deep-equal": "^3.1.3", 1856 | "file-entry-cache": "^6.0.1", 1857 | "find-up": "^5.0.0", 1858 | "glob-parent": "^6.0.2", 1859 | "globals": "^13.19.0", 1860 | "graphemer": "^1.4.0", 1861 | "ignore": "^5.2.0", 1862 | "imurmurhash": "^0.1.4", 1863 | "is-glob": "^4.0.0", 1864 | "is-path-inside": "^3.0.3", 1865 | "js-yaml": "^4.1.0", 1866 | "json-stable-stringify-without-jsonify": "^1.0.1", 1867 | "levn": "^0.4.1", 1868 | "lodash.merge": "^4.6.2", 1869 | "minimatch": "^3.1.2", 1870 | "natural-compare": "^1.4.0", 1871 | "optionator": "^0.9.3", 1872 | "strip-ansi": "^6.0.1", 1873 | "text-table": "^0.2.0" 1874 | }, 1875 | "bin": { 1876 | "eslint": "bin/eslint.js" 1877 | }, 1878 | "engines": { 1879 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1880 | }, 1881 | "funding": { 1882 | "url": "https://opencollective.com/eslint" 1883 | } 1884 | }, 1885 | "node_modules/eslint-plugin-react-hooks": { 1886 | "version": "4.6.0", 1887 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", 1888 | "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", 1889 | "dev": true, 1890 | "engines": { 1891 | "node": ">=10" 1892 | }, 1893 | "peerDependencies": { 1894 | "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" 1895 | } 1896 | }, 1897 | "node_modules/eslint-plugin-react-refresh": { 1898 | "version": "0.4.5", 1899 | "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.5.tgz", 1900 | "integrity": "sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==", 1901 | "dev": true, 1902 | "peerDependencies": { 1903 | "eslint": ">=7" 1904 | } 1905 | }, 1906 | "node_modules/eslint-scope": { 1907 | "version": "7.2.2", 1908 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 1909 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 1910 | "dev": true, 1911 | "dependencies": { 1912 | "esrecurse": "^4.3.0", 1913 | "estraverse": "^5.2.0" 1914 | }, 1915 | "engines": { 1916 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1917 | }, 1918 | "funding": { 1919 | "url": "https://opencollective.com/eslint" 1920 | } 1921 | }, 1922 | "node_modules/eslint-visitor-keys": { 1923 | "version": "3.4.3", 1924 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1925 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1926 | "dev": true, 1927 | "engines": { 1928 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1929 | }, 1930 | "funding": { 1931 | "url": "https://opencollective.com/eslint" 1932 | } 1933 | }, 1934 | "node_modules/eslint/node_modules/ansi-styles": { 1935 | "version": "4.3.0", 1936 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1937 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1938 | "dev": true, 1939 | "dependencies": { 1940 | "color-convert": "^2.0.1" 1941 | }, 1942 | "engines": { 1943 | "node": ">=8" 1944 | }, 1945 | "funding": { 1946 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1947 | } 1948 | }, 1949 | "node_modules/eslint/node_modules/brace-expansion": { 1950 | "version": "1.1.11", 1951 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1952 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1953 | "dev": true, 1954 | "dependencies": { 1955 | "balanced-match": "^1.0.0", 1956 | "concat-map": "0.0.1" 1957 | } 1958 | }, 1959 | "node_modules/eslint/node_modules/chalk": { 1960 | "version": "4.1.2", 1961 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1962 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1963 | "dev": true, 1964 | "dependencies": { 1965 | "ansi-styles": "^4.1.0", 1966 | "supports-color": "^7.1.0" 1967 | }, 1968 | "engines": { 1969 | "node": ">=10" 1970 | }, 1971 | "funding": { 1972 | "url": "https://github.com/chalk/chalk?sponsor=1" 1973 | } 1974 | }, 1975 | "node_modules/eslint/node_modules/color-convert": { 1976 | "version": "2.0.1", 1977 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1978 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1979 | "dev": true, 1980 | "dependencies": { 1981 | "color-name": "~1.1.4" 1982 | }, 1983 | "engines": { 1984 | "node": ">=7.0.0" 1985 | } 1986 | }, 1987 | "node_modules/eslint/node_modules/color-name": { 1988 | "version": "1.1.4", 1989 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1990 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1991 | "dev": true 1992 | }, 1993 | "node_modules/eslint/node_modules/escape-string-regexp": { 1994 | "version": "4.0.0", 1995 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1996 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1997 | "dev": true, 1998 | "engines": { 1999 | "node": ">=10" 2000 | }, 2001 | "funding": { 2002 | "url": "https://github.com/sponsors/sindresorhus" 2003 | } 2004 | }, 2005 | "node_modules/eslint/node_modules/globals": { 2006 | "version": "13.24.0", 2007 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 2008 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 2009 | "dev": true, 2010 | "dependencies": { 2011 | "type-fest": "^0.20.2" 2012 | }, 2013 | "engines": { 2014 | "node": ">=8" 2015 | }, 2016 | "funding": { 2017 | "url": "https://github.com/sponsors/sindresorhus" 2018 | } 2019 | }, 2020 | "node_modules/eslint/node_modules/has-flag": { 2021 | "version": "4.0.0", 2022 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2023 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2024 | "dev": true, 2025 | "engines": { 2026 | "node": ">=8" 2027 | } 2028 | }, 2029 | "node_modules/eslint/node_modules/minimatch": { 2030 | "version": "3.1.2", 2031 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2032 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2033 | "dev": true, 2034 | "dependencies": { 2035 | "brace-expansion": "^1.1.7" 2036 | }, 2037 | "engines": { 2038 | "node": "*" 2039 | } 2040 | }, 2041 | "node_modules/eslint/node_modules/supports-color": { 2042 | "version": "7.2.0", 2043 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2044 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2045 | "dev": true, 2046 | "dependencies": { 2047 | "has-flag": "^4.0.0" 2048 | }, 2049 | "engines": { 2050 | "node": ">=8" 2051 | } 2052 | }, 2053 | "node_modules/espree": { 2054 | "version": "9.6.1", 2055 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 2056 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 2057 | "dev": true, 2058 | "dependencies": { 2059 | "acorn": "^8.9.0", 2060 | "acorn-jsx": "^5.3.2", 2061 | "eslint-visitor-keys": "^3.4.1" 2062 | }, 2063 | "engines": { 2064 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 2065 | }, 2066 | "funding": { 2067 | "url": "https://opencollective.com/eslint" 2068 | } 2069 | }, 2070 | "node_modules/esquery": { 2071 | "version": "1.5.0", 2072 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 2073 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 2074 | "dev": true, 2075 | "dependencies": { 2076 | "estraverse": "^5.1.0" 2077 | }, 2078 | "engines": { 2079 | "node": ">=0.10" 2080 | } 2081 | }, 2082 | "node_modules/esrecurse": { 2083 | "version": "4.3.0", 2084 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 2085 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 2086 | "dev": true, 2087 | "dependencies": { 2088 | "estraverse": "^5.2.0" 2089 | }, 2090 | "engines": { 2091 | "node": ">=4.0" 2092 | } 2093 | }, 2094 | "node_modules/estraverse": { 2095 | "version": "5.3.0", 2096 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2097 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2098 | "dev": true, 2099 | "engines": { 2100 | "node": ">=4.0" 2101 | } 2102 | }, 2103 | "node_modules/esutils": { 2104 | "version": "2.0.3", 2105 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 2106 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 2107 | "dev": true, 2108 | "engines": { 2109 | "node": ">=0.10.0" 2110 | } 2111 | }, 2112 | "node_modules/fast-deep-equal": { 2113 | "version": "3.1.3", 2114 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 2115 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 2116 | "dev": true 2117 | }, 2118 | "node_modules/fast-glob": { 2119 | "version": "3.3.2", 2120 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 2121 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 2122 | "dev": true, 2123 | "dependencies": { 2124 | "@nodelib/fs.stat": "^2.0.2", 2125 | "@nodelib/fs.walk": "^1.2.3", 2126 | "glob-parent": "^5.1.2", 2127 | "merge2": "^1.3.0", 2128 | "micromatch": "^4.0.4" 2129 | }, 2130 | "engines": { 2131 | "node": ">=8.6.0" 2132 | } 2133 | }, 2134 | "node_modules/fast-glob/node_modules/glob-parent": { 2135 | "version": "5.1.2", 2136 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 2137 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 2138 | "dev": true, 2139 | "dependencies": { 2140 | "is-glob": "^4.0.1" 2141 | }, 2142 | "engines": { 2143 | "node": ">= 6" 2144 | } 2145 | }, 2146 | "node_modules/fast-json-stable-stringify": { 2147 | "version": "2.1.0", 2148 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 2149 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 2150 | "dev": true 2151 | }, 2152 | "node_modules/fast-levenshtein": { 2153 | "version": "2.0.6", 2154 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2155 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 2156 | "dev": true 2157 | }, 2158 | "node_modules/fastq": { 2159 | "version": "1.17.1", 2160 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 2161 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 2162 | "dev": true, 2163 | "dependencies": { 2164 | "reusify": "^1.0.4" 2165 | } 2166 | }, 2167 | "node_modules/file-entry-cache": { 2168 | "version": "6.0.1", 2169 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 2170 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 2171 | "dev": true, 2172 | "dependencies": { 2173 | "flat-cache": "^3.0.4" 2174 | }, 2175 | "engines": { 2176 | "node": "^10.12.0 || >=12.0.0" 2177 | } 2178 | }, 2179 | "node_modules/fill-range": { 2180 | "version": "7.0.1", 2181 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2182 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2183 | "dev": true, 2184 | "dependencies": { 2185 | "to-regex-range": "^5.0.1" 2186 | }, 2187 | "engines": { 2188 | "node": ">=8" 2189 | } 2190 | }, 2191 | "node_modules/find-up": { 2192 | "version": "5.0.0", 2193 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 2194 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 2195 | "dev": true, 2196 | "dependencies": { 2197 | "locate-path": "^6.0.0", 2198 | "path-exists": "^4.0.0" 2199 | }, 2200 | "engines": { 2201 | "node": ">=10" 2202 | }, 2203 | "funding": { 2204 | "url": "https://github.com/sponsors/sindresorhus" 2205 | } 2206 | }, 2207 | "node_modules/flat-cache": { 2208 | "version": "3.2.0", 2209 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 2210 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 2211 | "dev": true, 2212 | "dependencies": { 2213 | "flatted": "^3.2.9", 2214 | "keyv": "^4.5.3", 2215 | "rimraf": "^3.0.2" 2216 | }, 2217 | "engines": { 2218 | "node": "^10.12.0 || >=12.0.0" 2219 | } 2220 | }, 2221 | "node_modules/flatted": { 2222 | "version": "3.3.1", 2223 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 2224 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", 2225 | "dev": true 2226 | }, 2227 | "node_modules/fs.realpath": { 2228 | "version": "1.0.0", 2229 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2230 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 2231 | "dev": true 2232 | }, 2233 | "node_modules/fsevents": { 2234 | "version": "2.3.3", 2235 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 2236 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 2237 | "dev": true, 2238 | "hasInstallScript": true, 2239 | "optional": true, 2240 | "os": [ 2241 | "darwin" 2242 | ], 2243 | "engines": { 2244 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 2245 | } 2246 | }, 2247 | "node_modules/gensync": { 2248 | "version": "1.0.0-beta.2", 2249 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2250 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2251 | "dev": true, 2252 | "engines": { 2253 | "node": ">=6.9.0" 2254 | } 2255 | }, 2256 | "node_modules/glob": { 2257 | "version": "7.2.3", 2258 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 2259 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 2260 | "dev": true, 2261 | "dependencies": { 2262 | "fs.realpath": "^1.0.0", 2263 | "inflight": "^1.0.4", 2264 | "inherits": "2", 2265 | "minimatch": "^3.1.1", 2266 | "once": "^1.3.0", 2267 | "path-is-absolute": "^1.0.0" 2268 | }, 2269 | "engines": { 2270 | "node": "*" 2271 | }, 2272 | "funding": { 2273 | "url": "https://github.com/sponsors/isaacs" 2274 | } 2275 | }, 2276 | "node_modules/glob-parent": { 2277 | "version": "6.0.2", 2278 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 2279 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 2280 | "dev": true, 2281 | "dependencies": { 2282 | "is-glob": "^4.0.3" 2283 | }, 2284 | "engines": { 2285 | "node": ">=10.13.0" 2286 | } 2287 | }, 2288 | "node_modules/glob/node_modules/brace-expansion": { 2289 | "version": "1.1.11", 2290 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2291 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2292 | "dev": true, 2293 | "dependencies": { 2294 | "balanced-match": "^1.0.0", 2295 | "concat-map": "0.0.1" 2296 | } 2297 | }, 2298 | "node_modules/glob/node_modules/minimatch": { 2299 | "version": "3.1.2", 2300 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2301 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2302 | "dev": true, 2303 | "dependencies": { 2304 | "brace-expansion": "^1.1.7" 2305 | }, 2306 | "engines": { 2307 | "node": "*" 2308 | } 2309 | }, 2310 | "node_modules/globals": { 2311 | "version": "11.12.0", 2312 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2313 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2314 | "dev": true, 2315 | "engines": { 2316 | "node": ">=4" 2317 | } 2318 | }, 2319 | "node_modules/globby": { 2320 | "version": "11.1.0", 2321 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2322 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2323 | "dev": true, 2324 | "dependencies": { 2325 | "array-union": "^2.1.0", 2326 | "dir-glob": "^3.0.1", 2327 | "fast-glob": "^3.2.9", 2328 | "ignore": "^5.2.0", 2329 | "merge2": "^1.4.1", 2330 | "slash": "^3.0.0" 2331 | }, 2332 | "engines": { 2333 | "node": ">=10" 2334 | }, 2335 | "funding": { 2336 | "url": "https://github.com/sponsors/sindresorhus" 2337 | } 2338 | }, 2339 | "node_modules/goober": { 2340 | "version": "2.1.14", 2341 | "resolved": "https://registry.npmjs.org/goober/-/goober-2.1.14.tgz", 2342 | "integrity": "sha512-4UpC0NdGyAFqLNPnhCT2iHpza2q+RAY3GV85a/mRPdzyPQMsj0KmMMuetdIkzWRbJ+Hgau1EZztq8ImmiMGhsg==", 2343 | "peerDependencies": { 2344 | "csstype": "^3.0.10" 2345 | } 2346 | }, 2347 | "node_modules/graphemer": { 2348 | "version": "1.4.0", 2349 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 2350 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 2351 | "dev": true 2352 | }, 2353 | "node_modules/has-flag": { 2354 | "version": "3.0.0", 2355 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2356 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2357 | "dev": true, 2358 | "engines": { 2359 | "node": ">=4" 2360 | } 2361 | }, 2362 | "node_modules/ignore": { 2363 | "version": "5.3.1", 2364 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 2365 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 2366 | "dev": true, 2367 | "engines": { 2368 | "node": ">= 4" 2369 | } 2370 | }, 2371 | "node_modules/immer": { 2372 | "version": "10.0.3", 2373 | "resolved": "https://registry.npmjs.org/immer/-/immer-10.0.3.tgz", 2374 | "integrity": "sha512-pwupu3eWfouuaowscykeckFmVTpqbzW+rXFCX8rQLkZzM9ftBmU/++Ra+o+L27mz03zJTlyV4UUr+fdKNffo4A==", 2375 | "funding": { 2376 | "type": "opencollective", 2377 | "url": "https://opencollective.com/immer" 2378 | } 2379 | }, 2380 | "node_modules/import-fresh": { 2381 | "version": "3.3.0", 2382 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 2383 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 2384 | "dev": true, 2385 | "dependencies": { 2386 | "parent-module": "^1.0.0", 2387 | "resolve-from": "^4.0.0" 2388 | }, 2389 | "engines": { 2390 | "node": ">=6" 2391 | }, 2392 | "funding": { 2393 | "url": "https://github.com/sponsors/sindresorhus" 2394 | } 2395 | }, 2396 | "node_modules/imurmurhash": { 2397 | "version": "0.1.4", 2398 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2399 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 2400 | "dev": true, 2401 | "engines": { 2402 | "node": ">=0.8.19" 2403 | } 2404 | }, 2405 | "node_modules/inflight": { 2406 | "version": "1.0.6", 2407 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2408 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 2409 | "dev": true, 2410 | "dependencies": { 2411 | "once": "^1.3.0", 2412 | "wrappy": "1" 2413 | } 2414 | }, 2415 | "node_modules/inherits": { 2416 | "version": "2.0.4", 2417 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 2418 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 2419 | "dev": true 2420 | }, 2421 | "node_modules/is-extglob": { 2422 | "version": "2.1.1", 2423 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 2424 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 2425 | "dev": true, 2426 | "engines": { 2427 | "node": ">=0.10.0" 2428 | } 2429 | }, 2430 | "node_modules/is-glob": { 2431 | "version": "4.0.3", 2432 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 2433 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 2434 | "dev": true, 2435 | "dependencies": { 2436 | "is-extglob": "^2.1.1" 2437 | }, 2438 | "engines": { 2439 | "node": ">=0.10.0" 2440 | } 2441 | }, 2442 | "node_modules/is-number": { 2443 | "version": "7.0.0", 2444 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2445 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2446 | "dev": true, 2447 | "engines": { 2448 | "node": ">=0.12.0" 2449 | } 2450 | }, 2451 | "node_modules/is-path-inside": { 2452 | "version": "3.0.3", 2453 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 2454 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 2455 | "dev": true, 2456 | "engines": { 2457 | "node": ">=8" 2458 | } 2459 | }, 2460 | "node_modules/isexe": { 2461 | "version": "2.0.0", 2462 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2463 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 2464 | "dev": true 2465 | }, 2466 | "node_modules/js-tokens": { 2467 | "version": "4.0.0", 2468 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2469 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2470 | }, 2471 | "node_modules/js-yaml": { 2472 | "version": "4.1.0", 2473 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 2474 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 2475 | "dev": true, 2476 | "dependencies": { 2477 | "argparse": "^2.0.1" 2478 | }, 2479 | "bin": { 2480 | "js-yaml": "bin/js-yaml.js" 2481 | } 2482 | }, 2483 | "node_modules/jsesc": { 2484 | "version": "2.5.2", 2485 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2486 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2487 | "dev": true, 2488 | "bin": { 2489 | "jsesc": "bin/jsesc" 2490 | }, 2491 | "engines": { 2492 | "node": ">=4" 2493 | } 2494 | }, 2495 | "node_modules/json-buffer": { 2496 | "version": "3.0.1", 2497 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 2498 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 2499 | "dev": true 2500 | }, 2501 | "node_modules/json-schema-traverse": { 2502 | "version": "0.4.1", 2503 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2504 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2505 | "dev": true 2506 | }, 2507 | "node_modules/json-stable-stringify-without-jsonify": { 2508 | "version": "1.0.1", 2509 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2510 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 2511 | "dev": true 2512 | }, 2513 | "node_modules/json5": { 2514 | "version": "2.2.3", 2515 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", 2516 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", 2517 | "dev": true, 2518 | "bin": { 2519 | "json5": "lib/cli.js" 2520 | }, 2521 | "engines": { 2522 | "node": ">=6" 2523 | } 2524 | }, 2525 | "node_modules/keyv": { 2526 | "version": "4.5.4", 2527 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 2528 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 2529 | "dev": true, 2530 | "dependencies": { 2531 | "json-buffer": "3.0.1" 2532 | } 2533 | }, 2534 | "node_modules/levn": { 2535 | "version": "0.4.1", 2536 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 2537 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 2538 | "dev": true, 2539 | "dependencies": { 2540 | "prelude-ls": "^1.2.1", 2541 | "type-check": "~0.4.0" 2542 | }, 2543 | "engines": { 2544 | "node": ">= 0.8.0" 2545 | } 2546 | }, 2547 | "node_modules/locate-path": { 2548 | "version": "6.0.0", 2549 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 2550 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 2551 | "dev": true, 2552 | "dependencies": { 2553 | "p-locate": "^5.0.0" 2554 | }, 2555 | "engines": { 2556 | "node": ">=10" 2557 | }, 2558 | "funding": { 2559 | "url": "https://github.com/sponsors/sindresorhus" 2560 | } 2561 | }, 2562 | "node_modules/lodash.merge": { 2563 | "version": "4.6.2", 2564 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 2565 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 2566 | "dev": true 2567 | }, 2568 | "node_modules/loose-envify": { 2569 | "version": "1.4.0", 2570 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2571 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2572 | "dependencies": { 2573 | "js-tokens": "^3.0.0 || ^4.0.0" 2574 | }, 2575 | "bin": { 2576 | "loose-envify": "cli.js" 2577 | } 2578 | }, 2579 | "node_modules/lru-cache": { 2580 | "version": "5.1.1", 2581 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 2582 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 2583 | "dev": true, 2584 | "dependencies": { 2585 | "yallist": "^3.0.2" 2586 | } 2587 | }, 2588 | "node_modules/merge2": { 2589 | "version": "1.4.1", 2590 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2591 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2592 | "dev": true, 2593 | "engines": { 2594 | "node": ">= 8" 2595 | } 2596 | }, 2597 | "node_modules/micromatch": { 2598 | "version": "4.0.5", 2599 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 2600 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 2601 | "dev": true, 2602 | "dependencies": { 2603 | "braces": "^3.0.2", 2604 | "picomatch": "^2.3.1" 2605 | }, 2606 | "engines": { 2607 | "node": ">=8.6" 2608 | } 2609 | }, 2610 | "node_modules/minimatch": { 2611 | "version": "9.0.3", 2612 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 2613 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 2614 | "dev": true, 2615 | "dependencies": { 2616 | "brace-expansion": "^2.0.1" 2617 | }, 2618 | "engines": { 2619 | "node": ">=16 || 14 >=14.17" 2620 | }, 2621 | "funding": { 2622 | "url": "https://github.com/sponsors/isaacs" 2623 | } 2624 | }, 2625 | "node_modules/ms": { 2626 | "version": "2.1.2", 2627 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2628 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2629 | "dev": true 2630 | }, 2631 | "node_modules/nanoid": { 2632 | "version": "3.3.7", 2633 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 2634 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 2635 | "dev": true, 2636 | "funding": [ 2637 | { 2638 | "type": "github", 2639 | "url": "https://github.com/sponsors/ai" 2640 | } 2641 | ], 2642 | "bin": { 2643 | "nanoid": "bin/nanoid.cjs" 2644 | }, 2645 | "engines": { 2646 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2647 | } 2648 | }, 2649 | "node_modules/natural-compare": { 2650 | "version": "1.4.0", 2651 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2652 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 2653 | "dev": true 2654 | }, 2655 | "node_modules/node-releases": { 2656 | "version": "2.0.14", 2657 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", 2658 | "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", 2659 | "dev": true 2660 | }, 2661 | "node_modules/once": { 2662 | "version": "1.4.0", 2663 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2664 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2665 | "dev": true, 2666 | "dependencies": { 2667 | "wrappy": "1" 2668 | } 2669 | }, 2670 | "node_modules/optionator": { 2671 | "version": "0.9.3", 2672 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 2673 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 2674 | "dev": true, 2675 | "dependencies": { 2676 | "@aashutoshrathi/word-wrap": "^1.2.3", 2677 | "deep-is": "^0.1.3", 2678 | "fast-levenshtein": "^2.0.6", 2679 | "levn": "^0.4.1", 2680 | "prelude-ls": "^1.2.1", 2681 | "type-check": "^0.4.0" 2682 | }, 2683 | "engines": { 2684 | "node": ">= 0.8.0" 2685 | } 2686 | }, 2687 | "node_modules/p-limit": { 2688 | "version": "3.1.0", 2689 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 2690 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 2691 | "dev": true, 2692 | "dependencies": { 2693 | "yocto-queue": "^0.1.0" 2694 | }, 2695 | "engines": { 2696 | "node": ">=10" 2697 | }, 2698 | "funding": { 2699 | "url": "https://github.com/sponsors/sindresorhus" 2700 | } 2701 | }, 2702 | "node_modules/p-locate": { 2703 | "version": "5.0.0", 2704 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 2705 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 2706 | "dev": true, 2707 | "dependencies": { 2708 | "p-limit": "^3.0.2" 2709 | }, 2710 | "engines": { 2711 | "node": ">=10" 2712 | }, 2713 | "funding": { 2714 | "url": "https://github.com/sponsors/sindresorhus" 2715 | } 2716 | }, 2717 | "node_modules/parent-module": { 2718 | "version": "1.0.1", 2719 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2720 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2721 | "dev": true, 2722 | "dependencies": { 2723 | "callsites": "^3.0.0" 2724 | }, 2725 | "engines": { 2726 | "node": ">=6" 2727 | } 2728 | }, 2729 | "node_modules/path-exists": { 2730 | "version": "4.0.0", 2731 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2732 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2733 | "dev": true, 2734 | "engines": { 2735 | "node": ">=8" 2736 | } 2737 | }, 2738 | "node_modules/path-is-absolute": { 2739 | "version": "1.0.1", 2740 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2741 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2742 | "dev": true, 2743 | "engines": { 2744 | "node": ">=0.10.0" 2745 | } 2746 | }, 2747 | "node_modules/path-key": { 2748 | "version": "3.1.1", 2749 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2750 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2751 | "dev": true, 2752 | "engines": { 2753 | "node": ">=8" 2754 | } 2755 | }, 2756 | "node_modules/path-type": { 2757 | "version": "4.0.0", 2758 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 2759 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 2760 | "dev": true, 2761 | "engines": { 2762 | "node": ">=8" 2763 | } 2764 | }, 2765 | "node_modules/picocolors": { 2766 | "version": "1.0.0", 2767 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2768 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2769 | "dev": true 2770 | }, 2771 | "node_modules/picomatch": { 2772 | "version": "2.3.1", 2773 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2774 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2775 | "dev": true, 2776 | "engines": { 2777 | "node": ">=8.6" 2778 | }, 2779 | "funding": { 2780 | "url": "https://github.com/sponsors/jonschlinkert" 2781 | } 2782 | }, 2783 | "node_modules/postcss": { 2784 | "version": "8.4.35", 2785 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.35.tgz", 2786 | "integrity": "sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA==", 2787 | "dev": true, 2788 | "funding": [ 2789 | { 2790 | "type": "opencollective", 2791 | "url": "https://opencollective.com/postcss/" 2792 | }, 2793 | { 2794 | "type": "tidelift", 2795 | "url": "https://tidelift.com/funding/github/npm/postcss" 2796 | }, 2797 | { 2798 | "type": "github", 2799 | "url": "https://github.com/sponsors/ai" 2800 | } 2801 | ], 2802 | "dependencies": { 2803 | "nanoid": "^3.3.7", 2804 | "picocolors": "^1.0.0", 2805 | "source-map-js": "^1.0.2" 2806 | }, 2807 | "engines": { 2808 | "node": "^10 || ^12 || >=14" 2809 | } 2810 | }, 2811 | "node_modules/prelude-ls": { 2812 | "version": "1.2.1", 2813 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 2814 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 2815 | "dev": true, 2816 | "engines": { 2817 | "node": ">= 0.8.0" 2818 | } 2819 | }, 2820 | "node_modules/punycode": { 2821 | "version": "2.3.1", 2822 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 2823 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 2824 | "dev": true, 2825 | "engines": { 2826 | "node": ">=6" 2827 | } 2828 | }, 2829 | "node_modules/queue-microtask": { 2830 | "version": "1.2.3", 2831 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2832 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2833 | "dev": true, 2834 | "funding": [ 2835 | { 2836 | "type": "github", 2837 | "url": "https://github.com/sponsors/feross" 2838 | }, 2839 | { 2840 | "type": "patreon", 2841 | "url": "https://www.patreon.com/feross" 2842 | }, 2843 | { 2844 | "type": "consulting", 2845 | "url": "https://feross.org/support" 2846 | } 2847 | ] 2848 | }, 2849 | "node_modules/react": { 2850 | "version": "18.2.0", 2851 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 2852 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 2853 | "dependencies": { 2854 | "loose-envify": "^1.1.0" 2855 | }, 2856 | "engines": { 2857 | "node": ">=0.10.0" 2858 | } 2859 | }, 2860 | "node_modules/react-dom": { 2861 | "version": "18.2.0", 2862 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 2863 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 2864 | "dependencies": { 2865 | "loose-envify": "^1.1.0", 2866 | "scheduler": "^0.23.0" 2867 | }, 2868 | "peerDependencies": { 2869 | "react": "^18.2.0" 2870 | } 2871 | }, 2872 | "node_modules/react-hot-toast": { 2873 | "version": "2.4.1", 2874 | "resolved": "https://registry.npmjs.org/react-hot-toast/-/react-hot-toast-2.4.1.tgz", 2875 | "integrity": "sha512-j8z+cQbWIM5LY37pR6uZR6D4LfseplqnuAO4co4u8917hBUvXlEqyP1ZzqVLcqoyUesZZv/ImreoCeHVDpE5pQ==", 2876 | "dependencies": { 2877 | "goober": "^2.1.10" 2878 | }, 2879 | "engines": { 2880 | "node": ">=10" 2881 | }, 2882 | "peerDependencies": { 2883 | "react": ">=16", 2884 | "react-dom": ">=16" 2885 | } 2886 | }, 2887 | "node_modules/react-icons": { 2888 | "version": "5.0.1", 2889 | "resolved": "https://registry.npmjs.org/react-icons/-/react-icons-5.0.1.tgz", 2890 | "integrity": "sha512-WqLZJ4bLzlhmsvme6iFdgO8gfZP17rfjYEJ2m9RsZjZ+cc4k1hTzknEz63YS1MeT50kVzoa1Nz36f4BEx+Wigw==", 2891 | "peerDependencies": { 2892 | "react": "*" 2893 | } 2894 | }, 2895 | "node_modules/react-redux": { 2896 | "version": "9.1.0", 2897 | "resolved": "https://registry.npmjs.org/react-redux/-/react-redux-9.1.0.tgz", 2898 | "integrity": "sha512-6qoDzIO+gbrza8h3hjMA9aq4nwVFCKFtY2iLxCtVT38Swyy2C/dJCGBXHeHLtx6qlg/8qzc2MrhOeduf5K32wQ==", 2899 | "dependencies": { 2900 | "@types/use-sync-external-store": "^0.0.3", 2901 | "use-sync-external-store": "^1.0.0" 2902 | }, 2903 | "peerDependencies": { 2904 | "@types/react": "^18.2.25", 2905 | "react": "^18.0", 2906 | "react-native": ">=0.69", 2907 | "redux": "^5.0.0" 2908 | }, 2909 | "peerDependenciesMeta": { 2910 | "@types/react": { 2911 | "optional": true 2912 | }, 2913 | "react-native": { 2914 | "optional": true 2915 | }, 2916 | "redux": { 2917 | "optional": true 2918 | } 2919 | } 2920 | }, 2921 | "node_modules/react-refresh": { 2922 | "version": "0.14.0", 2923 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 2924 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 2925 | "dev": true, 2926 | "engines": { 2927 | "node": ">=0.10.0" 2928 | } 2929 | }, 2930 | "node_modules/redux": { 2931 | "version": "5.0.1", 2932 | "resolved": "https://registry.npmjs.org/redux/-/redux-5.0.1.tgz", 2933 | "integrity": "sha512-M9/ELqF6fy8FwmkpnF0S3YKOqMyoWJ4+CS5Efg2ct3oY9daQvd/Pc71FpGZsVsbl3Cpb+IIcjBDUnnyBdQbq4w==" 2934 | }, 2935 | "node_modules/redux-thunk": { 2936 | "version": "3.1.0", 2937 | "resolved": "https://registry.npmjs.org/redux-thunk/-/redux-thunk-3.1.0.tgz", 2938 | "integrity": "sha512-NW2r5T6ksUKXCabzhL9z+h206HQw/NJkcLm1GPImRQ8IzfXwRGqjVhKJGauHirT0DAuyy6hjdnMZaRoAcy0Klw==", 2939 | "peerDependencies": { 2940 | "redux": "^5.0.0" 2941 | } 2942 | }, 2943 | "node_modules/reselect": { 2944 | "version": "5.1.0", 2945 | "resolved": "https://registry.npmjs.org/reselect/-/reselect-5.1.0.tgz", 2946 | "integrity": "sha512-aw7jcGLDpSgNDyWBQLv2cedml85qd95/iszJjN988zX1t7AVRJi19d9kto5+W7oCfQ94gyo40dVbT6g2k4/kXg==" 2947 | }, 2948 | "node_modules/resolve-from": { 2949 | "version": "4.0.0", 2950 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2951 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2952 | "dev": true, 2953 | "engines": { 2954 | "node": ">=4" 2955 | } 2956 | }, 2957 | "node_modules/reusify": { 2958 | "version": "1.0.4", 2959 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2960 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2961 | "dev": true, 2962 | "engines": { 2963 | "iojs": ">=1.0.0", 2964 | "node": ">=0.10.0" 2965 | } 2966 | }, 2967 | "node_modules/rimraf": { 2968 | "version": "3.0.2", 2969 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2970 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2971 | "dev": true, 2972 | "dependencies": { 2973 | "glob": "^7.1.3" 2974 | }, 2975 | "bin": { 2976 | "rimraf": "bin.js" 2977 | }, 2978 | "funding": { 2979 | "url": "https://github.com/sponsors/isaacs" 2980 | } 2981 | }, 2982 | "node_modules/rollup": { 2983 | "version": "4.12.0", 2984 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.12.0.tgz", 2985 | "integrity": "sha512-wz66wn4t1OHIJw3+XU7mJJQV/2NAfw5OAk6G6Hoo3zcvz/XOfQ52Vgi+AN4Uxoxi0KBBwk2g8zPrTDA4btSB/Q==", 2986 | "dev": true, 2987 | "dependencies": { 2988 | "@types/estree": "1.0.5" 2989 | }, 2990 | "bin": { 2991 | "rollup": "dist/bin/rollup" 2992 | }, 2993 | "engines": { 2994 | "node": ">=18.0.0", 2995 | "npm": ">=8.0.0" 2996 | }, 2997 | "optionalDependencies": { 2998 | "@rollup/rollup-android-arm-eabi": "4.12.0", 2999 | "@rollup/rollup-android-arm64": "4.12.0", 3000 | "@rollup/rollup-darwin-arm64": "4.12.0", 3001 | "@rollup/rollup-darwin-x64": "4.12.0", 3002 | "@rollup/rollup-linux-arm-gnueabihf": "4.12.0", 3003 | "@rollup/rollup-linux-arm64-gnu": "4.12.0", 3004 | "@rollup/rollup-linux-arm64-musl": "4.12.0", 3005 | "@rollup/rollup-linux-riscv64-gnu": "4.12.0", 3006 | "@rollup/rollup-linux-x64-gnu": "4.12.0", 3007 | "@rollup/rollup-linux-x64-musl": "4.12.0", 3008 | "@rollup/rollup-win32-arm64-msvc": "4.12.0", 3009 | "@rollup/rollup-win32-ia32-msvc": "4.12.0", 3010 | "@rollup/rollup-win32-x64-msvc": "4.12.0", 3011 | "fsevents": "~2.3.2" 3012 | } 3013 | }, 3014 | "node_modules/run-parallel": { 3015 | "version": "1.2.0", 3016 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3017 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3018 | "dev": true, 3019 | "funding": [ 3020 | { 3021 | "type": "github", 3022 | "url": "https://github.com/sponsors/feross" 3023 | }, 3024 | { 3025 | "type": "patreon", 3026 | "url": "https://www.patreon.com/feross" 3027 | }, 3028 | { 3029 | "type": "consulting", 3030 | "url": "https://feross.org/support" 3031 | } 3032 | ], 3033 | "dependencies": { 3034 | "queue-microtask": "^1.2.2" 3035 | } 3036 | }, 3037 | "node_modules/scheduler": { 3038 | "version": "0.23.0", 3039 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 3040 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 3041 | "dependencies": { 3042 | "loose-envify": "^1.1.0" 3043 | } 3044 | }, 3045 | "node_modules/semver": { 3046 | "version": "7.6.0", 3047 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", 3048 | "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", 3049 | "dev": true, 3050 | "dependencies": { 3051 | "lru-cache": "^6.0.0" 3052 | }, 3053 | "bin": { 3054 | "semver": "bin/semver.js" 3055 | }, 3056 | "engines": { 3057 | "node": ">=10" 3058 | } 3059 | }, 3060 | "node_modules/semver/node_modules/lru-cache": { 3061 | "version": "6.0.0", 3062 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3063 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3064 | "dev": true, 3065 | "dependencies": { 3066 | "yallist": "^4.0.0" 3067 | }, 3068 | "engines": { 3069 | "node": ">=10" 3070 | } 3071 | }, 3072 | "node_modules/semver/node_modules/yallist": { 3073 | "version": "4.0.0", 3074 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3075 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3076 | "dev": true 3077 | }, 3078 | "node_modules/shebang-command": { 3079 | "version": "2.0.0", 3080 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3081 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3082 | "dev": true, 3083 | "dependencies": { 3084 | "shebang-regex": "^3.0.0" 3085 | }, 3086 | "engines": { 3087 | "node": ">=8" 3088 | } 3089 | }, 3090 | "node_modules/shebang-regex": { 3091 | "version": "3.0.0", 3092 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3093 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3094 | "dev": true, 3095 | "engines": { 3096 | "node": ">=8" 3097 | } 3098 | }, 3099 | "node_modules/slash": { 3100 | "version": "3.0.0", 3101 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3102 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3103 | "dev": true, 3104 | "engines": { 3105 | "node": ">=8" 3106 | } 3107 | }, 3108 | "node_modules/source-map-js": { 3109 | "version": "1.0.2", 3110 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 3111 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 3112 | "dev": true, 3113 | "engines": { 3114 | "node": ">=0.10.0" 3115 | } 3116 | }, 3117 | "node_modules/strip-ansi": { 3118 | "version": "6.0.1", 3119 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3120 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3121 | "dev": true, 3122 | "dependencies": { 3123 | "ansi-regex": "^5.0.1" 3124 | }, 3125 | "engines": { 3126 | "node": ">=8" 3127 | } 3128 | }, 3129 | "node_modules/strip-json-comments": { 3130 | "version": "3.1.1", 3131 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3132 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3133 | "dev": true, 3134 | "engines": { 3135 | "node": ">=8" 3136 | }, 3137 | "funding": { 3138 | "url": "https://github.com/sponsors/sindresorhus" 3139 | } 3140 | }, 3141 | "node_modules/supports-color": { 3142 | "version": "5.5.0", 3143 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3144 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3145 | "dev": true, 3146 | "dependencies": { 3147 | "has-flag": "^3.0.0" 3148 | }, 3149 | "engines": { 3150 | "node": ">=4" 3151 | } 3152 | }, 3153 | "node_modules/text-table": { 3154 | "version": "0.2.0", 3155 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3156 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3157 | "dev": true 3158 | }, 3159 | "node_modules/to-fast-properties": { 3160 | "version": "2.0.0", 3161 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 3162 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 3163 | "dev": true, 3164 | "engines": { 3165 | "node": ">=4" 3166 | } 3167 | }, 3168 | "node_modules/to-regex-range": { 3169 | "version": "5.0.1", 3170 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3171 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3172 | "dev": true, 3173 | "dependencies": { 3174 | "is-number": "^7.0.0" 3175 | }, 3176 | "engines": { 3177 | "node": ">=8.0" 3178 | } 3179 | }, 3180 | "node_modules/ts-api-utils": { 3181 | "version": "1.2.1", 3182 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.2.1.tgz", 3183 | "integrity": "sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==", 3184 | "dev": true, 3185 | "engines": { 3186 | "node": ">=16" 3187 | }, 3188 | "peerDependencies": { 3189 | "typescript": ">=4.2.0" 3190 | } 3191 | }, 3192 | "node_modules/type-check": { 3193 | "version": "0.4.0", 3194 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3195 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3196 | "dev": true, 3197 | "dependencies": { 3198 | "prelude-ls": "^1.2.1" 3199 | }, 3200 | "engines": { 3201 | "node": ">= 0.8.0" 3202 | } 3203 | }, 3204 | "node_modules/type-fest": { 3205 | "version": "0.20.2", 3206 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3207 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3208 | "dev": true, 3209 | "engines": { 3210 | "node": ">=10" 3211 | }, 3212 | "funding": { 3213 | "url": "https://github.com/sponsors/sindresorhus" 3214 | } 3215 | }, 3216 | "node_modules/typescript": { 3217 | "version": "5.3.3", 3218 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.3.3.tgz", 3219 | "integrity": "sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==", 3220 | "dev": true, 3221 | "bin": { 3222 | "tsc": "bin/tsc", 3223 | "tsserver": "bin/tsserver" 3224 | }, 3225 | "engines": { 3226 | "node": ">=14.17" 3227 | } 3228 | }, 3229 | "node_modules/update-browserslist-db": { 3230 | "version": "1.0.13", 3231 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", 3232 | "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", 3233 | "dev": true, 3234 | "funding": [ 3235 | { 3236 | "type": "opencollective", 3237 | "url": "https://opencollective.com/browserslist" 3238 | }, 3239 | { 3240 | "type": "tidelift", 3241 | "url": "https://tidelift.com/funding/github/npm/browserslist" 3242 | }, 3243 | { 3244 | "type": "github", 3245 | "url": "https://github.com/sponsors/ai" 3246 | } 3247 | ], 3248 | "dependencies": { 3249 | "escalade": "^3.1.1", 3250 | "picocolors": "^1.0.0" 3251 | }, 3252 | "bin": { 3253 | "update-browserslist-db": "cli.js" 3254 | }, 3255 | "peerDependencies": { 3256 | "browserslist": ">= 4.21.0" 3257 | } 3258 | }, 3259 | "node_modules/uri-js": { 3260 | "version": "4.4.1", 3261 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3262 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3263 | "dev": true, 3264 | "dependencies": { 3265 | "punycode": "^2.1.0" 3266 | } 3267 | }, 3268 | "node_modules/use-sync-external-store": { 3269 | "version": "1.2.0", 3270 | "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", 3271 | "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", 3272 | "peerDependencies": { 3273 | "react": "^16.8.0 || ^17.0.0 || ^18.0.0" 3274 | } 3275 | }, 3276 | "node_modules/vite": { 3277 | "version": "5.1.4", 3278 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.1.4.tgz", 3279 | "integrity": "sha512-n+MPqzq+d9nMVTKyewqw6kSt+R3CkvF9QAKY8obiQn8g1fwTscKxyfaYnC632HtBXAQGc1Yjomphwn1dtwGAHg==", 3280 | "dev": true, 3281 | "dependencies": { 3282 | "esbuild": "^0.19.3", 3283 | "postcss": "^8.4.35", 3284 | "rollup": "^4.2.0" 3285 | }, 3286 | "bin": { 3287 | "vite": "bin/vite.js" 3288 | }, 3289 | "engines": { 3290 | "node": "^18.0.0 || >=20.0.0" 3291 | }, 3292 | "funding": { 3293 | "url": "https://github.com/vitejs/vite?sponsor=1" 3294 | }, 3295 | "optionalDependencies": { 3296 | "fsevents": "~2.3.3" 3297 | }, 3298 | "peerDependencies": { 3299 | "@types/node": "^18.0.0 || >=20.0.0", 3300 | "less": "*", 3301 | "lightningcss": "^1.21.0", 3302 | "sass": "*", 3303 | "stylus": "*", 3304 | "sugarss": "*", 3305 | "terser": "^5.4.0" 3306 | }, 3307 | "peerDependenciesMeta": { 3308 | "@types/node": { 3309 | "optional": true 3310 | }, 3311 | "less": { 3312 | "optional": true 3313 | }, 3314 | "lightningcss": { 3315 | "optional": true 3316 | }, 3317 | "sass": { 3318 | "optional": true 3319 | }, 3320 | "stylus": { 3321 | "optional": true 3322 | }, 3323 | "sugarss": { 3324 | "optional": true 3325 | }, 3326 | "terser": { 3327 | "optional": true 3328 | } 3329 | } 3330 | }, 3331 | "node_modules/which": { 3332 | "version": "2.0.2", 3333 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3334 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3335 | "dev": true, 3336 | "dependencies": { 3337 | "isexe": "^2.0.0" 3338 | }, 3339 | "bin": { 3340 | "node-which": "bin/node-which" 3341 | }, 3342 | "engines": { 3343 | "node": ">= 8" 3344 | } 3345 | }, 3346 | "node_modules/wrappy": { 3347 | "version": "1.0.2", 3348 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3349 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3350 | "dev": true 3351 | }, 3352 | "node_modules/yallist": { 3353 | "version": "3.1.1", 3354 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 3355 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", 3356 | "dev": true 3357 | }, 3358 | "node_modules/yocto-queue": { 3359 | "version": "0.1.0", 3360 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 3361 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 3362 | "dev": true, 3363 | "engines": { 3364 | "node": ">=10" 3365 | }, 3366 | "funding": { 3367 | "url": "https://github.com/sponsors/sindresorhus" 3368 | } 3369 | } 3370 | } 3371 | } 3372 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "task-manager", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "tsc && vite build", 9 | "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0", 10 | "preview": "vite preview" 11 | }, 12 | "dependencies": { 13 | "@reduxjs/toolkit": "^2.2.1", 14 | "react": "^18.2.0", 15 | "react-dom": "^18.2.0", 16 | "react-hot-toast": "^2.4.1", 17 | "react-icons": "^5.0.1", 18 | "react-redux": "^9.1.0" 19 | }, 20 | "devDependencies": { 21 | "@types/react": "^18.2.56", 22 | "@types/react-dom": "^18.2.19", 23 | "@typescript-eslint/eslint-plugin": "^7.0.2", 24 | "@typescript-eslint/parser": "^7.0.2", 25 | "@vitejs/plugin-react": "^4.2.1", 26 | "eslint": "^8.56.0", 27 | "eslint-plugin-react-hooks": "^4.6.0", 28 | "eslint-plugin-react-refresh": "^0.4.5", 29 | "typescript": "^5.2.2", 30 | "vite": "^5.1.4" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.tsx: -------------------------------------------------------------------------------- 1 | import { AppHeader, TaskForm, TaskList } from './components'; 2 | 3 | function App() { 4 | return ( 5 |
6 | 7 | 8 | 9 |
10 | ); 11 | } 12 | export default App; 13 | -------------------------------------------------------------------------------- /src/assets/react.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/components/AppHeader.tsx: -------------------------------------------------------------------------------- 1 | import ThemeToggle from './ThemeToggle'; 2 | 3 | function AppHeader() { 4 | return ( 5 |
6 |

Task Manager

7 | 8 |
9 | ); 10 | } 11 | export default AppHeader; 12 | -------------------------------------------------------------------------------- /src/components/RemoveCompletedBtn.tsx: -------------------------------------------------------------------------------- 1 | import { deleteCompletedTasks } from '../features/task/taskSlice'; 2 | import { useAppDispatch } from '../hooks'; 3 | function RemoveCompletedBtn() { 4 | const dispatch = useAppDispatch(); 5 | const handleRemoveCompleted = () => { 6 | dispatch(deleteCompletedTasks()); 7 | }; 8 | return ( 9 | 17 | ); 18 | } 19 | export default RemoveCompletedBtn; 20 | -------------------------------------------------------------------------------- /src/components/Task.tsx: -------------------------------------------------------------------------------- 1 | import { type Task } from '../utils/types'; 2 | import TaskCompletionToggle from './TaskCompletionToggle'; 3 | import TaskDeleteBtn from './TaskDeleteBtn'; 4 | 5 | function TaskComponent({ task }: { task: Task }) { 6 | return ( 7 |
  • 8 | 9 | 14 | {task.name} 15 | 16 | 17 |
  • 18 | ); 19 | } 20 | export default TaskComponent; 21 | -------------------------------------------------------------------------------- /src/components/TaskCompletionToggle.tsx: -------------------------------------------------------------------------------- 1 | import { useAppDispatch } from '../hooks'; 2 | import { toggleTaskCompletion } from '../features/task/taskSlice'; 3 | function TaskCompletionToggleInput({ 4 | isCompleted, 5 | id, 6 | }: { 7 | isCompleted: boolean; 8 | id: string; 9 | }) { 10 | const dispatch = useAppDispatch(); 11 | 12 | const handleToggleCompleted = () => { 13 | dispatch(toggleTaskCompletion(id)); 14 | }; 15 | 16 | return ( 17 | 26 | ); 27 | } 28 | 29 | export default TaskCompletionToggleInput; 30 | -------------------------------------------------------------------------------- /src/components/TaskDeleteBtn.tsx: -------------------------------------------------------------------------------- 1 | import { BsTrash } from 'react-icons/bs'; 2 | import { useAppDispatch } from '../hooks'; 3 | import { deleteTask } from '../features/task/taskSlice'; 4 | function TaskDeleteBtn({ id }: { id: string }) { 5 | const dispatch = useAppDispatch(); 6 | const handleDelete = () => { 7 | dispatch(deleteTask(id)); 8 | }; 9 | return ( 10 | 18 | ); 19 | } 20 | export default TaskDeleteBtn; 21 | -------------------------------------------------------------------------------- /src/components/TaskFilterBar.tsx: -------------------------------------------------------------------------------- 1 | import { useAppSelector } from '../hooks'; 2 | import RemoveCompletedBtn from './RemoveCompletedBtn'; 3 | import TaskFilterBtn from './TaskFilterBtn'; 4 | 5 | function pluralize(count: number, noun: string, suffix = 's') { 6 | return `${count} ${noun}${count !== 1 ? suffix : ''}`; 7 | } 8 | 9 | function TaskFilterBar() { 10 | const { filteredTasks } = useAppSelector((state) => state.taskState); 11 | 12 | return ( 13 |
    14 | {pluralize(filteredTasks.length, 'task')} 15 | 16 |
    17 | 18 | 19 | 20 |
    21 | 22 |
    23 | ); 24 | } 25 | export default TaskFilterBar; 26 | -------------------------------------------------------------------------------- /src/components/TaskFilterBtn.tsx: -------------------------------------------------------------------------------- 1 | import { type TaskFilterValue } from '../utils/types'; 2 | import { useAppSelector, useAppDispatch } from '../hooks'; 3 | import { filterTasks } from '../features/task/taskSlice'; 4 | 5 | function TaskFilterBtn({ filterValue }: { filterValue: TaskFilterValue }) { 6 | const activeFilter = useAppSelector((state) => state.taskState.filterValue); 7 | const isActive = filterValue === activeFilter; 8 | const dispatch = useAppDispatch(); 9 | const handleFilter = () => { 10 | dispatch(filterTasks(filterValue)); 11 | }; 12 | return ( 13 | 22 | ); 23 | } 24 | export default TaskFilterBtn; 25 | -------------------------------------------------------------------------------- /src/components/TaskForm.tsx: -------------------------------------------------------------------------------- 1 | import { useState } from 'react'; 2 | import { useAppDispatch } from '../hooks'; 3 | import { addTask } from '../features/task/taskSlice'; 4 | import toast from 'react-hot-toast'; 5 | 6 | function TaskForm() { 7 | const [task, setTask] = useState(''); 8 | const dispatch = useAppDispatch(); 9 | 10 | const handleSubmit = (e: React.FormEvent) => { 11 | e.preventDefault(); 12 | if (!task) { 13 | toast.error('Please enter a task'); 14 | return; 15 | } 16 | dispatch( 17 | addTask({ 18 | id: new Date().getTime().toString(), 19 | name: task, 20 | isCompleted: false, 21 | }) 22 | ); 23 | setTask(''); 24 | }; 25 | 26 | return ( 27 |
    28 |
    29 | 32 | setTask(e.target.value)} 38 | aria-label='Enter your task here' 39 | /> 40 |
    41 | 42 | 49 |
    50 | ); 51 | } 52 | export default TaskForm; 53 | -------------------------------------------------------------------------------- /src/components/TaskList.tsx: -------------------------------------------------------------------------------- 1 | import { useAppSelector } from '../hooks'; 2 | import Task from './Task'; 3 | import TaskFilterBar from './TaskFilterBar'; 4 | 5 | function TaskList() { 6 | const { tasks, filteredTasks } = useAppSelector((state) => state.taskState); 7 | if (tasks.length === 0) return

    Your task list is empty.

    ; 8 | const areNoTasksMatchingFilter = filteredTasks.length === 0; 9 | return ( 10 |
    11 | {areNoTasksMatchingFilter ? ( 12 | No tasks match the selected filter. 13 | ) : ( 14 | 19 | )} 20 | 21 | 22 |
    23 | ); 24 | } 25 | export default TaskList; 26 | -------------------------------------------------------------------------------- /src/components/ThemeToggle.tsx: -------------------------------------------------------------------------------- 1 | import { BsFillSunFill, BsFillMoonFill } from 'react-icons/bs'; 2 | import { useAppSelector } from '../hooks'; 3 | import { toggleTheme } from '../features/theme/themeSlice'; 4 | import { useAppDispatch } from '../hooks'; 5 | function ThemeToggle() { 6 | const darkThemeEnabled = useAppSelector( 7 | (state) => state.themeState.darkThemeEnabled 8 | ); 9 | const dispatch = useAppDispatch(); 10 | const handleToggleTheme = () => { 11 | dispatch(toggleTheme()); 12 | }; 13 | return ( 14 | 21 | ); 22 | } 23 | export default ThemeToggle; 24 | -------------------------------------------------------------------------------- /src/components/index.ts: -------------------------------------------------------------------------------- 1 | export { default as TaskForm } from './TaskForm'; 2 | export { default as TaskList } from './TaskList'; 3 | export { default as AppHeader } from './AppHeader'; 4 | -------------------------------------------------------------------------------- /src/features/task/taskSlice.ts: -------------------------------------------------------------------------------- 1 | import { createSlice, PayloadAction } from '@reduxjs/toolkit'; 2 | import { 3 | type Task, 4 | type TaskState, 5 | type TaskFilterValue, 6 | } from '../../utils/types'; 7 | import { 8 | retrieveTasksFromLocalStorage, 9 | saveTasksToLocalStorage, 10 | } from '../../utils/taskUtils'; 11 | import toast from 'react-hot-toast'; 12 | 13 | const initialState: TaskState = { 14 | tasks: retrieveTasksFromLocalStorage(), 15 | filteredTasks: retrieveTasksFromLocalStorage(), 16 | filterValue: 'all', 17 | }; 18 | const taskSlice = createSlice({ 19 | name: 'task', 20 | initialState, 21 | reducers: { 22 | addTask: (state, action: PayloadAction) => { 23 | state.tasks.push(action.payload); 24 | taskSlice.caseReducers.saveTasks(state); 25 | toast.success('Task created'); 26 | }, 27 | toggleTaskCompletion: (state, action: PayloadAction) => { 28 | const task = state.tasks.find((task) => task.id === action.payload); 29 | if (task) { 30 | task.isCompleted = !task.isCompleted; 31 | taskSlice.caseReducers.saveTasks(state); 32 | toast.success('Task updated'); 33 | } 34 | }, 35 | deleteTask: (state, action: PayloadAction) => { 36 | state.tasks = state.tasks.filter((task) => task.id !== action.payload); 37 | taskSlice.caseReducers.saveTasks(state); 38 | 39 | toast.error('Task removed'); 40 | }, 41 | filterTasks: (state, action: PayloadAction) => { 42 | state.filterValue = action.payload; 43 | switch (action.payload) { 44 | case 'active': 45 | state.filteredTasks = state.tasks.filter((task) => !task.isCompleted); 46 | break; 47 | case 'completed': 48 | state.filteredTasks = state.tasks.filter((task) => task.isCompleted); 49 | break; 50 | case 'all': 51 | state.filteredTasks = state.tasks; 52 | break; 53 | default: 54 | const unexpectedValue: never = action.payload; 55 | throw new Error(`Unexpected value: ${unexpectedValue}`); 56 | } 57 | }, 58 | deleteCompletedTasks: (state) => { 59 | state.tasks = state.tasks.filter((task) => !task.isCompleted); 60 | state.filterValue = 'all'; 61 | taskSlice.caseReducers.saveTasks(state); 62 | toast.error('Completed tasks removed'); 63 | }, 64 | saveTasks: (state) => { 65 | state.filteredTasks = state.tasks; 66 | saveTasksToLocalStorage(state.tasks); 67 | }, 68 | }, 69 | }); 70 | 71 | export const { 72 | addTask, 73 | toggleTaskCompletion, 74 | deleteTask, 75 | filterTasks, 76 | deleteCompletedTasks, 77 | } = taskSlice.actions; 78 | 79 | export default taskSlice.reducer; 80 | -------------------------------------------------------------------------------- /src/features/theme/themeSlice.ts: -------------------------------------------------------------------------------- 1 | import { createSlice } from '@reduxjs/toolkit'; 2 | import { 3 | THEME_KEY, 4 | DARK_THEME_CLASS, 5 | getInitialThemeStatus, 6 | } from '../../utils/themeUtils'; 7 | 8 | type ThemeState = { 9 | darkThemeEnabled: boolean; 10 | }; 11 | 12 | const initialState: ThemeState = { 13 | darkThemeEnabled: getInitialThemeStatus(), 14 | }; 15 | 16 | const themeSlice = createSlice({ 17 | name: 'theme', 18 | initialState, 19 | reducers: { 20 | toggleTheme: (state) => { 21 | const updatedDarkThemeStatus = !state.darkThemeEnabled; 22 | state.darkThemeEnabled = updatedDarkThemeStatus; 23 | document.body.classList.toggle(DARK_THEME_CLASS, updatedDarkThemeStatus); 24 | localStorage.setItem(THEME_KEY, JSON.stringify(updatedDarkThemeStatus)); 25 | }, 26 | }, 27 | }); 28 | 29 | export const { toggleTheme } = themeSlice.actions; 30 | 31 | export default themeSlice.reducer; 32 | -------------------------------------------------------------------------------- /src/hooks.ts: -------------------------------------------------------------------------------- 1 | import { useDispatch, useSelector } from 'react-redux'; 2 | import type { TypedUseSelectorHook } from 'react-redux'; 3 | import type { RootState, AppDispatch } from './store'; 4 | 5 | // Use throughout your app instead of plain `useDispatch` and `useSelector` 6 | export const useAppDispatch: () => AppDispatch = useDispatch; 7 | export const useAppSelector: TypedUseSelectorHook = useSelector; 8 | -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- 1 | /* ============= GLOBAL CSS =============== */ 2 | 3 | *, 4 | ::after, 5 | ::before { 6 | margin: 0; 7 | padding: 0; 8 | box-sizing: border-box; 9 | } 10 | 11 | html { 12 | font-size: 100%; 13 | } /*16px*/ 14 | 15 | :root { 16 | /* colors */ 17 | --primary-50: #e0fcff; 18 | --primary-100: #bef8fd; 19 | --primary-200: #87eaf2; 20 | --primary-300: #54d1db; 21 | --primary-400: #38bec9; 22 | --primary-500: #2cb1bc; 23 | --primary-600: #14919b; 24 | --primary-700: #0e7c86; 25 | --primary-800: #0a6c74; 26 | --primary-900: #044e54; 27 | 28 | /* grey */ 29 | --grey-50: #f8fafc; 30 | --grey-100: #f1f5f9; 31 | --grey-200: #e2e8f0; 32 | --grey-300: #cbd5e1; 33 | --grey-400: #94a3b8; 34 | --grey-500: #64748b; 35 | --grey-600: #475569; 36 | --grey-700: #334155; 37 | --grey-800: #1e293b; 38 | --grey-900: #0f172a; 39 | /* rest of the colors */ 40 | --black: #222; 41 | --white: #fff; 42 | --red-light: #f8d7da; 43 | --red-dark: #842029; 44 | --green-light: #d1e7dd; 45 | --green-dark: #0f5132; 46 | 47 | --small-text: 0.875rem; 48 | --extra-small-text: 0.7em; 49 | /* rest of the vars */ 50 | 51 | --border-radius: 0.25rem; 52 | --letter-spacing: 1px; 53 | --transition: 0.3s ease-in-out all; 54 | --max-width: 1120px; 55 | --fixed-width: 600px; 56 | --fluid-width: 90vw; 57 | --nav-height: 6rem; 58 | /* box shadow*/ 59 | --shadow-1: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06); 60 | --shadow-2: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 61 | 0 2px 4px -1px rgba(0, 0, 0, 0.06); 62 | --shadow-3: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 63 | 0 4px 6px -2px rgba(0, 0, 0, 0.05); 64 | --shadow-4: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 65 | 0 10px 10px -5px rgba(0, 0, 0, 0.04); 66 | /* DARK MODE */ 67 | 68 | --dark-mode-bg-color: #333; 69 | --dark-mode-text-color: #f0f0f0; 70 | --dark-mode-bg-secondary-color: #3f3f3f; 71 | --dark-mode-text-secondary-color: var(--grey-300); 72 | 73 | --background-color: var(--grey-50); 74 | --text-color: var(--grey-900); 75 | --background-secondary-color: var(--white); 76 | --text-secondary-color: var(--grey-500); 77 | } 78 | 79 | .dark-theme { 80 | --text-color: var(--dark-mode-text-color); 81 | --background-color: var(--dark-mode-bg-color); 82 | --text-secondary-color: var(--dark-mode-text-secondary-color); 83 | --background-secondary-color: var(--dark-mode-bg-secondary-color); 84 | } 85 | 86 | body { 87 | background: var(--background-color); 88 | color: var(--text-color); 89 | font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 90 | Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif; 91 | font-weight: 400; 92 | line-height: 1; 93 | } 94 | p { 95 | margin: 0; 96 | } 97 | h1, 98 | h2, 99 | h3, 100 | h4, 101 | h5 { 102 | margin: 0; 103 | font-weight: 400; 104 | line-height: 1; 105 | letter-spacing: var(--letter-spacing); 106 | } 107 | 108 | h1 { 109 | font-size: clamp(1.5rem, 4vw, 4rem); /* Large heading */ 110 | } 111 | 112 | h2 { 113 | font-size: clamp(1.25rem, 2.5vw, 2.5rem); /* Medium heading */ 114 | } 115 | 116 | h3 { 117 | font-size: clamp(1rem, 2vw, 2rem); /* Small heading */ 118 | } 119 | 120 | h4 { 121 | font-size: clamp(0.875rem, 1.5vw, 1.5rem); /* Extra small heading */ 122 | } 123 | 124 | h5 { 125 | font-size: clamp(0.75rem, 1vw, 1rem); /* Tiny heading */ 126 | } 127 | 128 | .text { 129 | margin-bottom: 1.5rem; 130 | max-width: 40em; 131 | } 132 | 133 | small, 134 | .text-small { 135 | font-size: var(--small-text); 136 | } 137 | 138 | a { 139 | text-decoration: none; 140 | } 141 | ul { 142 | list-style-type: none; 143 | padding: 0; 144 | } 145 | 146 | .img { 147 | width: 100%; 148 | display: block; 149 | object-fit: cover; 150 | } 151 | /* buttons */ 152 | 153 | .btn { 154 | cursor: pointer; 155 | color: var(--white); 156 | background: var(--primary-500); 157 | border: transparent; 158 | border-radius: var(--border-radius); 159 | letter-spacing: var(--letter-spacing); 160 | padding: 0.375rem 0.75rem; 161 | box-shadow: var(--shadow-1); 162 | transition: var(--transition); 163 | text-transform: capitalize; 164 | display: inline-block; 165 | } 166 | .btn:hover { 167 | background: var(--primary-700); 168 | box-shadow: var(--shadow-3); 169 | } 170 | .btn-hipster { 171 | color: var(--primary-500); 172 | background: var(--primary-200); 173 | } 174 | .btn-hipster:hover { 175 | color: var(--primary-200); 176 | background: var(--primary-700); 177 | } 178 | .btn-block { 179 | width: 100%; 180 | } 181 | button:disabled { 182 | cursor: wait; 183 | } 184 | .danger-btn { 185 | color: var(--red-dark); 186 | background: var(--red-light); 187 | } 188 | .danger-btn:hover { 189 | color: var(--white); 190 | background: var(--red-dark); 191 | } 192 | /* alerts */ 193 | .alert { 194 | padding: 0.375rem 0.75rem; 195 | margin-bottom: 1rem; 196 | border-color: transparent; 197 | border-radius: var(--border-radius); 198 | } 199 | 200 | .alert-danger { 201 | color: var(--red-dark); 202 | background: var(--red-light); 203 | } 204 | .alert-success { 205 | color: var(--green-dark); 206 | background: var(--green-light); 207 | } 208 | /* form */ 209 | 210 | .form { 211 | background: var(--background-secondary-color); 212 | border-radius: var(--border-radius); 213 | box-shadow: var(--shadow-2); 214 | padding: 2rem 2.5rem; 215 | } 216 | .form-label { 217 | display: block; 218 | font-size: var(--small-text); 219 | margin-bottom: 0.75rem; 220 | text-transform: capitalize; 221 | letter-spacing: var(--letter-spacing); 222 | line-height: 1.5; 223 | } 224 | .form-input, 225 | .form-textarea, 226 | .form-select { 227 | width: 100%; 228 | padding: 0.375rem 0.75rem; 229 | border-radius: var(--border-radius); 230 | background: var(--background-color); 231 | border: 1px solid var(--grey-300); 232 | color: var(--text-color); 233 | } 234 | .form-input, 235 | .form-select, 236 | .form-btn { 237 | height: 35px; 238 | } 239 | .form-row { 240 | margin-bottom: 1rem; 241 | } 242 | 243 | .form-textarea { 244 | height: 7rem; 245 | } 246 | ::placeholder { 247 | font-family: inherit; 248 | color: var(--grey-400); 249 | } 250 | .form-alert { 251 | color: var(--red-dark); 252 | letter-spacing: var(--letter-spacing); 253 | text-transform: capitalize; 254 | } 255 | 256 | /* Main Container */ 257 | .container { 258 | width: var(--fluid-width); 259 | max-width: var(--fixed-width); 260 | margin: 0 auto; 261 | padding: 5rem 0; 262 | } 263 | 264 | /* App Header */ 265 | 266 | .app-header { 267 | display: flex; 268 | justify-content: space-between; 269 | align-items: center; 270 | margin-bottom: 3rem; 271 | } 272 | .app-header h1 { 273 | font-size: clamp(1.25rem, 2.5vw, 2.5rem); /* Medium heading */ 274 | } 275 | 276 | .toggle-btn { 277 | font-size: 1.5rem; 278 | background: transparent; 279 | border-color: transparent; 280 | color: var(--text-color); 281 | cursor: pointer; 282 | transition: var(--transition); 283 | display: grid; 284 | place-items: center; 285 | } 286 | .toggle-btn:hover { 287 | color: var(--primary-500); 288 | } 289 | 290 | /* Task Form */ 291 | 292 | .task-form { 293 | margin-bottom: 3rem; 294 | display: grid; 295 | } 296 | .submit-btn { 297 | height: 35px; 298 | } 299 | @media screen and (min-width: 640px) { 300 | .task-form { 301 | grid-template-columns: 1fr auto; 302 | align-items: center; 303 | gap: 1rem; 304 | } 305 | .form-row { 306 | margin-bottom: 0; 307 | } 308 | .submit-btn { 309 | align-self: flex-end; 310 | } 311 | } 312 | 313 | /* Task List */ 314 | 315 | .task-list { 316 | margin-bottom: 3rem; 317 | background-color: var(--background-secondary-color); 318 | border-radius: var(--border-radius); 319 | box-shadow: var(--shadow-2); 320 | padding: 2rem 2.5rem 0; 321 | } 322 | 323 | .task { 324 | display: grid; 325 | grid-template-columns: auto 1fr auto; 326 | align-items: center; 327 | gap: 1rem; 328 | margin-bottom: 1rem; 329 | } 330 | .task span { 331 | letter-spacing: var(--letter-spacing); 332 | text-transform: capitalize; 333 | } 334 | .delete-task { 335 | display: grid; 336 | place-items: center; 337 | cursor: pointer; 338 | color: var(--primary-500); 339 | background: transparent; 340 | border-color: transparent; 341 | font-size: 1.1rem; 342 | } 343 | 344 | .tasklist-filters { 345 | display: flex; 346 | gap: 1rem; 347 | align-items: center; 348 | flex-wrap: wrap; 349 | padding: 2rem 0 1rem; 350 | } 351 | @media screen and (min-width: 640px) { 352 | .tasklist-filters { 353 | justify-content: space-between; 354 | } 355 | } 356 | .tasklist-filters span { 357 | color: var(--text-secondary-color); 358 | } 359 | .btn-container { 360 | display: flex; 361 | gap: 1rem; 362 | } 363 | 364 | .filter-btn { 365 | background: transparent; 366 | border-color: transparent; 367 | color: var(--text-secondary-color); 368 | cursor: pointer; 369 | transition: var(--transition); 370 | text-transform: capitalize; 371 | letter-spacing: var(--letter-spacing); 372 | } 373 | .filter-btn.active-btn { 374 | color: var(--primary-500); 375 | } 376 | -------------------------------------------------------------------------------- /src/main.tsx: -------------------------------------------------------------------------------- 1 | import ReactDOM from 'react-dom/client'; 2 | import App from './App.tsx'; 3 | import './index.css'; 4 | import { store } from './store'; 5 | import { Provider } from 'react-redux'; 6 | import { Toaster } from 'react-hot-toast'; 7 | ReactDOM.createRoot(document.getElementById('root')!).render( 8 | 9 | 10 | 11 | 12 | ); 13 | -------------------------------------------------------------------------------- /src/store.ts: -------------------------------------------------------------------------------- 1 | import { configureStore } from '@reduxjs/toolkit'; 2 | import themeReducer from './features/theme/themeSlice'; 3 | import taskSlice from './features/task/taskSlice'; 4 | 5 | export const store = configureStore({ 6 | reducer: { 7 | themeState: themeReducer, 8 | taskState: taskSlice, 9 | }, 10 | }); 11 | 12 | export type RootState = ReturnType; 13 | export type AppDispatch = typeof store.dispatch; 14 | -------------------------------------------------------------------------------- /src/utils/taskUtils.ts: -------------------------------------------------------------------------------- 1 | import { Task } from './types'; 2 | 3 | export const retrieveTasksFromLocalStorage = (): Task[] => { 4 | const tasks = localStorage.getItem('tasks'); 5 | return tasks ? JSON.parse(tasks) : []; 6 | }; 7 | 8 | export const saveTasksToLocalStorage = (tasks: Task[]): void => { 9 | localStorage.setItem('tasks', JSON.stringify(tasks)); 10 | }; 11 | -------------------------------------------------------------------------------- /src/utils/themeUtils.ts: -------------------------------------------------------------------------------- 1 | export const THEME_KEY = 'darkTheme'; 2 | export const DARK_THEME_CLASS = 'dark-theme'; 3 | 4 | export const getInitialThemeStatus = (): boolean => { 5 | const darkThemeEnabled = localStorage.getItem(THEME_KEY) === 'true'; 6 | document.body.classList.toggle(DARK_THEME_CLASS, darkThemeEnabled); 7 | return darkThemeEnabled; 8 | }; 9 | -------------------------------------------------------------------------------- /src/utils/types.ts: -------------------------------------------------------------------------------- 1 | export type Task = { 2 | id: string; 3 | name: string; 4 | isCompleted: boolean; 5 | }; 6 | 7 | export type TaskState = { 8 | tasks: Task[]; 9 | filterValue: TaskFilterValue; 10 | filteredTasks: Task[]; 11 | }; 12 | 13 | export type TaskFilterValue = 'all' | 'active' | 'completed'; 14 | -------------------------------------------------------------------------------- /src/vite-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES2020", 4 | "useDefineForClassFields": true, 5 | "lib": ["ES2020", "DOM", "DOM.Iterable"], 6 | "module": "ESNext", 7 | "skipLibCheck": true, 8 | 9 | /* Bundler mode */ 10 | "moduleResolution": "bundler", 11 | "allowImportingTsExtensions": true, 12 | "resolveJsonModule": true, 13 | "isolatedModules": true, 14 | "noEmit": true, 15 | "jsx": "react-jsx", 16 | 17 | /* Linting */ 18 | "strict": true, 19 | "noUnusedLocals": true, 20 | "noUnusedParameters": true, 21 | "noFallthroughCasesInSwitch": true 22 | }, 23 | "include": ["src"], 24 | "references": [{ "path": "./tsconfig.node.json" }] 25 | } 26 | -------------------------------------------------------------------------------- /tsconfig.node.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "composite": true, 4 | "skipLibCheck": true, 5 | "module": "ESNext", 6 | "moduleResolution": "bundler", 7 | "allowSyntheticDefaultImports": true, 8 | "strict": true 9 | }, 10 | "include": ["vite.config.ts"] 11 | } 12 | -------------------------------------------------------------------------------- /vite.config.ts: -------------------------------------------------------------------------------- 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 | --------------------------------------------------------------------------------