From cc8cbd7658d238ca699eb20c295721b1f667b4b6 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Fri, 18 Oct 2024 13:48:31 +0900 Subject: [PATCH 01/12] =?UTF-8?q?react=ED=94=84=EB=A1=9C=EC=A0=9D=ED=8A=B8?= =?UTF-8?q?=20=EC=8B=9C=EC=9E=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package-lock.json | 6 + react-psh-sprint5/.gitignore | 24 + react-psh-sprint5/README.md | 8 + react-psh-sprint5/eslint.config.js | 40 + react-psh-sprint5/index.html | 13 + react-psh-sprint5/package-lock.json | 4371 +++++++++++++++++++++++++++ react-psh-sprint5/package.json | 28 + react-psh-sprint5/src/App.css | 0 react-psh-sprint5/src/App.jsx | 11 + react-psh-sprint5/src/index.css | 0 react-psh-sprint5/src/main.jsx | 7 + react-psh-sprint5/vite.config.js | 7 + 12 files changed, 4515 insertions(+) create mode 100644 package-lock.json create mode 100644 react-psh-sprint5/.gitignore create mode 100644 react-psh-sprint5/README.md create mode 100644 react-psh-sprint5/eslint.config.js create mode 100644 react-psh-sprint5/index.html create mode 100644 react-psh-sprint5/package-lock.json create mode 100644 react-psh-sprint5/package.json create mode 100644 react-psh-sprint5/src/App.css create mode 100644 react-psh-sprint5/src/App.jsx create mode 100644 react-psh-sprint5/src/index.css create mode 100644 react-psh-sprint5/src/main.jsx create mode 100644 react-psh-sprint5/vite.config.js diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..bd91653f --- /dev/null +++ b/package-lock.json @@ -0,0 +1,6 @@ +{ + "name": "3-sprint-mission-fe", + "lockfileVersion": 3, + "requires": true, + "packages": {} +} diff --git a/react-psh-sprint5/.gitignore b/react-psh-sprint5/.gitignore new file mode 100644 index 00000000..a547bf36 --- /dev/null +++ b/react-psh-sprint5/.gitignore @@ -0,0 +1,24 @@ +# Logs +logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* +lerna-debug.log* + +node_modules +dist +dist-ssr +*.local + +# Editor directories and files +.vscode/* +!.vscode/extensions.json +.idea +.DS_Store +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? diff --git a/react-psh-sprint5/README.md b/react-psh-sprint5/README.md new file mode 100644 index 00000000..f768e33f --- /dev/null +++ b/react-psh-sprint5/README.md @@ -0,0 +1,8 @@ +# React + Vite + +This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. + +Currently, two official plugins are available: + +- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh +- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh diff --git a/react-psh-sprint5/eslint.config.js b/react-psh-sprint5/eslint.config.js new file mode 100644 index 00000000..19031f0f --- /dev/null +++ b/react-psh-sprint5/eslint.config.js @@ -0,0 +1,40 @@ +import js from '@eslint/js' +import globals from 'globals' +import react from 'eslint-plugin-react' +import reactHooks from 'eslint-plugin-react-hooks' +import reactRefresh from 'eslint-plugin-react-refresh' + +export default [ + { ignores: ['dist'] }, + { + files: ['**/*.{js,jsx}'], + languageOptions: { + ecmaVersion: 2020, + globals: globals.browser, + parserOptions: { + ecmaVersion: 'latest', + ecmaFeatures: { jsx: true }, + sourceType: 'module', + }, + }, + settings: { react: { version: '18.3' } }, + plugins: { + react, + 'react-hooks': reactHooks, + 'react-refresh': reactRefresh, + }, + rules: { + ...js.configs.recommended.rules, + ...react.configs.recommended.rules, + ...react.configs['jsx-runtime'].rules, + ...reactHooks.configs.recommended.rules, + 'react/jsx-no-target-blank': 'off', + 'react-refresh/only-export-components': [ + 'warn', + { allowConstantExport: true }, + ], + }, + "no-unused-vars": "off", + "react/prop-types": "off", + }, +] diff --git a/react-psh-sprint5/index.html b/react-psh-sprint5/index.html new file mode 100644 index 00000000..0c589ecc --- /dev/null +++ b/react-psh-sprint5/index.html @@ -0,0 +1,13 @@ + + + + + + + Vite + React + + +
+ + + diff --git a/react-psh-sprint5/package-lock.json b/react-psh-sprint5/package-lock.json new file mode 100644 index 00000000..726ee438 --- /dev/null +++ b/react-psh-sprint5/package-lock.json @@ -0,0 +1,4371 @@ +{ + "name": "react-psh-sprint5", + "version": "0.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "react-psh-sprint5", + "version": "0.0.0", + "dependencies": { + "react": "^18.3.1", + "react-dom": "^18.3.1" + }, + "devDependencies": { + "@eslint/js": "^9.11.1", + "@types/react": "^18.3.10", + "@types/react-dom": "^18.3.0", + "@vitejs/plugin-react": "^4.3.2", + "eslint": "^9.11.1", + "eslint-plugin-react": "^7.37.0", + "eslint-plugin-react-hooks": "^5.1.0-rc.0", + "eslint-plugin-react-refresh": "^0.4.12", + "globals": "^15.9.0", + "vite": "^5.4.8" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.25.7.tgz", + "integrity": "sha512-0xZJFNE5XMpENsgfHYTw8FbX4kv53mFLn2i3XPoq69LyhYSCBJtitaHx9QnsVTrsogI4Z3+HtEfZ2/GFPOtf5g==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/highlight": "^7.25.7", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.25.8", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.8.tgz", + "integrity": "sha512-ZsysZyXY4Tlx+Q53XdnOFmqwfB9QDTHYxaZYajWRoBLuLEAwI2UIbtxOjWh/cFaa9IKUlcB+DDuoskLuKu56JA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.25.8", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.8.tgz", + "integrity": "sha512-Oixnb+DzmRT30qu9d3tJSQkxuygWm32DFykT4bRoORPa9hZ/L4KhVB/XiRm6KG+roIEM7DBQlmg27kw2HZkdZg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.25.7", + "@babel/generator": "^7.25.7", + "@babel/helper-compilation-targets": "^7.25.7", + "@babel/helper-module-transforms": "^7.25.7", + "@babel/helpers": "^7.25.7", + "@babel/parser": "^7.25.8", + "@babel/template": "^7.25.7", + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.8", + "convert-source-map": "^2.0.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.3", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/generator": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.7.tgz", + "integrity": "sha512-5Dqpl5fyV9pIAD62yK9P7fcA768uVPUyrQmqpqstHWgMma4feF1x/oFysBCVZLY5wJ2GkMUCdsNDnGZrPoR6rA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/types": "^7.25.7", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", + "jsesc": "^3.0.2" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.7.tgz", + "integrity": "sha512-DniTEax0sv6isaw6qSQSfV4gVRNtw2rte8HHM45t9ZR0xILaufBRNkpMifCRiAPyvL4ACD6v0gfCwCmtOQaV4A==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/compat-data": "^7.25.7", + "@babel/helper-validator-option": "^7.25.7", + "browserslist": "^4.24.0", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.7.tgz", + "integrity": "sha512-o0xCgpNmRohmnoWKQ0Ij8IdddjyBFE4T2kagL/x6M3+4zUgc+4qTOUBoNe4XxDskt1HPKO007ZPiMgLDq2s7Kw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.7.tgz", + "integrity": "sha512-k/6f8dKG3yDz/qCwSM+RKovjMix563SLxQFo0UhRNo239SP6n9u5/eLtKD6EAjwta2JHJ49CsD8pms2HdNiMMQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-module-imports": "^7.25.7", + "@babel/helper-simple-access": "^7.25.7", + "@babel/helper-validator-identifier": "^7.25.7", + "@babel/traverse": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.25.7.tgz", + "integrity": "sha512-eaPZai0PiqCi09pPs3pAFfl/zYgGaE6IdXtYvmf0qlcDTd3WCtO7JWCcRd64e0EQrcYgiHibEZnOGsSY4QSgaw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.25.7.tgz", + "integrity": "sha512-FPGAkJmyoChQeM+ruBGIDyrT2tKfZJO8NcxdC+CWNJi7N8/rZpSxK7yvBJ5O/nF1gfu5KzN7VKG3YVSLFfRSxQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.7.tgz", + "integrity": "sha512-CbkjYdsJNHFk8uqpEkpCvRs3YRp9tY6FmFY7wLMSYuGYkrdUi7r2lc4/wqsvlHoMznX3WJ9IP8giGPq68T/Y6g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.7.tgz", + "integrity": "sha512-AM6TzwYqGChO45oiuPqwL2t20/HdMC1rTPAesnBCgPCSF1x3oN9MVUwQV2iyz4xqWrctwK5RNC8LV22kaQCNYg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.7.tgz", + "integrity": "sha512-ytbPLsm+GjArDYXJ8Ydr1c/KJuutjF2besPNbIZnZ6MKUxi/uTA22t2ymmA4WFjZFpjiAMO0xuuJPqK2nvDVfQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.7.tgz", + "integrity": "sha512-Sv6pASx7Esm38KQpF/U/OXLwPPrdGHNKoeblRxgZRLXnAtnkEe4ptJPDtAZM7fBLadbc1Q07kQpSiGQ0Jg6tRA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/template": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.25.7.tgz", + "integrity": "sha512-iYyACpW3iW8Fw+ZybQK+drQre+ns/tKpXbNESfrhNnPLIklLbXr7MYJ6gPEd0iETGLOK+SxMjVvKb/ffmk+FEw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-validator-identifier": "^7.25.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.25.8", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.8.tgz", + "integrity": "sha512-HcttkxzdPucv3nNFmfOOMfFf64KgdJVqm1KaCm25dPGMLElo9nsLvXeJECQg8UzPuBGLyTSA0ZzqCtDSzKTEoQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/types": "^7.25.8" + }, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-self": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.25.7.tgz", + "integrity": "sha512-JD9MUnLbPL0WdVK8AWC7F7tTG2OS6u/AKKnsK+NdRhUiVdnzyR1S3kKQCaRLOiaULvUiqK6Z4JQE635VgtCFeg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-source": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.25.7.tgz", + "integrity": "sha512-S/JXG/KrbIY06iyJPKfxr0qRxnhNOdkNXYBl/rmwgDd72cQLH9tEGkDm/yJPGvcSIUoikzfjMios9i+xT/uv9w==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/template": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.7.tgz", + "integrity": "sha512-wRwtAgI3bAS+JGU2upWNL9lSlDcRCqD05BZ1n3X2ONLH1WilFP6O1otQjeMK/1g0pvYcXC7b/qVUB1keofjtZA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/code-frame": "^7.25.7", + "@babel/parser": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.7.tgz", + "integrity": "sha512-jatJPT1Zjqvh/1FyJs6qAHL+Dzb7sTb+xr7Q+gM1b+1oBsMsQQ4FkVKb6dFlJvLlVssqkRzV05Jzervt9yhnzg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/code-frame": "^7.25.7", + "@babel/generator": "^7.25.7", + "@babel/parser": "^7.25.7", + "@babel/template": "^7.25.7", + "@babel/types": "^7.25.7", + "debug": "^4.3.1", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/types": { + "version": "7.25.8", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.8.tgz", + "integrity": "sha512-JWtuCu8VQsMladxVz/P4HzHUGCAwpuqacmowgXFs5XjxIgKuNjnLokQzuVjlTvIzODaDmpjT3oxcC48vyk9EWg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-string-parser": "^7.25.7", + "@babel/helper-validator-identifier": "^7.25.7", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@esbuild/aix-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", + "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", + "cpu": [ + "ppc64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", + "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", + "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", + "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", + "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", + "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", + "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", + "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", + "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", + "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", + "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", + "cpu": [ + "ia32" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", + "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", + "cpu": [ + "loong64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", + "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", + "cpu": [ + "mips64el" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", + "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", + "cpu": [ + "ppc64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", + "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", + "cpu": [ + "riscv64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", + "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", + "cpu": [ + "s390x" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", + "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", + "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", + "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", + "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", + "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", + "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", + "cpu": [ + "ia32" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", + "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "license": "MIT", + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.11.1", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.1.tgz", + "integrity": "sha512-m4DVN9ZqskZoLU5GlWZadwDnYo3vAEydiUayB9widCl9ffWx2IvPnp6n3on5rJmziJSw9Bv+Z3ChDVdMwXCY8Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/config-array": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.18.0.tgz", + "integrity": "sha512-fTxvnS1sRMu3+JjXwJG0j/i4RT9u4qJ+lqS/yCGap4lH4zZGzQ7tu+xZqQmcMZq5OBZDL4QRxQzRjkWcGt8IVw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@eslint/object-schema": "^2.1.4", + "debug": "^4.3.1", + "minimatch": "^3.1.2" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/core": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.6.0.tgz", + "integrity": "sha512-8I2Q8ykA4J0x0o7cg67FPVnehcqWTBehu/lmY+bolPFHGjh49YzGBMXTvpqVgEbBdvNCSxj6iFgiIyHzf03lzg==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz", + "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^10.0.1", + "globals": "^14.0.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/eslintrc/node_modules/globals": { + "version": "14.0.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", + "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@eslint/js": { + "version": "9.12.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.12.0.tgz", + "integrity": "sha512-eohesHH8WFRUprDNyEREgqP6beG6htMeUYeCpkEgBCieCMme5r9zFWjzAJp//9S+Kub4rqE+jXe9Cp1a7IYIIA==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/object-schema": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz", + "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/plugin-kit": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.0.tgz", + "integrity": "sha512-vH9PiIMMwvhCx31Af3HiGzsVNULDbyVkHXwlemn/B0TFj/00ho3y55efXrUZTfQipxoHC5u4xq6zblww1zm1Ig==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "levn": "^0.4.1" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@humanfs/core": { + "version": "0.19.0", + "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.0.tgz", + "integrity": "sha512-2cbWIHbZVEweE853g8jymffCA+NCMiuqeECeBBLm8dg2oFdjuGJhgN4UAbI+6v0CKbbhvtXA4qV8YR5Ji86nmw==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">=18.18.0" + } + }, + "node_modules/@humanfs/node": { + "version": "0.16.5", + "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.5.tgz", + "integrity": "sha512-KSPA4umqSG4LHYRodq31VDwKAvaTF4xmVlzM8Aeh4PlU1JQ3IG0wiA8C25d3RQ9nJyM3mBHyI53K06VVL/oFFg==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@humanfs/core": "^0.19.0", + "@humanwhocodes/retry": "^0.3.0" + }, + "engines": { + "node": ">=18.18.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/retry": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", + "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">=18.18" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.0.tgz", + "integrity": "sha512-Q6HJd7Y6xdB48x8ZNVDOqsbh2uByBhgK8PiQgPhwkIw/HC/YX5Ghq2mQY5sRMZWHb3VsFkWooUVOZHKr7DmDIA==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.0.tgz", + "integrity": "sha512-ijLnS1qFId8xhKjT81uBHuuJp2lU4x2yxa4ctFPtG+MqEE6+C5f/+X/bStmxapgmwLwiL3ih122xv8kVARNAZA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.0.tgz", + "integrity": "sha512-bIv+X9xeSs1XCk6DVvkO+S/z8/2AMt/2lMqdQbMrmVpgFvXlmde9mLcbQpztXm1tajC3raFDqegsH18HQPMYtA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.0.tgz", + "integrity": "sha512-X6/nOwoFN7RT2svEQWUsW/5C/fYMBe4fnLK9DQk4SX4mgVBiTA9h64kjUYPvGQ0F/9xwJ5U5UfTbl6BEjaQdBQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.0.tgz", + "integrity": "sha512-0KXvIJQMOImLCVCz9uvvdPgfyWo93aHHp8ui3FrtOP57svqrF/roSSR5pjqL2hcMp0ljeGlU4q9o/rQaAQ3AYA==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.0.tgz", + "integrity": "sha512-it2BW6kKFVh8xk/BnHfakEeoLPv8STIISekpoF+nBgWM4d55CZKc7T4Dx1pEbTnYm/xEKMgy1MNtYuoA8RFIWw==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.0.tgz", + "integrity": "sha512-i0xTLXjqap2eRfulFVlSnM5dEbTVque/3Pi4g2y7cxrs7+a9De42z4XxKLYJ7+OhE3IgxvfQM7vQc43bwTgPwA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.0.tgz", + "integrity": "sha512-9E6MKUJhDuDh604Qco5yP/3qn3y7SLXYuiC0Rpr89aMScS2UAmK1wHP2b7KAa1nSjWJc/f/Lc0Wl1L47qjiyQw==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.0.tgz", + "integrity": "sha512-2XFFPJ2XMEiF5Zi2EBf4h73oR1V/lycirxZxHZNc93SqDN/IWhYYSYj8I9381ikUFXZrz2v7r2tOVk2NBwxrWw==", + "cpu": [ + "ppc64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.0.tgz", + "integrity": "sha512-M3Dg4hlwuntUCdzU7KjYqbbd+BLq3JMAOhCKdBE3TcMGMZbKkDdJ5ivNdehOssMCIokNHFOsv7DO4rlEOfyKpg==", + "cpu": [ + "riscv64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.0.tgz", + "integrity": "sha512-mjBaoo4ocxJppTorZVKWFpy1bfFj9FeCMJqzlMQGjpNPY9JwQi7OuS1axzNIk0nMX6jSgy6ZURDZ2w0QW6D56g==", + "cpu": [ + "s390x" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.0.tgz", + "integrity": "sha512-ZXFk7M72R0YYFN5q13niV0B7G8/5dcQ9JDp8keJSfr3GoZeXEoMHP/HlvqROA3OMbMdfr19IjCeNAnPUG93b6A==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.0.tgz", + "integrity": "sha512-w1i+L7kAXZNdYl+vFvzSZy8Y1arS7vMgIy8wusXJzRrPyof5LAb02KGr1PD2EkRcl73kHulIID0M501lN+vobQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.0.tgz", + "integrity": "sha512-VXBrnPWgBpVDCVY6XF3LEW0pOU51KbaHhccHw6AS6vBWIC60eqsH19DAeeObl+g8nKAz04QFdl/Cefta0xQtUQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.0.tgz", + "integrity": "sha512-xrNcGDU0OxVcPTH/8n/ShH4UevZxKIO6HJFK0e15XItZP2UcaiLFd5kiX7hJnqCbSztUF8Qot+JWBC/QXRPYWQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.0.tgz", + "integrity": "sha512-fbMkAF7fufku0N2dE5TBXcNlg0pt0cJue4xBRE2Qc5Vqikxr4VCgKj/ht6SMdFcOacVA9rqF70APJ8RN/4vMJw==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@types/babel__core": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", + "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/parser": "^7.20.7", + "@babel/types": "^7.20.7", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "node_modules/@types/babel__generator": { + "version": "7.6.8", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", + "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__template": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", + "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__traverse": { + "version": "7.20.6", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz", + "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/types": "^7.20.7" + } + }, + "node_modules/@types/estree": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", + "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/json-schema": { + "version": "7.0.15", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/prop-types": { + "version": "15.7.13", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.13.tgz", + "integrity": "sha512-hCZTSvwbzWGvhqxp/RqVqwU999pBf2vp7hzIjiYOsl8wqOmUxkQ6ddw1cV3l8811+kdUFus/q4d1Y3E3SyEifA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/react": { + "version": "18.3.11", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.11.tgz", + "integrity": "sha512-r6QZ069rFTjrEYgFdOck1gK7FLVsgJE7tTz0pQBczlBNUhBNk0MQH4UbnFSwjpQLMkLzgqvBBa+qGpLje16eTQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/prop-types": "*", + "csstype": "^3.0.2" + } + }, + "node_modules/@types/react-dom": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.1.tgz", + "integrity": "sha512-qW1Mfv8taImTthu4KoXgDfLuk4bydU6Q/TkADnDWWHwi4NX4BR+LWfTp2sVmTqRrsHvyDDTelgelxJ+SsejKKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/react": "*" + } + }, + "node_modules/@vitejs/plugin-react": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.3.2.tgz", + "integrity": "sha512-hieu+o05v4glEBucTcKMK3dlES0OeJlD9YVOAPraVMOInBCwzumaIFiUjr4bHK7NPgnAHgiskUoceKercrN8vg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/core": "^7.25.2", + "@babel/plugin-transform-react-jsx-self": "^7.24.7", + "@babel/plugin-transform-react-jsx-source": "^7.24.7", + "@types/babel__core": "^7.20.5", + "react-refresh": "^0.14.2" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "peerDependencies": { + "vite": "^4.2.0 || ^5.0.0" + } + }, + "node_modules/acorn": { + "version": "8.13.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.13.0.tgz", + "integrity": "sha512-8zSiw54Oxrdym50NlZ9sUusyO1Z1ZchgRLWRaK6c86XJFClyCgFKetdowBg5bKxyp/u+CDBJG4Mpp0m3HLZl9w==", + "dev": true, + "license": "MIT", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true, + "license": "Python-2.0" + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-includes": { + "version": "3.1.8", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", + "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.findlast": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz", + "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flat": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", + "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", + "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.tosorted": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz", + "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/browserslist": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.0.tgz", + "integrity": "sha512-Rmb62sR1Zpjql25eSanFGEhAxcFwfA1K0GuQcLoaJBAcENegrQut3hYdhXFF1obQfiDyqIW/cLM5HSJ/9k884A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "caniuse-lite": "^1.0.30001663", + "electron-to-chromium": "^1.5.28", + "node-releases": "^2.0.18", + "update-browserslist-db": "^1.1.0" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001669", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001669.tgz", + "integrity": "sha512-DlWzFDJqstqtIVx1zeSpIMLjunf5SmwOw0N2Ck/QSQdS8PLS4+9HrLaYei4w8BIAL7IB/UEDu889d8vhCTPA0w==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "CC-BY-4.0" + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true, + "license": "MIT" + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true, + "license": "MIT" + }, + "node_modules/convert-source-map": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", + "dev": true, + "license": "MIT" + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "license": "MIT", + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", + "dev": true, + "license": "MIT" + }, + "node_modules/data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/debug": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", + "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/electron-to-chromium": { + "version": "1.5.41", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.41.tgz", + "integrity": "sha512-dfdv/2xNjX0P8Vzme4cfzHqnPm5xsZXwsolTYr0eyW18IUmNyG08vL+fttvinTfhKfIKdRoqkDIC9e9iWQCNYQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/es-abstract": { + "version": "1.23.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", + "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.8", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.6", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-iterator-helpers": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.1.0.tgz", + "integrity": "sha512-/SurEfycdyssORP/E+bj4sEu1CWw4EmLDsHynHwSXQ7utgbrMRWW195pTrCjFgFCddf/UkYm3oqKPRq5i8bJbw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.4", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "iterator.prototype": "^1.1.3", + "safe-array-concat": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", + "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", + "dev": true, + "license": "MIT", + "dependencies": { + "hasown": "^2.0.0" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/esbuild": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", + "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/aix-ppc64": "0.21.5", + "@esbuild/android-arm": "0.21.5", + "@esbuild/android-arm64": "0.21.5", + "@esbuild/android-x64": "0.21.5", + "@esbuild/darwin-arm64": "0.21.5", + "@esbuild/darwin-x64": "0.21.5", + "@esbuild/freebsd-arm64": "0.21.5", + "@esbuild/freebsd-x64": "0.21.5", + "@esbuild/linux-arm": "0.21.5", + "@esbuild/linux-arm64": "0.21.5", + "@esbuild/linux-ia32": "0.21.5", + "@esbuild/linux-loong64": "0.21.5", + "@esbuild/linux-mips64el": "0.21.5", + "@esbuild/linux-ppc64": "0.21.5", + "@esbuild/linux-riscv64": "0.21.5", + "@esbuild/linux-s390x": "0.21.5", + "@esbuild/linux-x64": "0.21.5", + "@esbuild/netbsd-x64": "0.21.5", + "@esbuild/openbsd-x64": "0.21.5", + "@esbuild/sunos-x64": "0.21.5", + "@esbuild/win32-arm64": "0.21.5", + "@esbuild/win32-ia32": "0.21.5", + "@esbuild/win32-x64": "0.21.5" + } + }, + "node_modules/escalade": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint": { + "version": "9.12.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.12.0.tgz", + "integrity": "sha512-UVIOlTEWxwIopRL1wgSQYdnVDcEvs2wyaO6DGo5mXqe3r16IoCNWkR29iHhyaP4cICWjbgbmFUGAhh0GJRuGZw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.11.0", + "@eslint/config-array": "^0.18.0", + "@eslint/core": "^0.6.0", + "@eslint/eslintrc": "^3.1.0", + "@eslint/js": "9.12.0", + "@eslint/plugin-kit": "^0.2.0", + "@humanfs/node": "^0.16.5", + "@humanwhocodes/module-importer": "^1.0.1", + "@humanwhocodes/retry": "^0.3.1", + "@types/estree": "^1.0.6", + "@types/json-schema": "^7.0.15", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^8.1.0", + "eslint-visitor-keys": "^4.1.0", + "espree": "^10.2.0", + "esquery": "^1.5.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^8.0.0", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + }, + "peerDependencies": { + "jiti": "*" + }, + "peerDependenciesMeta": { + "jiti": { + "optional": true + } + } + }, + "node_modules/eslint-plugin-react": { + "version": "7.37.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.37.1.tgz", + "integrity": "sha512-xwTnwDqzbDRA8uJ7BMxPs/EXRB3i8ZfnOIp8BsxEQkT0nHPp+WWceqGgo6rKb9ctNi8GJLDT4Go5HAWELa/WMg==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-includes": "^3.1.8", + "array.prototype.findlast": "^1.2.5", + "array.prototype.flatmap": "^1.3.2", + "array.prototype.tosorted": "^1.1.4", + "doctrine": "^2.1.0", + "es-iterator-helpers": "^1.0.19", + "estraverse": "^5.3.0", + "hasown": "^2.0.2", + "jsx-ast-utils": "^2.4.1 || ^3.0.0", + "minimatch": "^3.1.2", + "object.entries": "^1.1.8", + "object.fromentries": "^2.0.8", + "object.values": "^1.2.0", + "prop-types": "^15.8.1", + "resolve": "^2.0.0-next.5", + "semver": "^6.3.1", + "string.prototype.matchall": "^4.0.11", + "string.prototype.repeat": "^1.0.0" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9.7" + } + }, + "node_modules/eslint-plugin-react-hooks": { + "version": "5.1.0-rc-fb9a90fa48-20240614", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.1.0-rc-fb9a90fa48-20240614.tgz", + "integrity": "sha512-xsiRwaDNF5wWNC4ZHLut+x/YcAxksUd9Rizt7LaEn3bV8VyYRpXnRJQlLOfYaVy9esk4DFP4zPPnoNVjq5Gc0w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0" + } + }, + "node_modules/eslint-plugin-react-refresh": { + "version": "0.4.12", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.12.tgz", + "integrity": "sha512-9neVjoGv20FwYtCP6CB1dzR1vr57ZDNOXst21wd2xJ/cTlM2xLq0GWVlSNTdMn/4BtP6cHYBMCSp1wFBJ9jBsg==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "eslint": ">=7" + } + }, + "node_modules/eslint-scope": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.1.0.tgz", + "integrity": "sha512-14dSvlhaVhKKsa9Fx1l8A17s7ah7Ef7wCakJ10LYk6+GYmP9yDti2oq2SEwcyndt6knfcZyhyxwY3i9yL78EQw==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.1.0.tgz", + "integrity": "sha512-Q7lok0mqMUSf5a/AdAZkA5a/gHcO6snwQClVNNvFKCAVlxXucdU8pKydU5ZVZjBx5xr37vGbFFWtLQYreLzrZg==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/eslint/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/eslint/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/eslint/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true, + "license": "MIT" + }, + "node_modules/eslint/node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/eslint/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/espree": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/espree/-/espree-10.2.0.tgz", + "integrity": "sha512-upbkBJbckcCNBDBDXEbuhjbP68n+scUd3k/U2EkyM9nw+I/jPiL4cLF/Al06CF96wRltFda16sxDFrxsI1v0/g==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "acorn": "^8.12.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^4.1.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esquery": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", + "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true, + "license": "MIT" + }, + "node_modules/file-entry-cache": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", + "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "flat-cache": "^4.0.0" + }, + "engines": { + "node": ">=16.0.0" + } + }, + "node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "license": "MIT", + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/flat-cache": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", + "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", + "dev": true, + "license": "MIT", + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.4" + }, + "engines": { + "node": ">=16" + } + }, + "node_modules/flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true, + "license": "ISC" + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/globals": { + "version": "15.11.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-15.11.0.tgz", + "integrity": "sha512-yeyNSjdbyVaWurlwCpcA6XNBrHTMIeDdj0/hnvX/OLJ9ekOXYbLsLinH/MucQyGvNnXhidTdNhTtJaffL2sMfw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/globalthis": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", + "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.2.1", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/ignore": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", + "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 4" + } + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "license": "MIT", + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-async-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", + "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-core-module": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", + "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-finalizationregistry": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", + "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-generator-function": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", + "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-map": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz", + "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-set": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz", + "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "license": "MIT", + "dependencies": { + "which-typed-array": "^1.1.14" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakmap": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz", + "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakset": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz", + "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true, + "license": "MIT" + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true, + "license": "ISC" + }, + "node_modules/iterator.prototype": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.3.tgz", + "integrity": "sha512-FW5iMbeQ6rBGm/oKgzq2aW4KvAGpxPzYES8N4g4xNXUKpL1mclMvOe+76AcLDTvD+Ze+sOpVhgdAQEKF4L9iGQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.2.1", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "reflect.getprototypeof": "^1.0.4", + "set-function-name": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "license": "MIT" + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "license": "MIT", + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsesc": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz", + "integrity": "sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==", + "dev": true, + "license": "MIT", + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true, + "license": "MIT", + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsx-ast-utils": { + "version": "3.3.5", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", + "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "object.assign": "^4.1.4", + "object.values": "^1.1.6" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "license": "MIT", + "dependencies": { + "json-buffer": "3.0.1" + } + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "license": "MIT", + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "license": "ISC", + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true, + "license": "MIT" + }, + "node_modules/node-releases": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz", + "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==", + "dev": true, + "license": "MIT" + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.entries": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", + "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.fromentries": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", + "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.values": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", + "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "license": "MIT", + "dependencies": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.5" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "license": "MIT", + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true, + "license": "MIT" + }, + "node_modules/picocolors": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", + "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", + "dev": true, + "license": "ISC" + }, + "node_modules/possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/postcss": { + "version": "8.4.47", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", + "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.1.0", + "source-map-js": "^1.2.1" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/prop-types": { + "version": "15.8.1", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", + "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", + "dev": true, + "license": "MIT", + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/react": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", + "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-dom": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", + "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0", + "scheduler": "^0.23.2" + }, + "peerDependencies": { + "react": "^18.3.1" + } + }, + "node_modules/react-is": { + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", + "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/react-refresh": { + "version": "0.14.2", + "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.2.tgz", + "integrity": "sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/reflect.getprototypeof": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz", + "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.1", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "which-builtin-type": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.3.tgz", + "integrity": "sha512-vqlC04+RQoFalODCbCumG2xIOvapzVMHwsyIGM/SIE8fRhFFsXeH8/QQ+s0T0kDAhKc4k30s73/0ydkHQz6HlQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve": { + "version": "2.0.0-next.5", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", + "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/rollup": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.24.0.tgz", + "integrity": "sha512-DOmrlGSXNk1DM0ljiQA+i+o0rSLhtii1je5wgk60j49d1jHT5YYttBv1iWOnYSTG+fZZESUOSNiAl89SIet+Cg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/estree": "1.0.6" + }, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=18.0.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.24.0", + "@rollup/rollup-android-arm64": "4.24.0", + "@rollup/rollup-darwin-arm64": "4.24.0", + "@rollup/rollup-darwin-x64": "4.24.0", + "@rollup/rollup-linux-arm-gnueabihf": "4.24.0", + "@rollup/rollup-linux-arm-musleabihf": "4.24.0", + "@rollup/rollup-linux-arm64-gnu": "4.24.0", + "@rollup/rollup-linux-arm64-musl": "4.24.0", + "@rollup/rollup-linux-powerpc64le-gnu": "4.24.0", + "@rollup/rollup-linux-riscv64-gnu": "4.24.0", + "@rollup/rollup-linux-s390x-gnu": "4.24.0", + "@rollup/rollup-linux-x64-gnu": "4.24.0", + "@rollup/rollup-linux-x64-musl": "4.24.0", + "@rollup/rollup-win32-arm64-msvc": "4.24.0", + "@rollup/rollup-win32-ia32-msvc": "4.24.0", + "@rollup/rollup-win32-x64-msvc": "4.24.0", + "fsevents": "~2.3.2" + } + }, + "node_modules/safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/scheduler": { + "version": "0.23.2", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", + "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0" + } + }, + "node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/source-map-js": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/string.prototype.matchall": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz", + "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "regexp.prototype.flags": "^1.5.2", + "set-function-name": "^2.0.2", + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.repeat": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/string.prototype.repeat/-/string.prototype.repeat-1.0.0.tgz", + "integrity": "sha512-0u/TldDbKD8bFCQ/4f5+mNRrXwZ8hg2w7ZR8wa16e8z9XpePWl3eGEcUD0OXpEH/VJH/2G3gjUtR3ZOiBe2S/w==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.5" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", + "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true, + "license": "MIT" + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "license": "MIT", + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", + "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz", + "integrity": "sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "escalade": "^3.2.0", + "picocolors": "^1.1.0" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/vite": { + "version": "5.4.9", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.9.tgz", + "integrity": "sha512-20OVpJHh0PAM0oSOELa5GaZNWeDjcAvQjGXy2Uyr+Tp+/D2/Hdz6NLgpJLsarPTA2QJ6v8mX2P1ZfbsSKvdMkg==", + "dev": true, + "license": "MIT", + "dependencies": { + "esbuild": "^0.21.3", + "postcss": "^8.4.43", + "rollup": "^4.20.0" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^18.0.0 || >=20.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.3" + }, + "peerDependencies": { + "@types/node": "^18.0.0 || >=20.0.0", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "sass-embedded": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.4.0" + }, + "peerDependenciesMeta": { + "@types/node": { + "optional": true + }, + "less": { + "optional": true + }, + "lightningcss": { + "optional": true + }, + "sass": { + "optional": true + }, + "sass-embedded": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "terser": { + "optional": true + } + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-builtin-type": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.4.tgz", + "integrity": "sha512-bppkmBSsHFmIMSl8BO9TbsyzsvGjVoppt8xUiGzwiu/bhDCGxnpOKCxgqj6GuyHE0mINMDecBFPlOm2hzY084w==", + "dev": true, + "license": "MIT", + "dependencies": { + "function.prototype.name": "^1.1.6", + "has-tostringtag": "^1.0.2", + "is-async-function": "^2.0.0", + "is-date-object": "^1.0.5", + "is-finalizationregistry": "^1.0.2", + "is-generator-function": "^1.0.10", + "is-regex": "^1.1.4", + "is-weakref": "^1.0.2", + "isarray": "^2.0.5", + "which-boxed-primitive": "^1.0.2", + "which-collection": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-collection": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz", + "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-map": "^2.0.3", + "is-set": "^2.0.3", + "is-weakmap": "^2.0.2", + "is-weakset": "^2.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "license": "MIT", + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true, + "license": "ISC" + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/react-psh-sprint5/package.json b/react-psh-sprint5/package.json new file mode 100644 index 00000000..bdbe6cf8 --- /dev/null +++ b/react-psh-sprint5/package.json @@ -0,0 +1,28 @@ +{ + "name": "react-psh-sprint5", + "private": true, + "version": "0.0.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build", + "lint": "eslint .", + "preview": "vite preview" + }, + "dependencies": { + "react": "^18.3.1", + "react-dom": "^18.3.1" + }, + "devDependencies": { + "@eslint/js": "^9.11.1", + "@types/react": "^18.3.10", + "@types/react-dom": "^18.3.0", + "@vitejs/plugin-react": "^4.3.2", + "eslint": "^9.11.1", + "eslint-plugin-react": "^7.37.0", + "eslint-plugin-react-hooks": "^5.1.0-rc.0", + "eslint-plugin-react-refresh": "^0.4.12", + "globals": "^15.9.0", + "vite": "^5.4.8" + } +} diff --git a/react-psh-sprint5/src/App.css b/react-psh-sprint5/src/App.css new file mode 100644 index 00000000..e69de29b diff --git a/react-psh-sprint5/src/App.jsx b/react-psh-sprint5/src/App.jsx new file mode 100644 index 00000000..d2760b42 --- /dev/null +++ b/react-psh-sprint5/src/App.jsx @@ -0,0 +1,11 @@ +import './App.css' + +function App() { + + return ( + <> + + ) +} + +export default App diff --git a/react-psh-sprint5/src/index.css b/react-psh-sprint5/src/index.css new file mode 100644 index 00000000..e69de29b diff --git a/react-psh-sprint5/src/main.jsx b/react-psh-sprint5/src/main.jsx new file mode 100644 index 00000000..ba1a5b2b --- /dev/null +++ b/react-psh-sprint5/src/main.jsx @@ -0,0 +1,7 @@ +import { createRoot } from 'react-dom/client' +import App from './App.jsx' +import './index.css' + +createRoot(document.getElementById('root')).render( + +) diff --git a/react-psh-sprint5/vite.config.js b/react-psh-sprint5/vite.config.js new file mode 100644 index 00000000..5a33944a --- /dev/null +++ b/react-psh-sprint5/vite.config.js @@ -0,0 +1,7 @@ +import { defineConfig } from 'vite' +import react from '@vitejs/plugin-react' + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [react()], +}) From 63061e4885768bea51967017960157b03c353632 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sat, 19 Oct 2024 04:07:19 +0900 Subject: [PATCH 02/12] 241019_sprint5 --- react-psh-sprint5/src/App.css | 4 + react-psh-sprint5/src/App.jsx | 13 +- .../src/components/AllItemCompo.jsx | 9 ++ react-psh-sprint5/src/components/Body.jsx | 15 ++ react-psh-sprint5/src/components/Body1.jsx | 18 +++ react-psh-sprint5/src/components/Body2.jsx | 34 ++++ react-psh-sprint5/src/components/Footer.jsx | 47 ++++++ react-psh-sprint5/src/components/Header.jsx | 22 +++ .../src/components/ItemCompo.jsx | 9 ++ react-psh-sprint5/src/components/Num.jsx | 17 ++ react-psh-sprint5/src/css/Footer.css | 86 ++++++++++ react-psh-sprint5/src/css/Header.css | 89 +++++++++++ react-psh-sprint5/src/css/Num.css | 29 ++++ react-psh-sprint5/src/css/body.css | 149 ++++++++++++++++++ react-psh-sprint5/src/css/button.css | 34 ++++ react-psh-sprint5/src/css/main.css | 10 ++ react-psh-sprint5/src/css/media-qu.css | 15 ++ react-psh-sprint5/src/css/reset.css | 42 +++++ react-psh-sprint5/src/icon/facebook-logo.svg | 3 + react-psh-sprint5/src/icon/instagram-logo.svg | 3 + react-psh-sprint5/src/icon/twitter-logo.svg | 3 + react-psh-sprint5/src/icon/youtube-logo.svg | 10 ++ react-psh-sprint5/src/image/PandaLogo.png | Bin 0 -> 2955 bytes 23 files changed, 658 insertions(+), 3 deletions(-) create mode 100644 react-psh-sprint5/src/components/AllItemCompo.jsx create mode 100644 react-psh-sprint5/src/components/Body.jsx create mode 100644 react-psh-sprint5/src/components/Body1.jsx create mode 100644 react-psh-sprint5/src/components/Body2.jsx create mode 100644 react-psh-sprint5/src/components/Footer.jsx create mode 100644 react-psh-sprint5/src/components/Header.jsx create mode 100644 react-psh-sprint5/src/components/ItemCompo.jsx create mode 100644 react-psh-sprint5/src/components/Num.jsx create mode 100644 react-psh-sprint5/src/css/Footer.css create mode 100644 react-psh-sprint5/src/css/Header.css create mode 100644 react-psh-sprint5/src/css/Num.css create mode 100644 react-psh-sprint5/src/css/body.css create mode 100644 react-psh-sprint5/src/css/button.css create mode 100644 react-psh-sprint5/src/css/main.css create mode 100644 react-psh-sprint5/src/css/media-qu.css create mode 100644 react-psh-sprint5/src/css/reset.css create mode 100644 react-psh-sprint5/src/icon/facebook-logo.svg create mode 100644 react-psh-sprint5/src/icon/instagram-logo.svg create mode 100644 react-psh-sprint5/src/icon/twitter-logo.svg create mode 100644 react-psh-sprint5/src/icon/youtube-logo.svg create mode 100644 react-psh-sprint5/src/image/PandaLogo.png diff --git a/react-psh-sprint5/src/App.css b/react-psh-sprint5/src/App.css index e69de29b..c5557956 100644 --- a/react-psh-sprint5/src/App.css +++ b/react-psh-sprint5/src/App.css @@ -0,0 +1,4 @@ +.APP { + display: flex; + flex-direction: column; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/App.jsx b/react-psh-sprint5/src/App.jsx index d2760b42..0a8484de 100644 --- a/react-psh-sprint5/src/App.jsx +++ b/react-psh-sprint5/src/App.jsx @@ -1,10 +1,17 @@ import './App.css' +import Header from './components/Header' +import Body from './components/Body' +import Num from './components/Num' +import Footer from './components/Footer' function App() { - return ( - <> - +
+
+ + +
+
) } diff --git a/react-psh-sprint5/src/components/AllItemCompo.jsx b/react-psh-sprint5/src/components/AllItemCompo.jsx new file mode 100644 index 00000000..41d5ff63 --- /dev/null +++ b/react-psh-sprint5/src/components/AllItemCompo.jsx @@ -0,0 +1,9 @@ +function AllItemCompo() { + return ( +
+
아이템
+
+ ); +} + +export default AllItemCompo; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Body.jsx b/react-psh-sprint5/src/components/Body.jsx new file mode 100644 index 00000000..aa3a2937 --- /dev/null +++ b/react-psh-sprint5/src/components/Body.jsx @@ -0,0 +1,15 @@ +import Body1 from "./Body1"; +import Body2 from "./Body2"; + + +function Body() { + return ( +
+ + +
+ ); +} + +export default Body; + diff --git a/react-psh-sprint5/src/components/Body1.jsx b/react-psh-sprint5/src/components/Body1.jsx new file mode 100644 index 00000000..10af3e79 --- /dev/null +++ b/react-psh-sprint5/src/components/Body1.jsx @@ -0,0 +1,18 @@ +import '../css/body.css'; +import ItemCompo from './ItemCompo'; + +function Body1() { + return ( +
+
베스트 상품
+
+ + + + +
+
+ ); +} + +export default Body1; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx new file mode 100644 index 00000000..0574d0ba --- /dev/null +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -0,0 +1,34 @@ +import '../css/body.css'; +import AllItemCompo from './AllItemCompo'; + +function Body2() { + return ( +
+
+
판매 중인 상품
+
+ + + +
+
+
+ + + + + + + + + + +
+
+ ); +} + +export default Body2; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Footer.jsx b/react-psh-sprint5/src/components/Footer.jsx new file mode 100644 index 00000000..f645b3bb --- /dev/null +++ b/react-psh-sprint5/src/components/Footer.jsx @@ -0,0 +1,47 @@ +import '../css/Footer.css' +import facebook from '../icon/facebook-logo.svg'; +import twitter from '../icon/twitter-logo.svg'; +import instagram from '../icon/instagram-logo.svg'; +import youtube from '../icon/youtube-logo.svg'; + + + +function Footer() { + return ( +
+ +
+ ); +} + +export default Footer; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Header.jsx b/react-psh-sprint5/src/components/Header.jsx new file mode 100644 index 00000000..df14a442 --- /dev/null +++ b/react-psh-sprint5/src/components/Header.jsx @@ -0,0 +1,22 @@ +import '../css/main.css'; + +import PandaLogo from '../image/PandaLogo.png'; + +function Header() { + return ( +
+
+
+ Panda Market Logo +
+

자유게시판

+

중고마켓

+
+ 로그인 +
+
+
+ ); +} + +export default Header; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/ItemCompo.jsx b/react-psh-sprint5/src/components/ItemCompo.jsx new file mode 100644 index 00000000..fd13e9d1 --- /dev/null +++ b/react-psh-sprint5/src/components/ItemCompo.jsx @@ -0,0 +1,9 @@ +import '../css/body.css' + +function ItemCompo() { + return ( +
아이템
+ ); +} + +export default ItemCompo; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Num.jsx b/react-psh-sprint5/src/components/Num.jsx new file mode 100644 index 00000000..77e85c28 --- /dev/null +++ b/react-psh-sprint5/src/components/Num.jsx @@ -0,0 +1,17 @@ +import '../css/Num.css' + +function Num() { + return ( +
+ + + + + + + +
+ ); +} + +export default Num; \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Footer.css b/react-psh-sprint5/src/css/Footer.css new file mode 100644 index 00000000..e18d2d57 --- /dev/null +++ b/react-psh-sprint5/src/css/Footer.css @@ -0,0 +1,86 @@ +@import './reset.css'; + +footer { + background: var(--color10); + gap: 10px; + display: flex; + position: relative; + justify-content: center; + align-items: flex-start; + opacity: 1; +} + +.footer-box { + width: calc(100%); + min-width: 390px; + gap: 0px; + display: flex; + position: relative; + justify-content: space-between; + opacity: 0px; + margin-top: 32.5px; + margin-bottom: 108px; + margin-left: 200px; + margin-right: 200px; +} + +.footer-box-inner1 { + height: 19px; + color: var(--color2); + font-size: 1rem; + font-weight: 400; + line-height: 19.09px; + text-align: center; +} + + +.footer-box-inner2 { + height: 19px; + gap: 30px; + display: flex; + position: relative; + align-items: flex-start; + justify-content: space-between; +} + +.footer-box-inner3 { + height: 20px; + gap: 12px; + display: flex; + justify-content: center; + align-items: center; + cursor: pointer; +} + +.footer-box-inner2-1 { + height: 19px; + font-size: 1rem; + font-weight: 400; + line-height: 19.09px; + text-align: center; + color: var(--color11); + text-decoration-line: none; + cursor: pointer; +} + +.footer-box-inner2-2 { + width: 29px; + height: 19px; + font-size: 1rem; + font-weight: 400; + line-height: 19.09px; + text-align: center; + color: var(--color11); + cursor: pointer; +} + +/* footer 끝 */ + +@media screen and (max-width: 1199px) { + .footer-box { + margin-left: 16px; + margin-right: 16px; + } +} + +@media screen and (max-width: 744px) {} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css new file mode 100644 index 00000000..5579c307 --- /dev/null +++ b/react-psh-sprint5/src/css/Header.css @@ -0,0 +1,89 @@ +@import "./button.css"; + +.header-contain { + width: 100%; + height: 81px; + background: #FFFFFF; + display: flex; + position: fixed; + z-index: 11; + padding-bottom : 26px; + + border-bottom : 1px solid #DFDFDF +} + +header { + width: calc(100% - 400px); + margin-top: 9.5px; + display: flex; + position: fixed; + z-index: 1; + align-items: center; + justify-content: center; + margin: 9.5px 200px; + box-sizing: border-box; + top: 0px; + background: #FFFFFF; +} + +.header-1 { + width: calc(100%); + min-width: 300px; + display: flex; + align-items: center; + position: relative; + justify-content: space-between; +} + +.header-1 img { + width: 100%; + width: 153px; + height: auto; + box-sizing: border-box; + +} + +.header-text { + width: 100%; + height: 100%; + display: flex; + padding-left: 24px; +} + +.header-text-1 { + min-width: 108px; + height: 68px; + padding: 21px 15px 21px 15px; + gap: 10px; + + font-size: 18px; + font-weight: 700; + line-height: 26px; + +} + +.header-text-2 { + min-width: 108px; + height: 68px; + padding: 21px 15px 21px 15px; + gap: 10px; + + font-size: 18px; + font-weight: 700; + line-height: 26px; +} + + +@media screen and (max-width: 1199px) { + header { + width: calc(100% - 48px); + min-width: 750px; + margin: 9.5px 24px; + } +} + +@media screen and (max-width: 800px) { + header { + min-width: 376px; + } +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Num.css b/react-psh-sprint5/src/css/Num.css new file mode 100644 index 00000000..b2d79fa6 --- /dev/null +++ b/react-psh-sprint5/src/css/Num.css @@ -0,0 +1,29 @@ +.number-box { + display: flex; + justify-content: space-between; + margin: 0 auto; + width: 304px; + height: 40px; + margin-bottom: 140px; +} + +.buttonNum { + display: flex; + justify-content: center; + align-items: center; + width: 40px; + height: 40px; + gap: 12.5px; + border-radius: 40px; + border: 1px solid #E5E7EB; + background-color: white; + font-size: 16px; + font-weight: 600; + line-height: 26px; +} + +.buttonNum:hover { + background-color: #2F80ED; + color : white; + cursor: pointer; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css new file mode 100644 index 00000000..7c776037 --- /dev/null +++ b/react-psh-sprint5/src/css/body.css @@ -0,0 +1,149 @@ +@import './reset.css'; + +.body-main { + display: flex; + margin: 43px auto; + flex-direction: column; + gap: 40px; +} + +.best-item { + width: 1200px; + display: flex; + flex-direction: column; + gap: 8px; + margin: 0 auto; + margin-top : 50px; + border: 1px solid black; +} + +/* 베스트상품 텍스트 들어간곳 */ +.best-item-text { + font-size: 20px; + font-weight: 700; + line-height: 32px; +} + +.item-container { + display: flex; + justify-content: space-between; + + border: 1px solid red; + ; +} + +/* item들 보여주는 클래스 */ +.ItemComponent { + width: 282px; + height: 378px; + border: 1px solid black; +} + +.all-item { + width: 1200px; + margin: 0 auto; + display: flex; + flex-direction: column; + gap : 24px; + + border: 2px solid green; +} + +.all-item-header { + display: flex; + justify-content: space-between; + align-items: center; +} + +.all-item-text { + width: 200px; + height: 32px; + font-size: 20px; + font-weight: 700; + line-height: 32px; + text-align: left; + display: flex; + align-items: center; +} + +.all-item-option { + width: 620px; + display: flex; + justify-content: space-between; + align-items: center; + gap: 4px; +} + +.all-item-searchbox { + width: 325px; + height: 42px; + padding: 9px 20px 9px 16px; + gap: 10px; + border-radius: 12px; + background-color: #F3F4F6; + font-size: 16px; + font-weight: 400; + line-height: 26px; + text-align: left; +} + +.all-item-searchbox:focus { + border: 1px solid black; +} + +.all-item-addButton { + padding: 12px 23px 12px 23px; + gap: 10px; + border-radius: 8px; + font-size: 16px; + font-weight: 600; + line-height: 26px; + text-align: left; + color: white; + background-color: #3692FF; + cursor: pointer; +} + +.selectBox { + width: 130px; + height: 42px; + border: 1px solid #E5E7EB; + padding: 12px 20px 12px 20px; + gap: 10px; + border-radius: 12px; + cursor: pointer; +} + +.selectBox:focus { + outline: none; +} + +.option1 { + width: 130px; + height: 42px; + border-radius: 12px 12px 0px 0px; + border: 1px; +} + +.option2 { + width: 130px; + height: 42px; + border-radius: 0px 0px 12px 12px; + border: 1px; +} + +.all-item-list { + display: flex; + flex-wrap: wrap; + justify-content: space-between; + gap : 12px; + border: 1px solid black; +} + +.All-item-list-item { + width: 221px; + height: 317px; + gap: 16px; + + border : 1px solid black; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/button.css b/react-psh-sprint5/src/css/button.css new file mode 100644 index 00000000..90aff5d3 --- /dev/null +++ b/react-psh-sprint5/src/css/button.css @@ -0,0 +1,34 @@ +@import "reset.css"; + +.button { + background: var(--color5); + gap: 10px; + border-radius: 8px; + opacity: 1; + color: var(--color1); + font-size: 1.25rem; + text-align: center; + text-decoration: none; + display: inline-block; + line-height: 48px; + cursor: pointer; +} + +.button-def { + min-width: 88px; + min-height: 42px; +} + +.button-alt { + border-radius: 40px; + opacity: 0px; + line-height: 56px; + margin-top: 32px; +} + +.icon { + width: 20px; + height: 20px; + border: none; + cursor: pointer; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/main.css b/react-psh-sprint5/src/css/main.css new file mode 100644 index 00000000..9db130ae --- /dev/null +++ b/react-psh-sprint5/src/css/main.css @@ -0,0 +1,10 @@ +@import './media-qu.css'; +@import './Header.css'; +@import './reset.css'; +@import './body.css'; + +* { + font-size: 16px; + font-family: 'Pretendard'; + box-sizing: border-box; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/media-qu.css b/react-psh-sprint5/src/css/media-qu.css new file mode 100644 index 00000000..47a36aeb --- /dev/null +++ b/react-psh-sprint5/src/css/media-qu.css @@ -0,0 +1,15 @@ +@import "reset.css"; + +@media screen and (max-width: 1199px) { + header { + width: calc(100% - 48px); + min-width: 750px; + margin: 9.5px 24px; + } +} + +@media screen and (max-width: 744px) { + header { + min-width: 375px; + } +} diff --git a/react-psh-sprint5/src/css/reset.css b/react-psh-sprint5/src/css/reset.css new file mode 100644 index 00000000..f85d3774 --- /dev/null +++ b/react-psh-sprint5/src/css/reset.css @@ -0,0 +1,42 @@ +@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.8/dist/web/static/pretendard.css"); + +:root { + --color1: #F3F4F6; + --color2: #9CA3AF; + --color3: #E6F2FF; + --color4: #3182F6; + --color5: #3692FF; + --white: #FFFFFF; + --color6: #007bff; + --color7: #F74747; + --color8: #CFE5FF; + --color9: #374151; + --color10: #111827; + --color11: #E5E7EB; +} + + +* { + margin: 0; + padding: 0; + border: 0; + font-size: 16px; + font: inherit; + + font-family: 'Pretendard'; + vertical-align: baseline; + box-sizing: border-box; +} + +body { + line-height: 1; +} + +input:focus { + outline: none; +} + +a { + color: inherit; + text-decoration: none; +} \ No newline at end of file diff --git a/react-psh-sprint5/src/icon/facebook-logo.svg b/react-psh-sprint5/src/icon/facebook-logo.svg new file mode 100644 index 00000000..8491c2f8 --- /dev/null +++ b/react-psh-sprint5/src/icon/facebook-logo.svg @@ -0,0 +1,3 @@ + + + diff --git a/react-psh-sprint5/src/icon/instagram-logo.svg b/react-psh-sprint5/src/icon/instagram-logo.svg new file mode 100644 index 00000000..c83306f8 --- /dev/null +++ b/react-psh-sprint5/src/icon/instagram-logo.svg @@ -0,0 +1,3 @@ + + + diff --git a/react-psh-sprint5/src/icon/twitter-logo.svg b/react-psh-sprint5/src/icon/twitter-logo.svg new file mode 100644 index 00000000..14a6069a --- /dev/null +++ b/react-psh-sprint5/src/icon/twitter-logo.svg @@ -0,0 +1,3 @@ + + + diff --git a/react-psh-sprint5/src/icon/youtube-logo.svg b/react-psh-sprint5/src/icon/youtube-logo.svg new file mode 100644 index 00000000..5fcc0ff3 --- /dev/null +++ b/react-psh-sprint5/src/icon/youtube-logo.svg @@ -0,0 +1,10 @@ + + + + + + + + + + diff --git a/react-psh-sprint5/src/image/PandaLogo.png b/react-psh-sprint5/src/image/PandaLogo.png new file mode 100644 index 0000000000000000000000000000000000000000..a1dc1c6a1737000f4a664f6418cf4c5b90d8ea8f GIT binary patch literal 2955 zcmV;63v~2}P)7*ni}BUf*D!Fqo}ZzZh>e4Tg{RQ}y1Ki3nY*5!pes~`^0yKy0000PbW%=J0D#}0 zzhEFhAfWG%P!O-ra4-<>U~mw?uzmfbng9R^^+`lQRCwC#-Dy+PKp4RB%_eDLQhEvK zCTUA;OIwjcQBD=a3lzNX`}qFf!SsOLbkjCRlP1pdd*O^lGlc)_W^>RY0000000000 z0000000000{$IrfJ(tIqNg$VTUeXs71ZJ+ZAaM}`C6#0qff-UHGDVV%z>LV4Oc{on zGokcKLe2D3B@z)4j+^nyG7BCUnyDs`NC^nUq$HAviE{|Vp_C_)%R@{TsZ0qm;~|n* zhzRgfwd{cfP<&((n=ArRQZb2*1{V#6rSV|dCn3N{?+gpGY{W2$6^0X&3n?F#u$E<| zdsq^pA<&olVF^df$VkKsSjwh=N@f67KanVq87LsollmzZCfR5#67RmgefjF;+c%$y z)5pK|%P-#CBQ}_1XGkGleSBs0y?Wqy`Gqy`fOrQ_v`3)eIpvmh;Uyh|4=fvv2?xv> zxAr!j+VNMQ-RSvG%a8jVrayZ7uK+QuCIP3-e}=wehT+nPICfR zrnxbhumpcQDh%%$<{sxk3^Ex%03UAd9{t|i+dtYpJGO!yG2?70dZT!1DS9-Q)RuIL zJwE#O<%7Zc^6T*I;l(7I#FoSx*;7m6Q6{M^2Wybh%;@TeTP zCFL^yF7Y=(eYccGQT(^mFhld-k{70>@01@-e{4Rq&TXC@-f}-^CbcCFc|CUY?H(b~ zExD8*zMWaT-BY)i&@yyOQBf2*TuYjgzp~@*`0y?la~oQQYe|J~x$R7O_sAOK4p;LL zw4Bs3gE9njcrz1hIYuRVe(nCvC;-4v)O3PJlScVvwEoeEhr6P{_2jN>jGtNDy zeQNjHkDJZM2lu%Xl!JD&*=*NqBaWD>QMXjH3%L}xEGSHX>D1`if-S3K7+!wbAwWQ*}AV zd^f$8r5y3%iZW14c1vZ{C*VnQXi6<#J6AsZ9g+iPSXvYtlbK{&zFTH+4+)B%5+=B% zOgj$K5f!rKv*GImyOvX%wyaxDn`YmdL6v>CBt8Fk%Pbi|n@7`Y`EF{&9XMygw4aX^?t%RIBOMU5{h%%Q2a+@@!jT+1WFU|ZVkzuqzqtqYyO z8KyyPq`GBv*Vc2BN``M)rps7vj(vD|WdC{J*>d;rn44owXgRT^!k3(O%lF2)9kb`Y zHH1IEqz?F&H==H-67S?cmKf(mLC&h_eh#m<`jHAM3c=U$ zlD}9`y_i|=m}YIuqPj2eYo8OpEf+->x?q!KSt-&RxM_c;vY^X!U!rKa%|BC6+jI=e zTD8`;U+Fxq*%R$!{t}*TebOCF6vqG3ax76|1#3y~L@(1P@SdN>lOg_g0mq*~0t^ot*s z`+-|30xJtG1GH?=5G$dd!>f?MEd|07V`*8Eb^JfI+-?Q@4Fo#FQjPSqR0kcC(NYW9 zk`7E7GhE6FNkdCDyP)@<*+@)Fm4s?ZJu-q#v;42q?kBjVsw!Do5Oa7?F;OjL!otB@ zmRkmO-TTnw-m{=VB5yevVQG>iVH?*kNJ~v(;Ays0F=0tTTGI29AT`(542KPpxRxG7 z|9*Ir<%okGWpRzs zVb2J(4AfG=#MR}zBnq;kPTtSS?`yccwzIOnzT}9ww7#afHOvb>_(v`~mTEfJllAcu&BTvRCZx{jHSS4fS6WdY~^;xtm z73nFi4|#6A6uKr~a)PV=TS~HbbHQ3_xk53X_jRTeQIaqw0qKaLlL^ZEj|^X0jrU|C z-CN6`6yHC7P10o*+2U?lBw;8cFE5PDd86fZL^f857um$L)NoEO(Bn?*Ei)tp9B5PT z_ckU3t!(VAZWE7+aki8=IZ+e^L6#MD&hI@h$)h>1$4iX_CkEeCd3C?>?BvFyO64M8 zrE=qBqp|S(Su@j*sl_eaFhU8@C>G;g> zi{jX2pykM)KNbth#P3kgkC@&h5;GA&OKS1rJXaLt;vDiOGcOU{?R$?|26<^kJWGpDT6ymd000000002M${rL2&Q6hdQ%nE=002ovPDHLkV1oV- B%lrTU literal 0 HcmV?d00001 From ce5f06d9b834297c8ac2795596c79ca94e48a47a Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sun, 20 Oct 2024 04:41:30 +0900 Subject: [PATCH 03/12] =?UTF-8?q?header=EB=B6=80=EB=B6=84=20=EA=B0=84?= =?UTF-8?q?=EB=8B=A8=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/src/components/Header.jsx | 6 ++-- react-psh-sprint5/src/css/Header.css | 34 +++++++++++---------- 2 files changed, 21 insertions(+), 19 deletions(-) diff --git a/react-psh-sprint5/src/components/Header.jsx b/react-psh-sprint5/src/components/Header.jsx index df14a442..6af2e447 100644 --- a/react-psh-sprint5/src/components/Header.jsx +++ b/react-psh-sprint5/src/components/Header.jsx @@ -7,10 +7,10 @@ function Header() {
- Panda Market Logo + Panda Market Logo
-

자유게시판

-

중고마켓

+

자유게시판

+

중고마켓

로그인
diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css index 5579c307..4ca7a433 100644 --- a/react-psh-sprint5/src/css/Header.css +++ b/react-psh-sprint5/src/css/Header.css @@ -8,8 +8,8 @@ position: fixed; z-index: 11; padding-bottom : 26px; - - border-bottom : 1px solid #DFDFDF + align-items: center; + border-bottom : 1px solid #DFDFDF; } header { @@ -24,53 +24,55 @@ header { box-sizing: border-box; top: 0px; background: #FFFFFF; + } .header-1 { width: calc(100%); min-width: 300px; + height: 70px; display: flex; align-items: center; - position: relative; justify-content: space-between; + } .header-1 img { - width: 100%; width: 153px; - height: auto; - box-sizing: border-box; - } .header-text { width: 100%; height: 100%; display: flex; + position: relative; padding-left: 24px; + top : 0; + bottom: 0; } .header-text-1 { + display: block; min-width: 108px; - height: 68px; padding: 21px 15px 21px 15px; gap: 10px; - font-size: 18px; - font-weight: 700; - line-height: 26px; - + font-weight: bold; + line-height: 35px; +} +.header-text-1:hover, .header-text-2:hover { + color : orange; + transition: 0.5s; } .header-text-2 { + display: block; min-width: 108px; - height: 68px; padding: 21px 15px 21px 15px; gap: 10px; - font-size: 18px; - font-weight: 700; - line-height: 26px; + font-weight: bold; + line-height: 35px; } From f95f39374b19223ba2e92fe9e103022fab5d39d2 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sun, 20 Oct 2024 21:41:53 +0900 Subject: [PATCH 04/12] =?UTF-8?q?Num.jsx=20=EC=95=84=EC=95=84=EC=BD=98?= =?UTF-8?q?=EC=B6=94=EA=B0=80/1020?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/index.html | 28 +++++++++++++--------- react-psh-sprint5/src/components/Body2.jsx | 6 +++-- react-psh-sprint5/src/components/Num.jsx | 12 ++++++++-- react-psh-sprint5/src/css/Num.css | 3 ++- react-psh-sprint5/src/css/body.css | 23 ++++++++---------- react-psh-sprint5/src/css/button.css | 2 ++ 6 files changed, 45 insertions(+), 29 deletions(-) diff --git a/react-psh-sprint5/index.html b/react-psh-sprint5/index.html index 0c589ecc..f1f38ddb 100644 --- a/react-psh-sprint5/index.html +++ b/react-psh-sprint5/index.html @@ -1,13 +1,19 @@ - - - - - Vite + React - - -
- - - + + + + + + Vite + React + + + + + +
+ + + + \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx index 0574d0ba..47aac584 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -9,10 +9,12 @@ function Body2() {
+ +
diff --git a/react-psh-sprint5/src/components/Num.jsx b/react-psh-sprint5/src/components/Num.jsx index 77e85c28..0fa363ba 100644 --- a/react-psh-sprint5/src/components/Num.jsx +++ b/react-psh-sprint5/src/components/Num.jsx @@ -3,13 +3,21 @@ import '../css/Num.css' function Num() { return (
- + - +
); } diff --git a/react-psh-sprint5/src/css/Num.css b/react-psh-sprint5/src/css/Num.css index b2d79fa6..076735d1 100644 --- a/react-psh-sprint5/src/css/Num.css +++ b/react-psh-sprint5/src/css/Num.css @@ -18,7 +18,7 @@ border: 1px solid #E5E7EB; background-color: white; font-size: 16px; - font-weight: 600; + font-weight: bold; line-height: 26px; } @@ -26,4 +26,5 @@ background-color: #2F80ED; color : white; cursor: pointer; + transition: 0.5s; } \ No newline at end of file diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index 7c776037..bcc80641 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -118,18 +118,11 @@ outline: none; } -.option1 { - width: 130px; - height: 42px; - border-radius: 12px 12px 0px 0px; - border: 1px; -} - -.option2 { - width: 130px; - height: 42px; - border-radius: 0px 0px 12px 12px; - border: 1px; +.selectBox option { + background-color: white; + color: black; + padding: 12px 20px; + cursor: pointer; } .all-item-list { @@ -146,4 +139,8 @@ gap: 16px; border : 1px solid black; -} \ No newline at end of file +} + + + + diff --git a/react-psh-sprint5/src/css/button.css b/react-psh-sprint5/src/css/button.css index 90aff5d3..67ef2280 100644 --- a/react-psh-sprint5/src/css/button.css +++ b/react-psh-sprint5/src/css/button.css @@ -1,5 +1,7 @@ @import "reset.css"; + + .button { background: var(--color5); gap: 10px; From f59d45d1ac5169ea9def89a8064b9db1dd26248d Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Mon, 21 Oct 2024 17:35:47 +0900 Subject: [PATCH 05/12] =?UTF-8?q?1021=20=EC=9E=91=EC=97=85=EB=A7=88?= =?UTF-8?q?=EB=AC=B4=EB=A6=ACcommit?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/index.html | 2 +- react-psh-sprint5/src/components/Body1.jsx | 114 +++++++++++- react-psh-sprint5/src/components/Body2.jsx | 41 +++-- react-psh-sprint5/src/components/Footer.jsx | 22 +-- react-psh-sprint5/src/components/Num.jsx | 4 +- react-psh-sprint5/src/css/Header.css | 4 +- react-psh-sprint5/src/css/body.css | 192 ++++++++++++-------- react-psh-sprint5/src/css/body2.css | 185 +++++++++++++++++++ 8 files changed, 450 insertions(+), 114 deletions(-) create mode 100644 react-psh-sprint5/src/css/body2.css diff --git a/react-psh-sprint5/index.html b/react-psh-sprint5/index.html index f1f38ddb..1d86df50 100644 --- a/react-psh-sprint5/index.html +++ b/react-psh-sprint5/index.html @@ -8,7 +8,7 @@ Vite + React + href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&icon_names=chevron_left,chevron_right,favorite" /> diff --git a/react-psh-sprint5/src/components/Body1.jsx b/react-psh-sprint5/src/components/Body1.jsx index 10af3e79..9514cbee 100644 --- a/react-psh-sprint5/src/components/Body1.jsx +++ b/react-psh-sprint5/src/components/Body1.jsx @@ -1,15 +1,119 @@ import '../css/body.css'; -import ItemCompo from './ItemCompo'; + +import { useEffect, useState } from 'react'; + function Body1() { + + const [products, setProducts] = useState([]); + + useEffect(() => { + fetch('https://panda-market-api.vercel.app/products?page=1&pageSize=10&orderBy=favorite') + .then((response) => response.json()) + .then((data) => { + const sortedProducts = data.list.sort((a, b) => b.favoriteCount - a.favoriteCount).slice(0, 4); + setProducts(sortedProducts); + }) + .catch((error) => console.error('Error fetching data:', error)); + }, []); + return (
베스트 상품
- - - - + +
+ {products[0] && ( +
+
+ {products[0].name[0]} +
+
+
{products[0].description}
+
{products[0].price}원
+
+ + + favorite + + +
+ {products[0].favoriteCount} +
+
+
+
+ )} +
+
+ {products[1] && ( +
+
+ {products[1].name} +
+
+
{products[1].description}
+
{products[1].price}원
+
+ + + favorite + + +
+ {products[1].favoriteCount} +
+
+
+
+ )} +
+
+ {products[2] && ( +
+
+ {products[2].name} +
+
+
{products[2].description}
+
{products[2].price}원
+
+ + + favorite + + +
+ {products[2].favoriteCount} +
+
+
+
+ )} +
+
+ {products[3] && ( +
+
+ {products[3].name} +
+
+
{products[3].description}
+
{products[3].price}원
+
+ + + favorite + + +
+ {products[3].favoriteCount} +
+
+
+
+ )} +
); diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx index 47aac584..2af9b7fe 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -1,13 +1,14 @@ -import '../css/body.css'; -import AllItemCompo from './AllItemCompo'; +import '../css/body2.css'; +// import { useEffect, useState } from 'react'; function Body2() { + return (
판매 중인 상품
- + + +
+
+
- - - - - - - - - - +
아이템
+
아이템
+
아이템
+
아이템
+
아이템
+
아이템
+
아이템
+
아이템
+
아이템
+
아이템
); diff --git a/react-psh-sprint5/src/components/Footer.jsx b/react-psh-sprint5/src/components/Footer.jsx index f645b3bb..0197463f 100644 --- a/react-psh-sprint5/src/components/Footer.jsx +++ b/react-psh-sprint5/src/components/Footer.jsx @@ -10,35 +10,35 @@ function Footer() { return (
); diff --git a/react-psh-sprint5/src/components/Num.jsx b/react-psh-sprint5/src/components/Num.jsx index 0fa363ba..bb68b4dc 100644 --- a/react-psh-sprint5/src/components/Num.jsx +++ b/react-psh-sprint5/src/components/Num.jsx @@ -4,7 +4,7 @@ function Num() { return (
@@ -14,7 +14,7 @@ function Num() { diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css index 4ca7a433..42d82d6c 100644 --- a/react-psh-sprint5/src/css/Header.css +++ b/react-psh-sprint5/src/css/Header.css @@ -53,8 +53,8 @@ header { .header-text-1 { display: block; - min-width: 108px; - padding: 21px 15px 21px 15px; + min-width: 110px; + padding: 21px 15px; gap: 10px; font-size: 18px; font-weight: bold; diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index bcc80641..67fc7bf4 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -2,19 +2,19 @@ .body-main { display: flex; - margin: 43px auto; + margin: 45px auto; flex-direction: column; gap: 40px; } .best-item { - width: 1200px; + width: 100%; + max-width: 1200px; display: flex; flex-direction: column; gap: 8px; margin: 0 auto; - margin-top : 50px; - border: 1px solid black; + margin-top: 50px; } /* 베스트상품 텍스트 들어간곳 */ @@ -27,120 +27,152 @@ .item-container { display: flex; justify-content: space-between; - - border: 1px solid red; - ; + gap: 24px; } /* item들 보여주는 클래스 */ .ItemComponent { width: 282px; height: 378px; - border: 1px solid black; -} - -.all-item { - width: 1200px; - margin: 0 auto; display: flex; flex-direction: column; - gap : 24px; + justify-content: center; + align-items: center; +} - border: 2px solid green; +.contain-img { + width: 282px; + height: 282px; + border-radius: 16px; } -.all-item-header { - display: flex; - justify-content: space-between; - align-items: center; +.contain-img img { + width: 282px; } -.all-item-text { - width: 200px; - height: 32px; - font-size: 20px; - font-weight: 700; - line-height: 32px; - text-align: left; +.contain-text { + width: 100%; + gap: 10px; display: flex; - align-items: center; + flex-direction: column; + justify-content: space-around; } -.all-item-option { - width: 620px; - display: flex; - justify-content: space-between; - align-items: center; - gap: 4px; +.contain-text-product-des { + height: 24px; + font-size: 14px; + font-weight: 500; + line-height: 24px; + text-align: left; } -.all-item-searchbox { - width: 325px; - height: 42px; - padding: 9px 20px 9px 16px; - gap: 10px; - border-radius: 12px; - background-color: #F3F4F6; +.contain-text-price { + height: 26px; font-size: 16px; - font-weight: 400; + font-weight: 700; line-height: 26px; text-align: left; } -.all-item-searchbox:focus { - border: 1px solid black; +.contain-text-like { + height: 18px; + display: flex; + position: relative; + gap: 2px; + } -.all-item-addButton { - padding: 12px 23px 12px 23px; - gap: 10px; - border-radius: 8px; - font-size: 16px; - font-weight: 600; - line-height: 26px; - text-align: left; - color: white; - background-color: #3692FF; - cursor: pointer; + +.like-button { + display: flex; } -.selectBox { - width: 130px; - height: 42px; - border: 1px solid #E5E7EB; - padding: 12px 20px 12px 20px; - gap: 10px; - border-radius: 12px; +.like-button:hover { cursor: pointer; + color: paleturquoise; + transition: 0.5s; } -.selectBox:focus { - outline: none; +.favorite-icon { + font-size: 16px; } -.selectBox option { - background-color: white; - color: black; - padding: 12px 20px; - cursor: pointer; -} +.contain-text-like-fs { + font-size: 12px; + font-weight: 500; + line-height: 16px; + text-align: left; -.all-item-list { - display: flex; - flex-wrap: wrap; - justify-content: space-between; - gap : 12px; - border: 1px solid black; } -.All-item-list-item { - width: 221px; - height: 317px; - gap: 16px; +@media screen and (max-width: 1199px) { + .best-item { + width: 85%; + min-width: 720px; + justify-content: center; + } + + .best-item-text{ + width: 87%; + min-width: 750px; + margin : 0 auto; + } + .item-container { + width: 100%; + min-width: 720px; + border-radius: 19.46px; + margin: 0 auto; + display: flex; + justify-content: space-around; + } + + .ItemComponent { + width: 343px; + height: auto; + } + + .contain-img { + width: 343px; + height: 343px; + border-radius: 16px; + } + + .contain-img img { + width: 343px; + } + + .ItemCompo2, + .ItemCompo3 { + display: none; + + } - border : 1px solid black; } +@media screen and (max-width: 800px) { + + .best-item { + width: 100%; + min-width: 343px; + } + + .ItemCompo4 { + display: none; + } + + .ItemComponent { + width: 343px; + height: 482px; + gap: 16px; + } + .best-item-text{ + width: 45%; + min-width: 343px; + } + .item-container { + min-width: 343px; + } +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css new file mode 100644 index 00000000..22ca019a --- /dev/null +++ b/react-psh-sprint5/src/css/body2.css @@ -0,0 +1,185 @@ +@import './reset.css'; + +.all-item { + width: 1200px; + margin: 0 auto; + display: flex; + flex-direction: column; + gap: 24px; +} + +.all-item-header { + display: flex; + justify-content: space-between; + align-items: center; + border : 1px solid black; +} +.all-item-header2 { + display: none; +} + +.all-item-text { + min-width: 150px; + font-size: 20px; + font-weight: 700; + line-height: 32px; + text-align: left; + display: flex; + align-items: center; +} + +.all-item-option { + width: 620px; + display: flex; + justify-content: space-between; + align-items: center; + gap: 4px; +} + +.all-item-searchBox { + width: 325px; + height: 42px; + padding: 9px 20px 9px 16px; + gap: 10px; + border-radius: 12px; + background-color: #F3F4F6; + font-size: 16px; + font-weight: 400; + line-height: 26px; + text-align: left; +} + +.all-item-searchBox:hover { + border: 1px solid black; +} + +.all-item-addButton { + min-width: 133px; + padding: 12px 23px; + gap: 10px; + border-radius: 8px; + font-size: 16px; + font-weight: 600; + line-height: 26px; + text-align: left; + color: white; + background-color: #3692FF; + cursor: pointer; +} + +.selectBox { + width: 130px; + height: 42px; + border: 1px solid #E5E7EB; + padding: 12px 20px; + gap: 10px; + border-radius: 12px; + cursor: pointer; +} + +.selectBox:focus { + outline: none; +} + +.all-item-list { + display: flex; + flex-wrap: wrap; + justify-content: space-between; + gap: 12px; + +} + +.All-item-list-item { + display: block; + width: 221px; + height: 317px; + gap: 16px; + + border: 1px solid black; +} + +@media screen and (max-width: 1199px) { + .all-item { + width: 80%; + min-width: 750px; + justify-content: center; + padding: 0 24px; + } + + .all-item-list { + width: 100%; + min-width: 695px; + display: flex; + gap : 16px; + } + .All-item-list-item:nth-child(n+7) { + display: none; + + } + + .all-item-searchBox { + width: 242px; + } + + .all-item-option{ + width: 529px; + } +} + +@media screen and (max-width: 800px) { + .all-item-header { + display: none; + } + .all-item-header2 { + display:block; + width: 100%; + display: flex; + flex-direction: column; + margin:0 auto; + gap:10px; + } + .all-item-header2 .all-item-text { + width: 100%; + display: flex; + justify-content: space-between; + margin-left : 10px; + } + .all-item-header2 .all-item-searchBox { + width: 100%; + } + .all-item-header2 .all-item-option{ + min-width: 344px; + width: 100%; + justify-content: space-between; + } + .all-item-header2 .selectBox{ + width: 50px; + } + .all-item-header2 .all-item-addButton{ + width: 133px; + margin-top : 5px; + margin-right:45px; + } + + .all-item { + width: 100%; + min-width: 344px; + justify-content: center; + } + .all-item-list { + min-width: 344px; + display: grid; + grid-template-columns: repeat(2, 1fr); + margin : 0 auto; + justify-content: space-around; + } + + .All-item-list-item{ + margin: 0 auto; + } + + .All-item-list-item:nth-child(n+5) { + display: none; + } + +} \ No newline at end of file From 5f990e40a10eaf3363fc72fb57de749358c07025 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Tue, 22 Oct 2024 18:37:15 +0900 Subject: [PATCH 06/12] =?UTF-8?q?1022=EC=9E=91=EC=97=85=20=EB=A7=88?= =?UTF-8?q?=EB=AC=B4=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/index.html | 3 +- react-psh-sprint5/package-lock.json | 100 ++++++++++++++ react-psh-sprint5/package.json | 1 + react-psh-sprint5/src/App.jsx | 4 +- react-psh-sprint5/src/api/getProductsList.jsx | 13 ++ .../src/components/AllItemCompo.jsx | 9 -- react-psh-sprint5/src/components/Body1.jsx | 126 ++++-------------- react-psh-sprint5/src/components/Body2.jsx | 115 +++++++++++++--- .../src/components/{Body.jsx => BodyMain.jsx} | 4 +- .../src/components/ItemCompo.jsx | 9 -- react-psh-sprint5/src/css/Footer.css | 2 +- react-psh-sprint5/src/css/Header.css | 2 +- react-psh-sprint5/src/css/Num.css | 2 + react-psh-sprint5/src/css/body.css | 68 ++++++---- react-psh-sprint5/src/css/body2.css | 121 ++++++++++++----- react-psh-sprint5/src/css/reset.css | 1 - react-psh-sprint5/src/icon/btn_sort.svg | 8 ++ 17 files changed, 391 insertions(+), 197 deletions(-) create mode 100644 react-psh-sprint5/src/api/getProductsList.jsx delete mode 100644 react-psh-sprint5/src/components/AllItemCompo.jsx rename react-psh-sprint5/src/components/{Body.jsx => BodyMain.jsx} (79%) delete mode 100644 react-psh-sprint5/src/components/ItemCompo.jsx create mode 100644 react-psh-sprint5/src/icon/btn_sort.svg diff --git a/react-psh-sprint5/index.html b/react-psh-sprint5/index.html index 1d86df50..b952accd 100644 --- a/react-psh-sprint5/index.html +++ b/react-psh-sprint5/index.html @@ -3,12 +3,11 @@ - Vite + React + href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&icon_names=chevron_left,chevron_right,favorite,menu,search" /> diff --git a/react-psh-sprint5/package-lock.json b/react-psh-sprint5/package-lock.json index 726ee438..d81feb94 100644 --- a/react-psh-sprint5/package-lock.json +++ b/react-psh-sprint5/package-lock.json @@ -8,6 +8,7 @@ "name": "react-psh-sprint5", "version": "0.0.0", "dependencies": { + "axios": "^1.7.7", "react": "^18.3.1", "react-dom": "^18.3.1" }, @@ -1508,6 +1509,12 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "license": "MIT" + }, "node_modules/available-typed-arrays": { "version": "1.0.7", "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", @@ -1524,6 +1531,17 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/axios": { + "version": "1.7.7", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.7.tgz", + "integrity": "sha512-S4kL7XrjgBmvdGut0sN3yJxqYzrDOnivkBiN0OFs6hLiUam3UPvswUo0kqGyhqUZGEOytHyumEdXsAkgCOUf3Q==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, "node_modules/balanced-match": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", @@ -1658,6 +1676,18 @@ "dev": true, "license": "MIT" }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "license": "MIT", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, "node_modules/concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", @@ -1809,6 +1839,15 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, "node_modules/doctrine": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", @@ -2426,6 +2465,26 @@ "dev": true, "license": "ISC" }, + "node_modules/follow-redirects": { + "version": "1.15.9", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", + "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "license": "MIT", + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, "node_modules/for-each": { "version": "0.3.3", "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", @@ -2436,6 +2495,20 @@ "is-callable": "^1.1.3" } }, + "node_modules/form-data": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", + "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", + "license": "MIT", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, "node_modules/fsevents": { "version": "2.3.3", "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", @@ -3271,6 +3344,27 @@ "yallist": "^3.0.2" } }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, "node_modules/minimatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", @@ -3586,6 +3680,12 @@ "react-is": "^16.13.1" } }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "license": "MIT" + }, "node_modules/punycode": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", diff --git a/react-psh-sprint5/package.json b/react-psh-sprint5/package.json index bdbe6cf8..af1f3ae4 100644 --- a/react-psh-sprint5/package.json +++ b/react-psh-sprint5/package.json @@ -10,6 +10,7 @@ "preview": "vite preview" }, "dependencies": { + "axios": "^1.7.7", "react": "^18.3.1", "react-dom": "^18.3.1" }, diff --git a/react-psh-sprint5/src/App.jsx b/react-psh-sprint5/src/App.jsx index 0a8484de..796fed08 100644 --- a/react-psh-sprint5/src/App.jsx +++ b/react-psh-sprint5/src/App.jsx @@ -1,6 +1,6 @@ import './App.css' import Header from './components/Header' -import Body from './components/Body' +import BodyMain from './components/BodyMain' import Num from './components/Num' import Footer from './components/Footer' @@ -8,7 +8,7 @@ function App() { return (
- +
diff --git a/react-psh-sprint5/src/api/getProductsList.jsx b/react-psh-sprint5/src/api/getProductsList.jsx new file mode 100644 index 00000000..c45f4179 --- /dev/null +++ b/react-psh-sprint5/src/api/getProductsList.jsx @@ -0,0 +1,13 @@ +import axios from "axios"; + +const getProductsList = async (search="", option="favorite") => { + try { + const response = await axios.get(`https://panda-market-api.vercel.app/products?orderBy=${option}&keyword=${search}`); + return response.data.list; + } catch (error) { + console.log(error); + } +}; + +export default getProductsList; + diff --git a/react-psh-sprint5/src/components/AllItemCompo.jsx b/react-psh-sprint5/src/components/AllItemCompo.jsx deleted file mode 100644 index 41d5ff63..00000000 --- a/react-psh-sprint5/src/components/AllItemCompo.jsx +++ /dev/null @@ -1,9 +0,0 @@ -function AllItemCompo() { - return ( -
-
아이템
-
- ); -} - -export default AllItemCompo; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/Body1.jsx b/react-psh-sprint5/src/components/Body1.jsx index 9514cbee..8f92c777 100644 --- a/react-psh-sprint5/src/components/Body1.jsx +++ b/react-psh-sprint5/src/components/Body1.jsx @@ -1,121 +1,51 @@ import '../css/body.css'; +import getProductsList from '../api/getProductsList.jsx'; import { useEffect, useState } from 'react'; function Body1() { - const [products, setProducts] = useState([]); + const updateProducts = async () => { + const axiosProducts = await getProductsList(); + setProducts(axiosProducts); + } useEffect(() => { - fetch('https://panda-market-api.vercel.app/products?page=1&pageSize=10&orderBy=favorite') - .then((response) => response.json()) - .then((data) => { - const sortedProducts = data.list.sort((a, b) => b.favoriteCount - a.favoriteCount).slice(0, 4); - setProducts(sortedProducts); - }) - .catch((error) => console.error('Error fetching data:', error)); + updateProducts(); }, []); return (
-
베스트 상품
+
+ 베스트 상품 +
- -
- {products[0] && ( -
-
- {products[0].name[0]} -
-
-
{products[0].description}
-
{products[0].price}원
-
- - - favorite - - -
- {products[0].favoriteCount} -
-
-
-
- )} -
-
- {products[1] && ( -
-
- {products[1].name} -
-
-
{products[1].description}
-
{products[1].price}원
-
- - - favorite - - -
- {products[1].favoriteCount} -
-
-
-
- )} -
-
- {products[2] && ( -
-
- {products[2].name} -
-
-
{products[2].description}
-
{products[2].price}원
-
- - - favorite - - -
- {products[2].favoriteCount} -
-
-
+ {(products.map((product, index) => ( +
+
+ {product.name}
- )} -
-
- {products[3] && ( -
-
- {products[3].name} -
-
-
{products[3].description}
-
{products[3].price}원
-
- - - favorite - - -
- {products[3].favoriteCount} -
+
+
{product.name}
+
{product.price}원
+
+ + + favorite + + +
+ {products[0].favoriteCount}
- )} -
+
+ )) + )}
+ ); } diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx index 2af9b7fe..6ec46fe6 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -1,19 +1,71 @@ import '../css/body2.css'; -// import { useEffect, useState } from 'react'; +import { useEffect, useState } from 'react'; +import getProductsList from '../api/getProductsList.jsx'; function Body2() { + const [products, setProducts] = useState([]); + const [option, setOption] = useState('recent'); + const [tempSearch, setTempSearch] = useState(""); + const [search, setSearch] = useState("갤럭시"); + const updateProducts = async () => { + const axiosProducts = await getProductsList(search, option); + setProducts(axiosProducts); + }; + + useEffect(() => { + updateProducts(search, option); + }, [search, option]); + + const filterProductsBySearch = () => { + if (!search) return products; + return products.filter((products) => + products.name.toLowerCase().includes(search.toLowerCase()) + ); + } + + const onChangeSearch = (e) => { + setTempSearch(e.target.value); + } + + const onClickSearch = () => { + setSearch(tempSearch); + setTempSearch(""); + } + const onKeyDown = (e) => { + if (e.keyCode === 13) { + onClickSearch(); + } + } + const onChangeSortOption = (e) => { + setOption(e.target.value); + }; + + const filteredSearch = filterProductsBySearch(); return (
판매 중인 상품
- + - + +
@@ -24,25 +76,50 @@ function Body2() {
- - + + + search + + +
+ + +
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
-
아이템
+ {products.length === 0 ? (

상품이 없습니다.

) : + (products.map((product, index) => ( +
+
+ {product.name} +
+
+
{product.name}
+
{product.price}원
+
+ + + favorite + + + {product.favoriteCount}
+
+
+ )) + )}
); diff --git a/react-psh-sprint5/src/components/Body.jsx b/react-psh-sprint5/src/components/BodyMain.jsx similarity index 79% rename from react-psh-sprint5/src/components/Body.jsx rename to react-psh-sprint5/src/components/BodyMain.jsx index aa3a2937..52ac515f 100644 --- a/react-psh-sprint5/src/components/Body.jsx +++ b/react-psh-sprint5/src/components/BodyMain.jsx @@ -2,7 +2,7 @@ import Body1 from "./Body1"; import Body2 from "./Body2"; -function Body() { +function BodyMain() { return (
@@ -11,5 +11,5 @@ function Body() { ); } -export default Body; +export default BodyMain; diff --git a/react-psh-sprint5/src/components/ItemCompo.jsx b/react-psh-sprint5/src/components/ItemCompo.jsx deleted file mode 100644 index fd13e9d1..00000000 --- a/react-psh-sprint5/src/components/ItemCompo.jsx +++ /dev/null @@ -1,9 +0,0 @@ -import '../css/body.css' - -function ItemCompo() { - return ( -
아이템
- ); -} - -export default ItemCompo; \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Footer.css b/react-psh-sprint5/src/css/Footer.css index e18d2d57..67ab9e65 100644 --- a/react-psh-sprint5/src/css/Footer.css +++ b/react-psh-sprint5/src/css/Footer.css @@ -76,7 +76,7 @@ footer { /* footer 끝 */ -@media screen and (max-width: 1199px) { +@media screen and (max-width: 1230px) { .footer-box { margin-left: 16px; margin-right: 16px; diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css index 42d82d6c..8c464370 100644 --- a/react-psh-sprint5/src/css/Header.css +++ b/react-psh-sprint5/src/css/Header.css @@ -76,7 +76,7 @@ header { } -@media screen and (max-width: 1199px) { +@media screen and (max-width: 1230px) { header { width: calc(100% - 48px); min-width: 750px; diff --git a/react-psh-sprint5/src/css/Num.css b/react-psh-sprint5/src/css/Num.css index 076735d1..2206f951 100644 --- a/react-psh-sprint5/src/css/Num.css +++ b/react-psh-sprint5/src/css/Num.css @@ -1,3 +1,5 @@ +@import './reset.css'; + .number-box { display: flex; justify-content: space-between; diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index 67fc7bf4..45b7af96 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -24,35 +24,45 @@ line-height: 32px; } +/* nth-child(n+5) */ + .item-container { + min-width: 1200px; + height: 378px; display: flex; justify-content: space-between; gap: 24px; } + + /* item들 보여주는 클래스 */ .ItemComponent { - width: 282px; - height: 378px; - display: flex; - flex-direction: column; - justify-content: center; - align-items: center; + width: 23%; + display: block; + gap: 18px; } -.contain-img { - width: 282px; - height: 282px; +.ItemComponent:nth-child(n+5) { + display: none; +} + +.item-container .contain-img { + width: 100%; border-radius: 16px; + + } .contain-img img { - width: 282px; + width: 100%; + object-fit: cover; } -.contain-text { +.item-container .contain-text { width: 100%; gap: 10px; + margin-top : 60px; display: flex; flex-direction: column; justify-content: space-around; @@ -64,6 +74,7 @@ font-weight: 500; line-height: 24px; text-align: left; + border : none; } .contain-text-price { @@ -105,22 +116,24 @@ } -@media screen and (max-width: 1199px) { +@media screen and (max-width: 1230px) { .best-item { width: 85%; min-width: 720px; justify-content: center; } - .best-item-text{ + .best-item-text { width: 87%; min-width: 750px; - margin : 0 auto; + margin: 0 auto; + } + .item-container { width: 100%; min-width: 720px; - border-radius: 19.46px; + height: auto; margin: 0 auto; display: flex; justify-content: space-around; @@ -129,22 +142,25 @@ .ItemComponent { width: 343px; height: auto; + } - .contain-img { - width: 343px; - height: 343px; + .item-container .contain-img { + width: 100%; + height: auto; border-radius: 16px; } .contain-img img { - width: 343px; + width: 500px; + height: 100%; + } + .item-container .contain-text { + margin-top : 0px; } - .ItemCompo2, - .ItemCompo3 { + .ItemComponent:nth-child(n+3) { display: none; - } } @@ -155,6 +171,9 @@ width: 100%; min-width: 343px; } + .ItemComponent:nth-child(n+2) { + display: none; + } .ItemCompo4 { display: none; @@ -166,7 +185,7 @@ gap: 16px; } - .best-item-text{ + .best-item-text { width: 45%; min-width: 343px; } @@ -174,5 +193,8 @@ .item-container { min-width: 343px; } + .item-container .contain-text{ + margin-top: 25px; + } } \ No newline at end of file diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css index 22ca019a..4b9e956f 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/body2.css @@ -12,8 +12,8 @@ display: flex; justify-content: space-between; align-items: center; - border : 1px solid black; } + .all-item-header2 { display: none; } @@ -29,17 +29,19 @@ } .all-item-option { - width: 620px; + width: 50%; display: flex; justify-content: space-between; align-items: center; gap: 4px; + } .all-item-searchBox { width: 325px; height: 42px; padding: 9px 20px 9px 16px; + margin-left: 30px; gap: 10px; border-radius: 12px; background-color: #F3F4F6; @@ -49,19 +51,15 @@ text-align: left; } -.all-item-searchBox:hover { - border: 1px solid black; -} - .all-item-addButton { - min-width: 133px; + min-width: 150px; padding: 12px 23px; gap: 10px; border-radius: 8px; font-size: 16px; font-weight: 600; line-height: 26px; - text-align: left; + text-align: center; color: white; background-color: #3692FF; cursor: pointer; @@ -70,10 +68,10 @@ .selectBox { width: 130px; height: 42px; - border: 1px solid #E5E7EB; padding: 12px 20px; gap: 10px; border-radius: 12px; + background-color: #F3F4F6; cursor: pointer; } @@ -82,11 +80,11 @@ } .all-item-list { + width: 1200px; display: flex; flex-wrap: wrap; - justify-content: space-between; + justify-content: space-around; gap: 12px; - } .All-item-list-item { @@ -94,11 +92,54 @@ width: 221px; height: 317px; gap: 16px; + + +} - border: 1px solid black; +.contain-img { + width: 219px; + height: 221px; + margin-bottom: 5px; } -@media screen and (max-width: 1199px) { +.contain-img img { + width: 100%; +} + +.contain-text-product-des { + width: 100%; + height: 100%; + border-top: 1px solid #DFDFDF; +} + +.all-item-searchBox-container { + display: flex; + position: relative; + width: 50%; + align-items: center; + background-color: #F3F4F6; + border-radius: 7px; +} + +.search-icon { + font-size: 30px; + font-weight: 500; + cursor: pointer; +} + +.all-item-searchButton { + display: flex; + position: absolute; + padding-left: 7px; +} +.none-product{ + width: 100%; + height: 200px; + padding-top : 100px; + text-align: center; +} + +@media screen and (max-width: 1230px) { .all-item { width: 80%; min-width: 750px; @@ -110,19 +151,22 @@ width: 100%; min-width: 695px; display: flex; - gap : 16px; + gap: 16px; } + .All-item-list-item:nth-child(n+7) { display: none; - } .all-item-searchBox { width: 242px; + border-radius: 10px; } - .all-item-option{ - width: 529px; + .all-item-option { + width: 80%; + max-width: 570px; + gap: 10px; } } @@ -130,35 +174,42 @@ .all-item-header { display: none; } + .all-item-header2 { - display:block; + display: block; width: 100%; display: flex; flex-direction: column; - margin:0 auto; - gap:10px; + margin: 0 auto; + gap: 10px; } + .all-item-header2 .all-item-text { width: 100%; display: flex; justify-content: space-between; - margin-left : 10px; + margin-left: 10px; } + .all-item-header2 .all-item-searchBox { width: 100%; } - .all-item-header2 .all-item-option{ + + .all-item-header2 .all-item-option { min-width: 344px; width: 100%; justify-content: space-between; } - .all-item-header2 .selectBox{ + + .all-item-header2 .selectBox { width: 50px; } - .all-item-header2 .all-item-addButton{ - width: 133px; - margin-top : 5px; - margin-right:45px; + + .all-item-header2 .all-item-addButton { + width: 40%; + margin-top: 5px; + margin-right: 30px; + text-align: center; } .all-item { @@ -166,15 +217,16 @@ min-width: 344px; justify-content: center; } + .all-item-list { - min-width: 344px; + min-width: 500px; display: grid; grid-template-columns: repeat(2, 1fr); - margin : 0 auto; + margin: 0 auto; justify-content: space-around; } - .All-item-list-item{ + .All-item-list-item { margin: 0 auto; } @@ -182,4 +234,13 @@ display: none; } + .menu-icon { + font-size: 30px; + cursor: pointer; + } + + .all-item-searchBox-container { + width: 85%; + } + } \ No newline at end of file diff --git a/react-psh-sprint5/src/css/reset.css b/react-psh-sprint5/src/css/reset.css index f85d3774..d92fb82e 100644 --- a/react-psh-sprint5/src/css/reset.css +++ b/react-psh-sprint5/src/css/reset.css @@ -15,7 +15,6 @@ --color11: #E5E7EB; } - * { margin: 0; padding: 0; diff --git a/react-psh-sprint5/src/icon/btn_sort.svg b/react-psh-sprint5/src/icon/btn_sort.svg new file mode 100644 index 00000000..41751e7b --- /dev/null +++ b/react-psh-sprint5/src/icon/btn_sort.svg @@ -0,0 +1,8 @@ + + + + + + + + From 1950d1d445a51284604b44e75db603b80b50d52f Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Tue, 22 Oct 2024 22:56:38 +0900 Subject: [PATCH 07/12] =?UTF-8?q?=ED=8E=98=EC=9D=B4=EC=A7=80=EB=84=A4?= =?UTF-8?q?=EC=9D=B4=EC=85=98=20=EB=B6=80=EB=B6=84=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/src/App.jsx | 2 - react-psh-sprint5/src/api/getProductsList.jsx | 4 +- react-psh-sprint5/src/components/Body2.jsx | 49 ++++++++++++++++--- react-psh-sprint5/src/components/Num.jsx | 25 ---------- react-psh-sprint5/src/css/Num.css | 32 ------------ react-psh-sprint5/src/css/body.css | 12 ----- react-psh-sprint5/src/css/body2.css | 34 ++++++++++++- 7 files changed, 76 insertions(+), 82 deletions(-) delete mode 100644 react-psh-sprint5/src/components/Num.jsx delete mode 100644 react-psh-sprint5/src/css/Num.css diff --git a/react-psh-sprint5/src/App.jsx b/react-psh-sprint5/src/App.jsx index 796fed08..814fe494 100644 --- a/react-psh-sprint5/src/App.jsx +++ b/react-psh-sprint5/src/App.jsx @@ -1,7 +1,6 @@ import './App.css' import Header from './components/Header' import BodyMain from './components/BodyMain' -import Num from './components/Num' import Footer from './components/Footer' function App() { @@ -9,7 +8,6 @@ function App() {
-
) diff --git a/react-psh-sprint5/src/api/getProductsList.jsx b/react-psh-sprint5/src/api/getProductsList.jsx index c45f4179..4a08dd60 100644 --- a/react-psh-sprint5/src/api/getProductsList.jsx +++ b/react-psh-sprint5/src/api/getProductsList.jsx @@ -1,8 +1,8 @@ import axios from "axios"; -const getProductsList = async (search="", option="favorite") => { +const getProductsList = async (page=1, search="", option="favorite", pageSize=10) => { try { - const response = await axios.get(`https://panda-market-api.vercel.app/products?orderBy=${option}&keyword=${search}`); + const response = await axios.get(`https://panda-market-api.vercel.app/products?page=${page}&pageSize=${pageSize}&orderBy=${option}&keyword=${search}`); return response.data.list; } catch (error) { console.log(error); diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx index 6ec46fe6..17ca97a9 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -6,16 +6,17 @@ function Body2() { const [products, setProducts] = useState([]); const [option, setOption] = useState('recent'); const [tempSearch, setTempSearch] = useState(""); - const [search, setSearch] = useState("갤럭시"); + const [search, setSearch] = useState(""); + const [page, setPage] = useState(1); const updateProducts = async () => { - const axiosProducts = await getProductsList(search, option); + const axiosProducts = await getProductsList(page, search, option); setProducts(axiosProducts); }; useEffect(() => { - updateProducts(search, option); - }, [search, option]); + updateProducts(page, search, option); + }, [page, search, option]); const filterProductsBySearch = () => { if (!search) return products; @@ -31,17 +32,32 @@ function Body2() { const onClickSearch = () => { setSearch(tempSearch); setTempSearch(""); + setPage(1); } const onKeyDown = (e) => { if (e.keyCode === 13) { onClickSearch(); + setPage(1); } } const onChangeSortOption = (e) => { setOption(e.target.value); - }; + } + const onClickPage = (e) => { + setPage(e.target.value); + console.log(page); + } + + const onClickPagePlus = () => { + if (products.length === 10) setPage(page + 1); + } + + const onClickPageMinus = () => { + if (page > 1) setPage(page - 1); + } const filteredSearch = filterProductsBySearch(); + return (
@@ -50,7 +66,8 @@ function Body2() {
+ onChange={onChangeSearch} className='all-item-searchBox' placeholder='검색할 상품을 입력해주세요'> + search @@ -67,7 +84,6 @@ function Body2() { -
@@ -95,7 +111,6 @@ function Body2() { -
@@ -121,6 +136,24 @@ function Body2() { )) )}
+ +
+ + + + + + + +
); } diff --git a/react-psh-sprint5/src/components/Num.jsx b/react-psh-sprint5/src/components/Num.jsx deleted file mode 100644 index bb68b4dc..00000000 --- a/react-psh-sprint5/src/components/Num.jsx +++ /dev/null @@ -1,25 +0,0 @@ -import '../css/Num.css' - -function Num() { - return ( -
- - - - - - - -
- ); -} - -export default Num; \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Num.css b/react-psh-sprint5/src/css/Num.css deleted file mode 100644 index 2206f951..00000000 --- a/react-psh-sprint5/src/css/Num.css +++ /dev/null @@ -1,32 +0,0 @@ -@import './reset.css'; - -.number-box { - display: flex; - justify-content: space-between; - margin: 0 auto; - width: 304px; - height: 40px; - margin-bottom: 140px; -} - -.buttonNum { - display: flex; - justify-content: center; - align-items: center; - width: 40px; - height: 40px; - gap: 12.5px; - border-radius: 40px; - border: 1px solid #E5E7EB; - background-color: white; - font-size: 16px; - font-weight: bold; - line-height: 26px; -} - -.buttonNum:hover { - background-color: #2F80ED; - color : white; - cursor: pointer; - transition: 0.5s; -} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index 45b7af96..681c04af 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -17,15 +17,11 @@ margin-top: 50px; } -/* 베스트상품 텍스트 들어간곳 */ .best-item-text { font-size: 20px; font-weight: 700; line-height: 32px; } - -/* nth-child(n+5) */ - .item-container { min-width: 1200px; height: 378px; @@ -34,9 +30,6 @@ gap: 24px; } - - -/* item들 보여주는 클래스 */ .ItemComponent { width: 23%; display: block; @@ -50,8 +43,6 @@ .item-container .contain-img { width: 100%; border-radius: 16px; - - } .contain-img img { @@ -90,7 +81,6 @@ display: flex; position: relative; gap: 2px; - } @@ -113,7 +103,6 @@ font-weight: 500; line-height: 16px; text-align: left; - } @media screen and (max-width: 1230px) { @@ -127,7 +116,6 @@ width: 87%; min-width: 750px; margin: 0 auto; - } .item-container { diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css index 4b9e956f..30affbaa 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/body2.css @@ -12,6 +12,7 @@ display: flex; justify-content: space-between; align-items: center; + } .all-item-header2 { @@ -81,6 +82,7 @@ .all-item-list { width: 1200px; + min-height: 646px; display: flex; flex-wrap: wrap; justify-content: space-around; @@ -109,7 +111,6 @@ .contain-text-product-des { width: 100%; height: 100%; - border-top: 1px solid #DFDFDF; } .all-item-searchBox-container { @@ -139,6 +140,37 @@ text-align: center; } +.number-box { + display: flex; + justify-content: space-between; + margin: 0 auto; + width: 304px; + height: 40px; + margin-bottom: 140px; +} + +.buttonNum { + display: flex; + justify-content: center; + align-items: center; + width: 40px; + height: 40px; + gap: 12.5px; + border-radius: 40px; + border: 1px solid #E5E7EB; + background-color: white; + font-size: 16px; + font-weight: bold; + line-height: 26px; +} + +.buttonNum:hover { + background-color: #2F80ED; + color : white; + cursor: pointer; + transition: 0.5s; +} + @media screen and (max-width: 1230px) { .all-item { width: 80%; From 06c9463939539227a7ffd1443f0c50ce567b0d35 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Wed, 23 Oct 2024 20:18:51 +0900 Subject: [PATCH 08/12] =?UTF-8?q?241013=EC=9E=91=EC=97=85=20=EB=A7=88?= =?UTF-8?q?=EB=AC=B4=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/src/api/getProductsList.jsx | 5 +- react-psh-sprint5/src/components/Body1.jsx | 2 +- react-psh-sprint5/src/components/Body2.jsx | 62 ++++++++++++++++--- react-psh-sprint5/src/components/BodyMain.jsx | 2 +- react-psh-sprint5/src/css/body.css | 17 ++--- react-psh-sprint5/src/css/body2.css | 5 +- react-psh-sprint5/src/css/main.css | 5 -- react-psh-sprint5/src/css/reset.css | 4 +- react-psh-sprint5/src/main.jsx | 1 + 9 files changed, 72 insertions(+), 31 deletions(-) diff --git a/react-psh-sprint5/src/api/getProductsList.jsx b/react-psh-sprint5/src/api/getProductsList.jsx index 4a08dd60..4ae71026 100644 --- a/react-psh-sprint5/src/api/getProductsList.jsx +++ b/react-psh-sprint5/src/api/getProductsList.jsx @@ -3,7 +3,10 @@ import axios from "axios"; const getProductsList = async (page=1, search="", option="favorite", pageSize=10) => { try { const response = await axios.get(`https://panda-market-api.vercel.app/products?page=${page}&pageSize=${pageSize}&orderBy=${option}&keyword=${search}`); - return response.data.list; + return { + products : response.data.list, + totalCount : response.data.totalCount + }; } catch (error) { console.log(error); } diff --git a/react-psh-sprint5/src/components/Body1.jsx b/react-psh-sprint5/src/components/Body1.jsx index 8f92c777..77416654 100644 --- a/react-psh-sprint5/src/components/Body1.jsx +++ b/react-psh-sprint5/src/components/Body1.jsx @@ -9,7 +9,7 @@ function Body1() { const updateProducts = async () => { const axiosProducts = await getProductsList(); - setProducts(axiosProducts); + setProducts(axiosProducts.products); } useEffect(() => { updateProducts(); diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/Body2.jsx index 17ca97a9..c51b4fa2 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/Body2.jsx @@ -1,6 +1,8 @@ import '../css/body2.css'; -import { useEffect, useState } from 'react'; import getProductsList from '../api/getProductsList.jsx'; +import { useEffect, useState } from 'react'; + +//윈도우 크기감지 function Body2() { const [products, setProducts] = useState([]); @@ -8,15 +10,45 @@ function Body2() { const [tempSearch, setTempSearch] = useState(""); const [search, setSearch] = useState(""); const [page, setPage] = useState(1); + const [pageSize, setPageSize] = useState(10); + const [totalCount, setTotalCount] = useState(0); const updateProducts = async () => { - const axiosProducts = await getProductsList(page, search, option); - setProducts(axiosProducts); + const axiosProducts = await getProductsList(page, search, option, pageSize); + setProducts(axiosProducts.products); + setTotalCount(axiosProducts.totalCount); }; useEffect(() => { - updateProducts(page, search, option); - }, [page, search, option]); + updateProducts(); + }, [page, search, option, pageSize]); + + + useEffect(() => { + const windowSize = () => { + const width = window.innerWidth; + console.log(`현재 화면 너비: ${width}px`); + if (width >= 1230) { + setPageSize(10); + } else if (width >= 801 && width < 1230) { + setPageSize(6); + } else { + setPageSize(4); + } + console.log({pageSize}); + }; + + windowSize(); + window.addEventListener('resize', windowSize); + + return () => { + window.removeEventListener('resize', windowSize); + }; + }, [pageSize]); + + useEffect(() => { + updateProducts(page, search, option, pageSize); + }, [page, search, option, pageSize]); const filterProductsBySearch = () => { if (!search) return products; @@ -45,17 +77,24 @@ function Body2() { } const onClickPage = (e) => { setPage(e.target.value); - console.log(page); } const onClickPagePlus = () => { - if (products.length === 10) setPage(page + 1); + if ((pageSize % products.length === 0)) + setPage(parseInt(page) + 1); } const onClickPageMinus = () => { - if (page > 1) setPage(page - 1); + if (page > 1) { + setPage(parseInt(page) - 1); + } } + useEffect(() => { + console.log('page : ', { page }); + console.log('totalcount : ', { totalCount }); + }, [page, totalCount]); + const filteredSearch = filterProductsBySearch(); return ( @@ -153,6 +192,13 @@ function Body2() { chevron_right +
+ {page} +
+
+
+ +
); diff --git a/react-psh-sprint5/src/components/BodyMain.jsx b/react-psh-sprint5/src/components/BodyMain.jsx index 52ac515f..4feb463f 100644 --- a/react-psh-sprint5/src/components/BodyMain.jsx +++ b/react-psh-sprint5/src/components/BodyMain.jsx @@ -1,6 +1,6 @@ import Body1 from "./Body1"; import Body2 from "./Body2"; - +import '../css/body.css'; function BodyMain() { return ( diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index 681c04af..dcd62d5e 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -1,5 +1,3 @@ -@import './reset.css'; - .body-main { display: flex; margin: 45px auto; @@ -18,10 +16,11 @@ } .best-item-text { - font-size: 20px; + font-size: 1rem; font-weight: 700; line-height: 32px; } + .item-container { min-width: 1200px; height: 378px; @@ -53,7 +52,7 @@ .item-container .contain-text { width: 100%; gap: 10px; - margin-top : 60px; + margin-top: 60px; display: flex; flex-direction: column; justify-content: space-around; @@ -65,7 +64,6 @@ font-weight: 500; line-height: 24px; text-align: left; - border : none; } .contain-text-price { @@ -130,7 +128,7 @@ .ItemComponent { width: 343px; height: auto; - + } .item-container .contain-img { @@ -143,8 +141,9 @@ width: 500px; height: 100%; } + .item-container .contain-text { - margin-top : 0px; + margin-top: 0px; } .ItemComponent:nth-child(n+3) { @@ -159,6 +158,7 @@ width: 100%; min-width: 343px; } + .ItemComponent:nth-child(n+2) { display: none; } @@ -181,7 +181,8 @@ .item-container { min-width: 343px; } - .item-container .contain-text{ + + .item-container .contain-text { margin-top: 25px; } diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css index 30affbaa..af754ae4 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/body2.css @@ -1,5 +1,3 @@ -@import './reset.css'; - .all-item { width: 1200px; margin: 0 auto; @@ -12,7 +10,6 @@ display: flex; justify-content: space-between; align-items: center; - } .all-item-header2 { @@ -35,7 +32,6 @@ justify-content: space-between; align-items: center; gap: 4px; - } .all-item-searchBox { @@ -143,6 +139,7 @@ .number-box { display: flex; justify-content: space-between; + align-items: center; margin: 0 auto; width: 304px; height: 40px; diff --git a/react-psh-sprint5/src/css/main.css b/react-psh-sprint5/src/css/main.css index 9db130ae..b9e68293 100644 --- a/react-psh-sprint5/src/css/main.css +++ b/react-psh-sprint5/src/css/main.css @@ -3,8 +3,3 @@ @import './reset.css'; @import './body.css'; -* { - font-size: 16px; - font-family: 'Pretendard'; - box-sizing: border-box; -} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/reset.css b/react-psh-sprint5/src/css/reset.css index d92fb82e..001ad61c 100644 --- a/react-psh-sprint5/src/css/reset.css +++ b/react-psh-sprint5/src/css/reset.css @@ -19,11 +19,9 @@ margin: 0; padding: 0; border: 0; - font-size: 16px; + font-size: 30px; font: inherit; - font-family: 'Pretendard'; - vertical-align: baseline; box-sizing: border-box; } diff --git a/react-psh-sprint5/src/main.jsx b/react-psh-sprint5/src/main.jsx index ba1a5b2b..9a221831 100644 --- a/react-psh-sprint5/src/main.jsx +++ b/react-psh-sprint5/src/main.jsx @@ -1,6 +1,7 @@ import { createRoot } from 'react-dom/client' import App from './App.jsx' import './index.css' +import './css/reset.css' createRoot(document.getElementById('root')).render( From d43e6e547b5e5b9fa3401a55a958c6499765d054 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sat, 26 Oct 2024 02:24:43 +0900 Subject: [PATCH 09/12] =?UTF-8?q?1026=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/src/App.css | 3 +- react-psh-sprint5/src/App.jsx | 3 ++ .../src/components/{Body2.jsx => AllItem.jsx} | 51 ++++++++++--------- .../components/{Body1.jsx => BestItem.jsx} | 0 react-psh-sprint5/src/components/BodyMain.jsx | 8 +-- react-psh-sprint5/src/css/body.css | 29 ++++------- react-psh-sprint5/src/css/body2.css | 29 ++++++----- react-psh-sprint5/src/css/reset.css | 6 ++- react-psh-sprint5/src/main.jsx | 1 - 9 files changed, 65 insertions(+), 65 deletions(-) rename react-psh-sprint5/src/components/{Body2.jsx => AllItem.jsx} (86%) rename react-psh-sprint5/src/components/{Body1.jsx => BestItem.jsx} (100%) diff --git a/react-psh-sprint5/src/App.css b/react-psh-sprint5/src/App.css index c5557956..0b641182 100644 --- a/react-psh-sprint5/src/App.css +++ b/react-psh-sprint5/src/App.css @@ -1,4 +1,5 @@ .APP { display: flex; flex-direction: column; -} \ No newline at end of file +} + diff --git a/react-psh-sprint5/src/App.jsx b/react-psh-sprint5/src/App.jsx index 814fe494..28986a4a 100644 --- a/react-psh-sprint5/src/App.jsx +++ b/react-psh-sprint5/src/App.jsx @@ -1,8 +1,11 @@ +import './css/reset.css'; import './App.css' import Header from './components/Header' import BodyMain from './components/BodyMain' import Footer from './components/Footer' + + function App() { return (
diff --git a/react-psh-sprint5/src/components/Body2.jsx b/react-psh-sprint5/src/components/AllItem.jsx similarity index 86% rename from react-psh-sprint5/src/components/Body2.jsx rename to react-psh-sprint5/src/components/AllItem.jsx index c51b4fa2..70c94680 100644 --- a/react-psh-sprint5/src/components/Body2.jsx +++ b/react-psh-sprint5/src/components/AllItem.jsx @@ -2,8 +2,6 @@ import '../css/body2.css'; import getProductsList from '../api/getProductsList.jsx'; import { useEffect, useState } from 'react'; -//윈도우 크기감지 - function Body2() { const [products, setProducts] = useState([]); const [option, setOption] = useState('recent'); @@ -13,6 +11,9 @@ function Body2() { const [pageSize, setPageSize] = useState(10); const [totalCount, setTotalCount] = useState(0); + const totalPages = Math.ceil(totalCount / pageSize); + const startPage = Math.floor((page - 1) / 5) * 5 + 1; + const updateProducts = async () => { const axiosProducts = await getProductsList(page, search, option, pageSize); setProducts(axiosProducts.products); @@ -20,7 +21,9 @@ function Body2() { }; useEffect(() => { - updateProducts(); + if (page > 0) { + updateProducts(); + } }, [page, search, option, pageSize]); @@ -35,9 +38,8 @@ function Body2() { } else { setPageSize(4); } - console.log({pageSize}); }; - + windowSize(); window.addEventListener('resize', windowSize); @@ -47,7 +49,15 @@ function Body2() { }, [pageSize]); useEffect(() => { - updateProducts(page, search, option, pageSize); + if (totalPages > 0 & page > totalPages) { + setPage(totalPages); + } + }, [pageSize, totalPages]); + + useEffect(() => { + if (page > 0) { + updateProducts(page, search, option, pageSize); + } }, [page, search, option, pageSize]); const filterProductsBySearch = () => { @@ -76,19 +86,16 @@ function Body2() { setOption(e.target.value); } const onClickPage = (e) => { - setPage(e.target.value); + setPage(Number(e.target.value)); } const onClickPagePlus = () => { - if ((pageSize % products.length === 0)) - setPage(parseInt(page) + 1); + if (page < totalPages) setPage(page + 1); } const onClickPageMinus = () => { - if (page > 1) { - setPage(parseInt(page) - 1); - } - } + if (page > 1) setPage(page - 1); + }; useEffect(() => { console.log('page : ', { page }); @@ -182,23 +189,17 @@ function Body2() { chevron_left - - - - - + + + + + + -
- {page} -
-
-
- -
); diff --git a/react-psh-sprint5/src/components/Body1.jsx b/react-psh-sprint5/src/components/BestItem.jsx similarity index 100% rename from react-psh-sprint5/src/components/Body1.jsx rename to react-psh-sprint5/src/components/BestItem.jsx diff --git a/react-psh-sprint5/src/components/BodyMain.jsx b/react-psh-sprint5/src/components/BodyMain.jsx index 4feb463f..a1d0dbc6 100644 --- a/react-psh-sprint5/src/components/BodyMain.jsx +++ b/react-psh-sprint5/src/components/BodyMain.jsx @@ -1,12 +1,12 @@ -import Body1 from "./Body1"; -import Body2 from "./Body2"; +import BestItem from "./BestItem"; +import AllItem from "./AllItem"; import '../css/body.css'; function BodyMain() { return (
- - + +
); } diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/body.css index dcd62d5e..57f979ba 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/body.css @@ -16,9 +16,9 @@ } .best-item-text { - font-size: 1rem; + font-size: 1.6rem; font-weight: 700; - line-height: 32px; + line-height: 3.2rem; } .item-container { @@ -60,17 +60,17 @@ .contain-text-product-des { height: 24px; - font-size: 14px; + font-size: 1.4rem; font-weight: 500; - line-height: 24px; + line-height: 2.4rem; text-align: left; } .contain-text-price { height: 26px; - font-size: 16px; + font-size: 1.6rem; font-weight: 700; - line-height: 26px; + line-height: 2.6rem; text-align: left; } @@ -81,7 +81,6 @@ gap: 2px; } - .like-button { display: flex; } @@ -93,13 +92,13 @@ } .favorite-icon { - font-size: 16px; + font-size: 1.6rem; } .contain-text-like-fs { - font-size: 12px; + font-size: 1.2rem; font-weight: 500; - line-height: 16px; + line-height: 1.6rem; text-align: left; } @@ -128,7 +127,6 @@ .ItemComponent { width: 343px; height: auto; - } .item-container .contain-img { @@ -149,11 +147,9 @@ .ItemComponent:nth-child(n+3) { display: none; } - } @media screen and (max-width: 800px) { - .best-item { width: 100%; min-width: 343px; @@ -163,10 +159,6 @@ display: none; } - .ItemCompo4 { - display: none; - } - .ItemComponent { width: 343px; height: 482px; @@ -185,5 +177,4 @@ .item-container .contain-text { margin-top: 25px; } - -} \ No newline at end of file +} diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css index af754ae4..cd90025d 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/body2.css @@ -18,7 +18,7 @@ .all-item-text { min-width: 150px; - font-size: 20px; + font-size: 2rem; font-weight: 700; line-height: 32px; text-align: left; @@ -42,7 +42,7 @@ gap: 10px; border-radius: 12px; background-color: #F3F4F6; - font-size: 16px; + font-size: 1.6rem; font-weight: 400; line-height: 26px; text-align: left; @@ -53,7 +53,7 @@ padding: 12px 23px; gap: 10px; border-radius: 8px; - font-size: 16px; + font-size: 1.6rem; font-weight: 600; line-height: 26px; text-align: center; @@ -66,6 +66,7 @@ width: 130px; height: 42px; padding: 12px 20px; + font-size : 1.6rem; gap: 10px; border-radius: 12px; background-color: #F3F4F6; @@ -90,8 +91,6 @@ width: 221px; height: 317px; gap: 16px; - - } .contain-img { @@ -119,7 +118,7 @@ } .search-icon { - font-size: 30px; + font-size: 3rem; font-weight: 500; cursor: pointer; } @@ -129,10 +128,11 @@ position: absolute; padding-left: 7px; } -.none-product{ + +.none-product { width: 100%; height: 200px; - padding-top : 100px; + padding-top: 100px; text-align: center; } @@ -156,14 +156,14 @@ border-radius: 40px; border: 1px solid #E5E7EB; background-color: white; - font-size: 16px; + font-size: 1.6rem; font-weight: bold; line-height: 26px; } .buttonNum:hover { background-color: #2F80ED; - color : white; + color: white; cursor: pointer; transition: 0.5s; } @@ -190,6 +190,7 @@ .all-item-searchBox { width: 242px; border-radius: 10px; + font-size: 1.6rem; } .all-item-option { @@ -225,13 +226,13 @@ } .all-item-header2 .all-item-option { - min-width: 344px; + min-width: 34.4rem; width: 100%; justify-content: space-between; } .all-item-header2 .selectBox { - width: 50px; + width: 5rem; } .all-item-header2 .all-item-addButton { @@ -239,6 +240,7 @@ margin-top: 5px; margin-right: 30px; text-align: center; + font-size: 1.6rem; } .all-item { @@ -264,12 +266,11 @@ } .menu-icon { - font-size: 30px; + font-size: 3rem; cursor: pointer; } .all-item-searchBox-container { width: 85%; } - } \ No newline at end of file diff --git a/react-psh-sprint5/src/css/reset.css b/react-psh-sprint5/src/css/reset.css index 001ad61c..562743b0 100644 --- a/react-psh-sprint5/src/css/reset.css +++ b/react-psh-sprint5/src/css/reset.css @@ -15,11 +15,15 @@ --color11: #E5E7EB; } +html { + font-size: 10px; +} + * { margin: 0; padding: 0; border: 0; - font-size: 30px; + font-size: 40px; font: inherit; font-family: 'Pretendard'; box-sizing: border-box; diff --git a/react-psh-sprint5/src/main.jsx b/react-psh-sprint5/src/main.jsx index 9a221831..ba1a5b2b 100644 --- a/react-psh-sprint5/src/main.jsx +++ b/react-psh-sprint5/src/main.jsx @@ -1,7 +1,6 @@ import { createRoot } from 'react-dom/client' import App from './App.jsx' import './index.css' -import './css/reset.css' createRoot(document.getElementById('root')).render( From 69ece67742fc0bd5969c89d1e2b5c19f86553959 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sun, 27 Oct 2024 03:00:52 +0900 Subject: [PATCH 10/12] =?UTF-8?q?1027=EC=9E=91=EC=97=85=EB=A7=88=EB=AC=B4?= =?UTF-8?q?=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- react-psh-sprint5/src/components/AllItem.jsx | 71 ++++++++++++++++---- react-psh-sprint5/src/css/Footer.css | 6 +- react-psh-sprint5/src/css/Header.css | 4 +- react-psh-sprint5/src/css/body2.css | 11 +++ react-psh-sprint5/src/css/button.css | 2 +- 5 files changed, 75 insertions(+), 19 deletions(-) diff --git a/react-psh-sprint5/src/components/AllItem.jsx b/react-psh-sprint5/src/components/AllItem.jsx index 70c94680..c90bdb94 100644 --- a/react-psh-sprint5/src/components/AllItem.jsx +++ b/react-psh-sprint5/src/components/AllItem.jsx @@ -184,21 +184,66 @@ function Body2() {
- - - - - - - + )} + {startPage + 1 <= totalPages && ( + + )} + {startPage + 2 <= totalPages && ( + + )} + {startPage + 3 <= totalPages && ( + + )} + {startPage + 4 <= totalPages && ( + + )} + +
diff --git a/react-psh-sprint5/src/css/Footer.css b/react-psh-sprint5/src/css/Footer.css index 67ab9e65..d6e79e88 100644 --- a/react-psh-sprint5/src/css/Footer.css +++ b/react-psh-sprint5/src/css/Footer.css @@ -27,7 +27,7 @@ footer { .footer-box-inner1 { height: 19px; color: var(--color2); - font-size: 1rem; + font-size: 1.6rem; font-weight: 400; line-height: 19.09px; text-align: center; @@ -54,7 +54,7 @@ footer { .footer-box-inner2-1 { height: 19px; - font-size: 1rem; + font-size: 1.6rem; font-weight: 400; line-height: 19.09px; text-align: center; @@ -66,7 +66,7 @@ footer { .footer-box-inner2-2 { width: 29px; height: 19px; - font-size: 1rem; + font-size: 1.6rem; font-weight: 400; line-height: 19.09px; text-align: center; diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css index 8c464370..5cb73075 100644 --- a/react-psh-sprint5/src/css/Header.css +++ b/react-psh-sprint5/src/css/Header.css @@ -56,7 +56,7 @@ header { min-width: 110px; padding: 21px 15px; gap: 10px; - font-size: 18px; + font-size: 1.8rem; font-weight: bold; line-height: 35px; } @@ -70,7 +70,7 @@ header { min-width: 108px; padding: 21px 15px 21px 15px; gap: 10px; - font-size: 18px; + font-size: 1.8rem; font-weight: bold; line-height: 35px; } diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/body2.css index cd90025d..b1c8135a 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/body2.css @@ -168,6 +168,17 @@ transition: 0.5s; } +.buttonNum.disabled { + color: #ccc; + cursor: not-allowed; + pointer-events: none; +} + +.buttonNum.active { + background-color: #2F80ED; + color: #ccc; +} + @media screen and (max-width: 1230px) { .all-item { width: 80%; diff --git a/react-psh-sprint5/src/css/button.css b/react-psh-sprint5/src/css/button.css index 67ef2280..cb2a57e6 100644 --- a/react-psh-sprint5/src/css/button.css +++ b/react-psh-sprint5/src/css/button.css @@ -8,7 +8,7 @@ border-radius: 8px; opacity: 1; color: var(--color1); - font-size: 1.25rem; + font-size: 1.8rem; text-align: center; text-decoration: none; display: inline-block; From 59fd2c07cd58ae3c64dedce57ee8fce7efc1fa12 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sun, 27 Oct 2024 22:46:36 +0900 Subject: [PATCH 11/12] 1027 --- package-lock.json | 6 --- react-psh-sprint5/src/components/AllItem.jsx | 40 +++++-------------- react-psh-sprint5/src/components/BestItem.jsx | 10 ++--- react-psh-sprint5/src/components/BodyMain.jsx | 3 +- react-psh-sprint5/src/components/Footer.jsx | 2 - react-psh-sprint5/src/components/Header.jsx | 3 +- .../src/css/{body2.css => AllItem.css} | 25 ++++++------ .../src/css/{body.css => BestItem.css} | 2 +- react-psh-sprint5/src/css/Footer.css | 8 +--- react-psh-sprint5/src/css/Header.css | 9 ++--- react-psh-sprint5/src/css/button.css | 2 - react-psh-sprint5/src/css/main.css | 5 --- react-psh-sprint5/src/css/media-qu.css | 15 ------- react-psh-sprint5/src/css/reset.css | 4 +- 14 files changed, 38 insertions(+), 96 deletions(-) delete mode 100644 package-lock.json rename react-psh-sprint5/src/css/{body2.css => AllItem.css} (91%) rename react-psh-sprint5/src/css/{body.css => BestItem.css} (99%) delete mode 100644 react-psh-sprint5/src/css/main.css delete mode 100644 react-psh-sprint5/src/css/media-qu.css diff --git a/package-lock.json b/package-lock.json deleted file mode 100644 index bd91653f..00000000 --- a/package-lock.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "name": "3-sprint-mission-fe", - "lockfileVersion": 3, - "requires": true, - "packages": {} -} diff --git a/react-psh-sprint5/src/components/AllItem.jsx b/react-psh-sprint5/src/components/AllItem.jsx index c90bdb94..83168af0 100644 --- a/react-psh-sprint5/src/components/AllItem.jsx +++ b/react-psh-sprint5/src/components/AllItem.jsx @@ -1,8 +1,7 @@ -import '../css/body2.css'; import getProductsList from '../api/getProductsList.jsx'; import { useEffect, useState } from 'react'; -function Body2() { +function AllItem() { const [products, setProducts] = useState([]); const [option, setOption] = useState('recent'); const [tempSearch, setTempSearch] = useState(""); @@ -12,7 +11,7 @@ function Body2() { const [totalCount, setTotalCount] = useState(0); const totalPages = Math.ceil(totalCount / pageSize); - const startPage = Math.floor((page - 1) / 5) * 5 + 1; + const startPage = ~~((page - 1) / 5) * 5 + 1; const updateProducts = async () => { const axiosProducts = await getProductsList(page, search, option, pageSize); @@ -20,24 +19,12 @@ function Body2() { setTotalCount(axiosProducts.totalCount); }; - useEffect(() => { - if (page > 0) { - updateProducts(); - } - }, [page, search, option, pageSize]); - - useEffect(() => { const windowSize = () => { const width = window.innerWidth; - console.log(`현재 화면 너비: ${width}px`); - if (width >= 1230) { - setPageSize(10); - } else if (width >= 801 && width < 1230) { - setPageSize(6); - } else { - setPageSize(4); - } + if (width >= 1230) setPageSize(10); + if (width >= 801 && width < 1230) setPageSize(6); + if (width < 800) setPageSize(4); }; windowSize(); @@ -49,15 +36,11 @@ function Body2() { }, [pageSize]); useEffect(() => { - if (totalPages > 0 & page > totalPages) { - setPage(totalPages); - } + if (totalPages > 0 & page > totalPages) setPage(totalPages); }, [pageSize, totalPages]); useEffect(() => { - if (page > 0) { - updateProducts(page, search, option, pageSize); - } + if (page > 0) updateProducts(page, search, option, pageSize); }, [page, search, option, pageSize]); const filterProductsBySearch = () => { @@ -97,11 +80,6 @@ function Body2() { if (page > 1) setPage(page - 1); }; - useEffect(() => { - console.log('page : ', { page }); - console.log('totalcount : ', { totalCount }); - }, [page, totalCount]); - const filteredSearch = filterProductsBySearch(); return ( @@ -165,7 +143,7 @@ function Body2() { (products.map((product, index) => (
@@ -45,8 +42,7 @@ function Body1() { )} - ); } -export default Body1; \ No newline at end of file +export default BestItem; \ No newline at end of file diff --git a/react-psh-sprint5/src/components/BodyMain.jsx b/react-psh-sprint5/src/components/BodyMain.jsx index a1d0dbc6..c73d52fb 100644 --- a/react-psh-sprint5/src/components/BodyMain.jsx +++ b/react-psh-sprint5/src/components/BodyMain.jsx @@ -1,6 +1,7 @@ import BestItem from "./BestItem"; import AllItem from "./AllItem"; -import '../css/body.css'; +import '../css/BestItem.css'; +import '../css/AllItem.css'; function BodyMain() { return ( diff --git a/react-psh-sprint5/src/components/Footer.jsx b/react-psh-sprint5/src/components/Footer.jsx index 0197463f..a0b82583 100644 --- a/react-psh-sprint5/src/components/Footer.jsx +++ b/react-psh-sprint5/src/components/Footer.jsx @@ -4,8 +4,6 @@ import twitter from '../icon/twitter-logo.svg'; import instagram from '../icon/instagram-logo.svg'; import youtube from '../icon/youtube-logo.svg'; - - function Footer() { return (
diff --git a/react-psh-sprint5/src/components/Header.jsx b/react-psh-sprint5/src/components/Header.jsx index 6af2e447..b73274db 100644 --- a/react-psh-sprint5/src/components/Header.jsx +++ b/react-psh-sprint5/src/components/Header.jsx @@ -1,5 +1,4 @@ -import '../css/main.css'; - +import '../css/Header.css'; import PandaLogo from '../image/PandaLogo.png'; function Header() { diff --git a/react-psh-sprint5/src/css/body2.css b/react-psh-sprint5/src/css/AllItem.css similarity index 91% rename from react-psh-sprint5/src/css/body2.css rename to react-psh-sprint5/src/css/AllItem.css index b1c8135a..57547d48 100644 --- a/react-psh-sprint5/src/css/body2.css +++ b/react-psh-sprint5/src/css/AllItem.css @@ -41,7 +41,7 @@ margin-left: 30px; gap: 10px; border-radius: 12px; - background-color: #F3F4F6; + background-color: var(--color1); font-size: 1.6rem; font-weight: 400; line-height: 26px; @@ -57,8 +57,8 @@ font-weight: 600; line-height: 26px; text-align: center; - color: white; - background-color: #3692FF; + color: var(--white); + background-color: var(--color5); cursor: pointer; } @@ -69,7 +69,7 @@ font-size : 1.6rem; gap: 10px; border-radius: 12px; - background-color: #F3F4F6; + background-color: var(--color1); cursor: pointer; } @@ -113,7 +113,7 @@ position: relative; width: 50%; align-items: center; - background-color: #F3F4F6; + background-color: var(--color1); border-radius: 7px; } @@ -132,6 +132,7 @@ .none-product { width: 100%; height: 200px; + font-size : 1.6rem; padding-top: 100px; text-align: center; } @@ -154,29 +155,29 @@ height: 40px; gap: 12.5px; border-radius: 40px; - border: 1px solid #E5E7EB; - background-color: white; + border: 1px solid var(--color11); + background-color: var(--white); font-size: 1.6rem; font-weight: bold; line-height: 26px; } .buttonNum:hover { - background-color: #2F80ED; - color: white; + background-color: var(--color12); + color: var(--white); cursor: pointer; transition: 0.5s; } .buttonNum.disabled { - color: #ccc; + color: var(--color11); cursor: not-allowed; pointer-events: none; } .buttonNum.active { - background-color: #2F80ED; - color: #ccc; + background-color: var(--color5); + color: var(--color11); } @media screen and (max-width: 1230px) { diff --git a/react-psh-sprint5/src/css/body.css b/react-psh-sprint5/src/css/BestItem.css similarity index 99% rename from react-psh-sprint5/src/css/body.css rename to react-psh-sprint5/src/css/BestItem.css index 57f979ba..8c551507 100644 --- a/react-psh-sprint5/src/css/body.css +++ b/react-psh-sprint5/src/css/BestItem.css @@ -87,7 +87,7 @@ .like-button:hover { cursor: pointer; - color: paleturquoise; + color: var(--color7); transition: 0.5s; } diff --git a/react-psh-sprint5/src/css/Footer.css b/react-psh-sprint5/src/css/Footer.css index d6e79e88..47c256c1 100644 --- a/react-psh-sprint5/src/css/Footer.css +++ b/react-psh-sprint5/src/css/Footer.css @@ -67,20 +67,16 @@ footer { width: 29px; height: 19px; font-size: 1.6rem; - font-weight: 400; + font-weight: 400; line-height: 19.09px; text-align: center; color: var(--color11); cursor: pointer; } -/* footer 끝 */ - @media screen and (max-width: 1230px) { .footer-box { margin-left: 16px; margin-right: 16px; } -} - -@media screen and (max-width: 744px) {} \ No newline at end of file +} \ No newline at end of file diff --git a/react-psh-sprint5/src/css/Header.css b/react-psh-sprint5/src/css/Header.css index 5cb73075..f415ea3a 100644 --- a/react-psh-sprint5/src/css/Header.css +++ b/react-psh-sprint5/src/css/Header.css @@ -3,13 +3,13 @@ .header-contain { width: 100%; height: 81px; - background: #FFFFFF; + background: var(--white); display: flex; position: fixed; z-index: 11; padding-bottom : 26px; align-items: center; - border-bottom : 1px solid #DFDFDF; + border-bottom : 1px solid var(--color13); } header { @@ -23,7 +23,7 @@ header { margin: 9.5px 200px; box-sizing: border-box; top: 0px; - background: #FFFFFF; + background: var(--white); } @@ -61,7 +61,7 @@ header { line-height: 35px; } .header-text-1:hover, .header-text-2:hover { - color : orange; + color : var(--color7); transition: 0.5s; } @@ -75,7 +75,6 @@ header { line-height: 35px; } - @media screen and (max-width: 1230px) { header { width: calc(100% - 48px); diff --git a/react-psh-sprint5/src/css/button.css b/react-psh-sprint5/src/css/button.css index cb2a57e6..1576b27b 100644 --- a/react-psh-sprint5/src/css/button.css +++ b/react-psh-sprint5/src/css/button.css @@ -1,7 +1,5 @@ @import "reset.css"; - - .button { background: var(--color5); gap: 10px; diff --git a/react-psh-sprint5/src/css/main.css b/react-psh-sprint5/src/css/main.css deleted file mode 100644 index b9e68293..00000000 --- a/react-psh-sprint5/src/css/main.css +++ /dev/null @@ -1,5 +0,0 @@ -@import './media-qu.css'; -@import './Header.css'; -@import './reset.css'; -@import './body.css'; - diff --git a/react-psh-sprint5/src/css/media-qu.css b/react-psh-sprint5/src/css/media-qu.css deleted file mode 100644 index 47a36aeb..00000000 --- a/react-psh-sprint5/src/css/media-qu.css +++ /dev/null @@ -1,15 +0,0 @@ -@import "reset.css"; - -@media screen and (max-width: 1199px) { - header { - width: calc(100% - 48px); - min-width: 750px; - margin: 9.5px 24px; - } -} - -@media screen and (max-width: 744px) { - header { - min-width: 375px; - } -} diff --git a/react-psh-sprint5/src/css/reset.css b/react-psh-sprint5/src/css/reset.css index 562743b0..0265343f 100644 --- a/react-psh-sprint5/src/css/reset.css +++ b/react-psh-sprint5/src/css/reset.css @@ -13,6 +13,8 @@ --color9: #374151; --color10: #111827; --color11: #E5E7EB; + --color12 : #2F80ED; + --color13 : #DFDFDF; } html { @@ -23,7 +25,7 @@ html { margin: 0; padding: 0; border: 0; - font-size: 40px; + font-size: 10px; font: inherit; font-family: 'Pretendard'; box-sizing: border-box; From ba400e3445a3ee7125646b755c389406987813f3 Mon Sep 17 00:00:00 2001 From: soohwanpak Date: Sun, 27 Oct 2024 23:08:01 +0900 Subject: [PATCH 12/12] 1027-2 --- react-psh-sprint5/src/components/AllItem.jsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/react-psh-sprint5/src/components/AllItem.jsx b/react-psh-sprint5/src/components/AllItem.jsx index 83168af0..2b70359e 100644 --- a/react-psh-sprint5/src/components/AllItem.jsx +++ b/react-psh-sprint5/src/components/AllItem.jsx @@ -3,7 +3,7 @@ import { useEffect, useState } from 'react'; function AllItem() { const [products, setProducts] = useState([]); - const [option, setOption] = useState('recent'); + const [option, setOption] = useState('favorite'); const [tempSearch, setTempSearch] = useState(""); const [search, setSearch] = useState(""); const [page, setPage] = useState(1);