├── .gitignore ├── index.html ├── package-lock.json ├── package.json ├── public └── vite.svg ├── src ├── App.jsx ├── components │ ├── BlogActions.jsx │ ├── BlogActions.module.css │ ├── BlogPost.jsx │ ├── BlogPost.module.css │ ├── MainNavigation.jsx │ ├── MainNavigation.module.css │ ├── NewPostForm.jsx │ ├── NewPostForm.module.css │ ├── Posts.jsx │ ├── Posts.module.css │ └── RootLayout.jsx ├── index.css ├── main.jsx ├── pages │ ├── BlogLayout.jsx │ ├── BlogPosts.jsx │ ├── NewPost.jsx │ ├── PostDetail.jsx │ └── Welcome.jsx └── util │ └── api.js └── vite.config.js /.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 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Vite + React 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-router-64", 3 | "version": "0.0.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "react-router-64", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "react": "^18.2.0", 12 | "react-dom": "^18.2.0", 13 | "react-router-dom": "6.3" 14 | }, 15 | "devDependencies": { 16 | "@types/react": "^18.0.17", 17 | "@types/react-dom": "^18.0.6", 18 | "@vitejs/plugin-react": "^2.1.0", 19 | "vite": "^3.1.0" 20 | } 21 | }, 22 | "node_modules/@ampproject/remapping": { 23 | "version": "2.2.0", 24 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", 25 | "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", 26 | "dev": true, 27 | "dependencies": { 28 | "@jridgewell/gen-mapping": "^0.1.0", 29 | "@jridgewell/trace-mapping": "^0.3.9" 30 | }, 31 | "engines": { 32 | "node": ">=6.0.0" 33 | } 34 | }, 35 | "node_modules/@babel/code-frame": { 36 | "version": "7.18.6", 37 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", 38 | "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", 39 | "dev": true, 40 | "dependencies": { 41 | "@babel/highlight": "^7.18.6" 42 | }, 43 | "engines": { 44 | "node": ">=6.9.0" 45 | } 46 | }, 47 | "node_modules/@babel/compat-data": { 48 | "version": "7.19.1", 49 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.19.1.tgz", 50 | "integrity": "sha512-72a9ghR0gnESIa7jBN53U32FOVCEoztyIlKaNoU05zRhEecduGK9L9c3ww7Mp06JiR+0ls0GBPFJQwwtjn9ksg==", 51 | "dev": true, 52 | "engines": { 53 | "node": ">=6.9.0" 54 | } 55 | }, 56 | "node_modules/@babel/core": { 57 | "version": "7.19.1", 58 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.19.1.tgz", 59 | "integrity": "sha512-1H8VgqXme4UXCRv7/Wa1bq7RVymKOzC7znjyFM8KiEzwFqcKUKYNoQef4GhdklgNvoBXyW4gYhuBNCM5o1zImw==", 60 | "dev": true, 61 | "dependencies": { 62 | "@ampproject/remapping": "^2.1.0", 63 | "@babel/code-frame": "^7.18.6", 64 | "@babel/generator": "^7.19.0", 65 | "@babel/helper-compilation-targets": "^7.19.1", 66 | "@babel/helper-module-transforms": "^7.19.0", 67 | "@babel/helpers": "^7.19.0", 68 | "@babel/parser": "^7.19.1", 69 | "@babel/template": "^7.18.10", 70 | "@babel/traverse": "^7.19.1", 71 | "@babel/types": "^7.19.0", 72 | "convert-source-map": "^1.7.0", 73 | "debug": "^4.1.0", 74 | "gensync": "^1.0.0-beta.2", 75 | "json5": "^2.2.1", 76 | "semver": "^6.3.0" 77 | }, 78 | "engines": { 79 | "node": ">=6.9.0" 80 | }, 81 | "funding": { 82 | "type": "opencollective", 83 | "url": "https://opencollective.com/babel" 84 | } 85 | }, 86 | "node_modules/@babel/generator": { 87 | "version": "7.19.0", 88 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.19.0.tgz", 89 | "integrity": "sha512-S1ahxf1gZ2dpoiFgA+ohK9DIpz50bJ0CWs7Zlzb54Z4sG8qmdIrGrVqmy1sAtTVRb+9CU6U8VqT9L0Zj7hxHVg==", 90 | "dev": true, 91 | "dependencies": { 92 | "@babel/types": "^7.19.0", 93 | "@jridgewell/gen-mapping": "^0.3.2", 94 | "jsesc": "^2.5.1" 95 | }, 96 | "engines": { 97 | "node": ">=6.9.0" 98 | } 99 | }, 100 | "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": { 101 | "version": "0.3.2", 102 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", 103 | "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", 104 | "dev": true, 105 | "dependencies": { 106 | "@jridgewell/set-array": "^1.0.1", 107 | "@jridgewell/sourcemap-codec": "^1.4.10", 108 | "@jridgewell/trace-mapping": "^0.3.9" 109 | }, 110 | "engines": { 111 | "node": ">=6.0.0" 112 | } 113 | }, 114 | "node_modules/@babel/helper-annotate-as-pure": { 115 | "version": "7.18.6", 116 | "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", 117 | "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", 118 | "dev": true, 119 | "dependencies": { 120 | "@babel/types": "^7.18.6" 121 | }, 122 | "engines": { 123 | "node": ">=6.9.0" 124 | } 125 | }, 126 | "node_modules/@babel/helper-compilation-targets": { 127 | "version": "7.19.1", 128 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.19.1.tgz", 129 | "integrity": "sha512-LlLkkqhCMyz2lkQPvJNdIYU7O5YjWRgC2R4omjCTpZd8u8KMQzZvX4qce+/BluN1rcQiV7BoGUpmQ0LeHerbhg==", 130 | "dev": true, 131 | "dependencies": { 132 | "@babel/compat-data": "^7.19.1", 133 | "@babel/helper-validator-option": "^7.18.6", 134 | "browserslist": "^4.21.3", 135 | "semver": "^6.3.0" 136 | }, 137 | "engines": { 138 | "node": ">=6.9.0" 139 | }, 140 | "peerDependencies": { 141 | "@babel/core": "^7.0.0" 142 | } 143 | }, 144 | "node_modules/@babel/helper-environment-visitor": { 145 | "version": "7.18.9", 146 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", 147 | "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", 148 | "dev": true, 149 | "engines": { 150 | "node": ">=6.9.0" 151 | } 152 | }, 153 | "node_modules/@babel/helper-function-name": { 154 | "version": "7.19.0", 155 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz", 156 | "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==", 157 | "dev": true, 158 | "dependencies": { 159 | "@babel/template": "^7.18.10", 160 | "@babel/types": "^7.19.0" 161 | }, 162 | "engines": { 163 | "node": ">=6.9.0" 164 | } 165 | }, 166 | "node_modules/@babel/helper-hoist-variables": { 167 | "version": "7.18.6", 168 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", 169 | "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", 170 | "dev": true, 171 | "dependencies": { 172 | "@babel/types": "^7.18.6" 173 | }, 174 | "engines": { 175 | "node": ">=6.9.0" 176 | } 177 | }, 178 | "node_modules/@babel/helper-module-imports": { 179 | "version": "7.18.6", 180 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", 181 | "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", 182 | "dev": true, 183 | "dependencies": { 184 | "@babel/types": "^7.18.6" 185 | }, 186 | "engines": { 187 | "node": ">=6.9.0" 188 | } 189 | }, 190 | "node_modules/@babel/helper-module-transforms": { 191 | "version": "7.19.0", 192 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.19.0.tgz", 193 | "integrity": "sha512-3HBZ377Fe14RbLIA+ac3sY4PTgpxHVkFrESaWhoI5PuyXPBBX8+C34qblV9G89ZtycGJCmCI/Ut+VUDK4bltNQ==", 194 | "dev": true, 195 | "dependencies": { 196 | "@babel/helper-environment-visitor": "^7.18.9", 197 | "@babel/helper-module-imports": "^7.18.6", 198 | "@babel/helper-simple-access": "^7.18.6", 199 | "@babel/helper-split-export-declaration": "^7.18.6", 200 | "@babel/helper-validator-identifier": "^7.18.6", 201 | "@babel/template": "^7.18.10", 202 | "@babel/traverse": "^7.19.0", 203 | "@babel/types": "^7.19.0" 204 | }, 205 | "engines": { 206 | "node": ">=6.9.0" 207 | } 208 | }, 209 | "node_modules/@babel/helper-plugin-utils": { 210 | "version": "7.19.0", 211 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.19.0.tgz", 212 | "integrity": "sha512-40Ryx7I8mT+0gaNxm8JGTZFUITNqdLAgdg0hXzeVZxVD6nFsdhQvip6v8dqkRHzsz1VFpFAaOCHNn0vKBL7Czw==", 213 | "dev": true, 214 | "engines": { 215 | "node": ">=6.9.0" 216 | } 217 | }, 218 | "node_modules/@babel/helper-simple-access": { 219 | "version": "7.18.6", 220 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz", 221 | "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==", 222 | "dev": true, 223 | "dependencies": { 224 | "@babel/types": "^7.18.6" 225 | }, 226 | "engines": { 227 | "node": ">=6.9.0" 228 | } 229 | }, 230 | "node_modules/@babel/helper-split-export-declaration": { 231 | "version": "7.18.6", 232 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", 233 | "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", 234 | "dev": true, 235 | "dependencies": { 236 | "@babel/types": "^7.18.6" 237 | }, 238 | "engines": { 239 | "node": ">=6.9.0" 240 | } 241 | }, 242 | "node_modules/@babel/helper-string-parser": { 243 | "version": "7.18.10", 244 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.18.10.tgz", 245 | "integrity": "sha512-XtIfWmeNY3i4t7t4D2t02q50HvqHybPqW2ki1kosnvWCwuCMeo81Jf0gwr85jy/neUdg5XDdeFE/80DXiO+njw==", 246 | "dev": true, 247 | "engines": { 248 | "node": ">=6.9.0" 249 | } 250 | }, 251 | "node_modules/@babel/helper-validator-identifier": { 252 | "version": "7.19.1", 253 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 254 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 255 | "dev": true, 256 | "engines": { 257 | "node": ">=6.9.0" 258 | } 259 | }, 260 | "node_modules/@babel/helper-validator-option": { 261 | "version": "7.18.6", 262 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", 263 | "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", 264 | "dev": true, 265 | "engines": { 266 | "node": ">=6.9.0" 267 | } 268 | }, 269 | "node_modules/@babel/helpers": { 270 | "version": "7.19.0", 271 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.19.0.tgz", 272 | "integrity": "sha512-DRBCKGwIEdqY3+rPJgG/dKfQy9+08rHIAJx8q2p+HSWP87s2HCrQmaAMMyMll2kIXKCW0cO1RdQskx15Xakftg==", 273 | "dev": true, 274 | "dependencies": { 275 | "@babel/template": "^7.18.10", 276 | "@babel/traverse": "^7.19.0", 277 | "@babel/types": "^7.19.0" 278 | }, 279 | "engines": { 280 | "node": ">=6.9.0" 281 | } 282 | }, 283 | "node_modules/@babel/highlight": { 284 | "version": "7.18.6", 285 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 286 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 287 | "dev": true, 288 | "dependencies": { 289 | "@babel/helper-validator-identifier": "^7.18.6", 290 | "chalk": "^2.0.0", 291 | "js-tokens": "^4.0.0" 292 | }, 293 | "engines": { 294 | "node": ">=6.9.0" 295 | } 296 | }, 297 | "node_modules/@babel/parser": { 298 | "version": "7.19.1", 299 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.19.1.tgz", 300 | "integrity": "sha512-h7RCSorm1DdTVGJf3P2Mhj3kdnkmF/EiysUkzS2TdgAYqyjFdMQJbVuXOBej2SBJaXan/lIVtT6KkGbyyq753A==", 301 | "dev": true, 302 | "bin": { 303 | "parser": "bin/babel-parser.js" 304 | }, 305 | "engines": { 306 | "node": ">=6.0.0" 307 | } 308 | }, 309 | "node_modules/@babel/plugin-syntax-jsx": { 310 | "version": "7.18.6", 311 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz", 312 | "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==", 313 | "dev": true, 314 | "dependencies": { 315 | "@babel/helper-plugin-utils": "^7.18.6" 316 | }, 317 | "engines": { 318 | "node": ">=6.9.0" 319 | }, 320 | "peerDependencies": { 321 | "@babel/core": "^7.0.0-0" 322 | } 323 | }, 324 | "node_modules/@babel/plugin-transform-react-jsx": { 325 | "version": "7.19.0", 326 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.19.0.tgz", 327 | "integrity": "sha512-UVEvX3tXie3Szm3emi1+G63jyw1w5IcMY0FSKM+CRnKRI5Mr1YbCNgsSTwoTwKphQEG9P+QqmuRFneJPZuHNhg==", 328 | "dev": true, 329 | "dependencies": { 330 | "@babel/helper-annotate-as-pure": "^7.18.6", 331 | "@babel/helper-module-imports": "^7.18.6", 332 | "@babel/helper-plugin-utils": "^7.19.0", 333 | "@babel/plugin-syntax-jsx": "^7.18.6", 334 | "@babel/types": "^7.19.0" 335 | }, 336 | "engines": { 337 | "node": ">=6.9.0" 338 | }, 339 | "peerDependencies": { 340 | "@babel/core": "^7.0.0-0" 341 | } 342 | }, 343 | "node_modules/@babel/plugin-transform-react-jsx-development": { 344 | "version": "7.18.6", 345 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.18.6.tgz", 346 | "integrity": "sha512-SA6HEjwYFKF7WDjWcMcMGUimmw/nhNRDWxr+KaLSCrkD/LMDBvWRmHAYgE1HDeF8KUuI8OAu+RT6EOtKxSW2qA==", 347 | "dev": true, 348 | "dependencies": { 349 | "@babel/plugin-transform-react-jsx": "^7.18.6" 350 | }, 351 | "engines": { 352 | "node": ">=6.9.0" 353 | }, 354 | "peerDependencies": { 355 | "@babel/core": "^7.0.0-0" 356 | } 357 | }, 358 | "node_modules/@babel/plugin-transform-react-jsx-self": { 359 | "version": "7.18.6", 360 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.18.6.tgz", 361 | "integrity": "sha512-A0LQGx4+4Jv7u/tWzoJF7alZwnBDQd6cGLh9P+Ttk4dpiL+J5p7NSNv/9tlEFFJDq3kjxOavWmbm6t0Gk+A3Ig==", 362 | "dev": true, 363 | "dependencies": { 364 | "@babel/helper-plugin-utils": "^7.18.6" 365 | }, 366 | "engines": { 367 | "node": ">=6.9.0" 368 | }, 369 | "peerDependencies": { 370 | "@babel/core": "^7.0.0-0" 371 | } 372 | }, 373 | "node_modules/@babel/plugin-transform-react-jsx-source": { 374 | "version": "7.18.6", 375 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.18.6.tgz", 376 | "integrity": "sha512-utZmlASneDfdaMh0m/WausbjUjEdGrQJz0vFK93d7wD3xf5wBtX219+q6IlCNZeguIcxS2f/CvLZrlLSvSHQXw==", 377 | "dev": true, 378 | "dependencies": { 379 | "@babel/helper-plugin-utils": "^7.18.6" 380 | }, 381 | "engines": { 382 | "node": ">=6.9.0" 383 | }, 384 | "peerDependencies": { 385 | "@babel/core": "^7.0.0-0" 386 | } 387 | }, 388 | "node_modules/@babel/runtime": { 389 | "version": "7.19.0", 390 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.19.0.tgz", 391 | "integrity": "sha512-eR8Lo9hnDS7tqkO7NsV+mKvCmv5boaXFSZ70DnfhcgiEne8hv9oCEd36Klw74EtizEqLsy4YnW8UWwpBVolHZA==", 392 | "dependencies": { 393 | "regenerator-runtime": "^0.13.4" 394 | }, 395 | "engines": { 396 | "node": ">=6.9.0" 397 | } 398 | }, 399 | "node_modules/@babel/template": { 400 | "version": "7.18.10", 401 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.10.tgz", 402 | "integrity": "sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA==", 403 | "dev": true, 404 | "dependencies": { 405 | "@babel/code-frame": "^7.18.6", 406 | "@babel/parser": "^7.18.10", 407 | "@babel/types": "^7.18.10" 408 | }, 409 | "engines": { 410 | "node": ">=6.9.0" 411 | } 412 | }, 413 | "node_modules/@babel/traverse": { 414 | "version": "7.19.1", 415 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.19.1.tgz", 416 | "integrity": "sha512-0j/ZfZMxKukDaag2PtOPDbwuELqIar6lLskVPPJDjXMXjfLb1Obo/1yjxIGqqAJrmfaTIY3z2wFLAQ7qSkLsuA==", 417 | "dev": true, 418 | "dependencies": { 419 | "@babel/code-frame": "^7.18.6", 420 | "@babel/generator": "^7.19.0", 421 | "@babel/helper-environment-visitor": "^7.18.9", 422 | "@babel/helper-function-name": "^7.19.0", 423 | "@babel/helper-hoist-variables": "^7.18.6", 424 | "@babel/helper-split-export-declaration": "^7.18.6", 425 | "@babel/parser": "^7.19.1", 426 | "@babel/types": "^7.19.0", 427 | "debug": "^4.1.0", 428 | "globals": "^11.1.0" 429 | }, 430 | "engines": { 431 | "node": ">=6.9.0" 432 | } 433 | }, 434 | "node_modules/@babel/types": { 435 | "version": "7.19.0", 436 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.19.0.tgz", 437 | "integrity": "sha512-YuGopBq3ke25BVSiS6fgF49Ul9gH1x70Bcr6bqRLjWCkcX8Hre1/5+z+IiWOIerRMSSEfGZVB9z9kyq7wVs9YA==", 438 | "dev": true, 439 | "dependencies": { 440 | "@babel/helper-string-parser": "^7.18.10", 441 | "@babel/helper-validator-identifier": "^7.18.6", 442 | "to-fast-properties": "^2.0.0" 443 | }, 444 | "engines": { 445 | "node": ">=6.9.0" 446 | } 447 | }, 448 | "node_modules/@esbuild/android-arm": { 449 | "version": "0.15.8", 450 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.15.8.tgz", 451 | "integrity": "sha512-CyEWALmn+no/lbgbAJsbuuhT8s2J19EJGHkeyAwjbFJMrj80KJ9zuYsoAvidPTU7BgBf87r/sgae8Tw0dbOc4Q==", 452 | "cpu": [ 453 | "arm" 454 | ], 455 | "dev": true, 456 | "optional": true, 457 | "os": [ 458 | "android" 459 | ], 460 | "dependencies": { 461 | "esbuild-wasm": "0.15.8" 462 | }, 463 | "engines": { 464 | "node": ">=12" 465 | } 466 | }, 467 | "node_modules/@esbuild/linux-loong64": { 468 | "version": "0.15.8", 469 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.15.8.tgz", 470 | "integrity": "sha512-pE5RQsOTSERCtfZdfCT25wzo7dfhOSlhAXcsZmuvRYhendOv7djcdvtINdnDp2DAjP17WXlBB4nBO6sHLczmsg==", 471 | "cpu": [ 472 | "loong64" 473 | ], 474 | "dev": true, 475 | "optional": true, 476 | "os": [ 477 | "linux" 478 | ], 479 | "engines": { 480 | "node": ">=12" 481 | } 482 | }, 483 | "node_modules/@jridgewell/gen-mapping": { 484 | "version": "0.1.1", 485 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", 486 | "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", 487 | "dev": true, 488 | "dependencies": { 489 | "@jridgewell/set-array": "^1.0.0", 490 | "@jridgewell/sourcemap-codec": "^1.4.10" 491 | }, 492 | "engines": { 493 | "node": ">=6.0.0" 494 | } 495 | }, 496 | "node_modules/@jridgewell/resolve-uri": { 497 | "version": "3.1.0", 498 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 499 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 500 | "dev": true, 501 | "engines": { 502 | "node": ">=6.0.0" 503 | } 504 | }, 505 | "node_modules/@jridgewell/set-array": { 506 | "version": "1.1.2", 507 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 508 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 509 | "dev": true, 510 | "engines": { 511 | "node": ">=6.0.0" 512 | } 513 | }, 514 | "node_modules/@jridgewell/sourcemap-codec": { 515 | "version": "1.4.14", 516 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 517 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 518 | "dev": true 519 | }, 520 | "node_modules/@jridgewell/trace-mapping": { 521 | "version": "0.3.15", 522 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.15.tgz", 523 | "integrity": "sha512-oWZNOULl+UbhsgB51uuZzglikfIKSUBO/M9W2OfEjn7cmqoAiCgmv9lyACTUacZwBz0ITnJ2NqjU8Tx0DHL88g==", 524 | "dev": true, 525 | "dependencies": { 526 | "@jridgewell/resolve-uri": "^3.0.3", 527 | "@jridgewell/sourcemap-codec": "^1.4.10" 528 | } 529 | }, 530 | "node_modules/@types/prop-types": { 531 | "version": "15.7.5", 532 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", 533 | "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", 534 | "dev": true 535 | }, 536 | "node_modules/@types/react": { 537 | "version": "18.0.20", 538 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.0.20.tgz", 539 | "integrity": "sha512-MWul1teSPxujEHVwZl4a5HxQ9vVNsjTchVA+xRqv/VYGCuKGAU6UhfrTdF5aBefwD1BHUD8i/zq+O/vyCm/FrA==", 540 | "dev": true, 541 | "dependencies": { 542 | "@types/prop-types": "*", 543 | "@types/scheduler": "*", 544 | "csstype": "^3.0.2" 545 | } 546 | }, 547 | "node_modules/@types/react-dom": { 548 | "version": "18.0.6", 549 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.0.6.tgz", 550 | "integrity": "sha512-/5OFZgfIPSwy+YuIBP/FgJnQnsxhZhjjrnxudMddeblOouIodEQ75X14Rr4wGSG/bknL+Omy9iWlLo1u/9GzAA==", 551 | "dev": true, 552 | "dependencies": { 553 | "@types/react": "*" 554 | } 555 | }, 556 | "node_modules/@types/scheduler": { 557 | "version": "0.16.2", 558 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", 559 | "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", 560 | "dev": true 561 | }, 562 | "node_modules/@vitejs/plugin-react": { 563 | "version": "2.1.0", 564 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-2.1.0.tgz", 565 | "integrity": "sha512-am6rPyyU3LzUYne3Gd9oj9c4Rzbq5hQnuGXSMT6Gujq45Il/+bunwq3lrB7wghLkiF45ygMwft37vgJ/NE8IAA==", 566 | "dev": true, 567 | "dependencies": { 568 | "@babel/core": "^7.18.13", 569 | "@babel/plugin-transform-react-jsx": "^7.18.10", 570 | "@babel/plugin-transform-react-jsx-development": "^7.18.6", 571 | "@babel/plugin-transform-react-jsx-self": "^7.18.6", 572 | "@babel/plugin-transform-react-jsx-source": "^7.18.6", 573 | "magic-string": "^0.26.2", 574 | "react-refresh": "^0.14.0" 575 | }, 576 | "engines": { 577 | "node": "^14.18.0 || >=16.0.0" 578 | }, 579 | "peerDependencies": { 580 | "vite": "^3.0.0" 581 | } 582 | }, 583 | "node_modules/ansi-styles": { 584 | "version": "3.2.1", 585 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 586 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 587 | "dev": true, 588 | "dependencies": { 589 | "color-convert": "^1.9.0" 590 | }, 591 | "engines": { 592 | "node": ">=4" 593 | } 594 | }, 595 | "node_modules/browserslist": { 596 | "version": "4.21.4", 597 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.4.tgz", 598 | "integrity": "sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw==", 599 | "dev": true, 600 | "funding": [ 601 | { 602 | "type": "opencollective", 603 | "url": "https://opencollective.com/browserslist" 604 | }, 605 | { 606 | "type": "tidelift", 607 | "url": "https://tidelift.com/funding/github/npm/browserslist" 608 | } 609 | ], 610 | "dependencies": { 611 | "caniuse-lite": "^1.0.30001400", 612 | "electron-to-chromium": "^1.4.251", 613 | "node-releases": "^2.0.6", 614 | "update-browserslist-db": "^1.0.9" 615 | }, 616 | "bin": { 617 | "browserslist": "cli.js" 618 | }, 619 | "engines": { 620 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" 621 | } 622 | }, 623 | "node_modules/caniuse-lite": { 624 | "version": "1.0.30001409", 625 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001409.tgz", 626 | "integrity": "sha512-V0mnJ5dwarmhYv8/MzhJ//aW68UpvnQBXv8lJ2QUsvn2pHcmAuNtu8hQEDz37XnA1iE+lRR9CIfGWWpgJ5QedQ==", 627 | "dev": true, 628 | "funding": [ 629 | { 630 | "type": "opencollective", 631 | "url": "https://opencollective.com/browserslist" 632 | }, 633 | { 634 | "type": "tidelift", 635 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite" 636 | } 637 | ] 638 | }, 639 | "node_modules/chalk": { 640 | "version": "2.4.2", 641 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 642 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 643 | "dev": true, 644 | "dependencies": { 645 | "ansi-styles": "^3.2.1", 646 | "escape-string-regexp": "^1.0.5", 647 | "supports-color": "^5.3.0" 648 | }, 649 | "engines": { 650 | "node": ">=4" 651 | } 652 | }, 653 | "node_modules/color-convert": { 654 | "version": "1.9.3", 655 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 656 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 657 | "dev": true, 658 | "dependencies": { 659 | "color-name": "1.1.3" 660 | } 661 | }, 662 | "node_modules/color-name": { 663 | "version": "1.1.3", 664 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 665 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 666 | "dev": true 667 | }, 668 | "node_modules/convert-source-map": { 669 | "version": "1.8.0", 670 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", 671 | "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", 672 | "dev": true, 673 | "dependencies": { 674 | "safe-buffer": "~5.1.1" 675 | } 676 | }, 677 | "node_modules/csstype": { 678 | "version": "3.1.1", 679 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", 680 | "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==", 681 | "dev": true 682 | }, 683 | "node_modules/debug": { 684 | "version": "4.3.4", 685 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 686 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 687 | "dev": true, 688 | "dependencies": { 689 | "ms": "2.1.2" 690 | }, 691 | "engines": { 692 | "node": ">=6.0" 693 | }, 694 | "peerDependenciesMeta": { 695 | "supports-color": { 696 | "optional": true 697 | } 698 | } 699 | }, 700 | "node_modules/electron-to-chromium": { 701 | "version": "1.4.256", 702 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.256.tgz", 703 | "integrity": "sha512-x+JnqyluoJv8I0U9gVe+Sk2st8vF0CzMt78SXxuoWCooLLY2k5VerIBdpvG7ql6GKI4dzNnPjmqgDJ76EdaAKw==", 704 | "dev": true 705 | }, 706 | "node_modules/esbuild": { 707 | "version": "0.15.8", 708 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.15.8.tgz", 709 | "integrity": "sha512-Remsk2dmr1Ia65sU+QasE6svJbsHe62lzR+CnjpUvbZ+uSYo1SitiOWPRfZQkCu82YWZBBKXiD/j0i//XWMZ+Q==", 710 | "dev": true, 711 | "hasInstallScript": true, 712 | "bin": { 713 | "esbuild": "bin/esbuild" 714 | }, 715 | "engines": { 716 | "node": ">=12" 717 | }, 718 | "optionalDependencies": { 719 | "@esbuild/android-arm": "0.15.8", 720 | "@esbuild/linux-loong64": "0.15.8", 721 | "esbuild-android-64": "0.15.8", 722 | "esbuild-android-arm64": "0.15.8", 723 | "esbuild-darwin-64": "0.15.8", 724 | "esbuild-darwin-arm64": "0.15.8", 725 | "esbuild-freebsd-64": "0.15.8", 726 | "esbuild-freebsd-arm64": "0.15.8", 727 | "esbuild-linux-32": "0.15.8", 728 | "esbuild-linux-64": "0.15.8", 729 | "esbuild-linux-arm": "0.15.8", 730 | "esbuild-linux-arm64": "0.15.8", 731 | "esbuild-linux-mips64le": "0.15.8", 732 | "esbuild-linux-ppc64le": "0.15.8", 733 | "esbuild-linux-riscv64": "0.15.8", 734 | "esbuild-linux-s390x": "0.15.8", 735 | "esbuild-netbsd-64": "0.15.8", 736 | "esbuild-openbsd-64": "0.15.8", 737 | "esbuild-sunos-64": "0.15.8", 738 | "esbuild-windows-32": "0.15.8", 739 | "esbuild-windows-64": "0.15.8", 740 | "esbuild-windows-arm64": "0.15.8" 741 | } 742 | }, 743 | "node_modules/esbuild-android-64": { 744 | "version": "0.15.8", 745 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.15.8.tgz", 746 | "integrity": "sha512-bVh8FIKOolF7/d4AMzt7xHlL0Ljr+mYKSHI39TJWDkybVWHdn6+4ODL3xZGHOxPpdRpitemXA1WwMKYBsw8dGw==", 747 | "cpu": [ 748 | "x64" 749 | ], 750 | "dev": true, 751 | "optional": true, 752 | "os": [ 753 | "android" 754 | ], 755 | "dependencies": { 756 | "esbuild-wasm": "0.15.8" 757 | }, 758 | "engines": { 759 | "node": ">=12" 760 | } 761 | }, 762 | "node_modules/esbuild-android-arm64": { 763 | "version": "0.15.8", 764 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.15.8.tgz", 765 | "integrity": "sha512-ReAMDAHuo0H1h9LxRabI6gwYPn8k6WiUeyxuMvx17yTrJO+SCnIfNc/TSPFvDwtK9MiyiKG/2dBYHouT/M0BXQ==", 766 | "cpu": [ 767 | "arm64" 768 | ], 769 | "dev": true, 770 | "optional": true, 771 | "os": [ 772 | "android" 773 | ], 774 | "engines": { 775 | "node": ">=12" 776 | } 777 | }, 778 | "node_modules/esbuild-darwin-64": { 779 | "version": "0.15.8", 780 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.15.8.tgz", 781 | "integrity": "sha512-KaKcGfJ+yto7Fo5gAj3xwxHMd1fBIKatpCHK8znTJLVv+9+NN2/tIPBqA4w5rBwjX0UqXDeIE2v1xJP+nGEXgA==", 782 | "cpu": [ 783 | "x64" 784 | ], 785 | "dev": true, 786 | "optional": true, 787 | "os": [ 788 | "darwin" 789 | ], 790 | "engines": { 791 | "node": ">=12" 792 | } 793 | }, 794 | "node_modules/esbuild-darwin-arm64": { 795 | "version": "0.15.8", 796 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.15.8.tgz", 797 | "integrity": "sha512-8tjEaBgAKnXCkP7bhEJmEqdG9HEV6oLkF36BrMzpfW2rgaw0c48Zrxe+9RlfeGvs6gDF4w+agXyTjikzsS3izw==", 798 | "cpu": [ 799 | "arm64" 800 | ], 801 | "dev": true, 802 | "optional": true, 803 | "os": [ 804 | "darwin" 805 | ], 806 | "engines": { 807 | "node": ">=12" 808 | } 809 | }, 810 | "node_modules/esbuild-freebsd-64": { 811 | "version": "0.15.8", 812 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.15.8.tgz", 813 | "integrity": "sha512-jaxcsGHYzn2L0/lffON2WfH4Nc+d/EwozVTP5K2v016zxMb5UQMhLoJzvLgBqHT1SG0B/mO+a+THnJCMVg15zw==", 814 | "cpu": [ 815 | "x64" 816 | ], 817 | "dev": true, 818 | "optional": true, 819 | "os": [ 820 | "freebsd" 821 | ], 822 | "engines": { 823 | "node": ">=12" 824 | } 825 | }, 826 | "node_modules/esbuild-freebsd-arm64": { 827 | "version": "0.15.8", 828 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.15.8.tgz", 829 | "integrity": "sha512-2xp2UlljMvX8HExtcg7VHaeQk8OBU0CSl1j18B5CcZmSDkLF9p3utuMXIopG3a08fr9Hv+Dz6+seSXUow/G51w==", 830 | "cpu": [ 831 | "arm64" 832 | ], 833 | "dev": true, 834 | "optional": true, 835 | "os": [ 836 | "freebsd" 837 | ], 838 | "engines": { 839 | "node": ">=12" 840 | } 841 | }, 842 | "node_modules/esbuild-linux-32": { 843 | "version": "0.15.8", 844 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.15.8.tgz", 845 | "integrity": "sha512-9u1E54BRz1FQMl86iaHK146+4ID2KYNxL3trLZT4QLLx3M7Q9n4lGG3lrzqUatGR2cKy8c33b0iaCzsItZWkFg==", 846 | "cpu": [ 847 | "ia32" 848 | ], 849 | "dev": true, 850 | "optional": true, 851 | "os": [ 852 | "linux" 853 | ], 854 | "engines": { 855 | "node": ">=12" 856 | } 857 | }, 858 | "node_modules/esbuild-linux-64": { 859 | "version": "0.15.8", 860 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.15.8.tgz", 861 | "integrity": "sha512-4HxrsN9eUzJXdVGMTYA5Xler82FuZUu21bXKN42zcLHHNKCAMPUzD62I+GwDhsdgUBAUj0tRXDdsQHgaP6v0HA==", 862 | "cpu": [ 863 | "x64" 864 | ], 865 | "dev": true, 866 | "optional": true, 867 | "os": [ 868 | "linux" 869 | ], 870 | "engines": { 871 | "node": ">=12" 872 | } 873 | }, 874 | "node_modules/esbuild-linux-arm": { 875 | "version": "0.15.8", 876 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.15.8.tgz", 877 | "integrity": "sha512-7DVBU9SFjX4+vBwt8tHsUCbE6Vvl6y6FQWHAgyw1lybC5gULqn/WnjHYHN2/LJaZRsDBvxWT4msEgwLGq1Wd3Q==", 878 | "cpu": [ 879 | "arm" 880 | ], 881 | "dev": true, 882 | "optional": true, 883 | "os": [ 884 | "linux" 885 | ], 886 | "engines": { 887 | "node": ">=12" 888 | } 889 | }, 890 | "node_modules/esbuild-linux-arm64": { 891 | "version": "0.15.8", 892 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.15.8.tgz", 893 | "integrity": "sha512-1OCm7Aq0tEJT70PbxmHSGYDLYP8DKH8r4Nk7/XbVzWaduo9beCjGBB+tGZIHK6DdTQ3h00/4Tb/70YMH/bOtKg==", 894 | "cpu": [ 895 | "arm64" 896 | ], 897 | "dev": true, 898 | "optional": true, 899 | "os": [ 900 | "linux" 901 | ], 902 | "engines": { 903 | "node": ">=12" 904 | } 905 | }, 906 | "node_modules/esbuild-linux-mips64le": { 907 | "version": "0.15.8", 908 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.15.8.tgz", 909 | "integrity": "sha512-yeFoNPVFPEzZvFYBfUQNG2TjGRaCyV1E27OcOg4LOtnGrxb2wA+mkW3luckyv1CEyd00mpAg7UdHx8nlx3ghgA==", 910 | "cpu": [ 911 | "mips64el" 912 | ], 913 | "dev": true, 914 | "optional": true, 915 | "os": [ 916 | "linux" 917 | ], 918 | "engines": { 919 | "node": ">=12" 920 | } 921 | }, 922 | "node_modules/esbuild-linux-ppc64le": { 923 | "version": "0.15.8", 924 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.15.8.tgz", 925 | "integrity": "sha512-CEyMMUUNabXibw8OSNmBXhOIGhnjNVl5Lpseiuf00iKN0V47oqDrbo4dsHz1wH62m49AR8iG8wpDlTqfYgKbtg==", 926 | "cpu": [ 927 | "ppc64" 928 | ], 929 | "dev": true, 930 | "optional": true, 931 | "os": [ 932 | "linux" 933 | ], 934 | "engines": { 935 | "node": ">=12" 936 | } 937 | }, 938 | "node_modules/esbuild-linux-riscv64": { 939 | "version": "0.15.8", 940 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.15.8.tgz", 941 | "integrity": "sha512-OCGSOaspMUjexSCU8ZiA0UnV/NiRU+s2vIfEcAQWQ6u32R+2luyfh/4ZaY6jFbylJE07Esc/yRvb9Q5fXuClXA==", 942 | "cpu": [ 943 | "riscv64" 944 | ], 945 | "dev": true, 946 | "optional": true, 947 | "os": [ 948 | "linux" 949 | ], 950 | "engines": { 951 | "node": ">=12" 952 | } 953 | }, 954 | "node_modules/esbuild-linux-s390x": { 955 | "version": "0.15.8", 956 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.15.8.tgz", 957 | "integrity": "sha512-RHdpdfxRTSrZXZJlFSLazFU4YwXLB5Rgf6Zr5rffqSsO4y9JybgtKO38bFwxZNlDXliYISXN/YROKrG9s7mZQA==", 958 | "cpu": [ 959 | "s390x" 960 | ], 961 | "dev": true, 962 | "optional": true, 963 | "os": [ 964 | "linux" 965 | ], 966 | "engines": { 967 | "node": ">=12" 968 | } 969 | }, 970 | "node_modules/esbuild-netbsd-64": { 971 | "version": "0.15.8", 972 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.15.8.tgz", 973 | "integrity": "sha512-VolFFRatBH09T5QMWhiohAWCOien1R1Uz9K0BRVVTBgBaVBt7eArsXTKxVhUgRf2vwu2c2SXkuP0r7HLG0eozw==", 974 | "cpu": [ 975 | "x64" 976 | ], 977 | "dev": true, 978 | "optional": true, 979 | "os": [ 980 | "netbsd" 981 | ], 982 | "engines": { 983 | "node": ">=12" 984 | } 985 | }, 986 | "node_modules/esbuild-openbsd-64": { 987 | "version": "0.15.8", 988 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.15.8.tgz", 989 | "integrity": "sha512-HTAPlg+n4kUeE/isQxlCfsOz0xJGNoT5LJ9oYZWFKABfVf4Ycu7Zlf5ITgOnrdheTkz8JeL/gISIOCFAoOXrSA==", 990 | "cpu": [ 991 | "x64" 992 | ], 993 | "dev": true, 994 | "optional": true, 995 | "os": [ 996 | "openbsd" 997 | ], 998 | "engines": { 999 | "node": ">=12" 1000 | } 1001 | }, 1002 | "node_modules/esbuild-sunos-64": { 1003 | "version": "0.15.8", 1004 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.15.8.tgz", 1005 | "integrity": "sha512-qMP/jR/FzcIOwKj+W+Lb+8Cfr8GZHbHUJxAPi7DUhNZMQ/6y7sOgRzlOSpRrbbUntrRZh0MqOyDhJ3Gpo6L1QA==", 1006 | "cpu": [ 1007 | "x64" 1008 | ], 1009 | "dev": true, 1010 | "optional": true, 1011 | "os": [ 1012 | "sunos" 1013 | ], 1014 | "engines": { 1015 | "node": ">=12" 1016 | } 1017 | }, 1018 | "node_modules/esbuild-wasm": { 1019 | "version": "0.15.8", 1020 | "resolved": "https://registry.npmjs.org/esbuild-wasm/-/esbuild-wasm-0.15.8.tgz", 1021 | "integrity": "sha512-Y7uCl5RNO4URjlemjdx++ukVHEMt5s5AfMWYUnMiK4Sry+pPCvQIctzXq6r6FKCyGKjX6/NGMCqR2OX6aLxj0w==", 1022 | "dev": true, 1023 | "optional": true, 1024 | "bin": { 1025 | "esbuild": "bin/esbuild" 1026 | }, 1027 | "engines": { 1028 | "node": ">=12" 1029 | } 1030 | }, 1031 | "node_modules/esbuild-windows-32": { 1032 | "version": "0.15.8", 1033 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.15.8.tgz", 1034 | "integrity": "sha512-RKR1QHh4iWzjUhkP8Yqi75PPz/KS+b8zw3wUrzw6oAkj+iU5Qtyj61ZDaSG3Qf2vc6hTIUiPqVTqBH0NpXFNwg==", 1035 | "cpu": [ 1036 | "ia32" 1037 | ], 1038 | "dev": true, 1039 | "optional": true, 1040 | "os": [ 1041 | "win32" 1042 | ], 1043 | "engines": { 1044 | "node": ">=12" 1045 | } 1046 | }, 1047 | "node_modules/esbuild-windows-64": { 1048 | "version": "0.15.8", 1049 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.15.8.tgz", 1050 | "integrity": "sha512-ag9ptYrsizgsR+PQE8QKeMqnosLvAMonQREpLw4evA4FFgOBMLEat/dY/9txbpozTw9eEOYyD3a4cE9yTu20FA==", 1051 | "cpu": [ 1052 | "x64" 1053 | ], 1054 | "dev": true, 1055 | "optional": true, 1056 | "os": [ 1057 | "win32" 1058 | ], 1059 | "engines": { 1060 | "node": ">=12" 1061 | } 1062 | }, 1063 | "node_modules/esbuild-windows-arm64": { 1064 | "version": "0.15.8", 1065 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.15.8.tgz", 1066 | "integrity": "sha512-dbpAb0VyPaUs9mgw65KRfQ9rqiWCHpNzrJusoPu+LpEoswosjt/tFxN7cd2l68AT4qWdBkzAjDLRon7uqMeWcg==", 1067 | "cpu": [ 1068 | "arm64" 1069 | ], 1070 | "dev": true, 1071 | "optional": true, 1072 | "os": [ 1073 | "win32" 1074 | ], 1075 | "engines": { 1076 | "node": ">=12" 1077 | } 1078 | }, 1079 | "node_modules/escalade": { 1080 | "version": "3.1.1", 1081 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1082 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1083 | "dev": true, 1084 | "engines": { 1085 | "node": ">=6" 1086 | } 1087 | }, 1088 | "node_modules/escape-string-regexp": { 1089 | "version": "1.0.5", 1090 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1091 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 1092 | "dev": true, 1093 | "engines": { 1094 | "node": ">=0.8.0" 1095 | } 1096 | }, 1097 | "node_modules/fsevents": { 1098 | "version": "2.3.2", 1099 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1100 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1101 | "dev": true, 1102 | "hasInstallScript": true, 1103 | "optional": true, 1104 | "os": [ 1105 | "darwin" 1106 | ], 1107 | "engines": { 1108 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1109 | } 1110 | }, 1111 | "node_modules/function-bind": { 1112 | "version": "1.1.1", 1113 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1114 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1115 | "dev": true 1116 | }, 1117 | "node_modules/gensync": { 1118 | "version": "1.0.0-beta.2", 1119 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 1120 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 1121 | "dev": true, 1122 | "engines": { 1123 | "node": ">=6.9.0" 1124 | } 1125 | }, 1126 | "node_modules/globals": { 1127 | "version": "11.12.0", 1128 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1129 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1130 | "dev": true, 1131 | "engines": { 1132 | "node": ">=4" 1133 | } 1134 | }, 1135 | "node_modules/has": { 1136 | "version": "1.0.3", 1137 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1138 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1139 | "dev": true, 1140 | "dependencies": { 1141 | "function-bind": "^1.1.1" 1142 | }, 1143 | "engines": { 1144 | "node": ">= 0.4.0" 1145 | } 1146 | }, 1147 | "node_modules/has-flag": { 1148 | "version": "3.0.0", 1149 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1150 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 1151 | "dev": true, 1152 | "engines": { 1153 | "node": ">=4" 1154 | } 1155 | }, 1156 | "node_modules/history": { 1157 | "version": "5.3.0", 1158 | "resolved": "https://registry.npmjs.org/history/-/history-5.3.0.tgz", 1159 | "integrity": "sha512-ZqaKwjjrAYUYfLG+htGaIIZ4nioX2L70ZUMIFysS3xvBsSG4x/n1V6TXV3N8ZYNuFGlDirFg32T7B6WOUPDYcQ==", 1160 | "dependencies": { 1161 | "@babel/runtime": "^7.7.6" 1162 | } 1163 | }, 1164 | "node_modules/is-core-module": { 1165 | "version": "2.10.0", 1166 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.10.0.tgz", 1167 | "integrity": "sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==", 1168 | "dev": true, 1169 | "dependencies": { 1170 | "has": "^1.0.3" 1171 | }, 1172 | "funding": { 1173 | "url": "https://github.com/sponsors/ljharb" 1174 | } 1175 | }, 1176 | "node_modules/js-tokens": { 1177 | "version": "4.0.0", 1178 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1179 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 1180 | }, 1181 | "node_modules/jsesc": { 1182 | "version": "2.5.2", 1183 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1184 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1185 | "dev": true, 1186 | "bin": { 1187 | "jsesc": "bin/jsesc" 1188 | }, 1189 | "engines": { 1190 | "node": ">=4" 1191 | } 1192 | }, 1193 | "node_modules/json5": { 1194 | "version": "2.2.1", 1195 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz", 1196 | "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==", 1197 | "dev": true, 1198 | "bin": { 1199 | "json5": "lib/cli.js" 1200 | }, 1201 | "engines": { 1202 | "node": ">=6" 1203 | } 1204 | }, 1205 | "node_modules/loose-envify": { 1206 | "version": "1.4.0", 1207 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1208 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1209 | "dependencies": { 1210 | "js-tokens": "^3.0.0 || ^4.0.0" 1211 | }, 1212 | "bin": { 1213 | "loose-envify": "cli.js" 1214 | } 1215 | }, 1216 | "node_modules/magic-string": { 1217 | "version": "0.26.3", 1218 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.26.3.tgz", 1219 | "integrity": "sha512-u1Po0NDyFcwdg2nzHT88wSK0+Rih0N1M+Ph1Sp08k8yvFFU3KR72wryS7e1qMPJypt99WB7fIFVCA92mQrMjrg==", 1220 | "dev": true, 1221 | "dependencies": { 1222 | "sourcemap-codec": "^1.4.8" 1223 | }, 1224 | "engines": { 1225 | "node": ">=12" 1226 | } 1227 | }, 1228 | "node_modules/ms": { 1229 | "version": "2.1.2", 1230 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1231 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1232 | "dev": true 1233 | }, 1234 | "node_modules/nanoid": { 1235 | "version": "3.3.4", 1236 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz", 1237 | "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==", 1238 | "dev": true, 1239 | "bin": { 1240 | "nanoid": "bin/nanoid.cjs" 1241 | }, 1242 | "engines": { 1243 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1244 | } 1245 | }, 1246 | "node_modules/node-releases": { 1247 | "version": "2.0.6", 1248 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz", 1249 | "integrity": "sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg==", 1250 | "dev": true 1251 | }, 1252 | "node_modules/path-parse": { 1253 | "version": "1.0.7", 1254 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1255 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1256 | "dev": true 1257 | }, 1258 | "node_modules/picocolors": { 1259 | "version": "1.0.0", 1260 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1261 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 1262 | "dev": true 1263 | }, 1264 | "node_modules/postcss": { 1265 | "version": "8.4.16", 1266 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.16.tgz", 1267 | "integrity": "sha512-ipHE1XBvKzm5xI7hiHCZJCSugxvsdq2mPnsq5+UF+VHCjiBvtDrlxJfMBToWaP9D5XlgNmcFGqoHmUn0EYEaRQ==", 1268 | "dev": true, 1269 | "funding": [ 1270 | { 1271 | "type": "opencollective", 1272 | "url": "https://opencollective.com/postcss/" 1273 | }, 1274 | { 1275 | "type": "tidelift", 1276 | "url": "https://tidelift.com/funding/github/npm/postcss" 1277 | } 1278 | ], 1279 | "dependencies": { 1280 | "nanoid": "^3.3.4", 1281 | "picocolors": "^1.0.0", 1282 | "source-map-js": "^1.0.2" 1283 | }, 1284 | "engines": { 1285 | "node": "^10 || ^12 || >=14" 1286 | } 1287 | }, 1288 | "node_modules/react": { 1289 | "version": "18.2.0", 1290 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 1291 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 1292 | "dependencies": { 1293 | "loose-envify": "^1.1.0" 1294 | }, 1295 | "engines": { 1296 | "node": ">=0.10.0" 1297 | } 1298 | }, 1299 | "node_modules/react-dom": { 1300 | "version": "18.2.0", 1301 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 1302 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 1303 | "dependencies": { 1304 | "loose-envify": "^1.1.0", 1305 | "scheduler": "^0.23.0" 1306 | }, 1307 | "peerDependencies": { 1308 | "react": "^18.2.0" 1309 | } 1310 | }, 1311 | "node_modules/react-refresh": { 1312 | "version": "0.14.0", 1313 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 1314 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 1315 | "dev": true, 1316 | "engines": { 1317 | "node": ">=0.10.0" 1318 | } 1319 | }, 1320 | "node_modules/react-router": { 1321 | "version": "6.3.0", 1322 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.3.0.tgz", 1323 | "integrity": "sha512-7Wh1DzVQ+tlFjkeo+ujvjSqSJmkt1+8JO+T5xklPlgrh70y7ogx75ODRW0ThWhY7S+6yEDks8TYrtQe/aoboBQ==", 1324 | "dependencies": { 1325 | "history": "^5.2.0" 1326 | }, 1327 | "peerDependencies": { 1328 | "react": ">=16.8" 1329 | } 1330 | }, 1331 | "node_modules/react-router-dom": { 1332 | "version": "6.3.0", 1333 | "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.3.0.tgz", 1334 | "integrity": "sha512-uaJj7LKytRxZNQV8+RbzJWnJ8K2nPsOOEuX7aQstlMZKQT0164C+X2w6bnkqU3sjtLvpd5ojrezAyfZ1+0sStw==", 1335 | "dependencies": { 1336 | "history": "^5.2.0", 1337 | "react-router": "6.3.0" 1338 | }, 1339 | "peerDependencies": { 1340 | "react": ">=16.8", 1341 | "react-dom": ">=16.8" 1342 | } 1343 | }, 1344 | "node_modules/regenerator-runtime": { 1345 | "version": "0.13.9", 1346 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz", 1347 | "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==" 1348 | }, 1349 | "node_modules/resolve": { 1350 | "version": "1.22.1", 1351 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", 1352 | "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", 1353 | "dev": true, 1354 | "dependencies": { 1355 | "is-core-module": "^2.9.0", 1356 | "path-parse": "^1.0.7", 1357 | "supports-preserve-symlinks-flag": "^1.0.0" 1358 | }, 1359 | "bin": { 1360 | "resolve": "bin/resolve" 1361 | }, 1362 | "funding": { 1363 | "url": "https://github.com/sponsors/ljharb" 1364 | } 1365 | }, 1366 | "node_modules/rollup": { 1367 | "version": "2.78.1", 1368 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.78.1.tgz", 1369 | "integrity": "sha512-VeeCgtGi4P+o9hIg+xz4qQpRl6R401LWEXBmxYKOV4zlF82lyhgh2hTZnheFUbANE8l2A41F458iwj2vEYaXJg==", 1370 | "dev": true, 1371 | "bin": { 1372 | "rollup": "dist/bin/rollup" 1373 | }, 1374 | "engines": { 1375 | "node": ">=10.0.0" 1376 | }, 1377 | "optionalDependencies": { 1378 | "fsevents": "~2.3.2" 1379 | } 1380 | }, 1381 | "node_modules/safe-buffer": { 1382 | "version": "5.1.2", 1383 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1384 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1385 | "dev": true 1386 | }, 1387 | "node_modules/scheduler": { 1388 | "version": "0.23.0", 1389 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 1390 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 1391 | "dependencies": { 1392 | "loose-envify": "^1.1.0" 1393 | } 1394 | }, 1395 | "node_modules/semver": { 1396 | "version": "6.3.0", 1397 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1398 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1399 | "dev": true, 1400 | "bin": { 1401 | "semver": "bin/semver.js" 1402 | } 1403 | }, 1404 | "node_modules/source-map-js": { 1405 | "version": "1.0.2", 1406 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 1407 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 1408 | "dev": true, 1409 | "engines": { 1410 | "node": ">=0.10.0" 1411 | } 1412 | }, 1413 | "node_modules/sourcemap-codec": { 1414 | "version": "1.4.8", 1415 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 1416 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 1417 | "dev": true 1418 | }, 1419 | "node_modules/supports-color": { 1420 | "version": "5.5.0", 1421 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1422 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1423 | "dev": true, 1424 | "dependencies": { 1425 | "has-flag": "^3.0.0" 1426 | }, 1427 | "engines": { 1428 | "node": ">=4" 1429 | } 1430 | }, 1431 | "node_modules/supports-preserve-symlinks-flag": { 1432 | "version": "1.0.0", 1433 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1434 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1435 | "dev": true, 1436 | "engines": { 1437 | "node": ">= 0.4" 1438 | }, 1439 | "funding": { 1440 | "url": "https://github.com/sponsors/ljharb" 1441 | } 1442 | }, 1443 | "node_modules/to-fast-properties": { 1444 | "version": "2.0.0", 1445 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 1446 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 1447 | "dev": true, 1448 | "engines": { 1449 | "node": ">=4" 1450 | } 1451 | }, 1452 | "node_modules/update-browserslist-db": { 1453 | "version": "1.0.9", 1454 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.9.tgz", 1455 | "integrity": "sha512-/xsqn21EGVdXI3EXSum1Yckj3ZVZugqyOZQ/CxYPBD/R+ko9NSUScf8tFF4dOKY+2pvSSJA/S+5B8s4Zr4kyvg==", 1456 | "dev": true, 1457 | "funding": [ 1458 | { 1459 | "type": "opencollective", 1460 | "url": "https://opencollective.com/browserslist" 1461 | }, 1462 | { 1463 | "type": "tidelift", 1464 | "url": "https://tidelift.com/funding/github/npm/browserslist" 1465 | } 1466 | ], 1467 | "dependencies": { 1468 | "escalade": "^3.1.1", 1469 | "picocolors": "^1.0.0" 1470 | }, 1471 | "bin": { 1472 | "browserslist-lint": "cli.js" 1473 | }, 1474 | "peerDependencies": { 1475 | "browserslist": ">= 4.21.0" 1476 | } 1477 | }, 1478 | "node_modules/vite": { 1479 | "version": "3.1.3", 1480 | "resolved": "https://registry.npmjs.org/vite/-/vite-3.1.3.tgz", 1481 | "integrity": "sha512-/3XWiktaopByM5bd8dqvHxRt5EEgRikevnnrpND0gRfNkrMrPaGGexhtLCzv15RcCMtV2CLw+BPas8YFeSG0KA==", 1482 | "dev": true, 1483 | "dependencies": { 1484 | "esbuild": "^0.15.6", 1485 | "postcss": "^8.4.16", 1486 | "resolve": "^1.22.1", 1487 | "rollup": "~2.78.0" 1488 | }, 1489 | "bin": { 1490 | "vite": "bin/vite.js" 1491 | }, 1492 | "engines": { 1493 | "node": "^14.18.0 || >=16.0.0" 1494 | }, 1495 | "optionalDependencies": { 1496 | "fsevents": "~2.3.2" 1497 | }, 1498 | "peerDependencies": { 1499 | "less": "*", 1500 | "sass": "*", 1501 | "stylus": "*", 1502 | "terser": "^5.4.0" 1503 | }, 1504 | "peerDependenciesMeta": { 1505 | "less": { 1506 | "optional": true 1507 | }, 1508 | "sass": { 1509 | "optional": true 1510 | }, 1511 | "stylus": { 1512 | "optional": true 1513 | }, 1514 | "terser": { 1515 | "optional": true 1516 | } 1517 | } 1518 | } 1519 | }, 1520 | "dependencies": { 1521 | "@ampproject/remapping": { 1522 | "version": "2.2.0", 1523 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", 1524 | "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", 1525 | "dev": true, 1526 | "requires": { 1527 | "@jridgewell/gen-mapping": "^0.1.0", 1528 | "@jridgewell/trace-mapping": "^0.3.9" 1529 | } 1530 | }, 1531 | "@babel/code-frame": { 1532 | "version": "7.18.6", 1533 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", 1534 | "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", 1535 | "dev": true, 1536 | "requires": { 1537 | "@babel/highlight": "^7.18.6" 1538 | } 1539 | }, 1540 | "@babel/compat-data": { 1541 | "version": "7.19.1", 1542 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.19.1.tgz", 1543 | "integrity": "sha512-72a9ghR0gnESIa7jBN53U32FOVCEoztyIlKaNoU05zRhEecduGK9L9c3ww7Mp06JiR+0ls0GBPFJQwwtjn9ksg==", 1544 | "dev": true 1545 | }, 1546 | "@babel/core": { 1547 | "version": "7.19.1", 1548 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.19.1.tgz", 1549 | "integrity": "sha512-1H8VgqXme4UXCRv7/Wa1bq7RVymKOzC7znjyFM8KiEzwFqcKUKYNoQef4GhdklgNvoBXyW4gYhuBNCM5o1zImw==", 1550 | "dev": true, 1551 | "requires": { 1552 | "@ampproject/remapping": "^2.1.0", 1553 | "@babel/code-frame": "^7.18.6", 1554 | "@babel/generator": "^7.19.0", 1555 | "@babel/helper-compilation-targets": "^7.19.1", 1556 | "@babel/helper-module-transforms": "^7.19.0", 1557 | "@babel/helpers": "^7.19.0", 1558 | "@babel/parser": "^7.19.1", 1559 | "@babel/template": "^7.18.10", 1560 | "@babel/traverse": "^7.19.1", 1561 | "@babel/types": "^7.19.0", 1562 | "convert-source-map": "^1.7.0", 1563 | "debug": "^4.1.0", 1564 | "gensync": "^1.0.0-beta.2", 1565 | "json5": "^2.2.1", 1566 | "semver": "^6.3.0" 1567 | } 1568 | }, 1569 | "@babel/generator": { 1570 | "version": "7.19.0", 1571 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.19.0.tgz", 1572 | "integrity": "sha512-S1ahxf1gZ2dpoiFgA+ohK9DIpz50bJ0CWs7Zlzb54Z4sG8qmdIrGrVqmy1sAtTVRb+9CU6U8VqT9L0Zj7hxHVg==", 1573 | "dev": true, 1574 | "requires": { 1575 | "@babel/types": "^7.19.0", 1576 | "@jridgewell/gen-mapping": "^0.3.2", 1577 | "jsesc": "^2.5.1" 1578 | }, 1579 | "dependencies": { 1580 | "@jridgewell/gen-mapping": { 1581 | "version": "0.3.2", 1582 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", 1583 | "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", 1584 | "dev": true, 1585 | "requires": { 1586 | "@jridgewell/set-array": "^1.0.1", 1587 | "@jridgewell/sourcemap-codec": "^1.4.10", 1588 | "@jridgewell/trace-mapping": "^0.3.9" 1589 | } 1590 | } 1591 | } 1592 | }, 1593 | "@babel/helper-annotate-as-pure": { 1594 | "version": "7.18.6", 1595 | "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", 1596 | "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", 1597 | "dev": true, 1598 | "requires": { 1599 | "@babel/types": "^7.18.6" 1600 | } 1601 | }, 1602 | "@babel/helper-compilation-targets": { 1603 | "version": "7.19.1", 1604 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.19.1.tgz", 1605 | "integrity": "sha512-LlLkkqhCMyz2lkQPvJNdIYU7O5YjWRgC2R4omjCTpZd8u8KMQzZvX4qce+/BluN1rcQiV7BoGUpmQ0LeHerbhg==", 1606 | "dev": true, 1607 | "requires": { 1608 | "@babel/compat-data": "^7.19.1", 1609 | "@babel/helper-validator-option": "^7.18.6", 1610 | "browserslist": "^4.21.3", 1611 | "semver": "^6.3.0" 1612 | } 1613 | }, 1614 | "@babel/helper-environment-visitor": { 1615 | "version": "7.18.9", 1616 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", 1617 | "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", 1618 | "dev": true 1619 | }, 1620 | "@babel/helper-function-name": { 1621 | "version": "7.19.0", 1622 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz", 1623 | "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==", 1624 | "dev": true, 1625 | "requires": { 1626 | "@babel/template": "^7.18.10", 1627 | "@babel/types": "^7.19.0" 1628 | } 1629 | }, 1630 | "@babel/helper-hoist-variables": { 1631 | "version": "7.18.6", 1632 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", 1633 | "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", 1634 | "dev": true, 1635 | "requires": { 1636 | "@babel/types": "^7.18.6" 1637 | } 1638 | }, 1639 | "@babel/helper-module-imports": { 1640 | "version": "7.18.6", 1641 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", 1642 | "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", 1643 | "dev": true, 1644 | "requires": { 1645 | "@babel/types": "^7.18.6" 1646 | } 1647 | }, 1648 | "@babel/helper-module-transforms": { 1649 | "version": "7.19.0", 1650 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.19.0.tgz", 1651 | "integrity": "sha512-3HBZ377Fe14RbLIA+ac3sY4PTgpxHVkFrESaWhoI5PuyXPBBX8+C34qblV9G89ZtycGJCmCI/Ut+VUDK4bltNQ==", 1652 | "dev": true, 1653 | "requires": { 1654 | "@babel/helper-environment-visitor": "^7.18.9", 1655 | "@babel/helper-module-imports": "^7.18.6", 1656 | "@babel/helper-simple-access": "^7.18.6", 1657 | "@babel/helper-split-export-declaration": "^7.18.6", 1658 | "@babel/helper-validator-identifier": "^7.18.6", 1659 | "@babel/template": "^7.18.10", 1660 | "@babel/traverse": "^7.19.0", 1661 | "@babel/types": "^7.19.0" 1662 | } 1663 | }, 1664 | "@babel/helper-plugin-utils": { 1665 | "version": "7.19.0", 1666 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.19.0.tgz", 1667 | "integrity": "sha512-40Ryx7I8mT+0gaNxm8JGTZFUITNqdLAgdg0hXzeVZxVD6nFsdhQvip6v8dqkRHzsz1VFpFAaOCHNn0vKBL7Czw==", 1668 | "dev": true 1669 | }, 1670 | "@babel/helper-simple-access": { 1671 | "version": "7.18.6", 1672 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz", 1673 | "integrity": "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==", 1674 | "dev": true, 1675 | "requires": { 1676 | "@babel/types": "^7.18.6" 1677 | } 1678 | }, 1679 | "@babel/helper-split-export-declaration": { 1680 | "version": "7.18.6", 1681 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", 1682 | "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", 1683 | "dev": true, 1684 | "requires": { 1685 | "@babel/types": "^7.18.6" 1686 | } 1687 | }, 1688 | "@babel/helper-string-parser": { 1689 | "version": "7.18.10", 1690 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.18.10.tgz", 1691 | "integrity": "sha512-XtIfWmeNY3i4t7t4D2t02q50HvqHybPqW2ki1kosnvWCwuCMeo81Jf0gwr85jy/neUdg5XDdeFE/80DXiO+njw==", 1692 | "dev": true 1693 | }, 1694 | "@babel/helper-validator-identifier": { 1695 | "version": "7.19.1", 1696 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", 1697 | "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", 1698 | "dev": true 1699 | }, 1700 | "@babel/helper-validator-option": { 1701 | "version": "7.18.6", 1702 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", 1703 | "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", 1704 | "dev": true 1705 | }, 1706 | "@babel/helpers": { 1707 | "version": "7.19.0", 1708 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.19.0.tgz", 1709 | "integrity": "sha512-DRBCKGwIEdqY3+rPJgG/dKfQy9+08rHIAJx8q2p+HSWP87s2HCrQmaAMMyMll2kIXKCW0cO1RdQskx15Xakftg==", 1710 | "dev": true, 1711 | "requires": { 1712 | "@babel/template": "^7.18.10", 1713 | "@babel/traverse": "^7.19.0", 1714 | "@babel/types": "^7.19.0" 1715 | } 1716 | }, 1717 | "@babel/highlight": { 1718 | "version": "7.18.6", 1719 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", 1720 | "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", 1721 | "dev": true, 1722 | "requires": { 1723 | "@babel/helper-validator-identifier": "^7.18.6", 1724 | "chalk": "^2.0.0", 1725 | "js-tokens": "^4.0.0" 1726 | } 1727 | }, 1728 | "@babel/parser": { 1729 | "version": "7.19.1", 1730 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.19.1.tgz", 1731 | "integrity": "sha512-h7RCSorm1DdTVGJf3P2Mhj3kdnkmF/EiysUkzS2TdgAYqyjFdMQJbVuXOBej2SBJaXan/lIVtT6KkGbyyq753A==", 1732 | "dev": true 1733 | }, 1734 | "@babel/plugin-syntax-jsx": { 1735 | "version": "7.18.6", 1736 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz", 1737 | "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==", 1738 | "dev": true, 1739 | "requires": { 1740 | "@babel/helper-plugin-utils": "^7.18.6" 1741 | } 1742 | }, 1743 | "@babel/plugin-transform-react-jsx": { 1744 | "version": "7.19.0", 1745 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.19.0.tgz", 1746 | "integrity": "sha512-UVEvX3tXie3Szm3emi1+G63jyw1w5IcMY0FSKM+CRnKRI5Mr1YbCNgsSTwoTwKphQEG9P+QqmuRFneJPZuHNhg==", 1747 | "dev": true, 1748 | "requires": { 1749 | "@babel/helper-annotate-as-pure": "^7.18.6", 1750 | "@babel/helper-module-imports": "^7.18.6", 1751 | "@babel/helper-plugin-utils": "^7.19.0", 1752 | "@babel/plugin-syntax-jsx": "^7.18.6", 1753 | "@babel/types": "^7.19.0" 1754 | } 1755 | }, 1756 | "@babel/plugin-transform-react-jsx-development": { 1757 | "version": "7.18.6", 1758 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.18.6.tgz", 1759 | "integrity": "sha512-SA6HEjwYFKF7WDjWcMcMGUimmw/nhNRDWxr+KaLSCrkD/LMDBvWRmHAYgE1HDeF8KUuI8OAu+RT6EOtKxSW2qA==", 1760 | "dev": true, 1761 | "requires": { 1762 | "@babel/plugin-transform-react-jsx": "^7.18.6" 1763 | } 1764 | }, 1765 | "@babel/plugin-transform-react-jsx-self": { 1766 | "version": "7.18.6", 1767 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.18.6.tgz", 1768 | "integrity": "sha512-A0LQGx4+4Jv7u/tWzoJF7alZwnBDQd6cGLh9P+Ttk4dpiL+J5p7NSNv/9tlEFFJDq3kjxOavWmbm6t0Gk+A3Ig==", 1769 | "dev": true, 1770 | "requires": { 1771 | "@babel/helper-plugin-utils": "^7.18.6" 1772 | } 1773 | }, 1774 | "@babel/plugin-transform-react-jsx-source": { 1775 | "version": "7.18.6", 1776 | "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.18.6.tgz", 1777 | "integrity": "sha512-utZmlASneDfdaMh0m/WausbjUjEdGrQJz0vFK93d7wD3xf5wBtX219+q6IlCNZeguIcxS2f/CvLZrlLSvSHQXw==", 1778 | "dev": true, 1779 | "requires": { 1780 | "@babel/helper-plugin-utils": "^7.18.6" 1781 | } 1782 | }, 1783 | "@babel/runtime": { 1784 | "version": "7.19.0", 1785 | "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.19.0.tgz", 1786 | "integrity": "sha512-eR8Lo9hnDS7tqkO7NsV+mKvCmv5boaXFSZ70DnfhcgiEne8hv9oCEd36Klw74EtizEqLsy4YnW8UWwpBVolHZA==", 1787 | "requires": { 1788 | "regenerator-runtime": "^0.13.4" 1789 | } 1790 | }, 1791 | "@babel/template": { 1792 | "version": "7.18.10", 1793 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.10.tgz", 1794 | "integrity": "sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA==", 1795 | "dev": true, 1796 | "requires": { 1797 | "@babel/code-frame": "^7.18.6", 1798 | "@babel/parser": "^7.18.10", 1799 | "@babel/types": "^7.18.10" 1800 | } 1801 | }, 1802 | "@babel/traverse": { 1803 | "version": "7.19.1", 1804 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.19.1.tgz", 1805 | "integrity": "sha512-0j/ZfZMxKukDaag2PtOPDbwuELqIar6lLskVPPJDjXMXjfLb1Obo/1yjxIGqqAJrmfaTIY3z2wFLAQ7qSkLsuA==", 1806 | "dev": true, 1807 | "requires": { 1808 | "@babel/code-frame": "^7.18.6", 1809 | "@babel/generator": "^7.19.0", 1810 | "@babel/helper-environment-visitor": "^7.18.9", 1811 | "@babel/helper-function-name": "^7.19.0", 1812 | "@babel/helper-hoist-variables": "^7.18.6", 1813 | "@babel/helper-split-export-declaration": "^7.18.6", 1814 | "@babel/parser": "^7.19.1", 1815 | "@babel/types": "^7.19.0", 1816 | "debug": "^4.1.0", 1817 | "globals": "^11.1.0" 1818 | } 1819 | }, 1820 | "@babel/types": { 1821 | "version": "7.19.0", 1822 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.19.0.tgz", 1823 | "integrity": "sha512-YuGopBq3ke25BVSiS6fgF49Ul9gH1x70Bcr6bqRLjWCkcX8Hre1/5+z+IiWOIerRMSSEfGZVB9z9kyq7wVs9YA==", 1824 | "dev": true, 1825 | "requires": { 1826 | "@babel/helper-string-parser": "^7.18.10", 1827 | "@babel/helper-validator-identifier": "^7.18.6", 1828 | "to-fast-properties": "^2.0.0" 1829 | } 1830 | }, 1831 | "@esbuild/android-arm": { 1832 | "version": "0.15.8", 1833 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.15.8.tgz", 1834 | "integrity": "sha512-CyEWALmn+no/lbgbAJsbuuhT8s2J19EJGHkeyAwjbFJMrj80KJ9zuYsoAvidPTU7BgBf87r/sgae8Tw0dbOc4Q==", 1835 | "dev": true, 1836 | "optional": true, 1837 | "requires": { 1838 | "esbuild-wasm": "0.15.8" 1839 | } 1840 | }, 1841 | "@esbuild/linux-loong64": { 1842 | "version": "0.15.8", 1843 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.15.8.tgz", 1844 | "integrity": "sha512-pE5RQsOTSERCtfZdfCT25wzo7dfhOSlhAXcsZmuvRYhendOv7djcdvtINdnDp2DAjP17WXlBB4nBO6sHLczmsg==", 1845 | "dev": true, 1846 | "optional": true 1847 | }, 1848 | "@jridgewell/gen-mapping": { 1849 | "version": "0.1.1", 1850 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", 1851 | "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", 1852 | "dev": true, 1853 | "requires": { 1854 | "@jridgewell/set-array": "^1.0.0", 1855 | "@jridgewell/sourcemap-codec": "^1.4.10" 1856 | } 1857 | }, 1858 | "@jridgewell/resolve-uri": { 1859 | "version": "3.1.0", 1860 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", 1861 | "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", 1862 | "dev": true 1863 | }, 1864 | "@jridgewell/set-array": { 1865 | "version": "1.1.2", 1866 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", 1867 | "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", 1868 | "dev": true 1869 | }, 1870 | "@jridgewell/sourcemap-codec": { 1871 | "version": "1.4.14", 1872 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", 1873 | "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", 1874 | "dev": true 1875 | }, 1876 | "@jridgewell/trace-mapping": { 1877 | "version": "0.3.15", 1878 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.15.tgz", 1879 | "integrity": "sha512-oWZNOULl+UbhsgB51uuZzglikfIKSUBO/M9W2OfEjn7cmqoAiCgmv9lyACTUacZwBz0ITnJ2NqjU8Tx0DHL88g==", 1880 | "dev": true, 1881 | "requires": { 1882 | "@jridgewell/resolve-uri": "^3.0.3", 1883 | "@jridgewell/sourcemap-codec": "^1.4.10" 1884 | } 1885 | }, 1886 | "@types/prop-types": { 1887 | "version": "15.7.5", 1888 | "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", 1889 | "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==", 1890 | "dev": true 1891 | }, 1892 | "@types/react": { 1893 | "version": "18.0.20", 1894 | "resolved": "https://registry.npmjs.org/@types/react/-/react-18.0.20.tgz", 1895 | "integrity": "sha512-MWul1teSPxujEHVwZl4a5HxQ9vVNsjTchVA+xRqv/VYGCuKGAU6UhfrTdF5aBefwD1BHUD8i/zq+O/vyCm/FrA==", 1896 | "dev": true, 1897 | "requires": { 1898 | "@types/prop-types": "*", 1899 | "@types/scheduler": "*", 1900 | "csstype": "^3.0.2" 1901 | } 1902 | }, 1903 | "@types/react-dom": { 1904 | "version": "18.0.6", 1905 | "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.0.6.tgz", 1906 | "integrity": "sha512-/5OFZgfIPSwy+YuIBP/FgJnQnsxhZhjjrnxudMddeblOouIodEQ75X14Rr4wGSG/bknL+Omy9iWlLo1u/9GzAA==", 1907 | "dev": true, 1908 | "requires": { 1909 | "@types/react": "*" 1910 | } 1911 | }, 1912 | "@types/scheduler": { 1913 | "version": "0.16.2", 1914 | "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", 1915 | "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==", 1916 | "dev": true 1917 | }, 1918 | "@vitejs/plugin-react": { 1919 | "version": "2.1.0", 1920 | "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-2.1.0.tgz", 1921 | "integrity": "sha512-am6rPyyU3LzUYne3Gd9oj9c4Rzbq5hQnuGXSMT6Gujq45Il/+bunwq3lrB7wghLkiF45ygMwft37vgJ/NE8IAA==", 1922 | "dev": true, 1923 | "requires": { 1924 | "@babel/core": "^7.18.13", 1925 | "@babel/plugin-transform-react-jsx": "^7.18.10", 1926 | "@babel/plugin-transform-react-jsx-development": "^7.18.6", 1927 | "@babel/plugin-transform-react-jsx-self": "^7.18.6", 1928 | "@babel/plugin-transform-react-jsx-source": "^7.18.6", 1929 | "magic-string": "^0.26.2", 1930 | "react-refresh": "^0.14.0" 1931 | } 1932 | }, 1933 | "ansi-styles": { 1934 | "version": "3.2.1", 1935 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1936 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1937 | "dev": true, 1938 | "requires": { 1939 | "color-convert": "^1.9.0" 1940 | } 1941 | }, 1942 | "browserslist": { 1943 | "version": "4.21.4", 1944 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.4.tgz", 1945 | "integrity": "sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw==", 1946 | "dev": true, 1947 | "requires": { 1948 | "caniuse-lite": "^1.0.30001400", 1949 | "electron-to-chromium": "^1.4.251", 1950 | "node-releases": "^2.0.6", 1951 | "update-browserslist-db": "^1.0.9" 1952 | } 1953 | }, 1954 | "caniuse-lite": { 1955 | "version": "1.0.30001409", 1956 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001409.tgz", 1957 | "integrity": "sha512-V0mnJ5dwarmhYv8/MzhJ//aW68UpvnQBXv8lJ2QUsvn2pHcmAuNtu8hQEDz37XnA1iE+lRR9CIfGWWpgJ5QedQ==", 1958 | "dev": true 1959 | }, 1960 | "chalk": { 1961 | "version": "2.4.2", 1962 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1963 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1964 | "dev": true, 1965 | "requires": { 1966 | "ansi-styles": "^3.2.1", 1967 | "escape-string-regexp": "^1.0.5", 1968 | "supports-color": "^5.3.0" 1969 | } 1970 | }, 1971 | "color-convert": { 1972 | "version": "1.9.3", 1973 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1974 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1975 | "dev": true, 1976 | "requires": { 1977 | "color-name": "1.1.3" 1978 | } 1979 | }, 1980 | "color-name": { 1981 | "version": "1.1.3", 1982 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1983 | "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", 1984 | "dev": true 1985 | }, 1986 | "convert-source-map": { 1987 | "version": "1.8.0", 1988 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", 1989 | "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", 1990 | "dev": true, 1991 | "requires": { 1992 | "safe-buffer": "~5.1.1" 1993 | } 1994 | }, 1995 | "csstype": { 1996 | "version": "3.1.1", 1997 | "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", 1998 | "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==", 1999 | "dev": true 2000 | }, 2001 | "debug": { 2002 | "version": "4.3.4", 2003 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2004 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2005 | "dev": true, 2006 | "requires": { 2007 | "ms": "2.1.2" 2008 | } 2009 | }, 2010 | "electron-to-chromium": { 2011 | "version": "1.4.256", 2012 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.256.tgz", 2013 | "integrity": "sha512-x+JnqyluoJv8I0U9gVe+Sk2st8vF0CzMt78SXxuoWCooLLY2k5VerIBdpvG7ql6GKI4dzNnPjmqgDJ76EdaAKw==", 2014 | "dev": true 2015 | }, 2016 | "esbuild": { 2017 | "version": "0.15.8", 2018 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.15.8.tgz", 2019 | "integrity": "sha512-Remsk2dmr1Ia65sU+QasE6svJbsHe62lzR+CnjpUvbZ+uSYo1SitiOWPRfZQkCu82YWZBBKXiD/j0i//XWMZ+Q==", 2020 | "dev": true, 2021 | "requires": { 2022 | "@esbuild/android-arm": "0.15.8", 2023 | "@esbuild/linux-loong64": "0.15.8", 2024 | "esbuild-android-64": "0.15.8", 2025 | "esbuild-android-arm64": "0.15.8", 2026 | "esbuild-darwin-64": "0.15.8", 2027 | "esbuild-darwin-arm64": "0.15.8", 2028 | "esbuild-freebsd-64": "0.15.8", 2029 | "esbuild-freebsd-arm64": "0.15.8", 2030 | "esbuild-linux-32": "0.15.8", 2031 | "esbuild-linux-64": "0.15.8", 2032 | "esbuild-linux-arm": "0.15.8", 2033 | "esbuild-linux-arm64": "0.15.8", 2034 | "esbuild-linux-mips64le": "0.15.8", 2035 | "esbuild-linux-ppc64le": "0.15.8", 2036 | "esbuild-linux-riscv64": "0.15.8", 2037 | "esbuild-linux-s390x": "0.15.8", 2038 | "esbuild-netbsd-64": "0.15.8", 2039 | "esbuild-openbsd-64": "0.15.8", 2040 | "esbuild-sunos-64": "0.15.8", 2041 | "esbuild-windows-32": "0.15.8", 2042 | "esbuild-windows-64": "0.15.8", 2043 | "esbuild-windows-arm64": "0.15.8" 2044 | } 2045 | }, 2046 | "esbuild-android-64": { 2047 | "version": "0.15.8", 2048 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.15.8.tgz", 2049 | "integrity": "sha512-bVh8FIKOolF7/d4AMzt7xHlL0Ljr+mYKSHI39TJWDkybVWHdn6+4ODL3xZGHOxPpdRpitemXA1WwMKYBsw8dGw==", 2050 | "dev": true, 2051 | "optional": true, 2052 | "requires": { 2053 | "esbuild-wasm": "0.15.8" 2054 | } 2055 | }, 2056 | "esbuild-android-arm64": { 2057 | "version": "0.15.8", 2058 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.15.8.tgz", 2059 | "integrity": "sha512-ReAMDAHuo0H1h9LxRabI6gwYPn8k6WiUeyxuMvx17yTrJO+SCnIfNc/TSPFvDwtK9MiyiKG/2dBYHouT/M0BXQ==", 2060 | "dev": true, 2061 | "optional": true 2062 | }, 2063 | "esbuild-darwin-64": { 2064 | "version": "0.15.8", 2065 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.15.8.tgz", 2066 | "integrity": "sha512-KaKcGfJ+yto7Fo5gAj3xwxHMd1fBIKatpCHK8znTJLVv+9+NN2/tIPBqA4w5rBwjX0UqXDeIE2v1xJP+nGEXgA==", 2067 | "dev": true, 2068 | "optional": true 2069 | }, 2070 | "esbuild-darwin-arm64": { 2071 | "version": "0.15.8", 2072 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.15.8.tgz", 2073 | "integrity": "sha512-8tjEaBgAKnXCkP7bhEJmEqdG9HEV6oLkF36BrMzpfW2rgaw0c48Zrxe+9RlfeGvs6gDF4w+agXyTjikzsS3izw==", 2074 | "dev": true, 2075 | "optional": true 2076 | }, 2077 | "esbuild-freebsd-64": { 2078 | "version": "0.15.8", 2079 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.15.8.tgz", 2080 | "integrity": "sha512-jaxcsGHYzn2L0/lffON2WfH4Nc+d/EwozVTP5K2v016zxMb5UQMhLoJzvLgBqHT1SG0B/mO+a+THnJCMVg15zw==", 2081 | "dev": true, 2082 | "optional": true 2083 | }, 2084 | "esbuild-freebsd-arm64": { 2085 | "version": "0.15.8", 2086 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.15.8.tgz", 2087 | "integrity": "sha512-2xp2UlljMvX8HExtcg7VHaeQk8OBU0CSl1j18B5CcZmSDkLF9p3utuMXIopG3a08fr9Hv+Dz6+seSXUow/G51w==", 2088 | "dev": true, 2089 | "optional": true 2090 | }, 2091 | "esbuild-linux-32": { 2092 | "version": "0.15.8", 2093 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.15.8.tgz", 2094 | "integrity": "sha512-9u1E54BRz1FQMl86iaHK146+4ID2KYNxL3trLZT4QLLx3M7Q9n4lGG3lrzqUatGR2cKy8c33b0iaCzsItZWkFg==", 2095 | "dev": true, 2096 | "optional": true 2097 | }, 2098 | "esbuild-linux-64": { 2099 | "version": "0.15.8", 2100 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.15.8.tgz", 2101 | "integrity": "sha512-4HxrsN9eUzJXdVGMTYA5Xler82FuZUu21bXKN42zcLHHNKCAMPUzD62I+GwDhsdgUBAUj0tRXDdsQHgaP6v0HA==", 2102 | "dev": true, 2103 | "optional": true 2104 | }, 2105 | "esbuild-linux-arm": { 2106 | "version": "0.15.8", 2107 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.15.8.tgz", 2108 | "integrity": "sha512-7DVBU9SFjX4+vBwt8tHsUCbE6Vvl6y6FQWHAgyw1lybC5gULqn/WnjHYHN2/LJaZRsDBvxWT4msEgwLGq1Wd3Q==", 2109 | "dev": true, 2110 | "optional": true 2111 | }, 2112 | "esbuild-linux-arm64": { 2113 | "version": "0.15.8", 2114 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.15.8.tgz", 2115 | "integrity": "sha512-1OCm7Aq0tEJT70PbxmHSGYDLYP8DKH8r4Nk7/XbVzWaduo9beCjGBB+tGZIHK6DdTQ3h00/4Tb/70YMH/bOtKg==", 2116 | "dev": true, 2117 | "optional": true 2118 | }, 2119 | "esbuild-linux-mips64le": { 2120 | "version": "0.15.8", 2121 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.15.8.tgz", 2122 | "integrity": "sha512-yeFoNPVFPEzZvFYBfUQNG2TjGRaCyV1E27OcOg4LOtnGrxb2wA+mkW3luckyv1CEyd00mpAg7UdHx8nlx3ghgA==", 2123 | "dev": true, 2124 | "optional": true 2125 | }, 2126 | "esbuild-linux-ppc64le": { 2127 | "version": "0.15.8", 2128 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.15.8.tgz", 2129 | "integrity": "sha512-CEyMMUUNabXibw8OSNmBXhOIGhnjNVl5Lpseiuf00iKN0V47oqDrbo4dsHz1wH62m49AR8iG8wpDlTqfYgKbtg==", 2130 | "dev": true, 2131 | "optional": true 2132 | }, 2133 | "esbuild-linux-riscv64": { 2134 | "version": "0.15.8", 2135 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.15.8.tgz", 2136 | "integrity": "sha512-OCGSOaspMUjexSCU8ZiA0UnV/NiRU+s2vIfEcAQWQ6u32R+2luyfh/4ZaY6jFbylJE07Esc/yRvb9Q5fXuClXA==", 2137 | "dev": true, 2138 | "optional": true 2139 | }, 2140 | "esbuild-linux-s390x": { 2141 | "version": "0.15.8", 2142 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.15.8.tgz", 2143 | "integrity": "sha512-RHdpdfxRTSrZXZJlFSLazFU4YwXLB5Rgf6Zr5rffqSsO4y9JybgtKO38bFwxZNlDXliYISXN/YROKrG9s7mZQA==", 2144 | "dev": true, 2145 | "optional": true 2146 | }, 2147 | "esbuild-netbsd-64": { 2148 | "version": "0.15.8", 2149 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.15.8.tgz", 2150 | "integrity": "sha512-VolFFRatBH09T5QMWhiohAWCOien1R1Uz9K0BRVVTBgBaVBt7eArsXTKxVhUgRf2vwu2c2SXkuP0r7HLG0eozw==", 2151 | "dev": true, 2152 | "optional": true 2153 | }, 2154 | "esbuild-openbsd-64": { 2155 | "version": "0.15.8", 2156 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.15.8.tgz", 2157 | "integrity": "sha512-HTAPlg+n4kUeE/isQxlCfsOz0xJGNoT5LJ9oYZWFKABfVf4Ycu7Zlf5ITgOnrdheTkz8JeL/gISIOCFAoOXrSA==", 2158 | "dev": true, 2159 | "optional": true 2160 | }, 2161 | "esbuild-sunos-64": { 2162 | "version": "0.15.8", 2163 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.15.8.tgz", 2164 | "integrity": "sha512-qMP/jR/FzcIOwKj+W+Lb+8Cfr8GZHbHUJxAPi7DUhNZMQ/6y7sOgRzlOSpRrbbUntrRZh0MqOyDhJ3Gpo6L1QA==", 2165 | "dev": true, 2166 | "optional": true 2167 | }, 2168 | "esbuild-wasm": { 2169 | "version": "0.15.8", 2170 | "resolved": "https://registry.npmjs.org/esbuild-wasm/-/esbuild-wasm-0.15.8.tgz", 2171 | "integrity": "sha512-Y7uCl5RNO4URjlemjdx++ukVHEMt5s5AfMWYUnMiK4Sry+pPCvQIctzXq6r6FKCyGKjX6/NGMCqR2OX6aLxj0w==", 2172 | "dev": true, 2173 | "optional": true 2174 | }, 2175 | "esbuild-windows-32": { 2176 | "version": "0.15.8", 2177 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.15.8.tgz", 2178 | "integrity": "sha512-RKR1QHh4iWzjUhkP8Yqi75PPz/KS+b8zw3wUrzw6oAkj+iU5Qtyj61ZDaSG3Qf2vc6hTIUiPqVTqBH0NpXFNwg==", 2179 | "dev": true, 2180 | "optional": true 2181 | }, 2182 | "esbuild-windows-64": { 2183 | "version": "0.15.8", 2184 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.15.8.tgz", 2185 | "integrity": "sha512-ag9ptYrsizgsR+PQE8QKeMqnosLvAMonQREpLw4evA4FFgOBMLEat/dY/9txbpozTw9eEOYyD3a4cE9yTu20FA==", 2186 | "dev": true, 2187 | "optional": true 2188 | }, 2189 | "esbuild-windows-arm64": { 2190 | "version": "0.15.8", 2191 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.15.8.tgz", 2192 | "integrity": "sha512-dbpAb0VyPaUs9mgw65KRfQ9rqiWCHpNzrJusoPu+LpEoswosjt/tFxN7cd2l68AT4qWdBkzAjDLRon7uqMeWcg==", 2193 | "dev": true, 2194 | "optional": true 2195 | }, 2196 | "escalade": { 2197 | "version": "3.1.1", 2198 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 2199 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 2200 | "dev": true 2201 | }, 2202 | "escape-string-regexp": { 2203 | "version": "1.0.5", 2204 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2205 | "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", 2206 | "dev": true 2207 | }, 2208 | "fsevents": { 2209 | "version": "2.3.2", 2210 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2211 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2212 | "dev": true, 2213 | "optional": true 2214 | }, 2215 | "function-bind": { 2216 | "version": "1.1.1", 2217 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2218 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 2219 | "dev": true 2220 | }, 2221 | "gensync": { 2222 | "version": "1.0.0-beta.2", 2223 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 2224 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 2225 | "dev": true 2226 | }, 2227 | "globals": { 2228 | "version": "11.12.0", 2229 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 2230 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 2231 | "dev": true 2232 | }, 2233 | "has": { 2234 | "version": "1.0.3", 2235 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2236 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2237 | "dev": true, 2238 | "requires": { 2239 | "function-bind": "^1.1.1" 2240 | } 2241 | }, 2242 | "has-flag": { 2243 | "version": "3.0.0", 2244 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2245 | "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", 2246 | "dev": true 2247 | }, 2248 | "history": { 2249 | "version": "5.3.0", 2250 | "resolved": "https://registry.npmjs.org/history/-/history-5.3.0.tgz", 2251 | "integrity": "sha512-ZqaKwjjrAYUYfLG+htGaIIZ4nioX2L70ZUMIFysS3xvBsSG4x/n1V6TXV3N8ZYNuFGlDirFg32T7B6WOUPDYcQ==", 2252 | "requires": { 2253 | "@babel/runtime": "^7.7.6" 2254 | } 2255 | }, 2256 | "is-core-module": { 2257 | "version": "2.10.0", 2258 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.10.0.tgz", 2259 | "integrity": "sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==", 2260 | "dev": true, 2261 | "requires": { 2262 | "has": "^1.0.3" 2263 | } 2264 | }, 2265 | "js-tokens": { 2266 | "version": "4.0.0", 2267 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2268 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 2269 | }, 2270 | "jsesc": { 2271 | "version": "2.5.2", 2272 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2273 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2274 | "dev": true 2275 | }, 2276 | "json5": { 2277 | "version": "2.2.1", 2278 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz", 2279 | "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==", 2280 | "dev": true 2281 | }, 2282 | "loose-envify": { 2283 | "version": "1.4.0", 2284 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 2285 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 2286 | "requires": { 2287 | "js-tokens": "^3.0.0 || ^4.0.0" 2288 | } 2289 | }, 2290 | "magic-string": { 2291 | "version": "0.26.3", 2292 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.26.3.tgz", 2293 | "integrity": "sha512-u1Po0NDyFcwdg2nzHT88wSK0+Rih0N1M+Ph1Sp08k8yvFFU3KR72wryS7e1qMPJypt99WB7fIFVCA92mQrMjrg==", 2294 | "dev": true, 2295 | "requires": { 2296 | "sourcemap-codec": "^1.4.8" 2297 | } 2298 | }, 2299 | "ms": { 2300 | "version": "2.1.2", 2301 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2302 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2303 | "dev": true 2304 | }, 2305 | "nanoid": { 2306 | "version": "3.3.4", 2307 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz", 2308 | "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==", 2309 | "dev": true 2310 | }, 2311 | "node-releases": { 2312 | "version": "2.0.6", 2313 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz", 2314 | "integrity": "sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg==", 2315 | "dev": true 2316 | }, 2317 | "path-parse": { 2318 | "version": "1.0.7", 2319 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2320 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2321 | "dev": true 2322 | }, 2323 | "picocolors": { 2324 | "version": "1.0.0", 2325 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2326 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2327 | "dev": true 2328 | }, 2329 | "postcss": { 2330 | "version": "8.4.16", 2331 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.16.tgz", 2332 | "integrity": "sha512-ipHE1XBvKzm5xI7hiHCZJCSugxvsdq2mPnsq5+UF+VHCjiBvtDrlxJfMBToWaP9D5XlgNmcFGqoHmUn0EYEaRQ==", 2333 | "dev": true, 2334 | "requires": { 2335 | "nanoid": "^3.3.4", 2336 | "picocolors": "^1.0.0", 2337 | "source-map-js": "^1.0.2" 2338 | } 2339 | }, 2340 | "react": { 2341 | "version": "18.2.0", 2342 | "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", 2343 | "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", 2344 | "requires": { 2345 | "loose-envify": "^1.1.0" 2346 | } 2347 | }, 2348 | "react-dom": { 2349 | "version": "18.2.0", 2350 | "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", 2351 | "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", 2352 | "requires": { 2353 | "loose-envify": "^1.1.0", 2354 | "scheduler": "^0.23.0" 2355 | } 2356 | }, 2357 | "react-refresh": { 2358 | "version": "0.14.0", 2359 | "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.0.tgz", 2360 | "integrity": "sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==", 2361 | "dev": true 2362 | }, 2363 | "react-router": { 2364 | "version": "6.3.0", 2365 | "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.3.0.tgz", 2366 | "integrity": "sha512-7Wh1DzVQ+tlFjkeo+ujvjSqSJmkt1+8JO+T5xklPlgrh70y7ogx75ODRW0ThWhY7S+6yEDks8TYrtQe/aoboBQ==", 2367 | "requires": { 2368 | "history": "^5.2.0" 2369 | } 2370 | }, 2371 | "react-router-dom": { 2372 | "version": "6.3.0", 2373 | "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.3.0.tgz", 2374 | "integrity": "sha512-uaJj7LKytRxZNQV8+RbzJWnJ8K2nPsOOEuX7aQstlMZKQT0164C+X2w6bnkqU3sjtLvpd5ojrezAyfZ1+0sStw==", 2375 | "requires": { 2376 | "history": "^5.2.0", 2377 | "react-router": "6.3.0" 2378 | } 2379 | }, 2380 | "regenerator-runtime": { 2381 | "version": "0.13.9", 2382 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz", 2383 | "integrity": "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==" 2384 | }, 2385 | "resolve": { 2386 | "version": "1.22.1", 2387 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", 2388 | "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", 2389 | "dev": true, 2390 | "requires": { 2391 | "is-core-module": "^2.9.0", 2392 | "path-parse": "^1.0.7", 2393 | "supports-preserve-symlinks-flag": "^1.0.0" 2394 | } 2395 | }, 2396 | "rollup": { 2397 | "version": "2.78.1", 2398 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.78.1.tgz", 2399 | "integrity": "sha512-VeeCgtGi4P+o9hIg+xz4qQpRl6R401LWEXBmxYKOV4zlF82lyhgh2hTZnheFUbANE8l2A41F458iwj2vEYaXJg==", 2400 | "dev": true, 2401 | "requires": { 2402 | "fsevents": "~2.3.2" 2403 | } 2404 | }, 2405 | "safe-buffer": { 2406 | "version": "5.1.2", 2407 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2408 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2409 | "dev": true 2410 | }, 2411 | "scheduler": { 2412 | "version": "0.23.0", 2413 | "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", 2414 | "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", 2415 | "requires": { 2416 | "loose-envify": "^1.1.0" 2417 | } 2418 | }, 2419 | "semver": { 2420 | "version": "6.3.0", 2421 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2422 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2423 | "dev": true 2424 | }, 2425 | "source-map-js": { 2426 | "version": "1.0.2", 2427 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", 2428 | "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", 2429 | "dev": true 2430 | }, 2431 | "sourcemap-codec": { 2432 | "version": "1.4.8", 2433 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 2434 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 2435 | "dev": true 2436 | }, 2437 | "supports-color": { 2438 | "version": "5.5.0", 2439 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2440 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2441 | "dev": true, 2442 | "requires": { 2443 | "has-flag": "^3.0.0" 2444 | } 2445 | }, 2446 | "supports-preserve-symlinks-flag": { 2447 | "version": "1.0.0", 2448 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2449 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2450 | "dev": true 2451 | }, 2452 | "to-fast-properties": { 2453 | "version": "2.0.0", 2454 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2455 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 2456 | "dev": true 2457 | }, 2458 | "update-browserslist-db": { 2459 | "version": "1.0.9", 2460 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.9.tgz", 2461 | "integrity": "sha512-/xsqn21EGVdXI3EXSum1Yckj3ZVZugqyOZQ/CxYPBD/R+ko9NSUScf8tFF4dOKY+2pvSSJA/S+5B8s4Zr4kyvg==", 2462 | "dev": true, 2463 | "requires": { 2464 | "escalade": "^3.1.1", 2465 | "picocolors": "^1.0.0" 2466 | } 2467 | }, 2468 | "vite": { 2469 | "version": "3.1.3", 2470 | "resolved": "https://registry.npmjs.org/vite/-/vite-3.1.3.tgz", 2471 | "integrity": "sha512-/3XWiktaopByM5bd8dqvHxRt5EEgRikevnnrpND0gRfNkrMrPaGGexhtLCzv15RcCMtV2CLw+BPas8YFeSG0KA==", 2472 | "dev": true, 2473 | "requires": { 2474 | "esbuild": "^0.15.6", 2475 | "fsevents": "~2.3.2", 2476 | "postcss": "^8.4.16", 2477 | "resolve": "^1.22.1", 2478 | "rollup": "~2.78.0" 2479 | } 2480 | } 2481 | } 2482 | } 2483 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-router-64", 3 | "private": true, 4 | "version": "0.0.0", 5 | "type": "module", 6 | "scripts": { 7 | "dev": "vite", 8 | "build": "vite build", 9 | "preview": "vite preview" 10 | }, 11 | "dependencies": { 12 | "react": "^18.2.0", 13 | "react-dom": "^18.2.0", 14 | "react-router-dom": "6.3" 15 | }, 16 | "devDependencies": { 17 | "@types/react": "^18.0.17", 18 | "@types/react-dom": "^18.0.6", 19 | "@vitejs/plugin-react": "^2.1.0", 20 | "vite": "^3.1.0" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /public/vite.svg: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /src/App.jsx: -------------------------------------------------------------------------------- 1 | import { BrowserRouter, Route, Routes } from 'react-router-dom'; 2 | 3 | import BlogLayout from './pages/BlogLayout'; 4 | import BlogPostsPage from './pages/BlogPosts'; 5 | import NewPostPage from './pages/NewPost'; 6 | import PostDetailPage from './pages/PostDetail'; 7 | import RootLayout from './components/RootLayout'; 8 | import WelcomePage from './pages/Welcome'; 9 | 10 | function App() { 11 | return ( 12 | 13 | 14 | 15 | } /> 16 | }> 17 | } /> 18 | } /> 19 | 20 | } /> 21 | 22 | 23 | 24 | ); 25 | } 26 | 27 | export default App; 28 | -------------------------------------------------------------------------------- /src/components/BlogActions.jsx: -------------------------------------------------------------------------------- 1 | import { Link } from 'react-router-dom'; 2 | 3 | import classes from './BlogActions.module.css'; 4 | 5 | function BlogActions() { 6 | return ( 7 |
8 | Add Post 9 |
10 | ); 11 | } 12 | 13 | export default BlogActions; 14 | -------------------------------------------------------------------------------- /src/components/BlogActions.module.css: -------------------------------------------------------------------------------- 1 | .actions { 2 | display: flex; 3 | justify-content: center; 4 | max-width: 30rem; 5 | margin: 2rem auto; 6 | } 7 | 8 | .button { 9 | font: inherit; 10 | background-color: #e5e5e5; 11 | color: #343232; 12 | border-radius: 4px; 13 | padding: 0.5rem 1.5rem; 14 | text-decoration: none; 15 | } 16 | 17 | .button:hover { 18 | background-color: #f9d3a9; 19 | } -------------------------------------------------------------------------------- /src/components/BlogPost.jsx: -------------------------------------------------------------------------------- 1 | import classes from './BlogPost.module.css'; 2 | 3 | function BlogPost({ title, text }) { 4 | return ( 5 |
6 |

{title}

7 |

{text}

8 |
9 | ); 10 | } 11 | 12 | export default BlogPost; 13 | -------------------------------------------------------------------------------- /src/components/BlogPost.module.css: -------------------------------------------------------------------------------- 1 | .post { 2 | margin: 2rem auto; 3 | max-width: 40rem; 4 | text-align: center; 5 | text-transform: capitalize; 6 | } -------------------------------------------------------------------------------- /src/components/MainNavigation.jsx: -------------------------------------------------------------------------------- 1 | import { NavLink } from 'react-router-dom'; 2 | 3 | import classes from './MainNavigation.module.css'; 4 | 5 | function MainNavigation() { 6 | return ( 7 |
8 | 34 |
35 | ); 36 | } 37 | 38 | export default MainNavigation; 39 | -------------------------------------------------------------------------------- /src/components/MainNavigation.module.css: -------------------------------------------------------------------------------- 1 | .header { 2 | padding: 2rem; 3 | } 4 | 5 | .header ul { 6 | display: flex; 7 | gap: 2rem; 8 | justify-content: center; 9 | } 10 | 11 | .header a { 12 | color: #e5e5e5; 13 | font-size: 1.15rem; 14 | text-decoration: none; 15 | } 16 | 17 | .header a:hover, 18 | .header a:active, 19 | .header a.active { 20 | color: #fcb66b; 21 | } 22 | -------------------------------------------------------------------------------- /src/components/NewPostForm.jsx: -------------------------------------------------------------------------------- 1 | import classes from './NewPostForm.module.css'; 2 | 3 | function NewPostForm({ onCancel, onSubmit, submitting }) { 4 | return ( 5 |
6 |
7 | 8 | 9 |
10 |
11 | 12 | 19 |
20 | 23 | 26 |
27 | ); 28 | } 29 | 30 | export default NewPostForm; 31 | -------------------------------------------------------------------------------- /src/components/NewPostForm.module.css: -------------------------------------------------------------------------------- 1 | .form { 2 | margin: 2rem auto; 3 | max-width: 20rem; 4 | } 5 | 6 | .form fieldset { 7 | border: none; 8 | margin: 0.5rem 0; 9 | } 10 | 11 | .form input, 12 | .form label, 13 | .form textarea { 14 | font: inherit; 15 | display: block; 16 | } 17 | 18 | .form input, 19 | .form textarea { 20 | width: 100%; 21 | border-radius: 4px; 22 | padding: 0.5rem; 23 | } 24 | 25 | .form label { 26 | font-weight: bold; 27 | margin-bottom: 0.5rem; 28 | } 29 | 30 | .form button { 31 | font: inherit; 32 | padding: 0.5rem 1.5rem; 33 | border-radius: 4px; 34 | border: none; 35 | cursor: pointer; 36 | background-color: #e5e3e3; 37 | } 38 | 39 | .form button:hover { 40 | background-color: #fcb66b; 41 | } 42 | 43 | .form button[type='button'] { 44 | background-color: transparent; 45 | color: #c7c4c4; 46 | } 47 | 48 | .form button[type='button']:hover { 49 | color: #fcb66b; 50 | } 51 | 52 | .form button:disabled { 53 | background-color: #a2a1a1; 54 | color: #515151; 55 | } 56 | 57 | .form button[type='button']:disabled { 58 | color: #515151; 59 | background-color: transparent; 60 | } -------------------------------------------------------------------------------- /src/components/Posts.jsx: -------------------------------------------------------------------------------- 1 | import { Link } from 'react-router-dom'; 2 | 3 | import classes from './Posts.module.css'; 4 | 5 | function Posts({ blogPosts }) { 6 | return ( 7 | 16 | ); 17 | } 18 | 19 | export default Posts; 20 | -------------------------------------------------------------------------------- /src/components/Posts.module.css: -------------------------------------------------------------------------------- 1 | .posts { 2 | display: flex; 3 | flex-direction: column; 4 | gap: 1.5rem; 5 | max-width: 40rem; 6 | margin: 2rem auto; 7 | } 8 | 9 | .posts h2 { 10 | text-transform: capitalize; 11 | font-size: 1.15rem; 12 | font-weight: normal; 13 | } 14 | 15 | .posts a { 16 | border-radius: 4px; 17 | padding: 1rem; 18 | background-color: #343232; 19 | text-decoration: none; 20 | color: inherit; 21 | display: block; 22 | } 23 | 24 | .posts a:hover { 25 | background-color: #665a4d; 26 | } 27 | -------------------------------------------------------------------------------- /src/components/RootLayout.jsx: -------------------------------------------------------------------------------- 1 | import MainNavigation from './MainNavigation'; 2 | 3 | function RootLayout({ children }) { 4 | return ( 5 | <> 6 | 7 |
{children}
8 | 9 | ); 10 | } 11 | 12 | export default RootLayout; 13 | -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- 1 | * { 2 | box-sizing: border-box; 3 | } 4 | 5 | :root { 6 | font-family: Inter, Avenir, Helvetica, Arial, sans-serif; 7 | 8 | color: rgba(255, 255, 255, 0.87); 9 | background-color: #242424; 10 | 11 | font-synthesis: none; 12 | text-rendering: optimizeLegibility; 13 | -webkit-font-smoothing: antialiased; 14 | -moz-osx-font-smoothing: grayscale; 15 | -webkit-text-size-adjust: 100%; 16 | } 17 | 18 | body { 19 | margin: 0; 20 | text-align: center; 21 | } 22 | 23 | ul { 24 | list-style: none; 25 | margin: 0; 26 | padding: 0; 27 | } 28 | 29 | h1 { 30 | text-align: center; 31 | } 32 | 33 | #error-content { 34 | text-align: center; 35 | } 36 | -------------------------------------------------------------------------------- /src/main.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react' 2 | import ReactDOM from 'react-dom/client' 3 | 4 | import App from './App' 5 | import './index.css' 6 | 7 | ReactDOM.createRoot(document.getElementById('root')).render( 8 | 9 | 10 | 11 | ) 12 | -------------------------------------------------------------------------------- /src/pages/BlogLayout.jsx: -------------------------------------------------------------------------------- 1 | import { Outlet } from 'react-router-dom'; 2 | 3 | import BlogActions from '../components/BlogActions'; 4 | 5 | function BlogLayout() { 6 | return ( 7 | <> 8 | 9 | 10 | 11 | ); 12 | } 13 | 14 | export default BlogLayout; 15 | -------------------------------------------------------------------------------- /src/pages/BlogPosts.jsx: -------------------------------------------------------------------------------- 1 | import { useEffect, useState } from 'react'; 2 | 3 | import Posts from '../components/Posts'; 4 | import { getPosts } from '../util/api'; 5 | 6 | function BlogPostsPage() { 7 | const [error, setError] = useState(); 8 | const [posts, setPosts] = useState(); 9 | const [isLoading, setIsLoading] = useState(false); 10 | 11 | useEffect(() => { 12 | async function loadPosts() { 13 | setIsLoading(true); 14 | try { 15 | const posts = await getPosts(); 16 | setPosts(posts); 17 | } catch (err) { 18 | setError(err.message); 19 | } 20 | setIsLoading(false); 21 | } 22 | 23 | loadPosts(); 24 | }, []); 25 | 26 | return ( 27 | <> 28 |

Our Blog Posts

29 | {isLoading &&

Loading posts...

} 30 | {error &&

{error}

} 31 | {!error && posts && } 32 | 33 | ); 34 | } 35 | 36 | export default BlogPostsPage; -------------------------------------------------------------------------------- /src/pages/NewPost.jsx: -------------------------------------------------------------------------------- 1 | import { useState } from 'react'; 2 | import { useNavigate } from 'react-router-dom'; 3 | 4 | import NewPostForm from '../components/NewPostForm'; 5 | import { savePost } from '../util/api'; 6 | 7 | function NewPostPage() { 8 | const [isSubmitting, setIsSubmitting] = useState(false); 9 | const [error, setError] = useState(); 10 | const navigate = useNavigate(); 11 | 12 | async function submitHandler(event) { 13 | event.preventDefault(); 14 | setIsSubmitting(true); 15 | try { 16 | const formData = new FormData(event.target); 17 | const post = { 18 | title: formData.get('title'), 19 | body: formData.get('post-text'), 20 | }; 21 | await savePost(post); 22 | navigate('/'); 23 | } catch (err) { 24 | setError(err); 25 | } 26 | setIsSubmitting(false); 27 | } 28 | 29 | function cancelHandler() { 30 | navigate('/blog'); 31 | } 32 | 33 | return ( 34 | <> 35 | {error &&

{error.message}

} 36 | 41 | 42 | ); 43 | } 44 | 45 | export default NewPostPage; 46 | -------------------------------------------------------------------------------- /src/pages/PostDetail.jsx: -------------------------------------------------------------------------------- 1 | import { useState, useEffect } from 'react'; 2 | import { useParams } from 'react-router-dom'; 3 | 4 | import BlogPost from '../components/BlogPost'; 5 | import { getPost } from '../util/api'; 6 | 7 | function PostDetailPage() { 8 | const [error, setError] = useState(); 9 | const [post, setPost] = useState(); 10 | const [isLoading, setIsLoading] = useState(false); 11 | 12 | const params = useParams(); 13 | const { id } = params; 14 | 15 | useEffect(() => { 16 | async function loadPost() { 17 | setIsLoading(true); 18 | try { 19 | const post = await getPost(id); 20 | setPost(post); 21 | } catch (err) { 22 | setError(err.message); 23 | } 24 | setIsLoading(false); 25 | } 26 | 27 | loadPost(); 28 | }, [id]); 29 | 30 | return ( 31 | <> 32 | {isLoading &&

Loading post...

} 33 | {error &&

{error.message}

} 34 | {!error && post && } 35 | 36 | ); 37 | } 38 | 39 | export default PostDetailPage; -------------------------------------------------------------------------------- /src/pages/Welcome.jsx: -------------------------------------------------------------------------------- 1 | function WelcomePage() { 2 | return ( 3 |
4 |

Welcome Page

5 |

Learn more about React Router 6.4

6 |
7 | ); 8 | } 9 | 10 | export default WelcomePage; 11 | -------------------------------------------------------------------------------- /src/util/api.js: -------------------------------------------------------------------------------- 1 | export async function getPosts() { 2 | const response = await fetch('https://jsonplaceholder.typicode.com/posts'); 3 | if (!response.ok) { 4 | throw { message: 'Failed to fetch posts.', status: 500 }; 5 | } 6 | return response.json(); 7 | } 8 | 9 | export async function getPost(id) { 10 | const response = await fetch( 11 | 'https://jsonplaceholder.typicode.com/posts/' + id 12 | ); 13 | if (!response.ok) { 14 | throw { message: 'Failed to fetch post.', status: 500 }; 15 | } 16 | return response.json(); 17 | } 18 | 19 | export async function savePost(post) { 20 | if (post.title.trim().length < 5 || post.body.trim().length < 10) { 21 | throw { message: 'Invalid input data provided.', status: 422 }; 22 | } 23 | 24 | const response = await fetch('https://jsonplaceholder.typicode.com/posts', { 25 | method: 'POST', 26 | body: JSON.stringify(post), 27 | headers: { 28 | 'Content-Type': 'application/json', 29 | }, 30 | }); 31 | 32 | if (!response.ok) { 33 | throw { message: 'Could not save post.', status: 500 }; 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /vite.config.js: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite' 2 | import react from '@vitejs/plugin-react' 3 | 4 | // https://vitejs.dev/config/ 5 | export default defineConfig({ 6 | plugins: [react()] 7 | }) 8 | --------------------------------------------------------------------------------