diff --git a/README.md b/README.md
index 870c5448..9cd8fbdb 100644
--- a/README.md
+++ b/README.md
@@ -66,3 +66,170 @@
- [[영상] : 컴포넌트에 대한 이해](https://www.youtube.com/watch?v=21eiJc90ggo)
- [Tailwind CSS 사용법](https://www.heropy.dev/p/E67ZHS)
- [ts 절대경로 설정하기](https://tesseractjh.tistory.com/232)
+
+## **Project Tree**
+
+```
+ceos.week3.react-messenger-23rd
+├─ react-messenger-23rd
+│ ├─ .prettierrc
+│ ├─ dist
+│ │ ├─ assets
+│ │ │ ├─ index-BZvjYWlK.css
+│ │ │ └─ index-DuB9fP3j.js
+│ │ ├─ favicon.svg
+│ │ ├─ icons.svg
+│ │ ├─ images
+│ │ │ ├─ Frame 73.svg
+│ │ │ └─ user-02.svg
+│ │ └─ index.html
+│ ├─ eslint.config.js
+│ ├─ index.html
+│ ├─ package-lock.json
+│ ├─ package.json
+│ ├─ public
+│ │ ├─ favicon.svg
+│ │ ├─ icons.svg
+│ │ └─ images
+│ │ ├─ Frame 73.svg
+│ │ └─ user-02.svg
+│ ├─ README.md
+│ ├─ src
+│ │ ├─ app
+│ │ │ └─ styles
+│ │ │ └─ index.css
+│ │ ├─ App.tsx
+│ │ ├─ entities
+│ │ │ ├─ chat-room
+│ │ │ │ └─ model
+│ │ │ │ ├─ chatRooms.json
+│ │ │ │ └─ types.ts
+│ │ │ ├─ message
+│ │ │ │ ├─ model
+│ │ │ │ │ ├─ messages.json
+│ │ │ │ │ └─ types.ts
+│ │ │ │ └─ ui
+│ │ │ │ └─ MessageBubble.tsx
+│ │ │ └─ user
+│ │ │ └─ model
+│ │ │ ├─ types.ts
+│ │ │ └─ users.json
+│ │ ├─ features
+│ │ │ ├─ create-chat-room
+│ │ │ │ ├─ model
+│ │ │ │ └─ ui
+│ │ │ ├─ send-message
+│ │ │ │ ├─ model
+│ │ │ │ └─ ui
+│ │ │ └─ upload-image
+│ │ │ ├─ model
+│ │ │ └─ ui
+│ │ ├─ main.tsx
+│ │ ├─ pages
+│ │ │ ├─ chat-list
+│ │ │ │ ├─ model
+│ │ │ │ └─ ui
+│ │ │ │ └─ ChatListPage.tsx
+│ │ │ ├─ chat-room
+│ │ │ │ ├─ model
+│ │ │ │ └─ ui
+│ │ │ │ └─ ChatRoomPage.tsx
+│ │ │ ├─ friends
+│ │ │ │ ├─ model
+│ │ │ │ └─ ui
+│ │ │ │ └─ FriendsPage.tsx
+│ │ │ └─ my-profile
+│ │ │ ├─ model
+│ │ │ └─ ui
+│ │ │ └─ MyProfilePage.tsx
+│ │ ├─ shared
+│ │ │ ├─ assets
+│ │ │ │ └─ icons
+│ │ │ │ ├─ chat-list
+│ │ │ │ │ ├─ compass-03.svg
+│ │ │ │ │ ├─ Icon.svg
+│ │ │ │ │ ├─ new chatting(24_24).svg
+│ │ │ │ │ ├─ search(20_20).svg
+│ │ │ │ │ ├─ settings-02.svg
+│ │ │ │ │ ├─ Toggle.svg
+│ │ │ │ │ ├─ user-02.svg
+│ │ │ │ │ ├─ user-circle.svg
+│ │ │ │ │ └─ users-01.svg
+│ │ │ │ ├─ chat-room
+│ │ │ │ │ ├─ face-smile.svg
+│ │ │ │ │ ├─ Frame 73.svg
+│ │ │ │ │ ├─ hamburger(24_24).svg
+│ │ │ │ │ ├─ microphone-01.svg
+│ │ │ │ │ ├─ My_Text Box
+│ │ │ │ │ │ └─ Back (32_32).svg
+│ │ │ │ │ ├─ plus.svg
+│ │ │ │ │ ├─ search(24_24).svg
+│ │ │ │ │ └─ Status Bar
+│ │ │ │ │ ├─ Elements
+│ │ │ │ │ │ ├─ Battery.svg
+│ │ │ │ │ │ ├─ Connection.svg
+│ │ │ │ │ │ └─ Signal.svg
+│ │ │ │ │ └─ Mic & Cam.svg
+│ │ │ │ ├─ chattingRoom
+│ │ │ │ │ ├─ arrow-narrow-up.svg
+│ │ │ │ │ ├─ face-smile.svg
+│ │ │ │ │ ├─ Frame 73.svg
+│ │ │ │ │ ├─ hamburger(24_24).svg
+│ │ │ │ │ ├─ microphone-01.svg
+│ │ │ │ │ ├─ My_Text Box
+│ │ │ │ │ │ └─ Back (32_32).svg
+│ │ │ │ │ ├─ plus.svg
+│ │ │ │ │ ├─ search(24_24).svg
+│ │ │ │ │ └─ Status Bar
+│ │ │ │ │ ├─ Elements
+│ │ │ │ │ │ ├─ Battery.svg
+│ │ │ │ │ │ ├─ Connection.svg
+│ │ │ │ │ │ └─ Signal.svg
+│ │ │ │ │ └─ Mic & Cam.svg
+│ │ │ │ └─ friends
+│ │ │ │ ├─ folder-download.svg
+│ │ │ │ ├─ message-question-circle(24_24).svg
+│ │ │ │ ├─ notification-message (1).svg
+│ │ │ │ ├─ notification-message.svg
+│ │ │ │ ├─ plus.svg
+│ │ │ │ ├─ rightside(24_24).svg
+│ │ │ │ ├─ search(24_24).svg
+│ │ │ │ ├─ upside(24_24).svg
+│ │ │ │ ├─ user-02.svg
+│ │ │ │ └─ user-plus(24_24).svg
+│ │ │ ├─ constants
+│ │ │ ├─ lib
+│ │ │ └─ ui
+│ │ │ ├─ MobileLayout.tsx
+│ │ │ └─ StatusBar.tsx
+│ │ └─ widgets
+│ │ ├─ chat-list
+│ │ │ ├─ model
+│ │ │ └─ ui
+│ │ │ ├─ BottomTabBar.tsx
+│ │ │ ├─ ChatListHeader.tsx
+│ │ │ ├─ ChatListSearch.tsx
+│ │ │ ├─ ChatRoomItem.tsx
+│ │ │ └─ ChatRoomList.tsx
+│ │ ├─ chat-room
+│ │ │ ├─ model
+│ │ │ └─ ui
+│ │ │ ├─ ChatRoomHeader.tsx
+│ │ │ ├─ DateDivider.tsx
+│ │ │ ├─ MessageInputBar.tsx
+│ │ │ └─ MessageList.tsx
+│ │ └─ friends
+│ │ ├─ model
+│ │ └─ ui
+│ │ ├─ FriendItem.tsx
+│ │ ├─ FriendsHeader.tsx
+│ │ ├─ FriendsList.tsx
+│ │ ├─ MyProfileSection.tsx
+│ │ └─ TagSection.tsx
+│ ├─ tsconfig.app.json
+│ ├─ tsconfig.json
+│ ├─ tsconfig.node.json
+│ └─ vite.config.ts
+└─ README.md
+
+```
diff --git a/react-messenger-23rd/.gitignore b/react-messenger-23rd/.gitignore
new file mode 100644
index 00000000..a547bf36
--- /dev/null
+++ b/react-messenger-23rd/.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-messenger-23rd/.prettierrc b/react-messenger-23rd/.prettierrc
new file mode 100644
index 00000000..e4bed3ba
--- /dev/null
+++ b/react-messenger-23rd/.prettierrc
@@ -0,0 +1,9 @@
+{
+ "htmlWhitespaceSensitivity": "ignore",
+ "tabWidth": 2,
+ "printWidth": 120,
+ "singleQuote": true,
+ "trailingComma": "all",
+ "semi": true,
+ "endOfLine": "lf"
+}
diff --git a/react-messenger-23rd/README.md b/react-messenger-23rd/README.md
new file mode 100644
index 00000000..7dbf7ebf
--- /dev/null
+++ b/react-messenger-23rd/README.md
@@ -0,0 +1,73 @@
+# React + TypeScript + 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) uses [Oxc](https://oxc.rs)
+- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react-swc) uses [SWC](https://swc.rs/)
+
+## React Compiler
+
+The React Compiler is not enabled on this template because of its impact on dev & build performances. To add it, see [this documentation](https://react.dev/learn/react-compiler/installation).
+
+## Expanding the ESLint configuration
+
+If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:
+
+```js
+export default defineConfig([
+ globalIgnores(['dist']),
+ {
+ files: ['**/*.{ts,tsx}'],
+ extends: [
+ // Other configs...
+
+ // Remove tseslint.configs.recommended and replace with this
+ tseslint.configs.recommendedTypeChecked,
+ // Alternatively, use this for stricter rules
+ tseslint.configs.strictTypeChecked,
+ // Optionally, add this for stylistic rules
+ tseslint.configs.stylisticTypeChecked,
+
+ // Other configs...
+ ],
+ languageOptions: {
+ parserOptions: {
+ project: ['./tsconfig.node.json', './tsconfig.app.json'],
+ tsconfigRootDir: import.meta.dirname,
+ },
+ // other options...
+ },
+ },
+])
+```
+
+You can also install [eslint-plugin-react-x](https://github.com/Rel1cx/eslint-react/tree/main/packages/plugins/eslint-plugin-react-x) and [eslint-plugin-react-dom](https://github.com/Rel1cx/eslint-react/tree/main/packages/plugins/eslint-plugin-react-dom) for React-specific lint rules:
+
+```js
+// eslint.config.js
+import reactX from 'eslint-plugin-react-x'
+import reactDom from 'eslint-plugin-react-dom'
+
+export default defineConfig([
+ globalIgnores(['dist']),
+ {
+ files: ['**/*.{ts,tsx}'],
+ extends: [
+ // Other configs...
+ // Enable lint rules for React
+ reactX.configs['recommended-typescript'],
+ // Enable lint rules for React DOM
+ reactDom.configs.recommended,
+ ],
+ languageOptions: {
+ parserOptions: {
+ project: ['./tsconfig.node.json', './tsconfig.app.json'],
+ tsconfigRootDir: import.meta.dirname,
+ },
+ // other options...
+ },
+ },
+])
+```
diff --git a/react-messenger-23rd/eslint.config.js b/react-messenger-23rd/eslint.config.js
new file mode 100644
index 00000000..6f2a9c36
--- /dev/null
+++ b/react-messenger-23rd/eslint.config.js
@@ -0,0 +1,31 @@
+import js from '@eslint/js';
+import { defineConfig, globalIgnores } from 'eslint/config';
+import reactHooks from 'eslint-plugin-react-hooks';
+import reactRefresh from 'eslint-plugin-react-refresh';
+import simpleImportSort from 'eslint-plugin-simple-import-sort';
+import globals from 'globals';
+import tseslint from 'typescript-eslint';
+
+export default defineConfig([
+ globalIgnores(['dist']),
+ {
+ files: ['**/*.{ts,tsx,js,jsx}'],
+ extends: [
+ js.configs.recommended,
+ ...tseslint.configs.recommended,
+ reactHooks.configs.flat.recommended,
+ reactRefresh.configs.vite,
+ ],
+ languageOptions: {
+ ecmaVersion: 2020,
+ globals: globals.browser,
+ },
+ plugins: {
+ 'simple-import-sort': simpleImportSort,
+ },
+ rules: {
+ 'simple-import-sort/imports': 'error',
+ 'simple-import-sort/exports': 'error',
+ },
+ },
+]);
diff --git a/react-messenger-23rd/index.html b/react-messenger-23rd/index.html
new file mode 100644
index 00000000..e4980ec4
--- /dev/null
+++ b/react-messenger-23rd/index.html
@@ -0,0 +1,13 @@
+
+
+
+
+
+
+ react-messenger-23rd
+
+
+
+
+
+
diff --git a/react-messenger-23rd/package-lock.json b/react-messenger-23rd/package-lock.json
new file mode 100644
index 00000000..551b79c0
--- /dev/null
+++ b/react-messenger-23rd/package-lock.json
@@ -0,0 +1,3955 @@
+{
+ "name": "react-messenger-23rd",
+ "version": "0.0.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "react-messenger-23rd",
+ "version": "0.0.0",
+ "dependencies": {
+ "@tailwindcss/postcss": "^4.2.2",
+ "@tailwindcss/vite": "^4.2.2",
+ "react": "^19.2.4",
+ "react-dom": "^19.2.4",
+ "react-router-dom": "^7.14.0",
+ "tailwindcss": "^4.2.2",
+ "vite-tsconfig-paths": "^6.1.1"
+ },
+ "devDependencies": {
+ "@eslint/js": "^9.39.4",
+ "@trivago/prettier-plugin-sort-imports": "^6.0.2",
+ "@types/node": "^24.12.0",
+ "@types/react": "^19.2.14",
+ "@types/react-dom": "^19.2.3",
+ "@vitejs/plugin-react": "^6.0.1",
+ "eslint": "^9.39.4",
+ "eslint-plugin-react-hooks": "^7.0.1",
+ "eslint-plugin-react-refresh": "^0.5.2",
+ "eslint-plugin-simple-import-sort": "^12.1.1",
+ "globals": "^17.4.0",
+ "prettier": "^3.8.1",
+ "typescript": "~5.9.3",
+ "typescript-eslint": "^8.57.0",
+ "vite": "^8.0.1",
+ "vite-plugin-svgr": "^4.5.0"
+ }
+ },
+ "node_modules/@alloc/quick-lru": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz",
+ "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.29.0.tgz",
+ "integrity": "sha512-9NhCeYjq9+3uxgdtp20LSiJXJvN0FeCtNGpJxuMFZ1Kv3cWUNb6DOhJwUvcVCzKGR66cw4njwM6hrJLqgOwbcw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.28.5",
+ "js-tokens": "^4.0.0",
+ "picocolors": "^1.1.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/compat-data": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.29.0.tgz",
+ "integrity": "sha512-T1NCJqT/j9+cn8fvkt7jtwbLBfLC/1y1c7NtCeXFRgzGTsafi68MRv8yzkYSapBnFA6L3U2VSc02ciDzoAJhJg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/core": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.29.0.tgz",
+ "integrity": "sha512-CGOfOJqWjg2qW/Mb6zNsDm+u5vFQ8DxXfbM09z69p5Z6+mE1ikP2jUXw+j42Pf1XTYED2Rni5f95npYeuwMDQA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.29.0",
+ "@babel/generator": "^7.29.0",
+ "@babel/helper-compilation-targets": "^7.28.6",
+ "@babel/helper-module-transforms": "^7.28.6",
+ "@babel/helpers": "^7.28.6",
+ "@babel/parser": "^7.29.0",
+ "@babel/template": "^7.28.6",
+ "@babel/traverse": "^7.29.0",
+ "@babel/types": "^7.29.0",
+ "@jridgewell/remapping": "^2.3.5",
+ "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.29.1",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.29.1.tgz",
+ "integrity": "sha512-qsaF+9Qcm2Qv8SRIMMscAvG4O3lJ0F1GuMo5HR/Bp02LopNgnZBC/EkbevHFeGs4ls/oPz9v+Bsmzbkbe+0dUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.29.0",
+ "@babel/types": "^7.29.0",
+ "@jridgewell/gen-mapping": "^0.3.12",
+ "@jridgewell/trace-mapping": "^0.3.28",
+ "jsesc": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-compilation-targets": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.28.6.tgz",
+ "integrity": "sha512-JYtls3hqi15fcx5GaSNL7SCTJ2MNmjrkHXg4FSpOA/grxK8KwyZ5bubHsCq8FXCkua6xhuaaBit+3b7+VZRfcA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/compat-data": "^7.28.6",
+ "@babel/helper-validator-option": "^7.27.1",
+ "browserslist": "^4.24.0",
+ "lru-cache": "^5.1.1",
+ "semver": "^6.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-globals": {
+ "version": "7.28.0",
+ "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz",
+ "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.28.6.tgz",
+ "integrity": "sha512-l5XkZK7r7wa9LucGw9LwZyyCUscb4x37JWTPz7swwFE/0FMQAGpiWUZn8u9DzkSBWEcK25jmvubfpw2dnAMdbw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/traverse": "^7.28.6",
+ "@babel/types": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-transforms": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.6.tgz",
+ "integrity": "sha512-67oXFAYr2cDLDVGLXTEABjdBJZ6drElUSI7WKp70NrpyISso3plG9SAGEF6y7zbha/wOzUByWWTJvEDVNIUGcA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.28.6",
+ "@babel/helper-validator-identifier": "^7.28.5",
+ "@babel/traverse": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.27.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.27.1.tgz",
+ "integrity": "sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.28.5",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.28.5.tgz",
+ "integrity": "sha512-qSs4ifwzKJSV39ucNjsvc6WVHs6b7S03sOh2OcHF9UHfVPqWWALUsNUVzhSBiItjRZoLHx7nIarVjqKVusUZ1Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-option": {
+ "version": "7.27.1",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.27.1.tgz",
+ "integrity": "sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helpers": {
+ "version": "7.29.2",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.29.2.tgz",
+ "integrity": "sha512-HoGuUs4sCZNezVEKdVcwqmZN8GoHirLUcLaYVNBK2J0DadGtdcqgr3BCbvH8+XUo4NGjNl3VOtSjEKNzqfFgKw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/template": "^7.28.6",
+ "@babel/types": "^7.29.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.29.2",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.29.2.tgz",
+ "integrity": "sha512-4GgRzy/+fsBa72/RZVJmGKPmZu9Byn8o4MoLpmNe1m8ZfYnz5emHLQz3U4gLud6Zwl0RZIcgiLD7Uq7ySFuDLA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.29.0"
+ },
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.28.6",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.28.6.tgz",
+ "integrity": "sha512-YA6Ma2KsCdGb+WC6UpBVFJGXL58MDA6oyONbjyF/+5sBgxY/dwkhLogbMT2GXXyU84/IhRw/2D1Os1B/giz+BQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.28.6",
+ "@babel/parser": "^7.28.6",
+ "@babel/types": "^7.28.6"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.29.0.tgz",
+ "integrity": "sha512-4HPiQr0X7+waHfyXPZpWPfWL/J7dcN1mx9gL6WdQVMbPnF3+ZhSMs8tCxN7oHddJE9fhNE7+lxdnlyemKfJRuA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.29.0",
+ "@babel/generator": "^7.29.0",
+ "@babel/helper-globals": "^7.28.0",
+ "@babel/parser": "^7.29.0",
+ "@babel/template": "^7.28.6",
+ "@babel/types": "^7.29.0",
+ "debug": "^4.3.1"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.29.0",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.29.0.tgz",
+ "integrity": "sha512-LwdZHpScM4Qz8Xw2iKSzS+cfglZzJGvofQICy7W7v4caru4EaAmyUuO6BGrbyQ2mYV11W0U8j5mBhd14dd3B0A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.27.1",
+ "@babel/helper-validator-identifier": "^7.28.5"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@emnapi/core": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/@emnapi/core/-/core-1.9.1.tgz",
+ "integrity": "sha512-mukuNALVsoix/w1BJwFzwXBN/dHeejQtuVzcDsfOEsdpCumXb/E9j8w11h5S54tT1xhifGfbbSm/ICrObRb3KA==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@emnapi/wasi-threads": "1.2.0",
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@emnapi/runtime": {
+ "version": "1.9.1",
+ "resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-1.9.1.tgz",
+ "integrity": "sha512-VYi5+ZVLhpgK4hQ0TAjiQiZ6ol0oe4mBx7mVv7IflsiEp0OWoVsp/+f9Vc1hOhE0TtkORVrI1GvzyreqpgWtkA==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@emnapi/wasi-threads": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@emnapi/wasi-threads/-/wasi-threads-1.2.0.tgz",
+ "integrity": "sha512-N10dEJNSsUx41Z6pZsXU8FjPjpBEplgH24sfkmITrBED1/U2Esum9F3lfLrMjKHHjmi557zQn7kR9R+XWXu5Rg==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils": {
+ "version": "4.9.1",
+ "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.9.1.tgz",
+ "integrity": "sha512-phrYmNiYppR7znFEdqgfWHXR6NCkZEK7hwWDHZUjit/2/U0r6XvkDl0SYnoM51Hq7FhCGdLDT6zxCCOY1hexsQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "eslint-visitor-keys": "^3.4.3"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ },
+ "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.12.2",
+ "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.2.tgz",
+ "integrity": "sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/config-array": {
+ "version": "0.21.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.2.tgz",
+ "integrity": "sha512-nJl2KGTlrf9GjLimgIru+V/mzgSK0ABCDQRvxw5BjURL7WfH5uoWmizbH7QB6MmnMBd8cIC9uceWnezL1VZWWw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/object-schema": "^2.1.7",
+ "debug": "^4.3.1",
+ "minimatch": "^3.1.5"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/config-helpers": {
+ "version": "0.4.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.2.tgz",
+ "integrity": "sha512-gBrxN88gOIf3R7ja5K9slwNayVcZgK6SOUORm2uBzTeIEfeVaIhOpCtTox3P6R7o2jLFwLFTLnC7kU/RGcYEgw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^0.17.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/core": {
+ "version": "0.17.0",
+ "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.17.0.tgz",
+ "integrity": "sha512-yL/sLrpmtDaFEiUj1osRP4TI2MDz1AddJL+jZ7KSqvBuliN4xqYY54IfdN8qD8Toa6g1iloph1fxQNkjOxrrpQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@types/json-schema": "^7.0.15"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/eslintrc": {
+ "version": "3.3.5",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.5.tgz",
+ "integrity": "sha512-4IlJx0X0qftVsN5E+/vGujTRIFtwuLbNsVUe7TO6zYPDR1O6nFwvwhIKEKSrl6dZchmYBITazxKoUYOjdtjlRg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "ajv": "^6.14.0",
+ "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.1",
+ "minimatch": "^3.1.5",
+ "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.39.4",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.39.4.tgz",
+ "integrity": "sha512-nE7DEIchvtiFTwBw4Lfbu59PG+kCofhjsKaCWzxTpt4lfRjRMqG6uMBzKXuEcyXhOHoUp9riAm7/aWYGhXZ9cw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://eslint.org/donate"
+ }
+ },
+ "node_modules/@eslint/object-schema": {
+ "version": "2.1.7",
+ "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.7.tgz",
+ "integrity": "sha512-VtAOaymWVfZcmZbp6E2mympDIHvyjXs/12LqWYjVw6qjrfF+VK+fyG33kChz3nnK+SU5/NeHOqrTEHS8sXO3OA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@eslint/plugin-kit": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.1.tgz",
+ "integrity": "sha512-43/qtrDUokr7LJqoF2c3+RInu/t4zfrpYdoSDfYyhg52rwLV6TnOvdG4fXm7IkSB3wErkcmJS9iEhjVtOSEjjA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^0.17.0",
+ "levn": "^0.4.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ }
+ },
+ "node_modules/@humanfs/core": {
+ "version": "0.19.1",
+ "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
+ "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=18.18.0"
+ }
+ },
+ "node_modules/@humanfs/node": {
+ "version": "0.16.7",
+ "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.7.tgz",
+ "integrity": "sha512-/zUx+yOsIrG4Y43Eh2peDeKCxlRt/gET6aHfaKpuq267qXdYDFViVHfMaLyygZOnl0kGWxFIgsBy8QFuTLUXEQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@humanfs/core": "^0.19.1",
+ "@humanwhocodes/retry": "^0.4.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.4.3",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz",
+ "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==",
+ "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.13",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz",
+ "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.5.0",
+ "@jridgewell/trace-mapping": "^0.3.24"
+ }
+ },
+ "node_modules/@jridgewell/remapping": {
+ "version": "2.3.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz",
+ "integrity": "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/gen-mapping": "^0.3.5",
+ "@jridgewell/trace-mapping": "^0.3.24"
+ }
+ },
+ "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==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@jridgewell/sourcemap-codec": {
+ "version": "1.5.5",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz",
+ "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==",
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/trace-mapping": {
+ "version": "0.3.31",
+ "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz",
+ "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/resolve-uri": "^3.1.0",
+ "@jridgewell/sourcemap-codec": "^1.4.14"
+ }
+ },
+ "node_modules/@napi-rs/wasm-runtime": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@napi-rs/wasm-runtime/-/wasm-runtime-1.1.1.tgz",
+ "integrity": "sha512-p64ah1M1ld8xjWv3qbvFwHiFVWrq1yFvV4f7w+mzaqiR4IlSgkqhcRdHwsGgomwzBH51sRY4NEowLxnaBjcW/A==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@emnapi/core": "^1.7.1",
+ "@emnapi/runtime": "^1.7.1",
+ "@tybys/wasm-util": "^0.10.1"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/Brooooooklyn"
+ }
+ },
+ "node_modules/@oxc-project/types": {
+ "version": "0.122.0",
+ "resolved": "https://registry.npmjs.org/@oxc-project/types/-/types-0.122.0.tgz",
+ "integrity": "sha512-oLAl5kBpV4w69UtFZ9xqcmTi+GENWOcPF7FCrczTiBbmC0ibXxCwyvZGbO39rCVEuLGAZM84DH0pUIyyv/YJzA==",
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/Boshen"
+ }
+ },
+ "node_modules/@rolldown/binding-android-arm64": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-android-arm64/-/binding-android-arm64-1.0.0-rc.11.tgz",
+ "integrity": "sha512-SJ+/g+xNnOh6NqYxD0V3uVN4W3VfnrGsC9/hoglicgTNfABFG9JjISvkkU0dNY84MNHLWyOgxP9v9Y9pX4S7+A==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-darwin-arm64": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-darwin-arm64/-/binding-darwin-arm64-1.0.0-rc.11.tgz",
+ "integrity": "sha512-7WQgR8SfOPwmDZGFkThUvsmd/nwAWv91oCO4I5LS7RKrssPZmOt7jONN0cW17ydGC1n/+puol1IpoieKqQidmg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-darwin-x64": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-darwin-x64/-/binding-darwin-x64-1.0.0-rc.11.tgz",
+ "integrity": "sha512-39Ks6UvIHq4rEogIfQBoBRusj0Q0nPVWIvqmwBLaT6aqQGIakHdESBVOPRRLacy4WwUPIx4ZKzfZ9PMW+IeyUQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-freebsd-x64": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-freebsd-x64/-/binding-freebsd-x64-1.0.0-rc.11.tgz",
+ "integrity": "sha512-jfsm0ZHfhiqrvWjJAmzsqiIFPz5e7mAoCOPBNTcNgkiid/LaFKiq92+0ojH+nmJmKYkre4t71BWXUZDNp7vsag==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm-gnueabihf": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm-gnueabihf/-/binding-linux-arm-gnueabihf-1.0.0-rc.11.tgz",
+ "integrity": "sha512-zjQaUtSyq1nVe3nxmlSCuR96T1LPlpvmJ0SZy0WJFEsV4kFbXcq2u68L4E6O0XeFj4aex9bEauqjW8UQBeAvfQ==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm64-gnu": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm64-gnu/-/binding-linux-arm64-gnu-1.0.0-rc.11.tgz",
+ "integrity": "sha512-WMW1yE6IOnehTcFE9eipFkm3XN63zypWlrJQ2iF7NrQ9b2LDRjumFoOGJE8RJJTJCTBAdmLMnJ8uVitACUUo1Q==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-arm64-musl": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-arm64-musl/-/binding-linux-arm64-musl-1.0.0-rc.11.tgz",
+ "integrity": "sha512-jfndI9tsfm4APzjNt6QdBkYwre5lRPUgHeDHoI7ydKUuJvz3lZeCfMsI56BZj+7BYqiKsJm7cfd/6KYV7ubrBg==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-ppc64-gnu": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-ppc64-gnu/-/binding-linux-ppc64-gnu-1.0.0-rc.11.tgz",
+ "integrity": "sha512-ZlFgw46NOAGMgcdvdYwAGu2Q+SLFA9LzbJLW+iyMOJyhj5wk6P3KEE9Gct4xWwSzFoPI7JCdYmYMzVtlgQ+zfw==",
+ "cpu": [
+ "ppc64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-s390x-gnu": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-s390x-gnu/-/binding-linux-s390x-gnu-1.0.0-rc.11.tgz",
+ "integrity": "sha512-hIOYmuT6ofM4K04XAZd3OzMySEO4K0/nc9+jmNcxNAxRi6c5UWpqfw3KMFV4MVFWL+jQsSh+bGw2VqmaPMTLyw==",
+ "cpu": [
+ "s390x"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-x64-gnu": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-x64-gnu/-/binding-linux-x64-gnu-1.0.0-rc.11.tgz",
+ "integrity": "sha512-qXBQQO9OvkjjQPLdUVr7Nr2t3QTZI7s4KZtfw7HzBgjbmAPSFwSv4rmET9lLSgq3rH/ndA3ngv3Qb8l2njoPNA==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-linux-x64-musl": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-linux-x64-musl/-/binding-linux-x64-musl-1.0.0-rc.11.tgz",
+ "integrity": "sha512-/tpFfoSTzUkH9LPY+cYbqZBDyyX62w5fICq9qzsHLL8uTI6BHip3Q9Uzft0wylk/i8OOwKik8OxW+QAhDmzwmg==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-openharmony-arm64": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-openharmony-arm64/-/binding-openharmony-arm64-1.0.0-rc.11.tgz",
+ "integrity": "sha512-mcp3Rio2w72IvdZG0oQ4bM2c2oumtwHfUfKncUM6zGgz0KgPz4YmDPQfnXEiY5t3+KD/i8HG2rOB/LxdmieK2g==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "openharmony"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-wasm32-wasi": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-wasm32-wasi/-/binding-wasm32-wasi-1.0.0-rc.11.tgz",
+ "integrity": "sha512-LXk5Hii1Ph9asuGRjBuz8TUxdc1lWzB7nyfdoRgI0WGPZKmCxvlKk8KfYysqtr4MfGElu/f/pEQRh8fcEgkrWw==",
+ "cpu": [
+ "wasm32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@napi-rs/wasm-runtime": "^1.1.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ }
+ },
+ "node_modules/@rolldown/binding-win32-arm64-msvc": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-win32-arm64-msvc/-/binding-win32-arm64-msvc-1.0.0-rc.11.tgz",
+ "integrity": "sha512-dDwf5otnx0XgRY1yqxOC4ITizcdzS/8cQ3goOWv3jFAo4F+xQYni+hnMuO6+LssHHdJW7+OCVL3CoU4ycnh35Q==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/binding-win32-x64-msvc": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/binding-win32-x64-msvc/-/binding-win32-x64-msvc-1.0.0-rc.11.tgz",
+ "integrity": "sha512-LN4/skhSggybX71ews7dAj6r2geaMJfm3kMbK2KhFMg9B10AZXnKoLCVVgzhMHL0S+aKtr4p8QbAW8k+w95bAA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ }
+ },
+ "node_modules/@rolldown/pluginutils": {
+ "version": "1.0.0-rc.7",
+ "resolved": "https://registry.npmjs.org/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.7.tgz",
+ "integrity": "sha512-qujRfC8sFVInYSPPMLQByRh7zhwkGFS4+tyMQ83srV1qrxL4g8E2tyxVVyxd0+8QeBM1mIk9KbWxkegRr76XzA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/@rollup/pluginutils": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.3.0.tgz",
+ "integrity": "sha512-5EdhGZtnu3V88ces7s53hhfK5KSASnJZv8Lulpc04cWO3REESroJXg73DFsOmgbU2BhwV0E20bu2IDZb3VKW4Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@types/estree": "^1.0.0",
+ "estree-walker": "^2.0.2",
+ "picomatch": "^4.0.2"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ },
+ "peerDependencies": {
+ "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0"
+ },
+ "peerDependenciesMeta": {
+ "rollup": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@svgr/babel-plugin-add-jsx-attribute": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-8.0.0.tgz",
+ "integrity": "sha512-b9MIk7yhdS1pMCZM8VeNfUlSKVRhsHZNMl5O9SfaX0l0t5wjdgu4IDzGB8bpnGBBOjGST3rRFVsaaEtI4W6f7g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-remove-jsx-attribute": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-8.0.0.tgz",
+ "integrity": "sha512-BcCkm/STipKvbCl6b7QFrMh/vx00vIP63k2eM66MfHJzPr6O2U0jYEViXkHJWqXqQYjdeA9cuCl5KWmlwjDvbA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-remove-jsx-empty-expression": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-8.0.0.tgz",
+ "integrity": "sha512-5BcGCBfBxB5+XSDSWnhTThfI9jcO5f0Ai2V24gZpG+wXF14BzwxxdDb4g6trdOux0rhibGs385BeFMSmxtS3uA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-replace-jsx-attribute-value": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-8.0.0.tgz",
+ "integrity": "sha512-KVQ+PtIjb1BuYT3ht8M5KbzWBhdAjjUPdlMtpuw/VjT8coTrItWX6Qafl9+ji831JaJcu6PJNKCV0bp01lBNzQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-svg-dynamic-title": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-8.0.0.tgz",
+ "integrity": "sha512-omNiKqwjNmOQJ2v6ge4SErBbkooV2aAWwaPFs2vUY7p7GhVkzRkJ00kILXQvRhA6miHnNpXv7MRnnSjdRjK8og==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-svg-em-dimensions": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-8.0.0.tgz",
+ "integrity": "sha512-mURHYnu6Iw3UBTbhGwE/vsngtCIbHE43xCRK7kCw4t01xyGqb2Pd+WXekRRoFOBIY29ZoOhUCTEweDMdrjfi9g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-transform-react-native-svg": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-8.1.0.tgz",
+ "integrity": "sha512-Tx8T58CHo+7nwJ+EhUwx3LfdNSG9R2OKfaIXXs5soiy5HtgoAEkDay9LIimLOcG8dJQH1wPZp/cnAv6S9CrR1Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-plugin-transform-svg-component": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-8.0.0.tgz",
+ "integrity": "sha512-DFx8xa3cZXTdb/k3kfPeaixecQLgKh5NVBMwD0AQxOzcZawK4oo1Jh9LbrcACUivsCA7TLG8eeWgrDXjTMhRmw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/babel-preset": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/babel-preset/-/babel-preset-8.1.0.tgz",
+ "integrity": "sha512-7EYDbHE7MxHpv4sxvnVPngw5fuR6pw79SkcrILHJ/iMpuKySNCl5W1qcwPEpU+LgyRXOaAFgH0KhwD18wwg6ug==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@svgr/babel-plugin-add-jsx-attribute": "8.0.0",
+ "@svgr/babel-plugin-remove-jsx-attribute": "8.0.0",
+ "@svgr/babel-plugin-remove-jsx-empty-expression": "8.0.0",
+ "@svgr/babel-plugin-replace-jsx-attribute-value": "8.0.0",
+ "@svgr/babel-plugin-svg-dynamic-title": "8.0.0",
+ "@svgr/babel-plugin-svg-em-dimensions": "8.0.0",
+ "@svgr/babel-plugin-transform-react-native-svg": "8.1.0",
+ "@svgr/babel-plugin-transform-svg-component": "8.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@babel/core": "^7.0.0-0"
+ }
+ },
+ "node_modules/@svgr/core": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/core/-/core-8.1.0.tgz",
+ "integrity": "sha512-8QqtOQT5ACVlmsvKOJNEaWmRPmcojMOzCz4Hs2BGG/toAp/K38LcsMRyLp349glq5AzJbCEeimEoxaX6v/fLrA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/core": "^7.21.3",
+ "@svgr/babel-preset": "8.1.0",
+ "camelcase": "^6.2.0",
+ "cosmiconfig": "^8.1.3",
+ "snake-case": "^3.0.4"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ }
+ },
+ "node_modules/@svgr/hast-util-to-babel-ast": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-8.0.0.tgz",
+ "integrity": "sha512-EbDKwO9GpfWP4jN9sGdYwPBU0kdomaPIL2Eu4YwmgP+sJeXT+L7bMwJUBnhzfH8Q2qMBqZ4fJwpCyYsAN3mt2Q==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.21.3",
+ "entities": "^4.4.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ }
+ },
+ "node_modules/@svgr/plugin-jsx": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/@svgr/plugin-jsx/-/plugin-jsx-8.1.0.tgz",
+ "integrity": "sha512-0xiIyBsLlr8quN+WyuxooNW9RJ0Dpr8uOnH/xrCVO8GLUcwHISwj1AG0k+LFzteTkAA0GbX0kj9q6Dk70PTiPA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/core": "^7.21.3",
+ "@svgr/babel-preset": "8.1.0",
+ "@svgr/hast-util-to-babel-ast": "8.0.0",
+ "svg-parser": "^2.0.4"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/gregberge"
+ },
+ "peerDependencies": {
+ "@svgr/core": "*"
+ }
+ },
+ "node_modules/@tailwindcss/node": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/node/-/node-4.2.2.tgz",
+ "integrity": "sha512-pXS+wJ2gZpVXqFaUEjojq7jzMpTGf8rU6ipJz5ovJV6PUGmlJ+jvIwGrzdHdQ80Sg+wmQxUFuoW1UAAwHNEdFA==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/remapping": "^2.3.5",
+ "enhanced-resolve": "^5.19.0",
+ "jiti": "^2.6.1",
+ "lightningcss": "1.32.0",
+ "magic-string": "^0.30.21",
+ "source-map-js": "^1.2.1",
+ "tailwindcss": "4.2.2"
+ }
+ },
+ "node_modules/@tailwindcss/oxide": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide/-/oxide-4.2.2.tgz",
+ "integrity": "sha512-qEUA07+E5kehxYp9BVMpq9E8vnJuBHfJEC0vPC5e7iL/hw7HR61aDKoVoKzrG+QKp56vhNZe4qwkRmMC0zDLvg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">= 20"
+ },
+ "optionalDependencies": {
+ "@tailwindcss/oxide-android-arm64": "4.2.2",
+ "@tailwindcss/oxide-darwin-arm64": "4.2.2",
+ "@tailwindcss/oxide-darwin-x64": "4.2.2",
+ "@tailwindcss/oxide-freebsd-x64": "4.2.2",
+ "@tailwindcss/oxide-linux-arm-gnueabihf": "4.2.2",
+ "@tailwindcss/oxide-linux-arm64-gnu": "4.2.2",
+ "@tailwindcss/oxide-linux-arm64-musl": "4.2.2",
+ "@tailwindcss/oxide-linux-x64-gnu": "4.2.2",
+ "@tailwindcss/oxide-linux-x64-musl": "4.2.2",
+ "@tailwindcss/oxide-wasm32-wasi": "4.2.2",
+ "@tailwindcss/oxide-win32-arm64-msvc": "4.2.2",
+ "@tailwindcss/oxide-win32-x64-msvc": "4.2.2"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-android-arm64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-android-arm64/-/oxide-android-arm64-4.2.2.tgz",
+ "integrity": "sha512-dXGR1n+P3B6748jZO/SvHZq7qBOqqzQ+yFrXpoOWWALWndF9MoSKAT3Q0fYgAzYzGhxNYOoysRvYlpixRBBoDg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-darwin-arm64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-arm64/-/oxide-darwin-arm64-4.2.2.tgz",
+ "integrity": "sha512-iq9Qjr6knfMpZHj55/37ouZeykwbDqF21gPFtfnhCCKGDcPI/21FKC9XdMO/XyBM7qKORx6UIhGgg6jLl7BZlg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-darwin-x64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-darwin-x64/-/oxide-darwin-x64-4.2.2.tgz",
+ "integrity": "sha512-BlR+2c3nzc8f2G639LpL89YY4bdcIdUmiOOkv2GQv4/4M0vJlpXEa0JXNHhCHU7VWOKWT/CjqHdTP8aUuDJkuw==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-freebsd-x64": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-freebsd-x64/-/oxide-freebsd-x64-4.2.2.tgz",
+ "integrity": "sha512-YUqUgrGMSu2CDO82hzlQ5qSb5xmx3RUrke/QgnoEx7KvmRJHQuZHZmZTLSuuHwFf0DJPybFMXMYf+WJdxHy/nQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm-gnueabihf": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm-gnueabihf/-/oxide-linux-arm-gnueabihf-4.2.2.tgz",
+ "integrity": "sha512-FPdhvsW6g06T9BWT0qTwiVZYE2WIFo2dY5aCSpjG/S/u1tby+wXoslXS0kl3/KXnULlLr1E3NPRRw0g7t2kgaQ==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm64-gnu": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-gnu/-/oxide-linux-arm64-gnu-4.2.2.tgz",
+ "integrity": "sha512-4og1V+ftEPXGttOO7eCmW7VICmzzJWgMx+QXAJRAhjrSjumCwWqMfkDrNu1LXEQzNAwz28NCUpucgQPrR4S2yw==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-arm64-musl": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-arm64-musl/-/oxide-linux-arm64-musl-4.2.2.tgz",
+ "integrity": "sha512-oCfG/mS+/+XRlwNjnsNLVwnMWYH7tn/kYPsNPh+JSOMlnt93mYNCKHYzylRhI51X+TbR+ufNhhKKzm6QkqX8ag==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-x64-gnu": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-gnu/-/oxide-linux-x64-gnu-4.2.2.tgz",
+ "integrity": "sha512-rTAGAkDgqbXHNp/xW0iugLVmX62wOp2PoE39BTCGKjv3Iocf6AFbRP/wZT/kuCxC9QBh9Pu8XPkv/zCZB2mcMg==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-linux-x64-musl": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-linux-x64-musl/-/oxide-linux-x64-musl-4.2.2.tgz",
+ "integrity": "sha512-XW3t3qwbIwiSyRCggeO2zxe3KWaEbM0/kW9e8+0XpBgyKU4ATYzcVSMKteZJ1iukJ3HgHBjbg9P5YPRCVUxlnQ==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-wasm32-wasi": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-wasm32-wasi/-/oxide-wasm32-wasi-4.2.2.tgz",
+ "integrity": "sha512-eKSztKsmEsn1O5lJ4ZAfyn41NfG7vzCg496YiGtMDV86jz1q/irhms5O0VrY6ZwTUkFy/EKG3RfWgxSI3VbZ8Q==",
+ "bundleDependencies": [
+ "@napi-rs/wasm-runtime",
+ "@emnapi/core",
+ "@emnapi/runtime",
+ "@tybys/wasm-util",
+ "@emnapi/wasi-threads",
+ "tslib"
+ ],
+ "cpu": [
+ "wasm32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "@emnapi/core": "^1.8.1",
+ "@emnapi/runtime": "^1.8.1",
+ "@emnapi/wasi-threads": "^1.1.0",
+ "@napi-rs/wasm-runtime": "^1.1.1",
+ "@tybys/wasm-util": "^0.10.1",
+ "tslib": "^2.8.1"
+ },
+ "engines": {
+ "node": ">=14.0.0"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-win32-arm64-msvc": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-arm64-msvc/-/oxide-win32-arm64-msvc-4.2.2.tgz",
+ "integrity": "sha512-qPmaQM4iKu5mxpsrWZMOZRgZv1tOZpUm+zdhhQP0VhJfyGGO3aUKdbh3gDZc/dPLQwW4eSqWGrrcWNBZWUWaXQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/oxide-win32-x64-msvc": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/oxide-win32-x64-msvc/-/oxide-win32-x64-msvc-4.2.2.tgz",
+ "integrity": "sha512-1T/37VvI7WyH66b+vqHj/cLwnCxt7Qt3WFu5Q8hk65aOvlwAhs7rAp1VkulBJw/N4tMirXjVnylTR72uI0HGcA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 20"
+ }
+ },
+ "node_modules/@tailwindcss/postcss": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/postcss/-/postcss-4.2.2.tgz",
+ "integrity": "sha512-n4goKQbW8RVXIbNKRB/45LzyUqN451deQK0nzIeauVEqjlI49slUlgKYJM2QyUzap/PcpnS7kzSUmPb1sCRvYQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@alloc/quick-lru": "^5.2.0",
+ "@tailwindcss/node": "4.2.2",
+ "@tailwindcss/oxide": "4.2.2",
+ "postcss": "^8.5.6",
+ "tailwindcss": "4.2.2"
+ }
+ },
+ "node_modules/@tailwindcss/vite": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/@tailwindcss/vite/-/vite-4.2.2.tgz",
+ "integrity": "sha512-mEiF5HO1QqCLXoNEfXVA1Tzo+cYsrqV7w9Juj2wdUFyW07JRenqMG225MvPwr3ZD9N1bFQj46X7r33iHxLUW0w==",
+ "license": "MIT",
+ "dependencies": {
+ "@tailwindcss/node": "4.2.2",
+ "@tailwindcss/oxide": "4.2.2",
+ "tailwindcss": "4.2.2"
+ },
+ "peerDependencies": {
+ "vite": "^5.2.0 || ^6 || ^7 || ^8"
+ }
+ },
+ "node_modules/@trivago/prettier-plugin-sort-imports": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/@trivago/prettier-plugin-sort-imports/-/prettier-plugin-sort-imports-6.0.2.tgz",
+ "integrity": "sha512-3DgfkukFyC/sE/VuYjaUUWoFfuVjPK55vOFDsxD56XXynFMCZDYFogH2l/hDfOsQAm1myoU/1xByJ3tWqtulXA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@babel/generator": "^7.28.0",
+ "@babel/parser": "^7.28.0",
+ "@babel/traverse": "^7.28.0",
+ "@babel/types": "^7.28.0",
+ "javascript-natural-sort": "^0.7.1",
+ "lodash-es": "^4.17.21",
+ "minimatch": "^9.0.0",
+ "parse-imports-exports": "^0.2.4"
+ },
+ "engines": {
+ "node": ">= 20"
+ },
+ "peerDependencies": {
+ "@vue/compiler-sfc": "3.x",
+ "prettier": "2.x - 3.x",
+ "prettier-plugin-ember-template-tag": ">= 2.0.0",
+ "prettier-plugin-svelte": "3.x",
+ "svelte": "4.x || 5.x"
+ },
+ "peerDependenciesMeta": {
+ "@vue/compiler-sfc": {
+ "optional": true
+ },
+ "prettier-plugin-ember-template-tag": {
+ "optional": true
+ },
+ "prettier-plugin-svelte": {
+ "optional": true
+ },
+ "svelte": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@trivago/prettier-plugin-sort-imports/node_modules/brace-expansion": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.2.tgz",
+ "integrity": "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "balanced-match": "^1.0.0"
+ }
+ },
+ "node_modules/@trivago/prettier-plugin-sort-imports/node_modules/minimatch": {
+ "version": "9.0.9",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.9.tgz",
+ "integrity": "sha512-OBwBN9AL4dqmETlpS2zasx+vTeWclWzkblfZk7KTA5j3jeOONz/tRCnZomUyvNg83wL5Zv9Ss6HMJXAgL8R2Yg==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "brace-expansion": "^2.0.2"
+ },
+ "engines": {
+ "node": ">=16 || 14 >=14.17"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/@tybys/wasm-util": {
+ "version": "0.10.1",
+ "resolved": "https://registry.npmjs.org/@tybys/wasm-util/-/wasm-util-0.10.1.tgz",
+ "integrity": "sha512-9tTaPJLSiejZKx+Bmog4uSubteqTvFrVrURwkmHixBo0G4seD0zUxp98E1DzUBJxLQ3NPwXrGKDiVjwx/DpPsg==",
+ "license": "MIT",
+ "optional": true,
+ "dependencies": {
+ "tslib": "^2.4.0"
+ }
+ },
+ "node_modules/@types/estree": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz",
+ "integrity": "sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==",
+ "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/node": {
+ "version": "24.12.0",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-24.12.0.tgz",
+ "integrity": "sha512-GYDxsZi3ChgmckRT9HPU0WEhKLP08ev/Yfcq2AstjrDASOYCSXeyjDsHg4v5t4jOj7cyDX3vmprafKlWIG9MXQ==",
+ "devOptional": true,
+ "license": "MIT",
+ "dependencies": {
+ "undici-types": "~7.16.0"
+ }
+ },
+ "node_modules/@types/react": {
+ "version": "19.2.14",
+ "resolved": "https://registry.npmjs.org/@types/react/-/react-19.2.14.tgz",
+ "integrity": "sha512-ilcTH/UniCkMdtexkoCN0bI7pMcJDvmQFPvuPvmEaYA/NSfFTAgdUSLAoVjaRJm7+6PvcM+q1zYOwS4wTYMF9w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "csstype": "^3.2.2"
+ }
+ },
+ "node_modules/@types/react-dom": {
+ "version": "19.2.3",
+ "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.2.3.tgz",
+ "integrity": "sha512-jp2L/eY6fn+KgVVQAOqYItbF0VY/YApe5Mz2F0aykSO8gx31bYCZyvSeYxCHKvzHG5eZjc+zyaS5BrBWya2+kQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "@types/react": "^19.2.0"
+ }
+ },
+ "node_modules/@typescript-eslint/eslint-plugin": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.57.1.tgz",
+ "integrity": "sha512-Gn3aqnvNl4NGc6x3/Bqk1AOn0thyTU9bqDRhiRnUWezgvr2OnhYCWCgC8zXXRVqBsIL1pSDt7T9nJUe0oM0kDQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@eslint-community/regexpp": "^4.12.2",
+ "@typescript-eslint/scope-manager": "8.57.1",
+ "@typescript-eslint/type-utils": "8.57.1",
+ "@typescript-eslint/utils": "8.57.1",
+ "@typescript-eslint/visitor-keys": "8.57.1",
+ "ignore": "^7.0.5",
+ "natural-compare": "^1.4.0",
+ "ts-api-utils": "^2.4.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "@typescript-eslint/parser": "^8.57.1",
+ "eslint": "^8.57.0 || ^9.0.0 || ^10.0.0",
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/eslint-plugin/node_modules/ignore": {
+ "version": "7.0.5",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-7.0.5.tgz",
+ "integrity": "sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 4"
+ }
+ },
+ "node_modules/@typescript-eslint/parser": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.57.1.tgz",
+ "integrity": "sha512-k4eNDan0EIMTT/dUKc/g+rsJ6wcHYhNPdY19VoX/EOtaAG8DLtKCykhrUnuHPYvinn5jhAPgD2Qw9hXBwrahsw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/scope-manager": "8.57.1",
+ "@typescript-eslint/types": "8.57.1",
+ "@typescript-eslint/typescript-estree": "8.57.1",
+ "@typescript-eslint/visitor-keys": "8.57.1",
+ "debug": "^4.4.3"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^8.57.0 || ^9.0.0 || ^10.0.0",
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/project-service": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/project-service/-/project-service-8.57.1.tgz",
+ "integrity": "sha512-vx1F37BRO1OftsYlmG9xay1TqnjNVlqALymwWVuYTdo18XuKxtBpCj1QlzNIEHlvlB27osvXFWptYiEWsVdYsg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/tsconfig-utils": "^8.57.1",
+ "@typescript-eslint/types": "^8.57.1",
+ "debug": "^4.4.3"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/scope-manager": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.57.1.tgz",
+ "integrity": "sha512-hs/QcpCwlwT2L5S+3fT6gp0PabyGk4Q0Rv2doJXA0435/OpnSR3VRgvrp8Xdoc3UAYSg9cyUjTeFXZEPg/3OKg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/types": "8.57.1",
+ "@typescript-eslint/visitor-keys": "8.57.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/tsconfig-utils": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/tsconfig-utils/-/tsconfig-utils-8.57.1.tgz",
+ "integrity": "sha512-0lgOZB8cl19fHO4eI46YUx2EceQqhgkPSuCGLlGi79L2jwYY1cxeYc1Nae8Aw1xjgW3PKVDLlr3YJ6Bxx8HkWg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/type-utils": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.57.1.tgz",
+ "integrity": "sha512-+Bwwm0ScukFdyoJsh2u6pp4S9ktegF98pYUU0hkphOOqdMB+1sNQhIz8y5E9+4pOioZijrkfNO/HUJVAFFfPKA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/types": "8.57.1",
+ "@typescript-eslint/typescript-estree": "8.57.1",
+ "@typescript-eslint/utils": "8.57.1",
+ "debug": "^4.4.3",
+ "ts-api-utils": "^2.4.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^8.57.0 || ^9.0.0 || ^10.0.0",
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/types": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.57.1.tgz",
+ "integrity": "sha512-S29BOBPJSFUiblEl6RzPPjJt6w25A6XsBqRVDt53tA/tlL8q7ceQNZHTjPeONt/3S7KRI4quk+yP9jK2WjBiPQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.57.1.tgz",
+ "integrity": "sha512-ybe2hS9G6pXpqGtPli9Gx9quNV0TWLOmh58ADlmZe9DguLq0tiAKVjirSbtM1szG6+QH6rVXyU6GTLQbWnMY+g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/project-service": "8.57.1",
+ "@typescript-eslint/tsconfig-utils": "8.57.1",
+ "@typescript-eslint/types": "8.57.1",
+ "@typescript-eslint/visitor-keys": "8.57.1",
+ "debug": "^4.4.3",
+ "minimatch": "^10.2.2",
+ "semver": "^7.7.3",
+ "tinyglobby": "^0.2.15",
+ "ts-api-utils": "^2.4.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree/node_modules/balanced-match": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-4.0.4.tgz",
+ "integrity": "sha512-BLrgEcRTwX2o6gGxGOCNyMvGSp35YofuYzw9h1IMTRmKqttAZZVU67bdb9Pr2vUHA8+j3i2tJfjO6C6+4myGTA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "18 || 20 || >=22"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion": {
+ "version": "5.0.4",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-5.0.4.tgz",
+ "integrity": "sha512-h+DEnpVvxmfVefa4jFbCf5HdH5YMDXRsmKflpf1pILZWRFlTbJpxeU55nJl4Smt5HQaGzg1o6RHFPJaOqnmBDg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "balanced-match": "^4.0.2"
+ },
+ "engines": {
+ "node": "18 || 20 || >=22"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": {
+ "version": "10.2.4",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.2.4.tgz",
+ "integrity": "sha512-oRjTw/97aTBN0RHbYCdtF1MQfvusSIBQM0IZEgzl6426+8jSC0nF1a/GmnVLpfB9yyr6g6FTqWqiZVbxrtaCIg==",
+ "dev": true,
+ "license": "BlueOak-1.0.0",
+ "dependencies": {
+ "brace-expansion": "^5.0.2"
+ },
+ "engines": {
+ "node": "18 || 20 || >=22"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/@typescript-eslint/typescript-estree/node_modules/semver": {
+ "version": "7.7.4",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.4.tgz",
+ "integrity": "sha512-vFKC2IEtQnVhpT78h1Yp8wzwrf8CM+MzKMHGJZfBtzhZNycRFnXsHk6E5TxIkkMsgNS7mdX3AGB7x2QM2di4lA==",
+ "dev": true,
+ "license": "ISC",
+ "bin": {
+ "semver": "bin/semver.js"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/@typescript-eslint/utils": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.57.1.tgz",
+ "integrity": "sha512-XUNSJ/lEVFttPMMoDVA2r2bwrl8/oPx8cURtczkSEswY5T3AeLmCy+EKWQNdL4u0MmAHOjcWrqJp2cdvgjn8dQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.9.1",
+ "@typescript-eslint/scope-manager": "8.57.1",
+ "@typescript-eslint/types": "8.57.1",
+ "@typescript-eslint/typescript-estree": "8.57.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^8.57.0 || ^9.0.0 || ^10.0.0",
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/@typescript-eslint/visitor-keys": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.57.1.tgz",
+ "integrity": "sha512-YWnmJkXbofiz9KbnbbwuA2rpGkFPLbAIetcCNO6mJ8gdhdZ/v7WDXsoGFAJuM6ikUFKTlSQnjWnVO4ux+UzS6A==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/types": "8.57.1",
+ "eslint-visitor-keys": "^5.0.0"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ }
+ },
+ "node_modules/@typescript-eslint/visitor-keys/node_modules/eslint-visitor-keys": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-5.0.1.tgz",
+ "integrity": "sha512-tD40eHxA35h0PEIZNeIjkHoDR4YjjJp34biM0mDvplBe//mB+IHCqHDGV7pxF+7MklTvighcCPPZC7ynWyjdTA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@vitejs/plugin-react": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-6.0.1.tgz",
+ "integrity": "sha512-l9X/E3cDb+xY3SWzlG1MOGt2usfEHGMNIaegaUGFsLkb3RCn/k8/TOXBcab+OndDI4TBtktT8/9BwwW8Vi9KUQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@rolldown/pluginutils": "1.0.0-rc.7"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "peerDependencies": {
+ "@rolldown/plugin-babel": "^0.1.7 || ^0.2.0",
+ "babel-plugin-react-compiler": "^1.0.0",
+ "vite": "^8.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@rolldown/plugin-babel": {
+ "optional": true
+ },
+ "babel-plugin-react-compiler": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/acorn": {
+ "version": "8.16.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.16.0.tgz",
+ "integrity": "sha512-UVJyE9MttOsBQIDKw1skb9nAwQuR5wuGD3+82K6JgJlm/Y+KI92oNsMNGZCYdDsVtRHSak0pcV5Dno5+4jh9sw==",
+ "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.14.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.14.0.tgz",
+ "integrity": "sha512-IWrosm/yrn43eiKqkfkHis7QioDleaXQHdDVPKg0FSwwd/DuvyX79TZnFOnYpB7dcsFAMmtFztZuXPDvSePkFw==",
+ "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": "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/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/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/baseline-browser-mapping": {
+ "version": "2.10.10",
+ "resolved": "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.10.10.tgz",
+ "integrity": "sha512-sUoJ3IMxx4AyRqO4MLeHlnGDkyXRoUG0/AI9fjK+vS72ekpV0yWVY7O0BVjmBcRtkNcsAO2QDZ4tdKKGoI6YaQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "bin": {
+ "baseline-browser-mapping": "dist/cli.cjs"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/brace-expansion": {
+ "version": "1.1.12",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz",
+ "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "node_modules/browserslist": {
+ "version": "4.28.1",
+ "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.28.1.tgz",
+ "integrity": "sha512-ZC5Bd0LgJXgwGqUknZY/vkUQ04r8NXnJZ3yYi4vDmSiZmC/pdSN0NbNRPxZpbtO4uAfDUAFffO8IZoM3Gj8IkA==",
+ "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": {
+ "baseline-browser-mapping": "^2.9.0",
+ "caniuse-lite": "^1.0.30001759",
+ "electron-to-chromium": "^1.5.263",
+ "node-releases": "^2.0.27",
+ "update-browserslist-db": "^1.2.0"
+ },
+ "bin": {
+ "browserslist": "cli.js"
+ },
+ "engines": {
+ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
+ }
+ },
+ "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/camelcase": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz",
+ "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001781",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001781.tgz",
+ "integrity": "sha512-RdwNCyMsNBftLjW6w01z8bKEvT6e/5tpPVEgtn22TiLGlstHOVecsX2KHFkD5e/vRnIE4EGzpuIODb3mtswtkw==",
+ "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": "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/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/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/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/cookie": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-1.1.1.tgz",
+ "integrity": "sha512-ei8Aos7ja0weRpFzJnEA9UHJ/7XQmqglbRwnf2ATjcB9Wq874VKH9kfjjirM6UhU2/E5fFYadylyhFldcqSidQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=18"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/express"
+ }
+ },
+ "node_modules/cosmiconfig": {
+ "version": "8.3.6",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-8.3.6.tgz",
+ "integrity": "sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "import-fresh": "^3.3.0",
+ "js-yaml": "^4.1.0",
+ "parse-json": "^5.2.0",
+ "path-type": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/d-fischer"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.9.5"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/cross-spawn": {
+ "version": "7.0.6",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz",
+ "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==",
+ "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.2.3",
+ "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.2.3.tgz",
+ "integrity": "sha512-z1HGKcYy2xA8AGQfwrn0PAy+PB7X/GSj3UVJW9qKyn43xWa+gl5nXmU4qqLMRzWVLFC8KusUX8T/0kCiOYpAIQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/debug": {
+ "version": "4.4.3",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz",
+ "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==",
+ "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/detect-libc": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.1.2.tgz",
+ "integrity": "sha512-Btj2BOOO83o3WyH59e8MgXsxEQVcarkUOpEYrubB0urwnN10yQ364rsiByU11nZlqWYZm05i/of7io4mzihBtQ==",
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/dot-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz",
+ "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "no-case": "^3.0.4",
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/electron-to-chromium": {
+ "version": "1.5.321",
+ "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.321.tgz",
+ "integrity": "sha512-L2C7Q279W2D/J4PLZLk7sebOILDSWos7bMsMNN06rK482umHUrh/3lM8G7IlHFOYip2oAg5nha1rCMxr/rs6ZQ==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/enhanced-resolve": {
+ "version": "5.20.1",
+ "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.20.1.tgz",
+ "integrity": "sha512-Qohcme7V1inbAfvjItgw0EaxVX5q2rdVEZHRBrEQdRZTssLDGsL8Lwrznl8oQ/6kuTJONLaDcGjkNP247XEhcA==",
+ "license": "MIT",
+ "dependencies": {
+ "graceful-fs": "^4.2.4",
+ "tapable": "^2.3.0"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
+ "node_modules/entities": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
+ "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.12"
+ },
+ "funding": {
+ "url": "https://github.com/fb55/entities?sponsor=1"
+ }
+ },
+ "node_modules/error-ex": {
+ "version": "1.3.4",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.4.tgz",
+ "integrity": "sha512-sqQamAnR14VgCr1A618A3sGrygcpK+HEbenA/HiEAkkUwcZIIB/tgWqHFxWgOyDh4nB4JCRimh79dR5Ywc9MDQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "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": "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": {
+ "version": "9.39.4",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.39.4.tgz",
+ "integrity": "sha512-XoMjdBOwe/esVgEvLmNsD3IRHkm7fbKIUGvrleloJXUZgDHig2IPWNniv+GwjyJXzuNqVjlr5+4yVUZjycJwfQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.8.0",
+ "@eslint-community/regexpp": "^4.12.1",
+ "@eslint/config-array": "^0.21.2",
+ "@eslint/config-helpers": "^0.4.2",
+ "@eslint/core": "^0.17.0",
+ "@eslint/eslintrc": "^3.3.5",
+ "@eslint/js": "9.39.4",
+ "@eslint/plugin-kit": "^0.4.1",
+ "@humanfs/node": "^0.16.6",
+ "@humanwhocodes/module-importer": "^1.0.1",
+ "@humanwhocodes/retry": "^0.4.2",
+ "@types/estree": "^1.0.6",
+ "ajv": "^6.14.0",
+ "chalk": "^4.0.0",
+ "cross-spawn": "^7.0.6",
+ "debug": "^4.3.2",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^8.4.0",
+ "eslint-visitor-keys": "^4.2.1",
+ "espree": "^10.4.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.5",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.3"
+ },
+ "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-hooks": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-7.0.1.tgz",
+ "integrity": "sha512-O0d0m04evaNzEPoSW+59Mezf8Qt0InfgGIBJnpC0h3NH/WjUAR7BIKUfysC6todmtiZ/A0oUVS8Gce0WhBrHsA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/core": "^7.24.4",
+ "@babel/parser": "^7.24.4",
+ "hermes-parser": "^0.25.1",
+ "zod": "^3.25.0 || ^4.0.0",
+ "zod-validation-error": "^3.5.0 || ^4.0.0"
+ },
+ "engines": {
+ "node": ">=18"
+ },
+ "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.5.2",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.5.2.tgz",
+ "integrity": "sha512-hmgTH57GfzoTFjVN0yBwTggnsVUF2tcqi7RJZHqi9lIezSs4eFyAMktA68YD4r5kNw1mxyY4dmkyoFDb3FIqrA==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "eslint": "^9 || ^10"
+ }
+ },
+ "node_modules/eslint-plugin-simple-import-sort": {
+ "version": "12.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-simple-import-sort/-/eslint-plugin-simple-import-sort-12.1.1.tgz",
+ "integrity": "sha512-6nuzu4xwQtE3332Uz0to+TxDQYRLTKRESSc2hefVT48Zc8JthmN23Gx9lnYhu0FtkRSL1oxny3kJ2aveVhmOVA==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "eslint": ">=5.0.0"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "8.4.0",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.4.0.tgz",
+ "integrity": "sha512-sNXOfKCn74rt8RICKMvJS7XKV/Xk9kA7DyJr8mJik3S7Cwgy3qlkkmyS2uQB3jiJg6VNdZd/pDBJu0nvG2NlTg==",
+ "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.2.1",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.1.tgz",
+ "integrity": "sha512-Uhdk5sfqcee/9H/rCOJikYz67o0a2Tw2hGRPOG2Y1R2dg7brRe1uG0yaNQDHu+TO/uQPF/5eCapvYSmHUjt7JQ==",
+ "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/espree": {
+ "version": "10.4.0",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz",
+ "integrity": "sha512-j6PAQ2uUr79PZhBjP5C5fhl8e39FmRnOjsD5lGnWrFU8i2G776tBK7+nP8KuQUTTyAZUwfQqXAgrVH5MbH9CYQ==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "acorn": "^8.15.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^4.2.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.7.0.tgz",
+ "integrity": "sha512-Ap6G0WQwcU/LHsvLwON1fAQX9Zp0A2Y6Y/cJBl9r/JbW90Zyg4/zbG6zzKa2OTALELarYHmKu0GhpM5EO+7T0g==",
+ "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/estree-walker": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
+ "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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/fdir": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.5.0.tgz",
+ "integrity": "sha512-tIbYtZbucOs0BRGqPJkshJUYdL+SDH7dVM8gjy+ERp3WAUjLEFJE+02kanyHtwjWOnwrKYBiwAmM0p4kLJAnXg==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "peerDependencies": {
+ "picomatch": "^3 || ^4"
+ },
+ "peerDependenciesMeta": {
+ "picomatch": {
+ "optional": true
+ }
+ }
+ },
+ "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.4.2",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.4.2.tgz",
+ "integrity": "sha512-PjDse7RzhcPkIJwy5t7KPWQSZ9cAbzQXcafsetQoD7sOJRQlGikNbx7yZp2OotDnJyrDcbyRq3Ttb18iYOqkxA==",
+ "dev": true,
+ "license": "ISC"
+ },
+ "node_modules/fsevents": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
+ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
+ "hasInstallScript": true,
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
+ }
+ },
+ "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/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": "17.4.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-17.4.0.tgz",
+ "integrity": "sha512-hjrNztw/VajQwOLsMNT1cbJiH2muO3OROCHnbehc8eY5JyD2gqz4AcMHPqgaOR59DjgUjYAYLeH699g/eWi2jw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/globrex": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/globrex/-/globrex-0.1.2.tgz",
+ "integrity": "sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg==",
+ "license": "MIT"
+ },
+ "node_modules/graceful-fs": {
+ "version": "4.2.11",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
+ "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
+ "license": "ISC"
+ },
+ "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/hermes-estree": {
+ "version": "0.25.1",
+ "resolved": "https://registry.npmjs.org/hermes-estree/-/hermes-estree-0.25.1.tgz",
+ "integrity": "sha512-0wUoCcLp+5Ev5pDW2OriHC2MJCbwLwuRx+gAqMTOkGKJJiBCLjtrvy4PWUGn6MIVefecRpzoOZ/UV6iGdOr+Cw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/hermes-parser": {
+ "version": "0.25.1",
+ "resolved": "https://registry.npmjs.org/hermes-parser/-/hermes-parser-0.25.1.tgz",
+ "integrity": "sha512-6pEjquH3rqaI6cYAXYPcz9MS4rY6R4ngRgrgfDshRptUZIc3lw0MCIJIGDj9++mfySOuPTHB4nrSW99BCvOPIA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "hermes-estree": "0.25.1"
+ }
+ },
+ "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.1",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
+ "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
+ "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/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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-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/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/javascript-natural-sort": {
+ "version": "0.7.1",
+ "resolved": "https://registry.npmjs.org/javascript-natural-sort/-/javascript-natural-sort-0.7.1.tgz",
+ "integrity": "sha512-nO6jcEfZWQXDhOiBtG2KvKyEptz7RVbpGP4vTD2hLBdmNQSsCiicO2Ioinv6UI4y9ukqnBpy+XZ9H6uLNgJTlw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/jiti": {
+ "version": "2.6.1",
+ "resolved": "https://registry.npmjs.org/jiti/-/jiti-2.6.1.tgz",
+ "integrity": "sha512-ekilCSN1jwRvIbgeg/57YFh8qQDNbwDb9xT/qu2DAHbFFZUicIl4ygVaAvzveMhMVr3LnpSKTNnwt8PoOfmKhQ==",
+ "license": "MIT",
+ "bin": {
+ "jiti": "lib/jiti-cli.mjs"
+ }
+ },
+ "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==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/js-yaml": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.1.tgz",
+ "integrity": "sha512-qQKT4zQxXl8lLwBtHMWwaTcGfFOZviOJet3Oy/xmGk2gZH677CJM9EvtfdSkgWcATZhj/55JZ0rmy3myCT5lsA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "argparse": "^2.0.1"
+ },
+ "bin": {
+ "js-yaml": "bin/js-yaml.js"
+ }
+ },
+ "node_modules/jsesc": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz",
+ "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==",
+ "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-parse-even-better-errors": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz",
+ "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==",
+ "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/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/lightningcss": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss/-/lightningcss-1.32.0.tgz",
+ "integrity": "sha512-NXYBzinNrblfraPGyrbPoD19C1h9lfI/1mzgWYvXUTe414Gz/X1FD2XBZSZM7rRTrMA8JL3OtAaGifrIKhQ5yQ==",
+ "license": "MPL-2.0",
+ "dependencies": {
+ "detect-libc": "^2.0.3"
+ },
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ },
+ "optionalDependencies": {
+ "lightningcss-android-arm64": "1.32.0",
+ "lightningcss-darwin-arm64": "1.32.0",
+ "lightningcss-darwin-x64": "1.32.0",
+ "lightningcss-freebsd-x64": "1.32.0",
+ "lightningcss-linux-arm-gnueabihf": "1.32.0",
+ "lightningcss-linux-arm64-gnu": "1.32.0",
+ "lightningcss-linux-arm64-musl": "1.32.0",
+ "lightningcss-linux-x64-gnu": "1.32.0",
+ "lightningcss-linux-x64-musl": "1.32.0",
+ "lightningcss-win32-arm64-msvc": "1.32.0",
+ "lightningcss-win32-x64-msvc": "1.32.0"
+ }
+ },
+ "node_modules/lightningcss-android-arm64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-android-arm64/-/lightningcss-android-arm64-1.32.0.tgz",
+ "integrity": "sha512-YK7/ClTt4kAK0vo6w3X+Pnm0D2cf2vPHbhOXdoNti1Ga0al1P4TBZhwjATvjNwLEBCnKvjJc2jQgHXH0NEwlAg==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "android"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-darwin-arm64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-darwin-arm64/-/lightningcss-darwin-arm64-1.32.0.tgz",
+ "integrity": "sha512-RzeG9Ju5bag2Bv1/lwlVJvBE3q6TtXskdZLLCyfg5pt+HLz9BqlICO7LZM7VHNTTn/5PRhHFBSjk5lc4cmscPQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-darwin-x64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-darwin-x64/-/lightningcss-darwin-x64-1.32.0.tgz",
+ "integrity": "sha512-U+QsBp2m/s2wqpUYT/6wnlagdZbtZdndSmut/NJqlCcMLTWp5muCrID+K5UJ6jqD2BFshejCYXniPDbNh73V8w==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-freebsd-x64": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-freebsd-x64/-/lightningcss-freebsd-x64-1.32.0.tgz",
+ "integrity": "sha512-JCTigedEksZk3tHTTthnMdVfGf61Fky8Ji2E4YjUTEQX14xiy/lTzXnu1vwiZe3bYe0q+SpsSH/CTeDXK6WHig==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "freebsd"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm-gnueabihf": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm-gnueabihf/-/lightningcss-linux-arm-gnueabihf-1.32.0.tgz",
+ "integrity": "sha512-x6rnnpRa2GL0zQOkt6rts3YDPzduLpWvwAF6EMhXFVZXD4tPrBkEFqzGowzCsIWsPjqSK+tyNEODUBXeeVHSkw==",
+ "cpu": [
+ "arm"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm64-gnu": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-gnu/-/lightningcss-linux-arm64-gnu-1.32.0.tgz",
+ "integrity": "sha512-0nnMyoyOLRJXfbMOilaSRcLH3Jw5z9HDNGfT/gwCPgaDjnx0i8w7vBzFLFR1f6CMLKF8gVbebmkUN3fa/kQJpQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-arm64-musl": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-arm64-musl/-/lightningcss-linux-arm64-musl-1.32.0.tgz",
+ "integrity": "sha512-UpQkoenr4UJEzgVIYpI80lDFvRmPVg6oqboNHfoH4CQIfNA+HOrZ7Mo7KZP02dC6LjghPQJeBsvXhJod/wnIBg==",
+ "cpu": [
+ "arm64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-x64-gnu": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-gnu/-/lightningcss-linux-x64-gnu-1.32.0.tgz",
+ "integrity": "sha512-V7Qr52IhZmdKPVr+Vtw8o+WLsQJYCTd8loIfpDaMRWGUZfBOYEJeyJIkqGIDMZPwPx24pUMfwSxxI8phr/MbOA==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "glibc"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-linux-x64-musl": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-linux-x64-musl/-/lightningcss-linux-x64-musl-1.32.0.tgz",
+ "integrity": "sha512-bYcLp+Vb0awsiXg/80uCRezCYHNg1/l3mt0gzHnWV9XP1W5sKa5/TCdGWaR/zBM2PeF/HbsQv/j2URNOiVuxWg==",
+ "cpu": [
+ "x64"
+ ],
+ "libc": [
+ "musl"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-win32-arm64-msvc": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-win32-arm64-msvc/-/lightningcss-win32-arm64-msvc-1.32.0.tgz",
+ "integrity": "sha512-8SbC8BR40pS6baCM8sbtYDSwEVQd4JlFTOlaD3gWGHfThTcABnNDBda6eTZeqbofalIJhFx0qKzgHJmcPTnGdw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lightningcss-win32-x64-msvc": {
+ "version": "1.32.0",
+ "resolved": "https://registry.npmjs.org/lightningcss-win32-x64-msvc/-/lightningcss-win32-x64-msvc-1.32.0.tgz",
+ "integrity": "sha512-Amq9B/SoZYdDi1kFrojnoqPLxYhQ4Wo5XiL8EVJrVsB8ARoC1PWW6VGtT0WKCemjy8aC+louJnjS7U18x3b06Q==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MPL-2.0",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 12.0.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/parcel"
+ }
+ },
+ "node_modules/lines-and-columns": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz",
+ "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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-es": {
+ "version": "4.17.23",
+ "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.23.tgz",
+ "integrity": "sha512-kVI48u3PZr38HdYz98UmfPnXl2DXrpdctLrFLCd3kOx1xUkOmpFPx7gCWWM5MPkL/fD8zb+Ph0QzjGFs4+hHWg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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/lower-case": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz",
+ "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^2.0.3"
+ }
+ },
+ "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/magic-string": {
+ "version": "0.30.21",
+ "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.21.tgz",
+ "integrity": "sha512-vd2F4YUyEXKGcLHoq+TEyCjxueSeHnFxyyjNp80yg0XV4vUhnDer/lvvlqM/arB5bXQN5K2/3oinyCRyx8T2CQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@jridgewell/sourcemap-codec": "^1.5.5"
+ }
+ },
+ "node_modules/minimatch": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.5.tgz",
+ "integrity": "sha512-VgjWUsnnT6n+NUk6eZq77zeFdpW2LWDzP6zFGrCbHXiYNul5Dzqk2HHQ5uFH2DNW5Xbp8+jVzaeNt94ssEEl4w==",
+ "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==",
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.11",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.11.tgz",
+ "integrity": "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==",
+ "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/no-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz",
+ "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "lower-case": "^2.0.2",
+ "tslib": "^2.0.3"
+ }
+ },
+ "node_modules/node-releases": {
+ "version": "2.0.36",
+ "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.36.tgz",
+ "integrity": "sha512-TdC8FSgHz8Mwtw9g5L4gR/Sh9XhSP/0DEkQxfEFXOpiul5IiHgHan2VhYYb6agDSfp4KuvltmGApc8HMgUrIkA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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/parse-imports-exports": {
+ "version": "0.2.4",
+ "resolved": "https://registry.npmjs.org/parse-imports-exports/-/parse-imports-exports-0.2.4.tgz",
+ "integrity": "sha512-4s6vd6dx1AotCx/RCI2m7t7GCh5bDRUtGNvRfHSP2wbBQdMi67pPe7mtzmgwcaQ8VKK/6IB7Glfyu3qdZJPybQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "parse-statements": "1.0.11"
+ }
+ },
+ "node_modules/parse-json": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz",
+ "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-even-better-errors": "^2.3.0",
+ "lines-and-columns": "^1.1.6"
+ },
+ "engines": {
+ "node": ">=8"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/parse-statements": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/parse-statements/-/parse-statements-1.0.11.tgz",
+ "integrity": "sha512-HlsyYdMBnbPQ9Jr/VgJ1YF4scnldvJpJxCVx6KgqPL4dxppsWrJHCIIxQXMJrqGnsRkNPATbeMJ8Yxu7JMsYcA==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "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-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
+ "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
+ "license": "ISC"
+ },
+ "node_modules/picomatch": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz",
+ "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=12"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/jonschlinkert"
+ }
+ },
+ "node_modules/postcss": {
+ "version": "8.5.8",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.8.tgz",
+ "integrity": "sha512-OW/rX8O/jXnm82Ey1k44pObPtdblfiuWnrd8X7GJ7emImCOstunGbXUpp7HdBrFQX6rJzn3sPT397Wp5aCwCHg==",
+ "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.11",
+ "picocolors": "^1.1.1",
+ "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/prettier": {
+ "version": "3.8.1",
+ "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.8.1.tgz",
+ "integrity": "sha512-UOnG6LftzbdaHZcKoPFtOcCKztrQ57WkHDeRD9t/PTQtmT0NHSeWWepj6pS0z/N7+08BHFDQVUrfmfMRcZwbMg==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "prettier": "bin/prettier.cjs"
+ },
+ "engines": {
+ "node": ">=14"
+ },
+ "funding": {
+ "url": "https://github.com/prettier/prettier?sponsor=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": "19.2.4",
+ "resolved": "https://registry.npmjs.org/react/-/react-19.2.4.tgz",
+ "integrity": "sha512-9nfp2hYpCwOjAN+8TZFGhtWEwgvWHXqESH8qT89AT/lWklpLON22Lc8pEtnpsZz7VmawabSU0gCjnj8aC0euHQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/react-dom": {
+ "version": "19.2.4",
+ "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-19.2.4.tgz",
+ "integrity": "sha512-AXJdLo8kgMbimY95O2aKQqsz2iWi9jMgKJhRBAxECE4IFxfcazB2LmzloIoibJI3C12IlY20+KFaLv+71bUJeQ==",
+ "license": "MIT",
+ "dependencies": {
+ "scheduler": "^0.27.0"
+ },
+ "peerDependencies": {
+ "react": "^19.2.4"
+ }
+ },
+ "node_modules/react-router": {
+ "version": "7.14.0",
+ "resolved": "https://registry.npmjs.org/react-router/-/react-router-7.14.0.tgz",
+ "integrity": "sha512-m/xR9N4LQLmAS0ZhkY2nkPA1N7gQ5TUVa5n8TgANuDTARbn1gt+zLPXEm7W0XDTbrQ2AJSJKhoa6yx1D8BcpxQ==",
+ "license": "MIT",
+ "dependencies": {
+ "cookie": "^1.0.1",
+ "set-cookie-parser": "^2.6.0"
+ },
+ "engines": {
+ "node": ">=20.0.0"
+ },
+ "peerDependencies": {
+ "react": ">=18",
+ "react-dom": ">=18"
+ },
+ "peerDependenciesMeta": {
+ "react-dom": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-router-dom": {
+ "version": "7.14.0",
+ "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-7.14.0.tgz",
+ "integrity": "sha512-2G3ajSVSZMEtmTjIklRWlNvo8wICEpLihfD/0YMDxbWK2UyP5EGfnoIn9AIQGnF3G/FX0MRbHXdFcD+rL1ZreQ==",
+ "license": "MIT",
+ "dependencies": {
+ "react-router": "7.14.0"
+ },
+ "engines": {
+ "node": ">=20.0.0"
+ },
+ "peerDependencies": {
+ "react": ">=18",
+ "react-dom": ">=18"
+ }
+ },
+ "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/rolldown": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/rolldown/-/rolldown-1.0.0-rc.11.tgz",
+ "integrity": "sha512-NRjoKMusSjfRbSYiH3VSumlkgFe7kYAa3pzVOsVYVFY3zb5d7nS+a3KGQ7hJKXuYWbzJKPVQ9Wxq2UvyK+ENpw==",
+ "license": "MIT",
+ "dependencies": {
+ "@oxc-project/types": "=0.122.0",
+ "@rolldown/pluginutils": "1.0.0-rc.11"
+ },
+ "bin": {
+ "rolldown": "bin/cli.mjs"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "optionalDependencies": {
+ "@rolldown/binding-android-arm64": "1.0.0-rc.11",
+ "@rolldown/binding-darwin-arm64": "1.0.0-rc.11",
+ "@rolldown/binding-darwin-x64": "1.0.0-rc.11",
+ "@rolldown/binding-freebsd-x64": "1.0.0-rc.11",
+ "@rolldown/binding-linux-arm-gnueabihf": "1.0.0-rc.11",
+ "@rolldown/binding-linux-arm64-gnu": "1.0.0-rc.11",
+ "@rolldown/binding-linux-arm64-musl": "1.0.0-rc.11",
+ "@rolldown/binding-linux-ppc64-gnu": "1.0.0-rc.11",
+ "@rolldown/binding-linux-s390x-gnu": "1.0.0-rc.11",
+ "@rolldown/binding-linux-x64-gnu": "1.0.0-rc.11",
+ "@rolldown/binding-linux-x64-musl": "1.0.0-rc.11",
+ "@rolldown/binding-openharmony-arm64": "1.0.0-rc.11",
+ "@rolldown/binding-wasm32-wasi": "1.0.0-rc.11",
+ "@rolldown/binding-win32-arm64-msvc": "1.0.0-rc.11",
+ "@rolldown/binding-win32-x64-msvc": "1.0.0-rc.11"
+ }
+ },
+ "node_modules/rolldown/node_modules/@rolldown/pluginutils": {
+ "version": "1.0.0-rc.11",
+ "resolved": "https://registry.npmjs.org/@rolldown/pluginutils/-/pluginutils-1.0.0-rc.11.tgz",
+ "integrity": "sha512-xQO9vbwBecJRv9EUcQ/y0dzSTJgA7Q6UVN7xp6B81+tBGSLVAK03yJ9NkJaUA7JFD91kbjxRSC/mDnmvXzbHoQ==",
+ "license": "MIT"
+ },
+ "node_modules/scheduler": {
+ "version": "0.27.0",
+ "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.27.0.tgz",
+ "integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q==",
+ "license": "MIT"
+ },
+ "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-cookie-parser": {
+ "version": "2.7.2",
+ "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.7.2.tgz",
+ "integrity": "sha512-oeM1lpU/UvhTxw+g3cIfxXHyJRc/uidd3yK1P242gzHds0udQBYzs3y8j4gCCW+ZJ7ad0yctld8RYO+bdurlvw==",
+ "license": "MIT"
+ },
+ "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/snake-case": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz",
+ "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "dot-case": "^3.0.4",
+ "tslib": "^2.0.3"
+ }
+ },
+ "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==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "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": "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/svg-parser": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/svg-parser/-/svg-parser-2.0.4.tgz",
+ "integrity": "sha512-e4hG1hRwoOdRb37cIMSgzNsxyzKfayW6VOflrwvR+/bzrkyxY/31WkbgnQpgtrNp1SdpJvpUAGTa/ZoiPNDuRQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/tailwindcss": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-4.2.2.tgz",
+ "integrity": "sha512-KWBIxs1Xb6NoLdMVqhbhgwZf2PGBpPEiwOqgI4pFIYbNTfBXiKYyWoTsXgBQ9WFg/OlhnvHaY+AEpW7wSmFo2Q==",
+ "license": "MIT"
+ },
+ "node_modules/tapable": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.3.1.tgz",
+ "integrity": "sha512-b+u3CEM6FjDHru+nhUSjDofpWSBp2rINziJWgApm72wwGasQ/wKXftZe4tI2Y5HPv6OpzXSZHOFq87H4vfsgsw==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/webpack"
+ }
+ },
+ "node_modules/tinyglobby": {
+ "version": "0.2.15",
+ "resolved": "https://registry.npmjs.org/tinyglobby/-/tinyglobby-0.2.15.tgz",
+ "integrity": "sha512-j2Zq4NyQYG5XMST4cbs02Ak8iJUdxRM0XI5QyxXuZOzKOINmWurp3smXu3y5wDcJrptwpSjgXHzIQxR0omXljQ==",
+ "license": "MIT",
+ "dependencies": {
+ "fdir": "^6.5.0",
+ "picomatch": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=12.0.0"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/SuperchupuDev"
+ }
+ },
+ "node_modules/ts-api-utils": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-2.5.0.tgz",
+ "integrity": "sha512-OJ/ibxhPlqrMM0UiNHJ/0CKQkoKF243/AEmplt3qpRgkW8VG7IfOS41h7V8TjITqdByHzrjcS/2si+y4lIh8NA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18.12"
+ },
+ "peerDependencies": {
+ "typescript": ">=4.8.4"
+ }
+ },
+ "node_modules/tsconfck": {
+ "version": "3.1.6",
+ "resolved": "https://registry.npmjs.org/tsconfck/-/tsconfck-3.1.6.tgz",
+ "integrity": "sha512-ks6Vjr/jEw0P1gmOVwutM3B7fWxoWBL2KRDb1JfqGVawBmO5UsvmWOQFGHBPl5yxYz4eERr19E6L7NMv+Fej4w==",
+ "license": "MIT",
+ "bin": {
+ "tsconfck": "bin/tsconfck.js"
+ },
+ "engines": {
+ "node": "^18 || >=20"
+ },
+ "peerDependencies": {
+ "typescript": "^5.0.0"
+ },
+ "peerDependenciesMeta": {
+ "typescript": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/tslib": {
+ "version": "2.8.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz",
+ "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==",
+ "devOptional": true,
+ "license": "0BSD"
+ },
+ "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/typescript": {
+ "version": "5.9.3",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.9.3.tgz",
+ "integrity": "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw==",
+ "devOptional": true,
+ "license": "Apache-2.0",
+ "bin": {
+ "tsc": "bin/tsc",
+ "tsserver": "bin/tsserver"
+ },
+ "engines": {
+ "node": ">=14.17"
+ }
+ },
+ "node_modules/typescript-eslint": {
+ "version": "8.57.1",
+ "resolved": "https://registry.npmjs.org/typescript-eslint/-/typescript-eslint-8.57.1.tgz",
+ "integrity": "sha512-fLvZWf+cAGw3tqMCYzGIU6yR8K+Y9NT2z23RwOjlNFF2HwSB3KhdEFI5lSBv8tNmFkkBShSjsCjzx1vahZfISA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@typescript-eslint/eslint-plugin": "8.57.1",
+ "@typescript-eslint/parser": "8.57.1",
+ "@typescript-eslint/typescript-estree": "8.57.1",
+ "@typescript-eslint/utils": "8.57.1"
+ },
+ "engines": {
+ "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
+ },
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/typescript-eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^8.57.0 || ^9.0.0 || ^10.0.0",
+ "typescript": ">=4.8.4 <6.0.0"
+ }
+ },
+ "node_modules/undici-types": {
+ "version": "7.16.0",
+ "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.16.0.tgz",
+ "integrity": "sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==",
+ "devOptional": true,
+ "license": "MIT"
+ },
+ "node_modules/update-browserslist-db": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.2.3.tgz",
+ "integrity": "sha512-Js0m9cx+qOgDxo0eMiFGEueWztz+d4+M3rGlmKPT+T4IS/jP4ylw3Nwpu6cpTTP8R1MAC1kF4VbdLt3ARf209w==",
+ "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.1"
+ },
+ "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": "8.0.2",
+ "resolved": "https://registry.npmjs.org/vite/-/vite-8.0.2.tgz",
+ "integrity": "sha512-1gFhNi+bHhRE/qKZOJXACm6tX4bA3Isy9KuKF15AgSRuRazNBOJfdDemPBU16/mpMxApDPrWvZ08DcLPEoRnuA==",
+ "license": "MIT",
+ "dependencies": {
+ "lightningcss": "^1.32.0",
+ "picomatch": "^4.0.3",
+ "postcss": "^8.5.8",
+ "rolldown": "1.0.0-rc.11",
+ "tinyglobby": "^0.2.15"
+ },
+ "bin": {
+ "vite": "bin/vite.js"
+ },
+ "engines": {
+ "node": "^20.19.0 || >=22.12.0"
+ },
+ "funding": {
+ "url": "https://github.com/vitejs/vite?sponsor=1"
+ },
+ "optionalDependencies": {
+ "fsevents": "~2.3.3"
+ },
+ "peerDependencies": {
+ "@types/node": "^20.19.0 || >=22.12.0",
+ "@vitejs/devtools": "^0.1.0",
+ "esbuild": "^0.27.0",
+ "jiti": ">=1.21.0",
+ "less": "^4.0.0",
+ "sass": "^1.70.0",
+ "sass-embedded": "^1.70.0",
+ "stylus": ">=0.54.8",
+ "sugarss": "^5.0.0",
+ "terser": "^5.16.0",
+ "tsx": "^4.8.1",
+ "yaml": "^2.4.2"
+ },
+ "peerDependenciesMeta": {
+ "@types/node": {
+ "optional": true
+ },
+ "@vitejs/devtools": {
+ "optional": true
+ },
+ "esbuild": {
+ "optional": true
+ },
+ "jiti": {
+ "optional": true
+ },
+ "less": {
+ "optional": true
+ },
+ "sass": {
+ "optional": true
+ },
+ "sass-embedded": {
+ "optional": true
+ },
+ "stylus": {
+ "optional": true
+ },
+ "sugarss": {
+ "optional": true
+ },
+ "terser": {
+ "optional": true
+ },
+ "tsx": {
+ "optional": true
+ },
+ "yaml": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/vite-plugin-svgr": {
+ "version": "4.5.0",
+ "resolved": "https://registry.npmjs.org/vite-plugin-svgr/-/vite-plugin-svgr-4.5.0.tgz",
+ "integrity": "sha512-W+uoSpmVkSmNOGPSsDCWVW/DDAyv+9fap9AZXBvWiQqrboJ08j2vh0tFxTD/LjwqwAd3yYSVJgm54S/1GhbdnA==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "@rollup/pluginutils": "^5.2.0",
+ "@svgr/core": "^8.1.0",
+ "@svgr/plugin-jsx": "^8.1.0"
+ },
+ "peerDependencies": {
+ "vite": ">=2.6.0"
+ }
+ },
+ "node_modules/vite-tsconfig-paths": {
+ "version": "6.1.1",
+ "resolved": "https://registry.npmjs.org/vite-tsconfig-paths/-/vite-tsconfig-paths-6.1.1.tgz",
+ "integrity": "sha512-2cihq7zliibCCZ8P9cKJrQBkfgdvcFkOOc3Y02o3GWUDLgqjWsZudaoiuOwO/gzTzy17cS5F7ZPo4bsnS4DGkg==",
+ "license": "MIT",
+ "dependencies": {
+ "debug": "^4.1.1",
+ "globrex": "^0.1.2",
+ "tsconfck": "^3.0.3"
+ },
+ "peerDependencies": {
+ "vite": "*"
+ }
+ },
+ "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/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"
+ }
+ },
+ "node_modules/zod": {
+ "version": "4.3.6",
+ "resolved": "https://registry.npmjs.org/zod/-/zod-4.3.6.tgz",
+ "integrity": "sha512-rftlrkhHZOcjDwkGlnUtZZkvaPHCsDATp4pGpuOOMDaTdDDXF91wuVDJoWoPsKX/3YPQ5fHuF3STjcYyKr+Qhg==",
+ "dev": true,
+ "license": "MIT",
+ "funding": {
+ "url": "https://github.com/sponsors/colinhacks"
+ }
+ },
+ "node_modules/zod-validation-error": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/zod-validation-error/-/zod-validation-error-4.0.2.tgz",
+ "integrity": "sha512-Q6/nZLe6jxuU80qb/4uJ4t5v2VEZ44lzQjPDhYJNztRQ4wyWc6VF3D3Kb/fAuPetZQnhS3hnajCf9CsWesghLQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18.0.0"
+ },
+ "peerDependencies": {
+ "zod": "^3.25.0 || ^4.0.0"
+ }
+ }
+ }
+}
diff --git a/react-messenger-23rd/package.json b/react-messenger-23rd/package.json
new file mode 100644
index 00000000..4f5cef30
--- /dev/null
+++ b/react-messenger-23rd/package.json
@@ -0,0 +1,39 @@
+{
+ "name": "react-messenger-23rd",
+ "private": true,
+ "version": "0.0.0",
+ "type": "module",
+ "scripts": {
+ "dev": "vite",
+ "build": "tsc -b && vite build",
+ "lint": "eslint .",
+ "preview": "vite preview"
+ },
+ "dependencies": {
+ "@tailwindcss/postcss": "^4.2.2",
+ "@tailwindcss/vite": "^4.2.2",
+ "react": "^19.2.4",
+ "react-dom": "^19.2.4",
+ "react-router-dom": "^7.14.0",
+ "tailwindcss": "^4.2.2",
+ "vite-tsconfig-paths": "^6.1.1"
+ },
+ "devDependencies": {
+ "@eslint/js": "^9.39.4",
+ "@trivago/prettier-plugin-sort-imports": "^6.0.2",
+ "@types/node": "^24.12.0",
+ "@types/react": "^19.2.14",
+ "@types/react-dom": "^19.2.3",
+ "@vitejs/plugin-react": "^6.0.1",
+ "eslint": "^9.39.4",
+ "eslint-plugin-react-hooks": "^7.0.1",
+ "eslint-plugin-react-refresh": "^0.5.2",
+ "eslint-plugin-simple-import-sort": "^12.1.1",
+ "globals": "^17.4.0",
+ "prettier": "^3.8.1",
+ "typescript": "~5.9.3",
+ "typescript-eslint": "^8.57.0",
+ "vite": "^8.0.1",
+ "vite-plugin-svgr": "^4.5.0"
+ }
+}
diff --git a/react-messenger-23rd/public/favicon.svg b/react-messenger-23rd/public/favicon.svg
new file mode 100644
index 00000000..6893eb13
--- /dev/null
+++ b/react-messenger-23rd/public/favicon.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react-messenger-23rd/public/icons.svg b/react-messenger-23rd/public/icons.svg
new file mode 100644
index 00000000..e9522193
--- /dev/null
+++ b/react-messenger-23rd/public/icons.svg
@@ -0,0 +1,24 @@
+
diff --git a/react-messenger-23rd/public/images/Frame 73.svg b/react-messenger-23rd/public/images/Frame 73.svg
new file mode 100644
index 00000000..23463a98
--- /dev/null
+++ b/react-messenger-23rd/public/images/Frame 73.svg
@@ -0,0 +1,5 @@
+
diff --git a/react-messenger-23rd/public/images/user-02.svg b/react-messenger-23rd/public/images/user-02.svg
new file mode 100644
index 00000000..6b363328
--- /dev/null
+++ b/react-messenger-23rd/public/images/user-02.svg
@@ -0,0 +1,6 @@
+
diff --git a/react-messenger-23rd/src/App.tsx b/react-messenger-23rd/src/App.tsx
new file mode 100644
index 00000000..e28069ef
--- /dev/null
+++ b/react-messenger-23rd/src/App.tsx
@@ -0,0 +1,26 @@
+// 앱의 루트 컴포넌트.
+import { BrowserRouter, Route, Routes } from 'react-router-dom';
+
+import ChatListPage from '@/pages/chat-list/ui/ChatListPage';
+import ChatRoomPage from '@/pages/chat-room/ui/ChatRoomPage';
+import FriendsPage from '@/pages/friends/ui/FriendsPage';
+import MobileLayout from '@/shared/ui/MobileLayout';
+
+import MyProfilePage from './pages/my-profile/ui/MyProfilePage';
+
+const App = () => {
+ return (
+
+
+ }>
+ } />
+ } />
+ } />
+ } />
+
+
+
+ );
+};
+
+export default App;
diff --git a/react-messenger-23rd/src/app/styles/index.css b/react-messenger-23rd/src/app/styles/index.css
new file mode 100644
index 00000000..523a222f
--- /dev/null
+++ b/react-messenger-23rd/src/app/styles/index.css
@@ -0,0 +1,138 @@
+/*우선 채팅방 UI 스타일*/
+@import url('https://cdn.jsdelivr.net/gh/sunn-us/SUIT/fonts/static/woff2/SUIT.css');
+@import 'tailwindcss';
+
+@layer components {
+ /*Heading01*/
+ .Heading01R {
+ @apply text-[20px] font-normal tracking-[-1px] leading-[1.2];
+ }
+ .Heading01SB {
+ @apply text-[20px] font-semibold tracking-[-1px] leading-[1.2];
+ }
+
+ /*Heading02*/
+ .Heading02R {
+ @apply text-[17px] font-normal tracking-[-1px] leading-[1.4];
+ }
+ .Heading02SB {
+ @apply text-[17px] font-semibold tracking-[0px] leading-[1.4];
+ }
+
+ /*Body01*/
+ .Body01R {
+ @apply text-[16px] font-normal tracking-[-1px] leading-[1.7];
+ }
+ .Body01M {
+ @apply text-[16px] font-medium tracking-[-0.5px] leading-[1.5];
+ }
+ .Body01SB {
+ @apply text-[16px] font-semibold tracking-[-0.5px] leading-[1.5];
+ }
+
+ /*Body02*/
+ .Body02R {
+ @apply text-[15px] font-normal tracking-[-0.5px] leading-[1.5];
+ }
+ .Body02M {
+ @apply text-[15px] font-medium tracking-[-0.5px] leading-[1.5];
+ }
+
+ /*Body03*/
+ .Body03R {
+ @apply text-[14px] font-normal tracking-[-0.5px] leading-[1.5];
+ }
+ .Body03M {
+ @apply text-[14px] font-medium tracking-[-0.5px] leading-[1.5];
+ }
+ .Body03SB {
+ @apply text-[14px] font-semibold tracking-[-0.5px] leading-[1.5];
+ }
+
+ /*Caption01*/
+ .Caption01R {
+ @apply text-[13px] font-normal tracking-[-0.5px] leading-[1.4];
+ }
+ .Caption01M {
+ @apply text-[13px] font-medium tracking-[-0.5px] leading-[1.4];
+ }
+
+ /*Caption02*/
+ .Caption02R {
+ @apply text-[12px] font-normal tracking-[-0.5px] leading-[1.3];
+ }
+ .Caption02M {
+ @apply text-[12px] font-medium tracking-[-0.5px] leading-[1.3];
+ }
+
+ /*Caption03*/
+ .Caption03R {
+ @apply text-[10px] font-normal tracking-[-0.5px] leading-[1.3];
+ }
+ .Caption03SB {
+ @apply text-[10px] font-semibold tracking-[-0.5px] leading-[1.3];
+ }
+ .Caption03B {
+ @apply text-[10px] font-bold tracking-[-0.5px] leading-[1.3];
+ }
+}
+
+@theme {
+ /* color */
+ --color-bg: #f1f3f5;
+
+ --color-border: #edeff2;
+
+ --color-section-bg: #f1f3f5;
+ --color-gray-10: #f3f5f7;
+ --color-gray-20: #edeff2;
+ --color-gray-30: #e4e7eb;
+ --color-gray-40: #ccd2d9;
+ --color-gray-50: #b4b9c2;
+ --color-gray-60: #959ca6;
+
+ --color-gray-70: #636973;
+ --color-gray-80: #464950;
+ --color-gray-90: #282c33;
+ --color-main: #16d96a;
+ --color-main-light: #c1f7d9;
+ --color-main-light2: #e3fcee;
+ --color-textbox: #3dcc61;
+ --color-pressed: #1f9853;
+
+ --color-white: #ffffff;
+ --color-black: #191919;
+
+ /* font */
+ --font-suit: 'SUIT', sans-serif;
+
+ /* font size */
+ --text-ts: 12px;
+ --text-sm: 13px;
+ --text-base: 15px;
+ --text-partner: 17px;
+
+ /* line-height */
+ --leading-xs: 15.6px;
+ --leading-sm: 18.2px;
+ --leading-base: 22.5px;
+}
+
+body {
+ margin: 0;
+ font-family: 'SUIT', sans-serif;
+}
+
+/* 스크롤바 숨기기 유틸리티 */
+@utility scrollbar-hide {
+ /* Chrome, Safari, Opera */
+ &::-webkit-scrollbar {
+ display: none;
+ }
+
+ /* Firefox */
+ scrollbar-width: none;
+
+ /* IE, Edge */
+ -ms-overflow-style: none;
+}
diff --git a/react-messenger-23rd/src/entities/chat-room/lib/formatChatRoomListTime.ts b/react-messenger-23rd/src/entities/chat-room/lib/formatChatRoomListTime.ts
new file mode 100644
index 00000000..29668b15
--- /dev/null
+++ b/react-messenger-23rd/src/entities/chat-room/lib/formatChatRoomListTime.ts
@@ -0,0 +1,53 @@
+import type { Message } from '@/entities/message/model/types';
+
+import type { ChatRoom } from '../model/types';
+
+const parseKoreanDate = (dateText: string): Date | null => {
+ const match = dateText.match(/(\d{4})년\s*(\d{1,2})월\s*(\d{1,2})일/);
+ if (!match) return null;
+ const [, year, month, day] = match;
+ return new Date(Number(year), Number(month) - 1, Number(day));
+};
+
+const formatKoreanTime = (timeText: string): string => {
+ const match = timeText.match(/(\d{1,2}):(\d{2})(am|pm)/i);
+ if (!match) return timeText;
+
+ const [, hourText, minute, meridiem] = match;
+ const hour = Number(hourText);
+ const period = meridiem.toLowerCase() === 'am' ? '오전' : '오후';
+
+ return `${period} ${hour}시 ${minute}분`;
+};
+
+const isSameDay = (a: Date, b: Date): boolean => {
+ return a.getFullYear() === b.getFullYear() && a.getMonth() === b.getMonth() && a.getDate() === b.getDate();
+};
+
+export const formatChatRoomListTime = (lastMessage?: Message, room?: ChatRoom): string => {
+ if (!lastMessage) {
+ return room?.time ?? '';
+ }
+
+ const parsedDate = parseKoreanDate(lastMessage.date);
+
+ if (!parsedDate) {
+ return room?.time ?? '';
+ }
+
+ const now = new Date();
+ const today = new Date(now.getFullYear(), now.getMonth(), now.getDate());
+
+ const yesterday = new Date(today);
+ yesterday.setDate(today.getDate() - 1);
+
+ if (isSameDay(parsedDate, today)) {
+ return formatKoreanTime(lastMessage.time);
+ }
+
+ if (isSameDay(parsedDate, yesterday)) {
+ return '어제';
+ }
+
+ return `${parsedDate.getMonth() + 1}월 ${parsedDate.getDate()}일`;
+};
diff --git a/react-messenger-23rd/src/entities/chat-room/model/chatRooms.json b/react-messenger-23rd/src/entities/chat-room/model/chatRooms.json
new file mode 100644
index 00000000..bf1bdb98
--- /dev/null
+++ b/react-messenger-23rd/src/entities/chat-room/model/chatRooms.json
@@ -0,0 +1,65 @@
+[
+ {
+ "id": "1",
+ "name": "세오스 디자인",
+ "memberCount": 17,
+ "lastMessage": "내일까지 과제 마감입니다!",
+ "time": "오후 3시 29분",
+ "unreadCount": 0,
+ "isPinned": true
+ },
+ {
+ "id": "2",
+ "name": "시디 E반",
+ "memberCount": 8,
+ "lastMessage": "우리 언제봄?",
+ "time": "어제",
+ "unreadCount": 554,
+ "isPinned": true
+ },
+ {
+ "id": "3",
+ "name": "2026 홍익시디 3학년..",
+ "memberCount": 324,
+ "lastMessage": "[과잠 공구 공지]...",
+ "time": "3월 10일",
+ "unreadCount": 10,
+ "isPinned": true
+ },
+ {
+ "id": "4",
+ "name": "엄마",
+ "memberCount": null,
+ "lastMessage": "엄망 나 오늘 집에 늦게가",
+ "time": "오후 5시 00분",
+ "unreadCount": 0,
+ "isPinned": false
+ },
+ {
+ "id": "5",
+ "name": "삼백억",
+ "memberCount": 3,
+ "lastMessage": "아니 그래서",
+ "time": "어제",
+ "unreadCount": 88,
+ "isPinned": false
+ },
+ {
+ "id": "6",
+ "name": "세상에서 제일 깜직한 우강고..",
+ "memberCount": 5,
+ "lastMessage": "아아아앙아아아아아아아아아",
+ "time": "3월 7일",
+ "unreadCount": 0,
+ "isPinned": false
+ },
+ {
+ "id": "7",
+ "name": "백하린",
+ "memberCount": null,
+ "lastMessage": "뭐해?",
+ "time": "3월 6일",
+ "unreadCount": 1,
+ "isPinned": false
+ }
+]
diff --git a/react-messenger-23rd/src/entities/chat-room/model/types.ts b/react-messenger-23rd/src/entities/chat-room/model/types.ts
new file mode 100644
index 00000000..4ec484f8
--- /dev/null
+++ b/react-messenger-23rd/src/entities/chat-room/model/types.ts
@@ -0,0 +1,11 @@
+export interface ChatRoom {
+ id: string;
+ name: string;
+ memberCount: number | null;
+ lastMessage: string;
+ time: string;
+ unreadCount: number;
+ isPinned: boolean;
+ pinOrder?: number | null;
+ recentUnpinned?: number | null;
+}
\ No newline at end of file
diff --git a/react-messenger-23rd/src/entities/message/model/messages.json b/react-messenger-23rd/src/entities/message/model/messages.json
new file mode 100644
index 00000000..96fd7022
--- /dev/null
+++ b/react-messenger-23rd/src/entities/message/model/messages.json
@@ -0,0 +1,138 @@
+[
+ {
+ "id": "m7_0",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "구럼 내일 보자!!!",
+ "time": "3:34pm",
+ "date": "2026년 3월 15일"
+ },
+ {
+ "id": "m7_1",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "마곡 웰튼점으로 와!",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_2",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "여기서 카공하는 중인데 여기 조금 더워서 다른데 가야될 수도",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_3",
+ "chatRoomId": "7",
+ "userId": "other",
+ "messages": "나 안에 얇게 입었는데 그래도 좀 더울 것 같은가???",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_4",
+ "chatRoomId": "7",
+ "userId": "other",
+ "messages": "고민댄다",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_5",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "흐음.......",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_6",
+ "chatRoomId": "7",
+ "userId": "other",
+ "messages": "일단 그냥 갈게!!!!",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_7",
+ "chatRoomId": "7",
+ "userId": "other",
+ "messages": "이따바",
+ "time": "3:34pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_8",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "구래",
+ "time": "3:35pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_9",
+ "chatRoomId": "7",
+ "userId": "me",
+ "messages": "이따보자아!!",
+ "time": "3:35pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m7_10",
+ "chatRoomId": "7",
+ "userId": "other",
+ "messages": "뭐해?",
+ "time": "11:59pm",
+ "date": "2026년 3월 6일"
+ },
+ {
+ "id": "m1_0",
+ "chatRoomId": "1",
+ "userId": "other",
+ "messages": "내일까지 과제 마감입니다!",
+ "time": "3:29pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m2_0",
+ "chatRoomId": "2",
+ "userId": "other",
+ "messages": "우리 언제봄?",
+ "time": "10:40pm",
+ "date": "2026년 3월 4일"
+ },
+ {
+ "id": "m3_0",
+ "chatRoomId": "3",
+ "userId": "other",
+ "messages": "[과잠 공구 공지]...",
+ "time": "5:36pm",
+ "date": "2026년 3월 10일"
+ },
+ {
+ "id": "m4_0",
+ "chatRoomId": "4",
+ "userId": "me",
+ "messages": "엄망 나 오늘 집에 늦게가",
+ "time": "5:00pm",
+ "date": "2026년 3월 16일"
+ },
+ {
+ "id": "m5_0",
+ "chatRoomId": "5",
+ "userId": "other",
+ "messages": "아니 그래서",
+ "time": "10:44pm",
+ "date": "2026년 3월 15일"
+ },
+ {
+ "id": "m6_0",
+ "chatRoomId": "6",
+ "userId": "me",
+ "messages": "아아아앙아아아아아아아아아",
+ "time": "1:33am",
+ "date": "2026년 3월 7일"
+ }
+]
diff --git a/react-messenger-23rd/src/entities/message/model/types.ts b/react-messenger-23rd/src/entities/message/model/types.ts
new file mode 100644
index 00000000..72a11126
--- /dev/null
+++ b/react-messenger-23rd/src/entities/message/model/types.ts
@@ -0,0 +1,9 @@
+// 메시지 데이터의 타입을 정의.
+export interface Message {
+ id: string;
+ chatRoomId: string;
+ userId: string;
+ messages: string;
+ time: string;
+ date: string;
+}
diff --git a/react-messenger-23rd/src/entities/message/ui/MessageBubble.tsx b/react-messenger-23rd/src/entities/message/ui/MessageBubble.tsx
new file mode 100644
index 00000000..18e4c3f4
--- /dev/null
+++ b/react-messenger-23rd/src/entities/message/ui/MessageBubble.tsx
@@ -0,0 +1,57 @@
+// 메시지 한 개.
+import type { User } from '@/entities/user/model/types';
+
+import type { Message } from '../model/types';
+
+interface MessageBubbleProps {
+ message: Message;
+ user: User;
+ showTime: boolean;
+ showProfile: boolean;
+ isFlipped: boolean;
+ marginClass: string;
+}
+
+const MessageBubble = ({ message, user, showTime, showProfile, isFlipped, marginClass }: MessageBubbleProps) => {
+ const isMe = isFlipped ? message.userId !== 'me' : message.userId === 'me';
+
+ return (
+
+ {!isMe && (
+
+
+
+
+ {showProfile &&
{user.name}
}
+
+
+
+
+ {showTime &&
{message.time}}
+
+
+
+ )}
+
+ {isMe && (
+
+ {showTime &&
{message.time}}
+
+
+
+ )}
+
+ );
+};
+
+export default MessageBubble;
diff --git a/react-messenger-23rd/src/entities/user/model/types.ts b/react-messenger-23rd/src/entities/user/model/types.ts
new file mode 100644
index 00000000..88cafa60
--- /dev/null
+++ b/react-messenger-23rd/src/entities/user/model/types.ts
@@ -0,0 +1,11 @@
+export interface User {
+ id: string;
+ name: string;
+ profileImage: string;
+}
+
+export interface Friend {
+ id: number;
+ name: string;
+ status: 'read' | 'yet' | 'none';
+}
diff --git a/react-messenger-23rd/src/entities/user/model/users.json b/react-messenger-23rd/src/entities/user/model/users.json
new file mode 100644
index 00000000..4d627315
--- /dev/null
+++ b/react-messenger-23rd/src/entities/user/model/users.json
@@ -0,0 +1,12 @@
+[
+ {
+ "id": "me",
+ "name": "고다현",
+ "profileImage": "/images/user-02.svg"
+ },
+ {
+ "id": "other",
+ "name": "백하린",
+ "profileImage": "/images/Frame 73.svg"
+ }
+]
diff --git a/react-messenger-23rd/src/main.tsx b/react-messenger-23rd/src/main.tsx
new file mode 100644
index 00000000..f698eb8e
--- /dev/null
+++ b/react-messenger-23rd/src/main.tsx
@@ -0,0 +1,13 @@
+// React 엔트리 파일
+import '@/app/styles/index.css';
+
+import { StrictMode } from 'react';
+import { createRoot } from 'react-dom/client';
+
+import App from '@/App';
+
+createRoot(document.getElementById('root')!).render(
+
+
+ ,
+);
diff --git a/react-messenger-23rd/src/pages/chat-list/ui/ChatListPage.tsx b/react-messenger-23rd/src/pages/chat-list/ui/ChatListPage.tsx
new file mode 100644
index 00000000..cbf206e1
--- /dev/null
+++ b/react-messenger-23rd/src/pages/chat-list/ui/ChatListPage.tsx
@@ -0,0 +1,20 @@
+import BottomTabBar from '@/widgets/chat-list/ui/BottomTabBar';
+import ChatListHeader from '@/widgets/chat-list/ui/ChatListHeader';
+import ChatListSearch from '@/widgets/chat-list/ui/ChatListSearch';
+import ChatRoomList from '@/widgets/chat-list/ui/ChatRoomList';
+
+const ChatListPage = () => {
+ return (
+
+
+
+
+
+
+
+
+
+ );
+};
+
+export default ChatListPage;
diff --git a/react-messenger-23rd/src/pages/chat-room/ui/ChatRoomPage.tsx b/react-messenger-23rd/src/pages/chat-room/ui/ChatRoomPage.tsx
new file mode 100644
index 00000000..9c77c374
--- /dev/null
+++ b/react-messenger-23rd/src/pages/chat-room/ui/ChatRoomPage.tsx
@@ -0,0 +1,129 @@
+// 전체 페이지
+// 헤더, 메지지 영역, 입력창을 조립하는 파일.
+import { useEffect, useMemo, useRef, useState } from 'react';
+import { useParams } from 'react-router-dom';
+
+import rawChatRooms from '@/entities/chat-room/model/chatRooms.json';
+import type { ChatRoom } from '@/entities/chat-room/model/types';
+import rawMessages from '@/entities/message/model/messages.json';
+import type { Message } from '@/entities/message/model/types';
+import ChatRoomHeader from '@/widgets/chat-room/ui/ChatRoomHeader';
+import MessageInputBar from '@/widgets/chat-room/ui/MessageInputBar';
+import MessageList from '@/widgets/chat-room/ui/MessageList';
+
+const MESSAGE_STORAGE_KEY = 'chat-messages';
+const CHAT_ROOMS_STORAGE_KEY = 'chat-rooms';
+
+const initialMessages = rawMessages as Message[];
+const initialChatRooms = rawChatRooms as ChatRoom[];
+
+const getCurrentTime = () => {
+ const now = new Date();
+ const hours = now.getHours();
+ const minutes = String(now.getMinutes()).padStart(2, '0');
+ const period = hours < 12 ? 'am' : 'pm';
+ const displayHour = hours % 12 === 0 ? 12 : hours % 12;
+
+ return `${displayHour}:${minutes}${period}`;
+};
+
+const getCurrentDate = () => {
+ const now = new Date();
+ const year = now.getFullYear();
+ const month = now.getMonth() + 1;
+ const date = now.getDate();
+
+ return `${year}년 ${month}월 ${date}일`;
+};
+
+const getInitialMessages = (): Message[] => {
+ const storedMessages = localStorage.getItem(MESSAGE_STORAGE_KEY);
+
+ if (storedMessages) {
+ return JSON.parse(storedMessages) as Message[];
+ }
+
+ return initialMessages;
+};
+
+const getStoredChatRooms = (): ChatRoom[] => {
+ const storedRooms = localStorage.getItem(CHAT_ROOMS_STORAGE_KEY);
+
+ if (storedRooms) {
+ return JSON.parse(storedRooms) as ChatRoom[];
+ }
+
+ return initialChatRooms;
+};
+
+const ChatRoomPage = () => {
+ const { id } = useParams();
+ const currentRoomId = id ?? '';
+
+ const [allMessages, setAllMessages] = useState(getInitialMessages);
+ const [inputValue, setInputValue] = useState('');
+ const [isFlipped, setIsFlipped] = useState(false);
+ const bottomRef = useRef(null);
+
+ const currentRoom = getStoredChatRooms().find((room) => room.id === currentRoomId);
+
+ const roomMessages = useMemo(
+ () => allMessages.filter((message) => message.chatRoomId === currentRoomId),
+ [allMessages, currentRoomId],
+ );
+
+ // messsages가 바뀔 때 LocalStorage에 저장
+ useEffect(() => {
+ localStorage.setItem(MESSAGE_STORAGE_KEY, JSON.stringify(allMessages));
+ }, [allMessages]);
+
+ // 채팅방에 들어가면 해당 방의 unreadCount를 0으로 저장
+ useEffect(() => {
+ const storedRooms = getStoredChatRooms();
+
+ const updatedRooms = storedRooms.map((room) => (room.id === currentRoomId ? { ...room, unreadCount: 0 } : room));
+
+ localStorage.setItem(CHAT_ROOMS_STORAGE_KEY, JSON.stringify(updatedRooms));
+ }, [currentRoomId]);
+
+ // messages가 바뀔 때 맨 아래로 스크롤
+ useEffect(() => {
+ bottomRef.current?.scrollIntoView({ behavior: 'smooth' });
+ }, [roomMessages]);
+
+ const handleSendMessage = () => {
+ const trimmedValue = inputValue.trim();
+ if (!trimmedValue) return;
+
+ const newMessage: Message = {
+ id: String(Date.now()),
+ chatRoomId: currentRoomId,
+ userId: isFlipped ? 'other' : 'me',
+ messages: trimmedValue,
+ time: getCurrentTime(),
+ date: getCurrentDate(),
+ };
+
+ setAllMessages((prev) => [...prev, newMessage]);
+ setInputValue('');
+ };
+
+ return (
+
+ setIsFlipped((prev) => !prev)}
+ isFlipped={isFlipped}
+ title={currentRoom?.name ?? '채팅방'}
+ />
+
+
+
+ );
+};
+
+export default ChatRoomPage;
diff --git a/react-messenger-23rd/src/pages/friends/ui/FriendsPage.tsx b/react-messenger-23rd/src/pages/friends/ui/FriendsPage.tsx
new file mode 100644
index 00000000..8bddc39b
--- /dev/null
+++ b/react-messenger-23rd/src/pages/friends/ui/FriendsPage.tsx
@@ -0,0 +1,29 @@
+import { useState } from 'react';
+
+import BottomTabBar from '@/widgets/chat-list/ui/BottomTabBar';
+import FriendsHeader from '@/widgets/friends/ui/FriendsHeader';
+import FriendsList from '@/widgets/friends/ui/FriendsList';
+import MyProfileSection from '@/widgets/friends/ui/MyProfileSection';
+import TagSection from '@/widgets/friends/ui/TagSection';
+
+const FriendsPage = () => {
+ const [isTagOpen, setIsTagOpen] = useState(true);
+ const [isFriendsOpen, setIsFriendsOpen] = useState(true);
+
+ return (
+
+
+
+
+
+ setIsTagOpen((prev) => !prev)} />
+
+ setIsFriendsOpen((prev) => !prev)} />
+
+
+
+
+ );
+};
+
+export default FriendsPage;
diff --git a/react-messenger-23rd/src/pages/my-profile/ui/MyProfilePage.tsx b/react-messenger-23rd/src/pages/my-profile/ui/MyProfilePage.tsx
new file mode 100644
index 00000000..1ec74862
--- /dev/null
+++ b/react-messenger-23rd/src/pages/my-profile/ui/MyProfilePage.tsx
@@ -0,0 +1,42 @@
+import { useState } from 'react';
+
+import BottomTabBar from '@/widgets/chat-list/ui/BottomTabBar';
+import MyProfileHeader from '@/widgets/my-profile/ui/MyProfileHeader';
+import ProfileIdSection from '@/widgets/my-profile/ui/ProfileIdSection';
+import ProfileInfoSection from '@/widgets/my-profile/ui/ProfileInfoSection';
+import ProfileMenuList from '@/widgets/my-profile/ui/ProfileMenuList';
+
+const MyProfilePage = () => {
+ const [isToastOpen, setIsToastOpen] = useState(false);
+
+ const handleShowToast = () => {
+ setIsToastOpen(true);
+
+ setTimeout(() => {
+ setIsToastOpen(false);
+ }, 2000);
+ };
+
+ return (
+
+
+
+
+ {isToastOpen && (
+
+ )}
+
+
+
+ );
+};
+
+export default MyProfilePage;
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon-active.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon-active.svg
new file mode 100644
index 00000000..01eba6e5
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon-active.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon.svg
new file mode 100644
index 00000000..d0978642
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/Icon.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/Toggle.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/Toggle.svg
new file mode 100644
index 00000000..5bea2c68
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/Toggle.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/compass-03.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/compass-03.svg
new file mode 100644
index 00000000..2f9e1b64
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/compass-03.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/new chatting(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/new chatting(24_24).svg
new file mode 100644
index 00000000..0b91d29c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/new chatting(24_24).svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/pin-01.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/pin-01.svg
new file mode 100644
index 00000000..941b1f4c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/pin-01.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/search(20_20).svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/search(20_20).svg
new file mode 100644
index 00000000..5ced418d
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/search(20_20).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/settings-02.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/settings-02.svg
new file mode 100644
index 00000000..f310991f
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/settings-02.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/user-02.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-02.svg
new file mode 100644
index 00000000..63410066
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-02.svg
@@ -0,0 +1,6 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle-active.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle-active.svg
new file mode 100644
index 00000000..b6b9c529
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle-active.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle.svg
new file mode 100644
index 00000000..60fc1373
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/user-circle.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01-active.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01-active.svg
new file mode 100644
index 00000000..754e41d1
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01-active.svg
@@ -0,0 +1,24 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01.svg b/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01.svg
new file mode 100644
index 00000000..c4b240f1
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-list/users-01.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/Frame 73.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/Frame 73.svg
new file mode 100644
index 00000000..23463a98
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/Frame 73.svg
@@ -0,0 +1,5 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/My_Text Box/Back (32_32).svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/My_Text Box/Back (32_32).svg
new file mode 100644
index 00000000..1f8fd6c7
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/My_Text Box/Back (32_32).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Battery.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Battery.svg
new file mode 100644
index 00000000..c3a215db
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Battery.svg
@@ -0,0 +1,12 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Connection.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Connection.svg
new file mode 100644
index 00000000..072be07c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Connection.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Signal.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Signal.svg
new file mode 100644
index 00000000..fa496837
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Elements/Signal.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Mic & Cam.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/Status Bar/Mic & Cam.svg
new file mode 100644
index 00000000..e69de29b
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/face-smile.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/face-smile.svg
new file mode 100644
index 00000000..e1909b0e
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/face-smile.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/hamburger(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/hamburger(24_24).svg
new file mode 100644
index 00000000..0193f58c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/hamburger(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/microphone-01.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/microphone-01.svg
new file mode 100644
index 00000000..62c34753
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/microphone-01.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/plus.svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/plus.svg
new file mode 100644
index 00000000..67d55e82
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/plus.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chat-room/search(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/chat-room/search(24_24).svg
new file mode 100644
index 00000000..79ed0ded
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chat-room/search(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Frame 73.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Frame 73.svg
new file mode 100644
index 00000000..23463a98
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Frame 73.svg
@@ -0,0 +1,5 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/My_Text Box/Back (32_32).svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/My_Text Box/Back (32_32).svg
new file mode 100644
index 00000000..1f8fd6c7
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/My_Text Box/Back (32_32).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Battery.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Battery.svg
new file mode 100644
index 00000000..c3a215db
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Battery.svg
@@ -0,0 +1,12 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Connection.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Connection.svg
new file mode 100644
index 00000000..072be07c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Connection.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Signal.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Signal.svg
new file mode 100644
index 00000000..fa496837
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Elements/Signal.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Mic & Cam.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/Status Bar/Mic & Cam.svg
new file mode 100644
index 00000000..e69de29b
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/arrow-narrow-up.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/arrow-narrow-up.svg
new file mode 100644
index 00000000..14c2db9a
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/arrow-narrow-up.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/face-smile.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/face-smile.svg
new file mode 100644
index 00000000..e1909b0e
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/face-smile.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/hamburger(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/hamburger(24_24).svg
new file mode 100644
index 00000000..0193f58c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/hamburger(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/microphone-01.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/microphone-01.svg
new file mode 100644
index 00000000..62c34753
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/microphone-01.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/plus.svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/plus.svg
new file mode 100644
index 00000000..67d55e82
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/plus.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/chattingRoom/search(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/search(24_24).svg
new file mode 100644
index 00000000..79ed0ded
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/chattingRoom/search(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/downside (24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/downside (24_24).svg
new file mode 100644
index 00000000..cb7ed967
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/downside (24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/folder-download.svg b/react-messenger-23rd/src/shared/assets/icons/friends/folder-download.svg
new file mode 100644
index 00000000..b2455d7d
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/folder-download.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/message-question-circle(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/message-question-circle(24_24).svg
new file mode 100644
index 00000000..4b1339a7
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/message-question-circle(24_24).svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-read.svg b/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-read.svg
new file mode 100644
index 00000000..b6928413
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-read.svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-yet.svg b/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-yet.svg
new file mode 100644
index 00000000..bfddd351
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/notification-message-yet.svg
@@ -0,0 +1,5 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/plus.svg b/react-messenger-23rd/src/shared/assets/icons/friends/plus.svg
new file mode 100644
index 00000000..62b23d36
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/plus.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/rightside(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/rightside(24_24).svg
new file mode 100644
index 00000000..e7583d99
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/rightside(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/search(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/search(24_24).svg
new file mode 100644
index 00000000..79ed0ded
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/search(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/upside(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/upside(24_24).svg
new file mode 100644
index 00000000..30482050
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/upside(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/user-02.svg b/react-messenger-23rd/src/shared/assets/icons/friends/user-02.svg
new file mode 100644
index 00000000..13ab417b
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/user-02.svg
@@ -0,0 +1,6 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/friends/user-plus(24_24).svg b/react-messenger-23rd/src/shared/assets/icons/friends/user-plus(24_24).svg
new file mode 100644
index 00000000..29af04ef
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/friends/user-plus(24_24).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/chevron-left.svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/chevron-left.svg
new file mode 100644
index 00000000..3db423a6
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/chevron-left.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/copy(20_20).svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/copy(20_20).svg
new file mode 100644
index 00000000..4e17a044
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/copy(20_20).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/currency-dollar-circle.svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/currency-dollar-circle.svg
new file mode 100644
index 00000000..7b8be226
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/currency-dollar-circle.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/face-smile.svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/face-smile.svg
new file mode 100644
index 00000000..a9ce28a5
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/face-smile.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/folder-download (1).svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/folder-download (1).svg
new file mode 100644
index 00000000..1bcbef85
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/folder-download (1).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/image-03.svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/image-03.svg
new file mode 100644
index 00000000..de0d910a
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/image-03.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/qr-code(28_28).svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/qr-code(28_28).svg
new file mode 100644
index 00000000..9e3f7a12
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/qr-code(28_28).svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/settings-02 (1).svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/settings-02 (1).svg
new file mode 100644
index 00000000..0efab2d3
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/settings-02 (1).svg
@@ -0,0 +1,4 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/star-01.svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/star-01.svg
new file mode 100644
index 00000000..59956c41
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/star-01.svg
@@ -0,0 +1,3 @@
+
diff --git a/react-messenger-23rd/src/shared/assets/icons/my-profile/user-02 (2).svg b/react-messenger-23rd/src/shared/assets/icons/my-profile/user-02 (2).svg
new file mode 100644
index 00000000..6b363328
--- /dev/null
+++ b/react-messenger-23rd/src/shared/assets/icons/my-profile/user-02 (2).svg
@@ -0,0 +1,6 @@
+
diff --git a/react-messenger-23rd/src/shared/ui/MobileLayout.tsx b/react-messenger-23rd/src/shared/ui/MobileLayout.tsx
new file mode 100644
index 00000000..9b0b729c
--- /dev/null
+++ b/react-messenger-23rd/src/shared/ui/MobileLayout.tsx
@@ -0,0 +1,23 @@
+import { Outlet, useLocation } from 'react-router-dom';
+
+import StatusBar from './StatusBar';
+
+const MobileLayout = () => {
+ const location = useLocation();
+
+ const isChatRoomPage = location.pathname.startsWith('/chat/');
+ const statusBarBgClass = isChatRoomPage ? 'bg-bg' : 'bg-white';
+
+ return (
+
+ );
+};
+
+export default MobileLayout;
diff --git a/react-messenger-23rd/src/shared/ui/StatusBar.tsx b/react-messenger-23rd/src/shared/ui/StatusBar.tsx
new file mode 100644
index 00000000..e6b8d503
--- /dev/null
+++ b/react-messenger-23rd/src/shared/ui/StatusBar.tsx
@@ -0,0 +1,27 @@
+import batteryIcon from '@/shared/assets/icons/chattingRoom/Status Bar/Elements/Battery.svg';
+import connectionIcon from '@/shared/assets/icons/chattingRoom/Status Bar/Elements/Connection.svg';
+import signalIcon from '@/shared/assets/icons/chattingRoom/Status Bar/Elements/Signal.svg';
+
+interface StatusBarProps {
+ className?: string;
+}
+
+const StatusBar = ({ className = 'bg-white' }: StatusBarProps) => {
+ const now = new Date();
+ const hours = now.getHours();
+ const minutes = String(now.getMinutes()).padStart(2, '0');
+
+ return (
+
+
{`${hours}:${minutes}`}
+
+
+
+ );
+};
+
+export default StatusBar;
diff --git a/react-messenger-23rd/src/widgets/chat-list/ui/BottomTabBar.tsx b/react-messenger-23rd/src/widgets/chat-list/ui/BottomTabBar.tsx
new file mode 100644
index 00000000..ef34b368
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-list/ui/BottomTabBar.tsx
@@ -0,0 +1,73 @@
+import { Link, useLocation } from 'react-router-dom';
+
+import rawChatRooms from '@/entities/chat-room/model/chatRooms.json';
+import type { ChatRoom } from '@/entities/chat-room/model/types';
+import navIcon from '@/shared/assets/icons/chat-list/compass-03.svg';
+import chattingIcon from '@/shared/assets/icons/chat-list/Icon.svg';
+import activeChattingIcon from '@/shared/assets/icons/chat-list/Icon-active.svg';
+import myProfileIcon from '@/shared/assets/icons/chat-list/user-circle.svg';
+import activeMyProfileIcon from '@/shared/assets/icons/chat-list/user-circle-active.svg';
+import partnerIcon from '@/shared/assets/icons/chat-list/users-01.svg';
+import activePartnerIcon from '@/shared/assets/icons/chat-list/users-01-active.svg';
+
+const CHAT_ROOMS_STORAGE_KEY = 'chat-rooms';
+const initialChatRooms = rawChatRooms as ChatRoom[];
+
+const getStoredChatRooms = (): ChatRoom[] => {
+ const storedRooms = localStorage.getItem(CHAT_ROOMS_STORAGE_KEY);
+
+ if (!storedRooms) return initialChatRooms;
+
+ return JSON.parse(storedRooms) as ChatRoom[];
+};
+
+const BottomTabBar = () => {
+ const location = useLocation();
+
+ const isChatPage = location.pathname === '/' || location.pathname.startsWith('/chat');
+ const isFriendsPage = location.pathname.startsWith('/friends');
+ const isMyProfilePage = location.pathname.startsWith('/my-profile');
+
+ const unreadCount = getStoredChatRooms().reduce((sum, room) => {
+ return sum + (room.unreadCount ?? 0);
+ }, 0);
+
+ const badgeText = unreadCount > 999 ? '999+' : unreadCount;
+
+ return (
+
+ );
+};
+
+export default BottomTabBar;
diff --git a/react-messenger-23rd/src/widgets/chat-list/ui/ChatListHeader.tsx b/react-messenger-23rd/src/widgets/chat-list/ui/ChatListHeader.tsx
new file mode 100644
index 00000000..43dfcd1b
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-list/ui/ChatListHeader.tsx
@@ -0,0 +1,21 @@
+import newChattingIcon from '@/shared/assets/icons/chat-list/new chatting(24_24).svg';
+import settingIcon from '@/shared/assets/icons/chat-list/settings-02.svg';
+
+const ChatListHeader = () => {
+ return (
+
+ 채팅
+
+
+
+
+
+
+ );
+};
+
+export default ChatListHeader;
diff --git a/react-messenger-23rd/src/widgets/chat-list/ui/ChatListSearch.tsx b/react-messenger-23rd/src/widgets/chat-list/ui/ChatListSearch.tsx
new file mode 100644
index 00000000..67bc064d
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-list/ui/ChatListSearch.tsx
@@ -0,0 +1,26 @@
+import searchIcon from '@/shared/assets/icons/chat-list/search(20_20).svg';
+import toggleIcon from '@/shared/assets/icons/chat-list/Toggle.svg';
+
+const ChatListSearch = () => {
+ return (
+
+ {/*검색창*/}
+
+

+
+
+
+
+ {/*읽지 않은 메시지 토글*/}
+
+
읽지 않은 메시지
+
+
+
+
+ );
+};
+
+export default ChatListSearch;
diff --git a/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomItem.tsx b/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomItem.tsx
new file mode 100644
index 00000000..dcc982b4
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomItem.tsx
@@ -0,0 +1,70 @@
+import { Link } from 'react-router-dom';
+
+import { formatChatRoomListTime } from '@/entities/chat-room/lib/formatChatRoomListTime';
+import type { ChatRoom } from '@/entities/chat-room/model/types';
+import type { Message } from '@/entities/message/model/types';
+import pinIcon from '@/shared/assets/icons/chat-list/pin-01.svg';
+import profileIcon from '@/shared/assets/icons/chat-list/user-02.svg';
+
+interface ChatRoomItemProps {
+ room: ChatRoom;
+ lastMessage?: Message;
+ onTogglePin: (roomId: string) => void;
+}
+
+const ChatRoomItem = ({ room, lastMessage, onTogglePin }: ChatRoomItemProps) => {
+ return (
+
+ {/*프로필영역*/}
+
+

+
+ {/*텍스트영역*/}
+
+ {/*위쪽 (이름 + 멤버수)*/}
+
+
+
{room.name}
+
+ {room.memberCount &&
{room.memberCount}}
+
+ {/*핀 아이콘*/}
+
+
+ {/*시간*/}
+
{formatChatRoomListTime(lastMessage, room)}
+
+ {/*아래쪽 (메시지 + unread)*/}
+
+ {/*마지막 메시지*/}
+
{lastMessage?.messages ?? room.lastMessage}
+ {/*unread badge(지금은 고정값)*/}
+ {room.unreadCount > 0 ? (
+
+ {room.unreadCount}
+
+ ) : (
+
+ 0
+
+ )}
+
+
+
+ );
+};
+
+export default ChatRoomItem;
diff --git a/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomList.tsx b/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomList.tsx
new file mode 100644
index 00000000..2d3a5c4f
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-list/ui/ChatRoomList.tsx
@@ -0,0 +1,107 @@
+import { useState } from 'react';
+
+import rawChatRooms from '@/entities/chat-room/model/chatRooms.json';
+import type { ChatRoom } from '@/entities/chat-room/model/types';
+import type { Message } from '@/entities/message/model/types';
+
+import ChatRoomItem from './ChatRoomItem';
+
+const initialChatRooms = rawChatRooms as ChatRoom[];
+
+const MESSAGE_STORAGE_KEY = 'chat-messages';
+const CHAT_ROOMS_STORAGE_KEY = 'chat-rooms';
+
+const getMessages = (): Message[] => {
+ const stored = localStorage.getItem(MESSAGE_STORAGE_KEY);
+ if (!stored) return [];
+ return JSON.parse(stored) as Message[];
+};
+
+const getChatRooms = (): ChatRoom[] => {
+ const stored = localStorage.getItem(CHAT_ROOMS_STORAGE_KEY);
+ if (!stored) return initialChatRooms;
+ return JSON.parse(stored) as ChatRoom[];
+};
+
+const ChatRoomList = () => {
+ const [, setRefresh] = useState(false);
+
+ const allMessages = getMessages();
+ const chatRooms = getChatRooms();
+
+ const handleTogglePin = (roomId: string) => {
+ const now = Date.now();
+
+ const updatedRooms = chatRooms.map((room) => {
+ if (room.id !== roomId) return room;
+
+ if (!room.isPinned) {
+ return {
+ ...room,
+ isPinned: true,
+ pinOrder: now,
+ recentUnpinned: null,
+ };
+ }
+
+ return {
+ ...room,
+ isPinned: false,
+ pinOrder: null,
+ recentUnpinned: now,
+ };
+ });
+
+ localStorage.setItem(CHAT_ROOMS_STORAGE_KEY, JSON.stringify(updatedRooms));
+ setRefresh((prev) => !prev);
+ };
+
+ const sortedRooms = [...chatRooms].sort((a, b) => {
+ // 핀된 방이 먼저
+ if (a.isPinned !== b.isPinned) {
+ return a.isPinned ? -1 : 1;
+ }
+
+ // 둘 다 핀된 경우: 최근에 핀한 방이 위
+ if (a.isPinned && b.isPinned) {
+ return (b.pinOrder ?? 0) - (a.pinOrder ?? 0);
+ }
+
+ // 둘 다 핀이 안 된 경우: 최근에 핀 해제한 방이 위
+ const aRecentUnpinned = a.recentUnpinned ?? 0;
+ const bRecentUnpinned = b.recentUnpinned ?? 0;
+
+ if (aRecentUnpinned !== bRecentUnpinned) {
+ return bRecentUnpinned - aRecentUnpinned;
+ }
+
+ // 나머지는 기존 순서
+ return 0;
+ });
+
+ const getLastMessage = (roomId: string): Message | undefined => {
+ const roomMessages = allMessages.filter((message) => message.chatRoomId === roomId);
+
+ if (roomMessages.length === 0) return undefined;
+
+ return roomMessages[roomMessages.length - 1];
+ };
+
+ return (
+
+
+ {sortedRooms.map((room) => {
+ const lastMessage = getLastMessage(room.id);
+
+ return (
+ -
+
+
+ );
+ })}
+
+
+ );
+};
+
+export default ChatRoomList;
diff --git a/react-messenger-23rd/src/widgets/chat-room/ui/ChatRoomHeader.tsx b/react-messenger-23rd/src/widgets/chat-room/ui/ChatRoomHeader.tsx
new file mode 100644
index 00000000..bab03303
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-room/ui/ChatRoomHeader.tsx
@@ -0,0 +1,55 @@
+// 채팅방 상단 헤더.
+// 뒤로가기, 채팅방 이름, 검색, 메뉴 버튼 같은 거.
+import { useNavigate } from 'react-router-dom';
+
+import hamburgerIcon from '@/shared/assets/icons/chat-room/hamburger(24_24).svg';
+import backIcon from '@/shared/assets/icons/chat-room/My_Text Box/Back (32_32).svg';
+import searchIcon from '@/shared/assets/icons/chat-room/search(24_24).svg';
+
+interface ChatRoomHeaderProps {
+ title: string;
+ onFlip: () => void;
+ isFlipped: boolean;
+}
+
+const ChatRoomHeader = ({ title, onFlip, isFlipped }: ChatRoomHeaderProps) => {
+ const navigate = useNavigate();
+
+ return (
+
+ );
+};
+
+export default ChatRoomHeader;
diff --git a/react-messenger-23rd/src/widgets/chat-room/ui/DateDivider.tsx b/react-messenger-23rd/src/widgets/chat-room/ui/DateDivider.tsx
new file mode 100644
index 00000000..408e96ff
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-room/ui/DateDivider.tsx
@@ -0,0 +1,14 @@
+// 날짜 구분선 컴포넌트
+interface DateDividerProps {
+ date: string;
+}
+
+const DateDivider = ({ date }: DateDividerProps) => {
+ return (
+
+ {date}
+
+ );
+};
+
+export default DateDivider;
diff --git a/react-messenger-23rd/src/widgets/chat-room/ui/MessageInputBar.tsx b/react-messenger-23rd/src/widgets/chat-room/ui/MessageInputBar.tsx
new file mode 100644
index 00000000..ddcb748a
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-room/ui/MessageInputBar.tsx
@@ -0,0 +1,98 @@
+// 하단 채팅 입력창 전체 레이아웃, button부분은 enter로 채팅이 보내지게 수정해야됨.
+import type { KeyboardEvent } from 'react';
+import { useRef, useState } from 'react';
+
+import smileIcon from '@/shared/assets/icons/chat-room/face-smile.svg';
+import microPhoneIcon from '@/shared/assets/icons/chat-room/microphone-01.svg';
+import plusIcon from '@/shared/assets/icons/chat-room/plus.svg';
+import sendIcon from '@/shared/assets/icons/chattingRoom/arrow-narrow-up.svg';
+
+interface MessageInputBarProps {
+ value: string;
+ onChange: (value: string) => void;
+ onSend: () => void;
+}
+
+const MessageInputBar = ({ value, onChange, onSend }: MessageInputBarProps) => {
+ const [isComposing, setIsComposing] = useState(false);
+ const textareaRef = useRef(null);
+
+ const handleChange = (e: React.ChangeEvent) => {
+ onChange(e.target.value);
+
+ const textarea = textareaRef.current;
+ if (textarea) {
+ textarea.style.height = 'auto';
+ textarea.style.height = `${textarea.scrollHeight}px`;
+ }
+ };
+
+ const handleKeyDown = (e: KeyboardEvent) => {
+ if (isComposing || e.nativeEvent.isComposing || e.keyCode === 229) return;
+ if (e.key === 'Enter' && !e.shiftKey) {
+ e.preventDefault();
+ onSend();
+
+ //전송 후 높이 초기화
+ if (textareaRef.current) {
+ textareaRef.current.style.height = 'auto';
+ }
+ }
+ };
+
+ const hasText = value.trim().length > 0;
+
+ return (
+
+
+
+
+
+
+
+ );
+};
+
+export default MessageInputBar;
diff --git a/react-messenger-23rd/src/widgets/chat-room/ui/MessageList.tsx b/react-messenger-23rd/src/widgets/chat-room/ui/MessageList.tsx
new file mode 100644
index 00000000..59c0e7ee
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/chat-room/ui/MessageList.tsx
@@ -0,0 +1,79 @@
+// 메시지 목록 전체.
+import type { RefObject } from 'react';
+
+import type { Message } from '@/entities/message/model/types';
+import MessageBubble from '@/entities/message/ui/MessageBubble';
+import type { User } from '@/entities/user/model/types';
+import rawUsers from '@/entities/user/model/users.json';
+
+import DateDivider from './DateDivider';
+
+interface MessageListProps {
+ messages: Message[];
+ bottomRef: RefObject;
+ isFlipped: boolean;
+ roomName: string;
+}
+
+const users = rawUsers as User[];
+
+const getMarginClass = (currentUserId: string, nextUserId: string | undefined, isFlipped: boolean) => {
+ const toIsMe = (id: string) => (isFlipped ? id !== 'me' : id === 'me');
+
+ const currentIsMe = toIsMe(currentUserId);
+ const nextIsMe = nextUserId ? toIsMe(nextUserId) : null;
+
+ if (nextIsMe === null) return 'mb-2';
+ if (currentIsMe && nextIsMe) return 'mb-2';
+ if (currentIsMe && !nextIsMe) return 'mb-3';
+ if (!currentIsMe && nextIsMe) return 'mb-4';
+ return 'mb-2';
+};
+
+const MessageList = ({ messages, bottomRef, isFlipped, roomName }: MessageListProps) => {
+ return (
+
+ {messages.map((message, index) => {
+ const prevMessage = messages[index - 1];
+ const nextMessage = messages[index + 1];
+
+ const showDate = index === 0 || prevMessage.date !== message.date;
+
+ const showTime =
+ !nextMessage ||
+ nextMessage.userId !== message.userId ||
+ nextMessage.time !== message.time ||
+ nextMessage.date !== message.date;
+
+ const showProfile = index === 0 || prevMessage.userId !== message.userId || prevMessage.time !== message.time;
+
+ const marginClass = getMarginClass(message.userId, nextMessage?.userId, isFlipped);
+
+ const user = users.find((item) => item.id === message.userId);
+ if (!user) return null;
+
+ const resolvedUser: User = {
+ ...user,
+ name: message.userId === 'other' ? roomName : user.name,
+ };
+
+ return (
+
+ {showDate && }
+
+
+ );
+ })}
+
+
+ );
+};
+
+export default MessageList;
diff --git a/react-messenger-23rd/src/widgets/friends/ui/FriendItem.tsx b/react-messenger-23rd/src/widgets/friends/ui/FriendItem.tsx
new file mode 100644
index 00000000..bcf3333f
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/friends/ui/FriendItem.tsx
@@ -0,0 +1,33 @@
+import type { Friend } from '@/entities/user/model/types';
+import readIcon from '@/shared/assets/icons/friends/notification-message-read.svg';
+import yetIcon from '@/shared/assets/icons/friends/notification-message-yet.svg';
+import profileIcon from '@/shared/assets/icons/friends/user-02.svg';
+
+const FriendItem = ({ friend }: { friend: Friend }) => {
+ const renderStatusButton = () => {
+ if (friend.status === 'none') return null;
+
+ const iconSrc = friend.status === 'yet' ? yetIcon : readIcon;
+ const iconAlt = friend.status === 'yet' ? '안 읽은 메시지 있음' : '메시지 읽음';
+
+ return (
+
+ );
+ };
+
+ return (
+
+
+
+

+
+
{friend.name}
+
+ {renderStatusButton()}
+
+ );
+};
+
+export default FriendItem;
diff --git a/react-messenger-23rd/src/widgets/friends/ui/FriendsHeader.tsx b/react-messenger-23rd/src/widgets/friends/ui/FriendsHeader.tsx
new file mode 100644
index 00000000..8553790a
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/friends/ui/FriendsHeader.tsx
@@ -0,0 +1,25 @@
+import questionIcon from '@/shared/assets/icons/friends/message-question-circle(24_24).svg';
+import searchIcon from '@/shared/assets/icons/friends/search(24_24).svg';
+import addFriendIcon from '@/shared/assets/icons/friends/user-plus(24_24).svg';
+
+const FriendsHeader = () => {
+ return (
+
+ );
+};
+
+export default FriendsHeader;
diff --git a/react-messenger-23rd/src/widgets/friends/ui/FriendsList.tsx b/react-messenger-23rd/src/widgets/friends/ui/FriendsList.tsx
new file mode 100644
index 00000000..c2aa1d79
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/friends/ui/FriendsList.tsx
@@ -0,0 +1,48 @@
+import type { Friend } from '@/entities/user/model/types';
+import downSideIcon from '@/shared/assets/icons/friends/downside (24_24).svg';
+import upSideIcon from '@/shared/assets/icons/friends/upside(24_24).svg';
+
+import FriendItem from './FriendItem';
+
+interface FriendsListProps {
+ isOpen: boolean;
+ onToggle: () => void;
+}
+
+const mockFriends: Friend[] = [
+ { id: 1, name: '강감찬', status: 'read' },
+ { id: 2, name: '김씨', status: 'yet' },
+ { id: 3, name: '나훈아', status: 'none' },
+ { id: 4, name: '남궁선', status: 'read' },
+ { id: 4, name: '박지훈', status: 'none' },
+ { id: 4, name: '백하린', status: 'yet' },
+ { id: 4, name: '이지후', status: 'none' },
+ { id: 4, name: '한다현', status: 'none' },
+ { id: 4, name: '한아현', status: 'none' },
+];
+
+const FriendsList = ({ isOpen, onToggle }: FriendsListProps) => {
+ return (
+
+
+
+
+
+ {isOpen && (
+
+ {mockFriends.map((friend) => (
+
+ ))}
+
+ )}
+
+ );
+};
+
+export default FriendsList;
diff --git a/react-messenger-23rd/src/widgets/friends/ui/MyProfileSection.tsx b/react-messenger-23rd/src/widgets/friends/ui/MyProfileSection.tsx
new file mode 100644
index 00000000..3fa87b3f
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/friends/ui/MyProfileSection.tsx
@@ -0,0 +1,22 @@
+import filesIcon from '@/shared/assets/icons/friends/folder-download.svg';
+import profileIcon from '@/shared/assets/icons/friends/user-02.svg';
+
+const MyProfileSection = () => {
+ return (
+
+
+
+

+
+
고다현
+
+
+
+
+ );
+};
+
+export default MyProfileSection;
diff --git a/react-messenger-23rd/src/widgets/friends/ui/TagSection.tsx b/react-messenger-23rd/src/widgets/friends/ui/TagSection.tsx
new file mode 100644
index 00000000..ccbd5174
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/friends/ui/TagSection.tsx
@@ -0,0 +1,68 @@
+import downSideIcon from '@/shared/assets/icons/friends/downside (24_24).svg';
+import plusIcon from '@/shared/assets/icons/friends/plus.svg';
+import rightSideIcon from '@/shared/assets/icons/friends/rightside(24_24).svg';
+import upSideIcon from '@/shared/assets/icons/friends/upside(24_24).svg';
+
+interface TagSectionProps {
+ isOpen: boolean;
+ onToggle: () => void;
+}
+
+interface Tag {
+ id: number;
+ name: string;
+ count: number;
+}
+
+const mockTags: Tag[] = [
+ { id: 1, name: '우강고토주', count: 5 },
+ { id: 2, name: '홍익시디', count: 24 },
+ { id: 3, name: '세오스 디자인', count: 17 },
+];
+const TagSection = ({ isOpen, onToggle }: TagSectionProps) => {
+ return (
+
+ {/* divider */}
+
+
+ {/* 헤더 */}
+
+
+ {/* 내용 */}
+ {isOpen && (
+
+ {/* 태그 리스트 */}
+
+ {mockTags.map((tag) => (
+
+ ))}
+
+
+
+
+
+
+ )}
+
+ );
+};
+
+export default TagSection;
diff --git a/react-messenger-23rd/src/widgets/my-profile/ui/MyProfileHeader.tsx b/react-messenger-23rd/src/widgets/my-profile/ui/MyProfileHeader.tsx
new file mode 100644
index 00000000..81143484
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/my-profile/ui/MyProfileHeader.tsx
@@ -0,0 +1,15 @@
+import qrCodeIcon from '@/shared/assets/icons/my-profile/qr-code(28_28).svg';
+
+const MyProfileHeader = () => {
+ return (
+
+ 내 프로필
+
+
+
+ );
+};
+
+export default MyProfileHeader;
diff --git a/react-messenger-23rd/src/widgets/my-profile/ui/ProfileIdSection.tsx b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileIdSection.tsx
new file mode 100644
index 00000000..d40f910d
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileIdSection.tsx
@@ -0,0 +1,30 @@
+import copyIcon from '@/shared/assets/icons/my-profile/copy(20_20).svg';
+
+interface ProfileIdSectionProps {
+ onCopy: () => void;
+}
+
+const MY_ID = 'wxid_net0sc3hdxum12';
+
+const ProfileIdSection = ({ onCopy }: ProfileIdSectionProps) => {
+ const handleCopy = async () => {
+ await navigator.clipboard.writeText(MY_ID);
+ onCopy();
+ };
+
+ return (
+
+ ID
+
+
+
{MY_ID}
+
+
+
+
+ );
+};
+
+export default ProfileIdSection;
diff --git a/react-messenger-23rd/src/widgets/my-profile/ui/ProfileInfoSection.tsx b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileInfoSection.tsx
new file mode 100644
index 00000000..f46862d3
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileInfoSection.tsx
@@ -0,0 +1,21 @@
+import profileIcon from '@/shared/assets/icons/my-profile/user-02 (2).svg';
+
+const ProfileInfoSection = () => {
+ return (
+
+
+
+

+
+
+ 고다현
+ 잘 부탁드립니다! 고다현이라고 합니다
+
+
+
+
+
+ );
+};
+
+export default ProfileInfoSection;
diff --git a/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuItem.tsx b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuItem.tsx
new file mode 100644
index 00000000..5e8672ce
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuItem.tsx
@@ -0,0 +1,21 @@
+import rightSideIcon from '@/shared/assets/icons/my-profile/chevron-left.svg';
+
+interface ProfileMenuItemsProps {
+ icon: string;
+ label: string;
+}
+
+const ProfileMenuItem = ({icon, label}: ProfileMenuItemsProps) => {
+ return (
+
+ );
+};
+
+export default ProfileMenuItem;
diff --git a/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuList.tsx b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuList.tsx
new file mode 100644
index 00000000..e4d8af5d
--- /dev/null
+++ b/react-messenger-23rd/src/widgets/my-profile/ui/ProfileMenuList.tsx
@@ -0,0 +1,38 @@
+import dollarIcon from '@/shared/assets/icons/my-profile/currency-dollar-circle.svg';
+import smileIcon from '@/shared/assets/icons/my-profile/face-smile.svg';
+import filesIcon from '@/shared/assets/icons/my-profile/folder-download (1).svg';
+import imageIcon from '@/shared/assets/icons/my-profile/image-03.svg';
+import settingIcon from '@/shared/assets/icons/my-profile/settings-02 (1).svg';
+import starIcon from '@/shared/assets/icons/my-profile/star-01.svg';
+
+import ProfileMenuItem from './ProfileMenuItem';
+
+const ProfileMenuList = () => {
+ return (
+
+ );
+};
+
+export default ProfileMenuList;
diff --git a/react-messenger-23rd/tsconfig.app.json b/react-messenger-23rd/tsconfig.app.json
new file mode 100644
index 00000000..0dfbf85b
--- /dev/null
+++ b/react-messenger-23rd/tsconfig.app.json
@@ -0,0 +1,36 @@
+{
+ "compilerOptions": {
+ "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
+ "target": "ES2023",
+ "useDefineForClassFields": true,
+ "lib": ["ES2023", "DOM", "DOM.Iterable"],
+ "module": "ESNext",
+ "types": ["vite/client"],
+ "skipLibCheck": true,
+ "resolveJsonModule": true,
+ "esModuleInterop": true,
+
+ /* Bundler mode */
+ "moduleResolution": "bundler",
+ "allowImportingTsExtensions": true,
+ "verbatimModuleSyntax": true,
+ "moduleDetection": "force",
+ "noEmit": true,
+ "jsx": "react-jsx",
+
+ /* Linting */
+ "strict": true,
+ "noUnusedLocals": true,
+ "noUnusedParameters": true,
+ "erasableSyntaxOnly": true,
+ "noFallthroughCasesInSwitch": true,
+ "noUncheckedSideEffectImports": true,
+
+ /* 추가 설정 */
+ "baseUrl": ".",
+ "paths": {
+ "@/*": ["src/*"]
+ }
+ },
+ "include": ["src"]
+}
diff --git a/react-messenger-23rd/tsconfig.json b/react-messenger-23rd/tsconfig.json
new file mode 100644
index 00000000..27144065
--- /dev/null
+++ b/react-messenger-23rd/tsconfig.json
@@ -0,0 +1,16 @@
+{
+ "files": [],
+ "references": [{ "path": "./tsconfig.app.json" }, { "path": "./tsconfig.node.json" }],
+ "compilerOptions": {
+ "baseUrl": ".",
+ "paths": {
+ "@/src": ["src/*"],
+ "@/shared/*": ["shared/*"],
+ "@/app/*": ["app/*"],
+ "@/entities/*": ["entities/*"],
+ "@/features/*": ["features/*"],
+ "@/pages/*": ["pages/*"],
+ "@/widgets/*": ["widgets/*"]
+ }
+ }
+}
diff --git a/react-messenger-23rd/tsconfig.node.json b/react-messenger-23rd/tsconfig.node.json
new file mode 100644
index 00000000..8a67f62f
--- /dev/null
+++ b/react-messenger-23rd/tsconfig.node.json
@@ -0,0 +1,26 @@
+{
+ "compilerOptions": {
+ "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo",
+ "target": "ES2023",
+ "lib": ["ES2023"],
+ "module": "ESNext",
+ "types": ["node"],
+ "skipLibCheck": true,
+
+ /* Bundler mode */
+ "moduleResolution": "bundler",
+ "allowImportingTsExtensions": true,
+ "verbatimModuleSyntax": true,
+ "moduleDetection": "force",
+ "noEmit": true,
+
+ /* Linting */
+ "strict": true,
+ "noUnusedLocals": true,
+ "noUnusedParameters": true,
+ "erasableSyntaxOnly": true,
+ "noFallthroughCasesInSwitch": true,
+ "noUncheckedSideEffectImports": true
+ },
+ "include": ["vite.config.ts"]
+}
diff --git a/react-messenger-23rd/vite.config.ts b/react-messenger-23rd/vite.config.ts
new file mode 100644
index 00000000..dfdebdbe
--- /dev/null
+++ b/react-messenger-23rd/vite.config.ts
@@ -0,0 +1,18 @@
+import tailwindcss from '@tailwindcss/vite';
+import react from '@vitejs/plugin-react';
+import path from 'path';
+import { defineConfig } from 'vite';
+import svgr from 'vite-plugin-svgr';
+import tsconfigPaths from 'vite-tsconfig-paths';
+
+// https://vite.dev/config/
+
+export default defineConfig({
+ envDir: '.env',
+ plugins: [react(), svgr(), tsconfigPaths(), tailwindcss()],
+ resolve: {
+ alias: {
+ '@': path.resolve(__dirname, 'src'),
+ },
+ },
+});