From 18d253c7928e1a25558eb70374e6123a838373be Mon Sep 17 00:00:00 2001 From: hyuke81 Date: Thu, 31 Oct 2024 09:27:51 +0900 Subject: [PATCH 1/5] keyword: submit chapter04 keyword --- keyword/chapter04/keyword.md | 163 +++++++++++++++++++++++++++++++++++ 1 file changed, 163 insertions(+) create mode 100644 keyword/chapter04/keyword.md diff --git a/keyword/chapter04/keyword.md b/keyword/chapter04/keyword.md new file mode 100644 index 0000000..be5292b --- /dev/null +++ b/keyword/chapter04/keyword.md @@ -0,0 +1,163 @@ +- `useEffect` ๐Ÿ  + - `useEffect`๋Š” ์™ธ๋ถ€ ์‹œ์Šคํ…œ๊ณผ ์ปดํฌ๋„ŒํŠธ๋ฅผ ๋™๊ธฐํ™”ํ•˜๋Š” React Hook + + ```jsx + useEffect(setup, dependencies?) + ``` + + - `useEffect Hook`์„ ์ด์šฉํ•˜์—ฌ ์šฐ๋ฆฌ๊ฐ€ React์—๊ฒŒ ์ปดํฌ๋„ŒํŠธ๊ฐ€ ๋ Œ๋”๋ฆฐ ๋œ ์ดํ›„์— ์–ด๋–ค ์ผ์„ ์ˆ˜ํ–‰ํ• ์ง€ ์ •ํ•ด์ค„ ์ˆ˜ ์žˆ์Œ + - `useEffect Hook`์„ ์‚ฌ์šฉํ•˜๋ฉด ํ•จ์ˆ˜ ์ปดํฌ๋„ŒํŠธ์—์„œ๋„ `side effect`๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Œ + - `side effect`๋Š” ์™ธ๋ถ€์„ธ๊ณ„์™€์˜ ์ƒํ˜ธ์ž‘์šฉ์ด๋‚˜ ๊ฐ€๋ณ€ ๋ฐ์ดํ„ฐ์˜ ๋ณ€๊ฒฝ ๋“ฑ์„ ํฌํ•จํ•˜๋Š” ์ฝ”๋“œ + - ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค ๋ณ€๊ฒฝ + - ์ „์—ญ ๋ณ€์ˆ˜๋‚˜ ํด๋ž˜์Šค์˜ ๋ฉค๋ฒ„ ๋ณ€์ˆ˜ ๋ณ€๊ฒฝ + - API ํ˜ธ์ถœ + - ์ฝ˜์†” ๋กœ๊น… + - ๊ณผ๊ฑฐ์—” ํด๋ž˜์Šคํ˜• ์ปดํฌ๋„ŒํŠธ์—์„œ๋งŒ ์ƒ๋ช…์ฃผ๊ธฐ ๋ฉ”์†Œ๋“œ๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์—ˆ์ง€๋งŒ, ์˜ค๋Š˜๋‚ ์—๋Š” ํ•จ์ˆ˜ํ˜• ์ปดํฌ๋„ŒํŠธ์—์„œ๋„ ์‚ฌ์šฉ ๊ฐ€๋Šฅ + - `componentDidMount`, `componentDidUpdate`, `componentWillUnmount` โ†’ ๋ผ์ดํ”„์‚ฌ์ดํด ํ›… ๋Œ€์ฒด ๊ฐ€๋Šฅ + - `useEffect` ์ž‘๋™ ์กฐ๊ฑด + - ํŽ˜์ด์ง€๊ฐ€ ์ฒ˜์Œ ๋ Œ๋”๋ง๋˜๊ณ  `useEffect` ๋ฌด์กฐ๊ฑด ํ•œ ๋ฒˆ ์‹คํ–‰ + - `useEffect`์— ๋ฐฐ์—ด๋กœ ์ง€์ •ํ•œ `useState`๊ฐ’์ด ๋ณ€๊ฒฐ๋  ๋•Œ ์‹œํ–‰ + - ๋ Œ๋”๋ง๋ ๋•Œ๋งˆ๋‹ค ์‹คํ–‰๋˜๋Š” ๋ฌธ๋ฒ• + + ```jsx + useEffect(()=>{ + // ์ž‘์—… + }); + ``` + + - ํ™”๋ฉด์— ์ฒซ ๋ Œ๋”๋ง ๋  ๋•Œ ์‹คํ–‰, value๊ฐ’์ด ๋ฐ”๋€”๋•Œ ์‹คํ–‰๋˜๋Š” ๋ฌธ๋ฒ• + + ```jsx + useEffect(()=>{ + // ์ž‘์—… + },[value]); + ``` + +- `try, catch, finally` ๊ตฌ๋ฌธ ๐Ÿ  + - **`try...catch`**ย ๋ฌธ์€ย `try`ย ๋ธ”๋ก๊ณผย `catch`ย ๋ธ”๋ก,ย `finally`ย ๋ธ”๋ก ์ค‘ ํ•˜๋‚˜ ํ˜น์€ ๋‘ ๋ธ”๋ก์œผ๋กœ ๊ตฌ์„ฑ + - `try`ย ๋ธ”๋ก ๋‚ด ์ฝ”๋“œ๊ฐ€ ๋จผ์ € ์‹คํ–‰๋˜๊ณ , ๋งŒ์•ฝ ๊ทธ ์•ˆ์—์„œ ์˜ˆ์™ธ๊ฐ€ ๋ฐœ์ƒํ•œ๋‹ค๋ฉดย `catch`ย ๋ธ”๋ก ๋‚ด ์ฝ”๋“œ๊ฐ€ ์‹คํ–‰ + - `finally`ย ๋ธ”๋ก ๋‚ด ์ฝ”๋“œ๋Š” ํ•ญ์ƒ ์‹คํ–‰๋˜๋ฉฐ, ์ œ์–ด ํ๋ฆ„์ด ์ „์ฒด ๊ตฌ๋ฌธ์„ ์ข…๋ฃŒํ•˜๊ธฐ ์ „์— ์‹คํ–‰ + + ```jsx + try { + tryStatements //try ๋ธ”๋ก์—์„œ ์‹คํ–‰๋  ๊ตฌ๋ฌธ + } catch (exceptionVar) { //catch ๋ธ”๋ก์—์„œ ์žกํžŒ ์˜ˆ์™ธ๋ฅผ ๋‹ด๋Š” ์„ ํƒ์  ์‹๋ณ„์ž ํ˜น์€ ํŒจํ„ด(์˜ต์…˜) + catchStatements //try ๋ธ”๋ก์—์„œ ์˜ˆ์™ธ๊ฐ€ ๋ฐœ์ƒํ–ˆ์„ ๋•Œ ์‹คํ–‰๋  ๊ตฌ๋ฌธ + } finally { + finallyStatements //try...catch...finally ๊ตฌ๋ฌธ์—์„œ ์ œ์–ด ํ๋ฆ„์ด ๋น ์ ธ๋‚˜๊ฐ€๊ธฐ ์ „์— ์‹คํ–‰๋˜๋Š” ๊ตฌ๋ฌธ, ์˜ˆ์™ธ๊ฐ€ ๋ฐœ์ƒํ–ˆ๋Š”์ง€ ์—ฌ๋ถ€์™€ ๊ด€๊ณ„์—†์ด ํ•ญ์ƒ ์‹คํ–‰ + } + ``` + + - `try`ย ๋ฌธ์€ ํ•ญ์ƒย `try`ย ๋ธ”๋ก์œผ๋กœ ์‹œ์ž‘ + - `catch`ย ๋ธ”๋ก ๋˜๋Š”ย `finally`ย ๋ธ”๋ก ์ค‘ ํ•˜๋‚˜๊ฐ€ ๋ฐ˜๋“œ์‹œ ์กด์žฌํ•ด์•ผ ํ•จ + - `catch`ย ๋ธ”๋ก๊ณผย `finally`ย ๋ธ”๋ก์„ ๋ชจ๋‘ ๊ฐ€์งˆ ์ˆ˜๋„ ์žˆ์Œ + - `try...catch` + - `try...finally` + - `try...catch...finally` + - `catch` + - `try`ย ๋ธ”๋ก์—์„œ ์˜ˆ์™ธ๊ฐ€ ๋ฐœ์ƒํ•˜๋ฉด,ย `exceptionVar`(ย `catch (e)`ย ์—์„œ์˜ย `e`)์— ์˜ˆ์™ธ ๊ฐ’์ด ์ €์žฅ๋จ + - `catch` ๋ธ”๋ก ์Šค์ฝ”ํ”„ ๋‚ด์—์„œ๋งŒ ์‚ฌ์šฉ ๊ฐ€๋Šฅ + - `finally` + - `try`ย ๋ธ”๋ก์ด ์ •์ƒ์ ์œผ๋กœ ์‹คํ–‰์„ ๋งˆ์น˜๊ณ  (์˜ˆ์™ธ๊ฐ€ ๋ฐœ์ƒํ•˜์ง€ ์•Š์€ ๊ฒฝ์šฐ) + - `catch`ย ๋ธ”๋ก์ด ์ •์ƒ์ ์œผ๋กœ ์‹คํ–‰์„ ๋งˆ์น˜๊ณ  + - `try`ย ๋ธ”๋ก์ด๋‚˜ย `catch`ย ๋ธ”๋ก์—์„œ ์ œ์–ด ํ๋ฆ„ ๊ตฌ๋ฌธ(`return`,ย `throw`,ย `break`,ย `continue`)์ด ์‹คํ–‰๋˜์–ด ํ•ด๋‹น ๋ธ”๋ก์„ ๋ฒ—์–ด๋‚˜๊ธฐ ์ง์ „ +- `axios` ๐Ÿ  + - ๋ธŒ๋ผ์šฐ์ €, Node.js๋ฅผ ์œ„ํ•œ Promise API๋ฅผ ํ™œ์šฉํ•˜๋Š” HTTP ๋น„๋™๊ธฐ ํ†ต์‹  ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ + + ```jsx + npm i axios + ``` + + - ์žฅ์  + - ๊ฐ„๋‹จํ•˜์—ฌ HTTP ์š”์ฒญ์„ ๋ณด๋‚ด๊ณ  ์‘๋‹ตํ•˜๋Š” ๊ฒƒ์ด ์‰ฌ์›€ + - ์„œ๋ฒ„์—์„œ ๋ฐ›์€ ์‘๋‹ต์„ ์ž๋™์œผ๋กœ JSON์œผ๋กœ ํ”ผ์‹ฑํ•จ + - ์š”์ฒญ์ด๋‚˜ ์‘๋‹ต์„ ๊ฐ€๋กœ์ฑ„ ์ค‘๊ฐ„์—์„œ ๋กœ์ง์„ ์ถ”๊ฐ€ํ•˜๊ฑฐ๋‚˜ ํ—ค๋”๋ฅผ ์ˆ˜์ •ํ•˜๋Š” ์ž‘์—…์ด ๊ฐ€๋Šฅํ•จ + - ์ทจ์†Œ์š”์ฒญ ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•˜์—ฌ ๋ถˆํ•„์š”ํ•œ ๋„คํŠธ์›Œํฌ ์š”์ฒญ ๋ฐฉ์ง€ + - REST API (REST ๊ธฐ๋ฐ˜์˜ API๋ฅผ ์›น์œผ๋กœ ๊ตฌํ˜„ํ•œ ๊ฒƒ) + 1. GET: ๋ฐ์ดํ„ฐ ์กฐํšŒ + 2. POST: ๋ฐ์ดํ„ฐ ๋“ฑ๋ก ๋ฐ ์ „์†ก + 3. PUT: ๋ฐ์ดํ„ฐ ์ˆ˜์ • + 4. DELETE: ๋ฐ์ดํ„ฐ ์‚ญ์ œ + - POST, PUT, PATCH ์ฐจ์ด์  + + | POST | PUT | PATCH | + | --- | --- | --- | + | Create | Update | Partial Update | + | ์ƒ์„ฑ | ๊ฐฑ์‹ , ์ƒ์„ฑ | ์ผ๋ถ€ ๊ฐฑ์‹  | + | ์—ฌ๋Ÿฌ๋ฒˆ ํ˜ธ์ถœ์‹œ + ๋งค๋ฒˆ ๋‹ค๋ฅธ ๊ฒฐ๊ณผ ์ƒ์„ฑ | ์—ฌ๋Ÿฌ๋ฒˆ ํ˜ธ์ถœ ์‹œ ๋™์ผํ•œ ๊ฒฐ๊ณผ | ์ง€์ •ํ•œ ๋ณ€๊ฒฝ์‚ฌํ•ญ ์ผ๋ถ€๋งŒ ๋ณ€๊ฒฝ | +- `fetch` ๐Ÿ  + - HTTP ํŒŒ์ดํ”„๋ผ์ธ์„ ๊ตฌ์„ฑํ•˜๋Š” ์š”์ฒญ๊ณผ ์‘๋‹ต ๋“ฑ์˜ ์š”์†Œ๋ฅผ JavaScript์—์„œ ์ ‘๊ทผํ•˜๊ณ  ์กฐ์ž‘ํ•  ์ˆ˜ ์žˆ๋Š” ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ œ๊ณต + - fetch ํ•จ์ˆ˜๋Š” ๋„คํŠธ์›Œํฌ ์š”์ฒญ์„ ๋ณด๋‚ด๊ณ , ์„œ๋ฒ„๋กœ๋ถ€ํ„ฐ ์‘๋‹ต์„ ๋ฐ›์Œ + - ์‘๋‹ต์€ promise ๊ฐ์ฒด๋กœ ๋ฐ˜ํ™˜๋˜๋ฉฐ, ์ด๋ฅผ ํ†ตํ•ด ๋น„๋™๊ธฐ์ ์œผ๋กœ ๋ฐ์ดํ„ฐ๋ฅผ ์ฒ˜๋ฆฌํ•  ์ˆ˜ ์žˆ์Œ + + ```jsx + const promise = fetch(url, [options]) + ``` + + - url: ์ ‘๊ทผํ•˜๊ณ ์ž ํ•˜๋Š” URL + - options: ์„ ํƒ ๋งค๊ฐœ๋ณ€์ˆ˜, method๋‚˜ header ๋“ฑ์„ ์ง€์ • + +- `axios` vs `fetch` (์ฐจ์ด์ ) ๐Ÿ  + + + | X | **Axios** | **Fetch** | + | --- | --- | --- | + | **1** | ์š”์ฒญ ๊ฐ์ฒด์—ย **url**์„ ๊ฐ€์ง€๊ณ  ์žˆ๋‹ค | ์š”์ฒญ ๊ฐ์ฒด์—ย **url**์ด ์—†๋‹ค | + | **2** | **์„ค์น˜๊ณผ์ •**์ด ํ•„์š”ํ•˜๋‹ค | ๋Œ€๋ถ€๋ถ„์˜ ์ตœ์‹  ๋ธŒ๋ผ์šฐ์ €์— ๋‚ด์žฅ๋˜์–ด ์žˆ์–ดย **์„ค์น˜**๊ฐ€ ํ•„์š”์—†๋‹ค | + | **3** | ๋‚ด์žฅ๋œย **XSRF**ย ๋ณดํ˜ธ๊ธฐ๋Šฅ์ด ์žˆ๋‹ค | ๊ธฐ๋Šฅ ์—†์Œ | + | **4** | **data**ย ์†์„ฑ์„ ์‚ฌ์šฉํ•œ๋‹ค. | **body**ย ์†์„ฑ์„ ์‚ฌ์šฉํ•œ๋‹ค. | + | **5** | data์—๋Š”ย **๊ฐ์ฒด**๊ฐ€ ํฌํ•จ๋˜์–ด ์žˆ๋‹ค | body๋Š”ย **๋ฌธ์ž์—ดํ™”**ย ๋˜์–ด์•ผ ํ•œ๋‹ค. | + | **6** | status๊ฐ€ 200ย ์ด๊ณ ย statusText**๊ฐ€ 'OK'**ย ์ผ ๋•Œ ์š”์ฒญ์€ ์ •์ƒ์ด๋‹ค | ์‘๋‹ต ๊ฐ์ฒด์—ย **OK**ย ์†์„ฑ์ด ํฌํ•จ๋˜์–ดย ์žˆ์œผ๋ฉด ์š”์ฒญ์€ ์ •์ƒ์ด๋‹ค | + | **7** | JSON ๋ฐ์ดํ„ฐ์˜ย **์ž๋™ ๋ณ€ํ™˜**์„ย ์ˆ˜ํ–‰ํ•œ๋‹ค. | **json()**๋ฉ”์„œ๋“œ๋ฅผ ์‚ฌ์šฉํ•ด์•ผ ํ•œ๋‹ค. | + | **8** | ์š”์ฒญ ์ทจ์†Œ ๋ฐ ํƒ€์ž„์•„์›ƒ ๊ธฐ๋Šฅ์ด ์กด์žฌ | ๊ธฐ๋Šฅ ์—†์Œ | + | **9** | HTTP ์š”์ฒญ์„ย **๊ฐ€๋กœ์ฑŒ**ย ์ˆ˜ ์žˆ๋Š” ๊ธฐ๋Šฅ์ด ์žˆ๋‹ค | ๊ธฐ๋Šฅ ์—†์Œ | + | **10** | ๋‹ค์šด๋กœ๋“œ ์ง„ํ–‰๋ฅ ์— ๋Œ€ํ•œ ์ง€์›์ด ๋‚ด์žฅ๋˜์–ดย ์žˆ๋‹ค. | ๊ธฐ๋Šฅ ์—†์Œ | + | **11** | ๋” ๋งŽ์€ ๋ธŒ๋ผ์šฐ์ €๋ฅผ ์ง€์›ํ•œ๋‹ค. | Chrome 42 ์ด์ƒ, Firefox 39 ์ด์ƒ, Edge 14 ์ด์ƒ, Safari 10.1 ์ด์ƒ๋งŒ ใ…‡์ง€์›ํ•œ๋‹ค. | +- `.env` ํŒŒ์ผ์—๋Š” ์–ด๋–ค ๋‚ด์šฉ๋“ค์„ ๊ด€๋ฆฌํ• ๊นŒ์š”? ๐Ÿ  + - ์™ธ๋ถ€ API ํ˜ธ์ถœํ•  ๋•Œ APIํ‚ค์™€ ๊ฐ™์€ ๋ฏผ๊ฐํ•œ ์ •๋ณด๋Š” ์ง์ ‘ ์ฝ”๋“œ์— ์ž‘์„ฑํ•˜์ง€ ์•Š๊ณ  .env ํŒŒ์ผ์— ๋„ฃ์–ด ๊ด€๋ฆฌํ•จ. + - ํ™˜๊ฒฝ์— ๋”ฐ๋ผ ์„ค์ •์„ ๋‹ค๋ฅด๊ฒŒ ์ ์šฉํ•˜๊ธฐ ์œ„ํ•ด ํ™˜๊ฒฝ ๊ตฌ๋ถ„ ๋ณ€์ˆ˜๋ฅผ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Œ + - ๊ฐœ๋ฐœ ํ™˜๊ฒฝ๊ณผ ๋ฐฐํฌ ํ™˜๊ฒฝ์—์„œ ๊ฐ๊ฐ ํ•„์š”ํ•œ ์„ค์ •์„ ๋ถ„๋ฆฌํ•  ์ˆ˜ ์žˆ์Œ + - https://velog.io/@sj_yun/React-Vite-%ED%99%98%EA%B2%BD%EC%97%90%EC%84%9C-.env-%ED%99%98%EA%B2%BD%EB%B3%80%EC%88%98-%EC%84%A4%EC%A0%95%EB%B2%95 + - .env ํŒŒ์ผ์„ .gitignore์— ๋“ฑ๋กํ•ด์ค˜์•ผ ํ•จ + + ```jsx + ๊นƒ์— .env ํŒŒ์ผ์ด ์˜ฌ๋ผ๊ฐ€๋ฉด ์•ˆ ๋˜๊ธฐ ๋•Œ๋ฌธ์— ๊ผญ! gitIgnore์— .env๋ฅผ ๊ผญ ์ถ”๊ฐ€์‹œ์ผœ์ค๋‹ˆ๋‹ค!! + + gitIgnore + > .env + ``` + + - Vite์—์„œ ํ™˜๊ฒฝ๋ณ€์ˆ˜ ์‚ฌ์šฉ๋ฒ• + 1. ๋””๋ ‰ํ† ๋ฆฌ์— .envํŒŒ์ผ ์ƒ์„ฑ + 2. ๋ณ€์ˆ˜๋ช…ย `VITE_`ย ๋กœ ์‹œ์ž‘ํ•˜๋Š” ๋ณ€์ˆ˜์ƒ์„ฑ + 3. ๋”ฐ์˜ดํ‘œ๋ฅผ ๊ฐ์‹ธ๋„ ๊ดœ์ฐฎ์Œ + + ```jsx + VITE_APPLICATION_KEY = "์„ค์ •ํ•˜๊ณ ์ž ํ•˜๋Š” ๊ฐ’" + ``` + + 1. ํ•„์š”ํ•œ ๊ณณ์—์„œ ์‚ฌ์šฉ์‹œย `import.meta.env.`๋ณ€์ˆ˜๋ช…์œผ๋กœ ํ˜ธ์ถœ + + ```jsx + const APPLICATION_KEY = import.meta.env.VITE_APPLICATION_KEY + ``` + +- **`custom hook ?`** + - ๋ฆฌ์•กํŠธ๋Š” ์ œ๊ณตํ•ด์ฃผ์ง€ ์•Š์ง€๋งŒ, ๊ฐœ๋ฐœ์„ ์ง„ํ–‰ํ•  ๋•Œ ๊ฐœ์ธ์ ์œผ๋กœ 'hook'์œผ๋กœ ๋งŒ๋“ค๋ฉด ๋” ํŽธํ•˜๊ฒ ๋‹ค๊ณ  ๋Š๋‚„ ๋•Œ, ์ž์‹ ๋งŒ์˜ hook์œผ๋กœ ๋งŒ๋“œ๋Š” ๊ฒƒ์„ ์˜๋ฏธ + - ๊ฐ™์€ ๋กœ์ง์ด ๋ฐ˜๋ณต๋  ๋•Œ ๋‘ ๋กœ์ง์„ ๋‚˜๋ˆ„์–ด์„œ ์ž‘์„ฑํ•˜๋Š” ๊ฒŒ ๊ฐ€๋Šฅํ• ์ง€๋ผ๋„, ๊ต‰์žฅํžˆ ๋น„ํšจ์œจ์  + - ๋กœ์ง์„ ํ•˜๋‚˜์˜ **`custom hook`**ย ์œผ๋กœ ๋”ฐ๋กœ ์ •์˜ํ•˜์—ฌ ๋น„ํšจ์œจ์„ฑ์„ ๋‚ฎ์ถœ ์ˆ˜ ์žˆ์Œ + - ์ปดํฌ๋„ŒํŠธ ๋กœ์ง ์ž์ฒด๋ฅผ ๋ถ„ํ•  + ์žฌ์‚ฌ์šฉ + - ๊ทœ์น™ + 1. `use`๋กœ ์‹œ์ž‘ํ•  ๊ฒƒ + 1. ๋ฆฌ์•กํŠธ์—์„œย `hook`๋“ค์€ ๋ชจ๋‘ย `use`๋กœ ์‹œ์ž‘ํ•˜๋Š” ๊ฒƒ์ด ์›์น™ + 2. state ์ž์ฒด๊ฐ€ ์•„๋‹Œ state ์ €์žฅ ๋…ผ๋ฆฌ๋ฅผ ๊ณต์œ ํ•˜๋Š” ๊ฒƒ + 1. ๊ฐ™์€ hook์ด ์—ฐ์ด์–ด ํ˜ธ์ถœ๋˜์—ˆ๋‹ค๊ณ  ํ•ด๋„ ์„œ๋กœ์˜ ๊ธฐ๋Šฅ์—๋Š” ์˜ํ–ฅ์„ ๋ฏธ์น˜์ง€ ์•Š๋Š”๋‹ค + 3. `custom hook`์€ ์ˆœ์ˆ˜ ํ•จ์ˆ˜๋กœ ๊ธฐ๋Œ€๋จ + 4. ์ตœ์ƒ์œ„์—์„œ๋งŒ, react ํ•จ์ˆ˜ ๋‚ด์—์„œ๋งŒ ํ˜ธ์ถœํ•ด์•ผ ํ•จ + 5. `customHook`์— ํ•จ์ˆ˜ ๋„˜๊ฒจ์ฃผ๊ธฐ + - ์žฅ์  + - ์ฝ”๋“œ์˜ **์ค‘๋ณต์„ ์ค„์ด๊ณ ** ์ปดํฌ๋„ŒํŠธ์˜ ์žฌ์‚ฌ์šฉ์„ฑ๊ณผ ์œ ์ง€๋ณด์ˆ˜์„ฑ์„ ๋†’์ผ ์ˆ˜ ์žˆ์Œ + - Effect์™€ ๋ฐ์ดํ„ฐ ํ๋ฆ„์„ ๋ช…ํ™•ํ•˜๊ฒŒ ๋งŒ๋“ฆ + - ์ปดํฌ๋„ŒํŠธ๊ฐ€ ์ž์‹ ์˜ ์—ญํ• ์— ์ง‘์ค‘ํ•  ์ˆ˜ ์žˆ์Œ + - ๋ฆฌ์•กํŠธ๊ฐ€ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ ์ถ”๊ฐ€ํ–ˆ์„ ๋•Œ, ์ปดํฌ๋„ŒํŠธ ์š”์†Œ๋ฅผ ๋ฐ”๊พธ์ง€ ์•Š๊ณ ๋„ ํ•ด๋‹น effect๋ฅผ ์ œ๊ฑฐํ•  ์ˆ˜ ์žˆ์Œ \ No newline at end of file From fe00f418a86214d24764078c2903c2d46a9025e3 Mon Sep 17 00:00:00 2001 From: hyuke81 Date: Sat, 2 Nov 2024 04:22:46 +0900 Subject: [PATCH 2/5] mission: submit chapter04 mission --- mission/chapter04/mission/.gitignore | 26 + mission/chapter04/mission/README.md | 8 + mission/chapter04/mission/eslint.config.js | 38 + mission/chapter04/mission/index.html | 13 + mission/chapter04/mission/package-lock.json | 4331 +++++++++++++++++ mission/chapter04/mission/package.json | 32 + mission/chapter04/mission/public/vite.svg | 1 + mission/chapter04/mission/src/App.jsx | 35 + .../mission/src/apis/axios-instance.js | 10 + .../chapter04/mission/src/assets/react.svg | 1 + .../chapter04/mission/src/components/Card.jsx | 68 + .../mission/src/components/MoviesPage.jsx | 41 + .../src/components/category/nowplaying.jsx | 37 + .../src/components/category/popular.jsx | 42 + .../src/components/category/toprated.jsx | 41 + .../src/components/category/upcoming.jsx | 41 + .../mission/src/components/categorypage.jsx | 40 + .../mission/src/components/loginpage.jsx | 20 + .../mission/src/components/movieidpage.jsx | 146 + .../mission/src/components/navbar.jsx | 30 + .../mission/src/components/searchpage.jsx | 20 + .../mission/src/components/sidebar.jsx | 31 + .../mission/src/components/signuppage.jsx | 20 + .../mission/src/hooks/useCustomFetch.js | 37 + mission/chapter04/mission/src/img/blue.jpg | Bin 0 -> 1609 bytes mission/chapter04/mission/src/img/green.jpg | Bin 0 -> 1605 bytes mission/chapter04/mission/src/img/purple.jpg | Bin 0 -> 1393 bytes mission/chapter04/mission/src/img/yellow.jpg | Bin 0 -> 2149 bytes mission/chapter04/mission/src/main.jsx | 9 + mission/chapter04/mission/src/mocks/movies.js | 399 ++ mission/chapter04/mission/src/rootlayout.jsx | 20 + .../mission/src/styles/category.style.jsx | 38 + .../mission/src/styles/layout.style.jsx | 27 + .../mission/src/styles/movies.style.jsx | 9 + .../mission/src/styles/navbar.style.jsx | 53 + .../mission/src/styles/sidebar.style.jsx | 20 + mission/chapter04/mission/vite.config.js | 7 + 37 files changed, 5691 insertions(+) create mode 100644 mission/chapter04/mission/.gitignore create mode 100644 mission/chapter04/mission/README.md create mode 100644 mission/chapter04/mission/eslint.config.js create mode 100644 mission/chapter04/mission/index.html create mode 100644 mission/chapter04/mission/package-lock.json create mode 100644 mission/chapter04/mission/package.json create mode 100644 mission/chapter04/mission/public/vite.svg create mode 100644 mission/chapter04/mission/src/App.jsx create mode 100644 mission/chapter04/mission/src/apis/axios-instance.js create mode 100644 mission/chapter04/mission/src/assets/react.svg create mode 100644 mission/chapter04/mission/src/components/Card.jsx create mode 100644 mission/chapter04/mission/src/components/MoviesPage.jsx create mode 100644 mission/chapter04/mission/src/components/category/nowplaying.jsx create mode 100644 mission/chapter04/mission/src/components/category/popular.jsx create mode 100644 mission/chapter04/mission/src/components/category/toprated.jsx create mode 100644 mission/chapter04/mission/src/components/category/upcoming.jsx create mode 100644 mission/chapter04/mission/src/components/categorypage.jsx create mode 100644 mission/chapter04/mission/src/components/loginpage.jsx create mode 100644 mission/chapter04/mission/src/components/movieidpage.jsx create mode 100644 mission/chapter04/mission/src/components/navbar.jsx create mode 100644 mission/chapter04/mission/src/components/searchpage.jsx create mode 100644 mission/chapter04/mission/src/components/sidebar.jsx create mode 100644 mission/chapter04/mission/src/components/signuppage.jsx create mode 100644 mission/chapter04/mission/src/hooks/useCustomFetch.js create mode 100644 mission/chapter04/mission/src/img/blue.jpg create mode 100644 mission/chapter04/mission/src/img/green.jpg create mode 100644 mission/chapter04/mission/src/img/purple.jpg create mode 100644 mission/chapter04/mission/src/img/yellow.jpg create mode 100644 mission/chapter04/mission/src/main.jsx create mode 100644 mission/chapter04/mission/src/mocks/movies.js create mode 100644 mission/chapter04/mission/src/rootlayout.jsx create mode 100644 mission/chapter04/mission/src/styles/category.style.jsx create mode 100644 mission/chapter04/mission/src/styles/layout.style.jsx create mode 100644 mission/chapter04/mission/src/styles/movies.style.jsx create mode 100644 mission/chapter04/mission/src/styles/navbar.style.jsx create mode 100644 mission/chapter04/mission/src/styles/sidebar.style.jsx create mode 100644 mission/chapter04/mission/vite.config.js diff --git a/mission/chapter04/mission/.gitignore b/mission/chapter04/mission/.gitignore new file mode 100644 index 0000000..3b0b403 --- /dev/null +++ b/mission/chapter04/mission/.gitignore @@ -0,0 +1,26 @@ +# 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? + +.env \ No newline at end of file diff --git a/mission/chapter04/mission/README.md b/mission/chapter04/mission/README.md new file mode 100644 index 0000000..f768e33 --- /dev/null +++ b/mission/chapter04/mission/README.md @@ -0,0 +1,8 @@ +# React + Vite + +This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. + +Currently, two official plugins are available: + +- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh +- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh diff --git a/mission/chapter04/mission/eslint.config.js b/mission/chapter04/mission/eslint.config.js new file mode 100644 index 0000000..238d2e4 --- /dev/null +++ b/mission/chapter04/mission/eslint.config.js @@ -0,0 +1,38 @@ +import js from '@eslint/js' +import globals from 'globals' +import react from 'eslint-plugin-react' +import reactHooks from 'eslint-plugin-react-hooks' +import reactRefresh from 'eslint-plugin-react-refresh' + +export default [ + { ignores: ['dist'] }, + { + files: ['**/*.{js,jsx}'], + languageOptions: { + ecmaVersion: 2020, + globals: globals.browser, + parserOptions: { + ecmaVersion: 'latest', + ecmaFeatures: { jsx: true }, + sourceType: 'module', + }, + }, + settings: { react: { version: '18.3' } }, + plugins: { + react, + 'react-hooks': reactHooks, + 'react-refresh': reactRefresh, + }, + rules: { + ...js.configs.recommended.rules, + ...react.configs.recommended.rules, + ...react.configs['jsx-runtime'].rules, + ...reactHooks.configs.recommended.rules, + 'react/jsx-no-target-blank': 'off', + 'react-refresh/only-export-components': [ + 'warn', + { allowConstantExport: true }, + ], + }, + }, +] diff --git a/mission/chapter04/mission/index.html b/mission/chapter04/mission/index.html new file mode 100644 index 0000000..0c589ec --- /dev/null +++ b/mission/chapter04/mission/index.html @@ -0,0 +1,13 @@ + + + + + + + Vite + React + + +
+ + + diff --git a/mission/chapter04/mission/package-lock.json b/mission/chapter04/mission/package-lock.json new file mode 100644 index 0000000..c8723bc --- /dev/null +++ b/mission/chapter04/mission/package-lock.json @@ -0,0 +1,4331 @@ +{ + "name": "mission", + "version": "0.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "mission", + "version": "0.0.0", + "dependencies": { + "axios": "^1.7.7", + "react": "^18.3.1", + "react-dom": "^18.3.1", + "react-icons": "^5.3.0", + "react-router-dom": "^6.26.2", + "styled-components": "^6.1.13" + }, + "devDependencies": { + "@eslint/js": "^9.9.0", + "@types/react": "^18.3.3", + "@types/react-dom": "^18.3.0", + "@vitejs/plugin-react": "^4.3.1", + "eslint": "^9.9.0", + "eslint-plugin-react": "^7.35.0", + "eslint-plugin-react-hooks": "^5.1.0-rc.0", + "eslint-plugin-react-refresh": "^0.4.9", + "globals": "^15.9.0", + "vite": "^5.4.1" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.25.7.tgz", + "integrity": "sha512-0xZJFNE5XMpENsgfHYTw8FbX4kv53mFLn2i3XPoq69LyhYSCBJtitaHx9QnsVTrsogI4Z3+HtEfZ2/GFPOtf5g==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.25.7", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.7.tgz", + "integrity": "sha512-9ickoLz+hcXCeh7jrcin+/SLWm+GkxE2kTvoYyp38p4WkdFXfQJxDFGWp/YHjiKLPx06z2A7W8XKuqbReXDzsw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.7.tgz", + "integrity": "sha512-yJ474Zv3cwiSOO9nXJuqzvwEeM+chDuQ8GJirw+pZ91sCGCyOZ3dJkVE09fTV0VEVzXyLWhh3G/AolYTPX7Mow==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.25.7", + "@babel/generator": "^7.25.7", + "@babel/helper-compilation-targets": "^7.25.7", + "@babel/helper-module-transforms": "^7.25.7", + "@babel/helpers": "^7.25.7", + "@babel/parser": "^7.25.7", + "@babel/template": "^7.25.7", + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.7", + "convert-source-map": "^2.0.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.3", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/generator": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.7.tgz", + "integrity": "sha512-5Dqpl5fyV9pIAD62yK9P7fcA768uVPUyrQmqpqstHWgMma4feF1x/oFysBCVZLY5wJ2GkMUCdsNDnGZrPoR6rA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.25.7", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", + "jsesc": "^3.0.2" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.7.tgz", + "integrity": "sha512-DniTEax0sv6isaw6qSQSfV4gVRNtw2rte8HHM45t9ZR0xILaufBRNkpMifCRiAPyvL4ACD6v0gfCwCmtOQaV4A==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.25.7", + "@babel/helper-validator-option": "^7.25.7", + "browserslist": "^4.24.0", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.7.tgz", + "integrity": "sha512-o0xCgpNmRohmnoWKQ0Ij8IdddjyBFE4T2kagL/x6M3+4zUgc+4qTOUBoNe4XxDskt1HPKO007ZPiMgLDq2s7Kw==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.7.tgz", + "integrity": "sha512-k/6f8dKG3yDz/qCwSM+RKovjMix563SLxQFo0UhRNo239SP6n9u5/eLtKD6EAjwta2JHJ49CsD8pms2HdNiMMQ==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.25.7", + "@babel/helper-simple-access": "^7.25.7", + "@babel/helper-validator-identifier": "^7.25.7", + "@babel/traverse": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.25.7.tgz", + "integrity": "sha512-eaPZai0PiqCi09pPs3pAFfl/zYgGaE6IdXtYvmf0qlcDTd3WCtO7JWCcRd64e0EQrcYgiHibEZnOGsSY4QSgaw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.25.7.tgz", + "integrity": "sha512-FPGAkJmyoChQeM+ruBGIDyrT2tKfZJO8NcxdC+CWNJi7N8/rZpSxK7yvBJ5O/nF1gfu5KzN7VKG3YVSLFfRSxQ==", + "dev": true, + "dependencies": { + "@babel/traverse": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.7.tgz", + "integrity": "sha512-CbkjYdsJNHFk8uqpEkpCvRs3YRp9tY6FmFY7wLMSYuGYkrdUi7r2lc4/wqsvlHoMznX3WJ9IP8giGPq68T/Y6g==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.7.tgz", + "integrity": "sha512-AM6TzwYqGChO45oiuPqwL2t20/HdMC1rTPAesnBCgPCSF1x3oN9MVUwQV2iyz4xqWrctwK5RNC8LV22kaQCNYg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.7.tgz", + "integrity": "sha512-ytbPLsm+GjArDYXJ8Ydr1c/KJuutjF2besPNbIZnZ6MKUxi/uTA22t2ymmA4WFjZFpjiAMO0xuuJPqK2nvDVfQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.7.tgz", + "integrity": "sha512-Sv6pASx7Esm38KQpF/U/OXLwPPrdGHNKoeblRxgZRLXnAtnkEe4ptJPDtAZM7fBLadbc1Q07kQpSiGQ0Jg6tRA==", + "dev": true, + "dependencies": { + "@babel/template": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.25.7.tgz", + "integrity": "sha512-iYyACpW3iW8Fw+ZybQK+drQre+ns/tKpXbNESfrhNnPLIklLbXr7MYJ6gPEd0iETGLOK+SxMjVvKb/ffmk+FEw==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.25.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.7.tgz", + "integrity": "sha512-aZn7ETtQsjjGG5HruveUK06cU3Hljuhd9Iojm4M8WWv3wLE6OkE5PWbDUkItmMgegmccaITudyuW5RPYrYlgWw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.25.7" + }, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-self": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.25.7.tgz", + "integrity": "sha512-JD9MUnLbPL0WdVK8AWC7F7tTG2OS6u/AKKnsK+NdRhUiVdnzyR1S3kKQCaRLOiaULvUiqK6Z4JQE635VgtCFeg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-react-jsx-source": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.25.7.tgz", + "integrity": "sha512-S/JXG/KrbIY06iyJPKfxr0qRxnhNOdkNXYBl/rmwgDd72cQLH9tEGkDm/yJPGvcSIUoikzfjMios9i+xT/uv9w==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/template": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.7.tgz", + "integrity": "sha512-wRwtAgI3bAS+JGU2upWNL9lSlDcRCqD05BZ1n3X2ONLH1WilFP6O1otQjeMK/1g0pvYcXC7b/qVUB1keofjtZA==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.25.7", + "@babel/parser": "^7.25.7", + "@babel/types": "^7.25.7" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.7.tgz", + "integrity": "sha512-jatJPT1Zjqvh/1FyJs6qAHL+Dzb7sTb+xr7Q+gM1b+1oBsMsQQ4FkVKb6dFlJvLlVssqkRzV05Jzervt9yhnzg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.25.7", + "@babel/generator": "^7.25.7", + "@babel/parser": "^7.25.7", + "@babel/template": "^7.25.7", + "@babel/types": "^7.25.7", + "debug": "^4.3.1", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/types": { + "version": "7.25.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.7.tgz", + "integrity": "sha512-vwIVdXG+j+FOpkwqHRcBgHLYNL7XMkufrlaFvL9o6Ai9sJn9+PdyIL5qa0XzTZw084c+u9LOls53eoZWP/W5WQ==", + "dev": true, + "dependencies": { + "@babel/helper-string-parser": "^7.25.7", + "@babel/helper-validator-identifier": "^7.25.7", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@emotion/is-prop-valid": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.2.2.tgz", + "integrity": "sha512-uNsoYd37AFmaCdXlg6EYD1KaPOaRWRByMCYzbKUX4+hhMfrxdVSelShywL4JVaAeM/eHUOSprYBQls+/neX3pw==", + "dependencies": { + "@emotion/memoize": "^0.8.1" + } + }, + "node_modules/@emotion/memoize": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.1.tgz", + "integrity": "sha512-W2P2c/VRW1/1tLox0mVUalvnWXxavmv/Oum2aPsRcoDJuob75FC3Y8FbpfLwUegRcxINtGUMPq0tFCvYNTBXNA==" + }, + "node_modules/@emotion/unitless": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.1.tgz", + "integrity": "sha512-KOEGMu6dmJZtpadb476IsZBclKvILjopjUii3V+7MnXIQCYh8W3NgNcgwo21n9LXZX6EDIKvqfjYxXebDwxKmQ==" + }, + "node_modules/@esbuild/aix-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", + "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", + "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", + "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", + "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", + "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", + "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", + "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", + "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", + "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", + "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", + "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", + "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", + "cpu": [ + "loong64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", + "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", + "cpu": [ + "mips64el" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", + "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", + "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", + "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", + "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", + "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", + "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", + "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", + "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", + "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", + "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.11.1", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.1.tgz", + "integrity": "sha512-m4DVN9ZqskZoLU5GlWZadwDnYo3vAEydiUayB9widCl9ffWx2IvPnp6n3on5rJmziJSw9Bv+Z3ChDVdMwXCY8Q==", + "dev": true, + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/config-array": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.18.0.tgz", + "integrity": "sha512-fTxvnS1sRMu3+JjXwJG0j/i4RT9u4qJ+lqS/yCGap4lH4zZGzQ7tu+xZqQmcMZq5OBZDL4QRxQzRjkWcGt8IVw==", + "dev": true, + "dependencies": { + "@eslint/object-schema": "^2.1.4", + "debug": "^4.3.1", + "minimatch": "^3.1.2" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/core": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.6.0.tgz", + "integrity": "sha512-8I2Q8ykA4J0x0o7cg67FPVnehcqWTBehu/lmY+bolPFHGjh49YzGBMXTvpqVgEbBdvNCSxj6iFgiIyHzf03lzg==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz", + "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==", + "dev": true, + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^10.0.1", + "globals": "^14.0.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/eslintrc/node_modules/globals": { + "version": "14.0.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", + "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@eslint/js": { + "version": "9.12.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.12.0.tgz", + "integrity": "sha512-eohesHH8WFRUprDNyEREgqP6beG6htMeUYeCpkEgBCieCMme5r9zFWjzAJp//9S+Kub4rqE+jXe9Cp1a7IYIIA==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/object-schema": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz", + "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@eslint/plugin-kit": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.2.0.tgz", + "integrity": "sha512-vH9PiIMMwvhCx31Af3HiGzsVNULDbyVkHXwlemn/B0TFj/00ho3y55efXrUZTfQipxoHC5u4xq6zblww1zm1Ig==", + "dev": true, + "dependencies": { + "levn": "^0.4.1" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + } + }, + "node_modules/@humanfs/core": { + "version": "0.19.0", + "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.0.tgz", + "integrity": "sha512-2cbWIHbZVEweE853g8jymffCA+NCMiuqeECeBBLm8dg2oFdjuGJhgN4UAbI+6v0CKbbhvtXA4qV8YR5Ji86nmw==", + "dev": true, + "engines": { + "node": ">=18.18.0" + } + }, + "node_modules/@humanfs/node": { + "version": "0.16.5", + "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.5.tgz", + "integrity": "sha512-KSPA4umqSG4LHYRodq31VDwKAvaTF4xmVlzM8Aeh4PlU1JQ3IG0wiA8C25d3RQ9nJyM3mBHyI53K06VVL/oFFg==", + "dev": true, + "dependencies": { + "@humanfs/core": "^0.19.0", + "@humanwhocodes/retry": "^0.3.0" + }, + "engines": { + "node": ">=18.18.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/retry": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", + "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", + "dev": true, + "engines": { + "node": ">=18.18" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@remix-run/router": { + "version": "1.19.2", + "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.19.2.tgz", + "integrity": "sha512-baiMx18+IMuD1yyvOGaHM9QrVUPGGG0jC+z+IPHnRJWUAUvaKuWKyE8gjDj2rzv3sz9zOGoRSPgeBVHRhZnBlA==", + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.0.tgz", + "integrity": "sha512-Q6HJd7Y6xdB48x8ZNVDOqsbh2uByBhgK8PiQgPhwkIw/HC/YX5Ghq2mQY5sRMZWHb3VsFkWooUVOZHKr7DmDIA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.0.tgz", + "integrity": "sha512-ijLnS1qFId8xhKjT81uBHuuJp2lU4x2yxa4ctFPtG+MqEE6+C5f/+X/bStmxapgmwLwiL3ih122xv8kVARNAZA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.0.tgz", + "integrity": "sha512-bIv+X9xeSs1XCk6DVvkO+S/z8/2AMt/2lMqdQbMrmVpgFvXlmde9mLcbQpztXm1tajC3raFDqegsH18HQPMYtA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.0.tgz", + "integrity": "sha512-X6/nOwoFN7RT2svEQWUsW/5C/fYMBe4fnLK9DQk4SX4mgVBiTA9h64kjUYPvGQ0F/9xwJ5U5UfTbl6BEjaQdBQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.0.tgz", + "integrity": "sha512-0KXvIJQMOImLCVCz9uvvdPgfyWo93aHHp8ui3FrtOP57svqrF/roSSR5pjqL2hcMp0ljeGlU4q9o/rQaAQ3AYA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.0.tgz", + "integrity": "sha512-it2BW6kKFVh8xk/BnHfakEeoLPv8STIISekpoF+nBgWM4d55CZKc7T4Dx1pEbTnYm/xEKMgy1MNtYuoA8RFIWw==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.0.tgz", + "integrity": "sha512-i0xTLXjqap2eRfulFVlSnM5dEbTVque/3Pi4g2y7cxrs7+a9De42z4XxKLYJ7+OhE3IgxvfQM7vQc43bwTgPwA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.0.tgz", + "integrity": "sha512-9E6MKUJhDuDh604Qco5yP/3qn3y7SLXYuiC0Rpr89aMScS2UAmK1wHP2b7KAa1nSjWJc/f/Lc0Wl1L47qjiyQw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.0.tgz", + "integrity": "sha512-2XFFPJ2XMEiF5Zi2EBf4h73oR1V/lycirxZxHZNc93SqDN/IWhYYSYj8I9381ikUFXZrz2v7r2tOVk2NBwxrWw==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.0.tgz", + "integrity": "sha512-M3Dg4hlwuntUCdzU7KjYqbbd+BLq3JMAOhCKdBE3TcMGMZbKkDdJ5ivNdehOssMCIokNHFOsv7DO4rlEOfyKpg==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.0.tgz", + "integrity": "sha512-mjBaoo4ocxJppTorZVKWFpy1bfFj9FeCMJqzlMQGjpNPY9JwQi7OuS1axzNIk0nMX6jSgy6ZURDZ2w0QW6D56g==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.0.tgz", + "integrity": "sha512-ZXFk7M72R0YYFN5q13niV0B7G8/5dcQ9JDp8keJSfr3GoZeXEoMHP/HlvqROA3OMbMdfr19IjCeNAnPUG93b6A==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.0.tgz", + "integrity": "sha512-w1i+L7kAXZNdYl+vFvzSZy8Y1arS7vMgIy8wusXJzRrPyof5LAb02KGr1PD2EkRcl73kHulIID0M501lN+vobQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.0.tgz", + "integrity": "sha512-VXBrnPWgBpVDCVY6XF3LEW0pOU51KbaHhccHw6AS6vBWIC60eqsH19DAeeObl+g8nKAz04QFdl/Cefta0xQtUQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.0.tgz", + "integrity": "sha512-xrNcGDU0OxVcPTH/8n/ShH4UevZxKIO6HJFK0e15XItZP2UcaiLFd5kiX7hJnqCbSztUF8Qot+JWBC/QXRPYWQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.0.tgz", + "integrity": "sha512-fbMkAF7fufku0N2dE5TBXcNlg0pt0cJue4xBRE2Qc5Vqikxr4VCgKj/ht6SMdFcOacVA9rqF70APJ8RN/4vMJw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@types/babel__core": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", + "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.20.7", + "@babel/types": "^7.20.7", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "node_modules/@types/babel__generator": { + "version": "7.6.8", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", + "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__template": { + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", + "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "node_modules/@types/babel__traverse": { + "version": "7.20.6", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.6.tgz", + "integrity": "sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.20.7" + } + }, + "node_modules/@types/estree": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", + "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "dev": true + }, + "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 + }, + "node_modules/@types/prop-types": { + "version": "15.7.13", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.13.tgz", + "integrity": "sha512-hCZTSvwbzWGvhqxp/RqVqwU999pBf2vp7hzIjiYOsl8wqOmUxkQ6ddw1cV3l8811+kdUFus/q4d1Y3E3SyEifA==", + "dev": true + }, + "node_modules/@types/react": { + "version": "18.3.11", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.11.tgz", + "integrity": "sha512-r6QZ069rFTjrEYgFdOck1gK7FLVsgJE7tTz0pQBczlBNUhBNk0MQH4UbnFSwjpQLMkLzgqvBBa+qGpLje16eTQ==", + "dev": true, + "dependencies": { + "@types/prop-types": "*", + "csstype": "^3.0.2" + } + }, + "node_modules/@types/react-dom": { + "version": "18.3.0", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.0.tgz", + "integrity": "sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==", + "dev": true, + "dependencies": { + "@types/react": "*" + } + }, + "node_modules/@types/stylis": { + "version": "4.2.5", + "resolved": "https://registry.npmjs.org/@types/stylis/-/stylis-4.2.5.tgz", + "integrity": "sha512-1Xve+NMN7FWjY14vLoY5tL3BVEQ/n42YLwaqJIPYhotZ9uBHt87VceMwWQpzmdEt2TNXIorIFG+YeCUUW7RInw==" + }, + "node_modules/@vitejs/plugin-react": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-4.3.2.tgz", + "integrity": "sha512-hieu+o05v4glEBucTcKMK3dlES0OeJlD9YVOAPraVMOInBCwzumaIFiUjr4bHK7NPgnAHgiskUoceKercrN8vg==", + "dev": true, + "dependencies": { + "@babel/core": "^7.25.2", + "@babel/plugin-transform-react-jsx-self": "^7.24.7", + "@babel/plugin-transform-react-jsx-source": "^7.24.7", + "@types/babel__core": "^7.20.5", + "react-refresh": "^0.14.2" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "peerDependencies": { + "vite": "^4.2.0 || ^5.0.0" + } + }, + "node_modules/acorn": { + "version": "8.12.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", + "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", + "dev": true, + "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, + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-includes": { + "version": "3.1.8", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", + "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.findlast": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz", + "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flat": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", + "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", + "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.tosorted": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz", + "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "node_modules/available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "dependencies": { + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/axios": { + "version": "1.7.7", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.7.tgz", + "integrity": "sha512-S4kL7XrjgBmvdGut0sN3yJxqYzrDOnivkBiN0OFs6hLiUam3UPvswUo0kqGyhqUZGEOytHyumEdXsAkgCOUf3Q==", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/browserslist": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.0.tgz", + "integrity": "sha512-Rmb62sR1Zpjql25eSanFGEhAxcFwfA1K0GuQcLoaJBAcENegrQut3hYdhXFF1obQfiDyqIW/cLM5HSJ/9k884A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001663", + "electron-to-chromium": "^1.5.28", + "node-releases": "^2.0.18", + "update-browserslist-db": "^1.1.0" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/camelize": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/camelize/-/camelize-1.0.1.tgz", + "integrity": "sha512-dU+Tx2fsypxTgtLoE36npi3UqcjSSMNYfkqgmoEhtZrraP5VWq0K7FkWVTYa8eMPtnU/G2txVsfdCJTn9uzpuQ==", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001667", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001667.tgz", + "integrity": "sha512-7LTwJjcRkzKFmtqGsibMeuXmvFDfZq/nzIjnmgCGzKKRVzjD72selLDK1oPF/Oxzmt4fNcPvTDvGqSDG4tCALw==", + "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" + } + ] + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "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 + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/css-color-keywords": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/css-color-keywords/-/css-color-keywords-1.0.0.tgz", + "integrity": "sha512-FyyrDHZKEjXDpNJYvVsV960FiqQyXc/LlYmsxl2BcdMb2WPx0OGRVgTg55rPSyLSNMqP52R9r8geSp7apN3Ofg==", + "engines": { + "node": ">=4" + } + }, + "node_modules/css-to-react-native": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/css-to-react-native/-/css-to-react-native-3.2.0.tgz", + "integrity": "sha512-e8RKaLXMOFii+02mOlqwjbD00KSEKqblnpO9e++1aXS1fPQOpS1YoqdVHBqPjHNoxeF2mimzVqawm2KCbEdtHQ==", + "dependencies": { + "camelize": "^1.0.0", + "css-color-keywords": "^1.0.0", + "postcss-value-parser": "^4.0.2" + } + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==" + }, + "node_modules/data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/debug": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", + "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", + "dev": true, + "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 + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/electron-to-chromium": { + "version": "1.5.33", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.33.tgz", + "integrity": "sha512-+cYTcFB1QqD4j4LegwLfpCNxifb6dDFUAwk6RsLusCwIaZI6or2f+q8rs5tTB2YC53HhOlIbEaqHMAAC8IOIwA==", + "dev": true + }, + "node_modules/es-abstract": { + "version": "1.23.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", + "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.8", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.6", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-iterator-helpers": { + "version": "1.0.19", + "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz", + "integrity": "sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "iterator.prototype": "^1.1.2", + "safe-array-concat": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", + "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", + "dev": true, + "dependencies": { + "hasown": "^2.0.0" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/esbuild": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", + "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", + "dev": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/aix-ppc64": "0.21.5", + "@esbuild/android-arm": "0.21.5", + "@esbuild/android-arm64": "0.21.5", + "@esbuild/android-x64": "0.21.5", + "@esbuild/darwin-arm64": "0.21.5", + "@esbuild/darwin-x64": "0.21.5", + "@esbuild/freebsd-arm64": "0.21.5", + "@esbuild/freebsd-x64": "0.21.5", + "@esbuild/linux-arm": "0.21.5", + "@esbuild/linux-arm64": "0.21.5", + "@esbuild/linux-ia32": "0.21.5", + "@esbuild/linux-loong64": "0.21.5", + "@esbuild/linux-mips64el": "0.21.5", + "@esbuild/linux-ppc64": "0.21.5", + "@esbuild/linux-riscv64": "0.21.5", + "@esbuild/linux-s390x": "0.21.5", + "@esbuild/linux-x64": "0.21.5", + "@esbuild/netbsd-x64": "0.21.5", + "@esbuild/openbsd-x64": "0.21.5", + "@esbuild/sunos-x64": "0.21.5", + "@esbuild/win32-arm64": "0.21.5", + "@esbuild/win32-ia32": "0.21.5", + "@esbuild/win32-x64": "0.21.5" + } + }, + "node_modules/escalade": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint": { + "version": "9.12.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.12.0.tgz", + "integrity": "sha512-UVIOlTEWxwIopRL1wgSQYdnVDcEvs2wyaO6DGo5mXqe3r16IoCNWkR29iHhyaP4cICWjbgbmFUGAhh0GJRuGZw==", + "dev": true, + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.11.0", + "@eslint/config-array": "^0.18.0", + "@eslint/core": "^0.6.0", + "@eslint/eslintrc": "^3.1.0", + "@eslint/js": "9.12.0", + "@eslint/plugin-kit": "^0.2.0", + "@humanfs/node": "^0.16.5", + "@humanwhocodes/module-importer": "^1.0.1", + "@humanwhocodes/retry": "^0.3.1", + "@types/estree": "^1.0.6", + "@types/json-schema": "^7.0.15", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^8.1.0", + "eslint-visitor-keys": "^4.1.0", + "espree": "^10.2.0", + "esquery": "^1.5.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^8.0.0", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://eslint.org/donate" + }, + "peerDependencies": { + "jiti": "*" + }, + "peerDependenciesMeta": { + "jiti": { + "optional": true + } + } + }, + "node_modules/eslint-plugin-react": { + "version": "7.37.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.37.1.tgz", + "integrity": "sha512-xwTnwDqzbDRA8uJ7BMxPs/EXRB3i8ZfnOIp8BsxEQkT0nHPp+WWceqGgo6rKb9ctNi8GJLDT4Go5HAWELa/WMg==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.8", + "array.prototype.findlast": "^1.2.5", + "array.prototype.flatmap": "^1.3.2", + "array.prototype.tosorted": "^1.1.4", + "doctrine": "^2.1.0", + "es-iterator-helpers": "^1.0.19", + "estraverse": "^5.3.0", + "hasown": "^2.0.2", + "jsx-ast-utils": "^2.4.1 || ^3.0.0", + "minimatch": "^3.1.2", + "object.entries": "^1.1.8", + "object.fromentries": "^2.0.8", + "object.values": "^1.2.0", + "prop-types": "^15.8.1", + "resolve": "^2.0.0-next.5", + "semver": "^6.3.1", + "string.prototype.matchall": "^4.0.11", + "string.prototype.repeat": "^1.0.0" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8 || ^9.7" + } + }, + "node_modules/eslint-plugin-react-hooks": { + "version": "5.1.0-rc-fb9a90fa48-20240614", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-5.1.0-rc-fb9a90fa48-20240614.tgz", + "integrity": "sha512-xsiRwaDNF5wWNC4ZHLut+x/YcAxksUd9Rizt7LaEn3bV8VyYRpXnRJQlLOfYaVy9esk4DFP4zPPnoNVjq5Gc0w==", + "dev": true, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 || ^9.0.0" + } + }, + "node_modules/eslint-plugin-react-refresh": { + "version": "0.4.12", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-refresh/-/eslint-plugin-react-refresh-0.4.12.tgz", + "integrity": "sha512-9neVjoGv20FwYtCP6CB1dzR1vr57ZDNOXst21wd2xJ/cTlM2xLq0GWVlSNTdMn/4BtP6cHYBMCSp1wFBJ9jBsg==", + "dev": true, + "peerDependencies": { + "eslint": ">=7" + } + }, + "node_modules/eslint-scope": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.1.0.tgz", + "integrity": "sha512-14dSvlhaVhKKsa9Fx1l8A17s7ah7Ef7wCakJ10LYk6+GYmP9yDti2oq2SEwcyndt6knfcZyhyxwY3i9yL78EQw==", + "dev": true, + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.1.0.tgz", + "integrity": "sha512-Q7lok0mqMUSf5a/AdAZkA5a/gHcO6snwQClVNNvFKCAVlxXucdU8pKydU5ZVZjBx5xr37vGbFFWtLQYreLzrZg==", + "dev": true, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/eslint/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/eslint/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/eslint/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/eslint/node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/eslint/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/espree": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/espree/-/espree-10.2.0.tgz", + "integrity": "sha512-upbkBJbckcCNBDBDXEbuhjbP68n+scUd3k/U2EkyM9nw+I/jPiL4cLF/Al06CF96wRltFda16sxDFrxsI1v0/g==", + "dev": true, + "dependencies": { + "acorn": "^8.12.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^4.1.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esquery": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", + "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", + "dev": true, + "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, + "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, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "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 + }, + "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 + }, + "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 + }, + "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, + "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, + "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, + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.4" + }, + "engines": { + "node": ">=16" + } + }, + "node_modules/flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true + }, + "node_modules/follow-redirects": { + "version": "1.15.9", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", + "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/form-data": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", + "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/globals": { + "version": "15.10.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-15.10.0.tgz", + "integrity": "sha512-tqFIbz83w4Y5TCbtgjZjApohbuh7K9BxGYFm7ifwDR240tvdb7P9x+/9VvUKlmkPoiknoJtanI8UOrqxS3a7lQ==", + "dev": true, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/globalthis": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", + "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", + "dev": true, + "dependencies": { + "define-properties": "^1.2.1", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "dev": true, + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/ignore": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", + "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "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, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-async-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", + "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-core-module": { + "version": "2.15.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.15.1.tgz", + "integrity": "sha512-z0vtXSwucUJtANQWldhbtbt7BnL0vxiFjIdDLAatwhDYty2bad6s+rijD6Ri4YuYJubLzIJLUidCh09e1djEVQ==", + "dev": true, + "dependencies": { + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "dependencies": { + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-finalizationregistry": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", + "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-generator-function": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", + "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-map": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz", + "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-set": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz", + "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "dependencies": { + "which-typed-array": "^1.1.14" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakmap": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz", + "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakset": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz", + "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/iterator.prototype": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.2.tgz", + "integrity": "sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==", + "dev": true, + "dependencies": { + "define-properties": "^1.2.1", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "reflect.getprototypeof": "^1.0.4", + "set-function-name": "^2.0.1" + } + }, + "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==" + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsesc": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz", + "integrity": "sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==", + "dev": true, + "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 + }, + "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 + }, + "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 + }, + "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, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsx-ast-utils": { + "version": "3.3.5", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", + "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", + "dev": true, + "dependencies": { + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "object.assign": "^4.1.4", + "object.values": "^1.1.6" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "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, + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "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 + }, + "node_modules/node-releases": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.18.tgz", + "integrity": "sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==", + "dev": true + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.entries": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", + "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.fromentries": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", + "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.values": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", + "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "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, + "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, + "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, + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "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, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/picocolors": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz", + "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw==" + }, + "node_modules/possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/postcss": { + "version": "8.4.47", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", + "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.1.0", + "source-map-js": "^1.2.1" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==" + }, + "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, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/prop-types": { + "version": "15.8.1", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", + "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", + "dev": true, + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + }, + "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, + "engines": { + "node": ">=6" + } + }, + "node_modules/react": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", + "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", + "dependencies": { + "loose-envify": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-dom": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", + "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", + "dependencies": { + "loose-envify": "^1.1.0", + "scheduler": "^0.23.2" + }, + "peerDependencies": { + "react": "^18.3.1" + } + }, + "node_modules/react-icons": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/react-icons/-/react-icons-5.3.0.tgz", + "integrity": "sha512-DnUk8aFbTyQPSkCfF8dbX6kQjXA9DktMeJqfjrg6cK9vwQVMxmcA3BfP4QoiztVmEHtwlTgLFsPuH2NskKT6eg==", + "peerDependencies": { + "react": "*" + } + }, + "node_modules/react-is": { + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", + "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", + "dev": true + }, + "node_modules/react-refresh": { + "version": "0.14.2", + "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.14.2.tgz", + "integrity": "sha512-jCvmsr+1IUSMUyzOkRcvnVbX3ZYC6g9TDrDbFuFmRDq7PD4yaGbLKNQL6k2jnArV8hjYxh7hVhAZB6s9HDGpZA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-router": { + "version": "6.26.2", + "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.26.2.tgz", + "integrity": "sha512-tvN1iuT03kHgOFnLPfLJ8V95eijteveqdOSk+srqfePtQvqCExB8eHOYnlilbOcyJyKnYkr1vJvf7YqotAJu1A==", + "dependencies": { + "@remix-run/router": "1.19.2" + }, + "engines": { + "node": ">=14.0.0" + }, + "peerDependencies": { + "react": ">=16.8" + } + }, + "node_modules/react-router-dom": { + "version": "6.26.2", + "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.26.2.tgz", + "integrity": "sha512-z7YkaEW0Dy35T3/QKPYB1LjMK2R1fxnHO8kWpUMTBdfVzZrWOiY9a7CtN8HqdWtDUWd5FY6Dl8HFsqVwH4uOtQ==", + "dependencies": { + "@remix-run/router": "1.19.2", + "react-router": "6.26.2" + }, + "engines": { + "node": ">=14.0.0" + }, + "peerDependencies": { + "react": ">=16.8", + "react-dom": ">=16.8" + } + }, + "node_modules/reflect.getprototypeof": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz", + "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.1", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "which-builtin-type": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.3.tgz", + "integrity": "sha512-vqlC04+RQoFalODCbCumG2xIOvapzVMHwsyIGM/SIE8fRhFFsXeH8/QQ+s0T0kDAhKc4k30s73/0ydkHQz6HlQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve": { + "version": "2.0.0-next.5", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", + "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", + "dev": true, + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/rollup": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.24.0.tgz", + "integrity": "sha512-DOmrlGSXNk1DM0ljiQA+i+o0rSLhtii1je5wgk60j49d1jHT5YYttBv1iWOnYSTG+fZZESUOSNiAl89SIet+Cg==", + "dev": true, + "dependencies": { + "@types/estree": "1.0.6" + }, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=18.0.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.24.0", + "@rollup/rollup-android-arm64": "4.24.0", + "@rollup/rollup-darwin-arm64": "4.24.0", + "@rollup/rollup-darwin-x64": "4.24.0", + "@rollup/rollup-linux-arm-gnueabihf": "4.24.0", + "@rollup/rollup-linux-arm-musleabihf": "4.24.0", + "@rollup/rollup-linux-arm64-gnu": "4.24.0", + "@rollup/rollup-linux-arm64-musl": "4.24.0", + "@rollup/rollup-linux-powerpc64le-gnu": "4.24.0", + "@rollup/rollup-linux-riscv64-gnu": "4.24.0", + "@rollup/rollup-linux-s390x-gnu": "4.24.0", + "@rollup/rollup-linux-x64-gnu": "4.24.0", + "@rollup/rollup-linux-x64-musl": "4.24.0", + "@rollup/rollup-win32-arm64-msvc": "4.24.0", + "@rollup/rollup-win32-ia32-msvc": "4.24.0", + "@rollup/rollup-win32-x64-msvc": "4.24.0", + "fsevents": "~2.3.2" + } + }, + "node_modules/safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/scheduler": { + "version": "0.23.2", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", + "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", + "dependencies": { + "loose-envify": "^1.1.0" + } + }, + "node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/shallowequal": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/shallowequal/-/shallowequal-1.1.0.tgz", + "integrity": "sha512-y0m1JoUZSlPAjXVtPPW70aZWfIL/dSP7AFkRnniLCrK/8MDKog3TySTBmckD+RObVxH0v4Tox67+F14PdED2oQ==" + }, + "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, + "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, + "engines": { + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/source-map-js": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/string.prototype.matchall": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz", + "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "regexp.prototype.flags": "^1.5.2", + "set-function-name": "^2.0.2", + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.repeat": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/string.prototype.repeat/-/string.prototype.repeat-1.0.0.tgz", + "integrity": "sha512-0u/TldDbKD8bFCQ/4f5+mNRrXwZ8hg2w7ZR8wa16e8z9XpePWl3eGEcUD0OXpEH/VJH/2G3gjUtR3ZOiBe2S/w==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.5" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", + "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/styled-components": { + "version": "6.1.13", + "resolved": "https://registry.npmjs.org/styled-components/-/styled-components-6.1.13.tgz", + "integrity": "sha512-M0+N2xSnAtwcVAQeFEsGWFFxXDftHUD7XrKla06QbpUMmbmtFBMMTcKWvFXtWxuD5qQkB8iU5gk6QASlx2ZRMw==", + "dependencies": { + "@emotion/is-prop-valid": "1.2.2", + "@emotion/unitless": "0.8.1", + "@types/stylis": "4.2.5", + "css-to-react-native": "3.2.0", + "csstype": "3.1.3", + "postcss": "8.4.38", + "shallowequal": "1.1.0", + "stylis": "4.3.2", + "tslib": "2.6.2" + }, + "engines": { + "node": ">= 16" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/styled-components" + }, + "peerDependencies": { + "react": ">= 16.8.0", + "react-dom": ">= 16.8.0" + } + }, + "node_modules/styled-components/node_modules/postcss": { + "version": "8.4.38", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", + "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "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" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/stylis": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.3.2.tgz", + "integrity": "sha512-bhtUjWd/z6ltJiQwg0dUfxEJ+W+jdqQd8TbWLWyeIJHlnsqmGLRFFd8e5mA0AZi/zx90smXRlN66YMTcaSFifg==" + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/tslib": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" + }, + "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, + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", + "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz", + "integrity": "sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "escalade": "^3.2.0", + "picocolors": "^1.1.0" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/vite": { + "version": "5.4.8", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.8.tgz", + "integrity": "sha512-FqrItQ4DT1NC4zCUqMB4c4AZORMKIa0m8/URVCZ77OZ/QSNeJ54bU1vrFADbDsuwfIPcgknRkmqakQcgnL4GiQ==", + "dev": true, + "dependencies": { + "esbuild": "^0.21.3", + "postcss": "^8.4.43", + "rollup": "^4.20.0" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^18.0.0 || >=20.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.3" + }, + "peerDependencies": { + "@types/node": "^18.0.0 || >=20.0.0", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "sass-embedded": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.4.0" + }, + "peerDependenciesMeta": { + "@types/node": { + "optional": true + }, + "less": { + "optional": true + }, + "lightningcss": { + "optional": true + }, + "sass": { + "optional": true + }, + "sass-embedded": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "terser": { + "optional": true + } + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-builtin-type": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.4.tgz", + "integrity": "sha512-bppkmBSsHFmIMSl8BO9TbsyzsvGjVoppt8xUiGzwiu/bhDCGxnpOKCxgqj6GuyHE0mINMDecBFPlOm2hzY084w==", + "dev": true, + "dependencies": { + "function.prototype.name": "^1.1.6", + "has-tostringtag": "^1.0.2", + "is-async-function": "^2.0.0", + "is-date-object": "^1.0.5", + "is-finalizationregistry": "^1.0.2", + "is-generator-function": "^1.0.10", + "is-regex": "^1.1.4", + "is-weakref": "^1.0.2", + "isarray": "^2.0.5", + "which-boxed-primitive": "^1.0.2", + "which-collection": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-collection": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz", + "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==", + "dev": true, + "dependencies": { + "is-map": "^2.0.3", + "is-set": "^2.0.3", + "is-weakmap": "^2.0.2", + "is-weakset": "^2.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "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 + }, + "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, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/mission/chapter04/mission/package.json b/mission/chapter04/mission/package.json new file mode 100644 index 0000000..21bc4e2 --- /dev/null +++ b/mission/chapter04/mission/package.json @@ -0,0 +1,32 @@ +{ + "name": "mission", + "private": true, + "version": "0.0.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build", + "lint": "eslint .", + "preview": "vite preview" + }, + "dependencies": { + "axios": "^1.7.7", + "react": "^18.3.1", + "react-dom": "^18.3.1", + "react-icons": "^5.3.0", + "react-router-dom": "^6.26.2", + "styled-components": "^6.1.13" + }, + "devDependencies": { + "@eslint/js": "^9.9.0", + "@types/react": "^18.3.3", + "@types/react-dom": "^18.3.0", + "@vitejs/plugin-react": "^4.3.1", + "eslint": "^9.9.0", + "eslint-plugin-react": "^7.35.0", + "eslint-plugin-react-hooks": "^5.1.0-rc.0", + "eslint-plugin-react-refresh": "^0.4.9", + "globals": "^15.9.0", + "vite": "^5.4.1" + } +} diff --git a/mission/chapter04/mission/public/vite.svg b/mission/chapter04/mission/public/vite.svg new file mode 100644 index 0000000..e7b8dfb --- /dev/null +++ b/mission/chapter04/mission/public/vite.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/mission/chapter04/mission/src/App.jsx b/mission/chapter04/mission/src/App.jsx new file mode 100644 index 0000000..2a756fd --- /dev/null +++ b/mission/chapter04/mission/src/App.jsx @@ -0,0 +1,35 @@ +import { BrowserRouter as Router, Routes, Route } from 'react-router-dom'; +import RootLayout from './rootlayout.jsx'; +import MoviesPage from './components/MoviesPage.jsx'; +import LoginPage from './components/loginpage.jsx'; +import SignupPage from './components/signuppage.jsx'; +import SearchPage from './components/searchpage.jsx'; +import Cartegorypage from './components/categorypage.jsx'; +import NowPlaying from './components/category/nowplaying.jsx'; +import Popular from './components/category/popular.jsx'; +import TopRated from './components/category/toprated.jsx'; +import UpComing from './components/category/upcoming.jsx'; +import MovieIdPage from './components/movieidpage.jsx'; + +const App = () => { + return ( + + + }> + } /> + } /> + } /> + } /> + } /> + } /> + } /> + } /> + } /> + } /> + + + + ); +}; + +export default App; diff --git a/mission/chapter04/mission/src/apis/axios-instance.js b/mission/chapter04/mission/src/apis/axios-instance.js new file mode 100644 index 0000000..a66ec38 --- /dev/null +++ b/mission/chapter04/mission/src/apis/axios-instance.js @@ -0,0 +1,10 @@ +import axios from "axios"; + +const axiosInstance = axios.create({ + headers: { + Authorization: `Bearer ${import.meta.env.VITE_TMDB_ACCESS_TOKEN}` + }, + baseURL: import.meta.env.VITE_MOVIE_API_URL, +}); + +export {axiosInstance}; \ No newline at end of file diff --git a/mission/chapter04/mission/src/assets/react.svg b/mission/chapter04/mission/src/assets/react.svg new file mode 100644 index 0000000..6c87de9 --- /dev/null +++ b/mission/chapter04/mission/src/assets/react.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/mission/chapter04/mission/src/components/Card.jsx b/mission/chapter04/mission/src/components/Card.jsx new file mode 100644 index 0000000..7480f13 --- /dev/null +++ b/mission/chapter04/mission/src/components/Card.jsx @@ -0,0 +1,68 @@ +// Card.jsx +import PropTypes from 'prop-types'; +import styled from 'styled-components'; +import { useNavigate } from 'react-router-dom'; + +const CardContainer = styled.div` + position: relative; + width: 150px; + margin-bottom: 20px; + cursor: pointer; + text-align: center; + color: black; +`; + +const CardImage = styled.img` + width: 100%; + height: 200px; + border-radius: 5%; +`; + +const CardContent = styled.div` + margin-top: 5px; + color: white; +`; + +const Title = styled.h4` + font-size: 12px; + margin: 2px 0; +`; + +const ReleaseDate = styled.p` + font-size: 11px; + margin: 0px; +`; + +const Card = ({ movie, handleClicked }) => { + const navigate = useNavigate(); + + const handleCardClick = () => { + handleClicked(movie.id); + navigate(`/movies/${movie.id}`); + }; + + return ( + + + + {movie.title} + {new Date(movie.release_date).toLocaleDateString('ko-KR')} + + + ); +}; + +Card.propTypes = { + movie: PropTypes.shape({ + id: PropTypes.number.isRequired, + poster_path: PropTypes.string.isRequired, + title: PropTypes.string, + release_date: PropTypes.string.isRequired, + }).isRequired, + handleClicked: PropTypes.func.isRequired, +}; + +export default Card; diff --git a/mission/chapter04/mission/src/components/MoviesPage.jsx b/mission/chapter04/mission/src/components/MoviesPage.jsx new file mode 100644 index 0000000..25fb73d --- /dev/null +++ b/mission/chapter04/mission/src/components/MoviesPage.jsx @@ -0,0 +1,41 @@ +import { useState } from "react"; +import Card from "../components/Card.jsx"; +import * as S from '../styles/movies.style.jsx'; +import useCustomFetch from "../hooks/useCustomFetch.js"; + +const MoviesPage = () => { + const [clickedMovie, setClickedMovie] = useState(null); + + const handleClicked = (movieId) => { + setClickedMovie(movieId); + }; + + const { data: movies, isLoading, isError } = useCustomFetch(`/movie/popular?language=ko-KR&page=1`); + + if (isLoading) { + return
+

loading...

+
; + } + + if (isError) { + return
+

Error...

+
; + } + + return ( + + {Array.isArray(movies) && movies.map((movie) => ( + + ))} + + ); +}; + +export default MoviesPage; diff --git a/mission/chapter04/mission/src/components/category/nowplaying.jsx b/mission/chapter04/mission/src/components/category/nowplaying.jsx new file mode 100644 index 0000000..3186d95 --- /dev/null +++ b/mission/chapter04/mission/src/components/category/nowplaying.jsx @@ -0,0 +1,37 @@ +import { useState } from "react"; +import Card from "../Card.jsx"; +import * as S from '../../styles/movies.style.jsx'; +import useCustomFetch from "../../hooks/useCustomFetch.js"; + +const Nowplaying = () => { + const [clickedMovie, setClickedMovie] = useState(null); + + const handleClicked = (movieId) => { + setClickedMovie(movieId); + }; + + const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc&with_release_type=2|3&release_date.gte={min_date}&release_date.lte={max_date}`); + + if (isLoading) { + return

๋กœ๋”ฉ์ค‘ ์ž…๋‹ˆ๋‹ค...

; + } + + if (isError) { + return

์—๋Ÿฌ ๋ฐœ์ƒ

; + } + + return ( + + {Array.isArray(movies) && movies.map((movie) => ( + + ))} + + ); +}; + +export default Nowplaying; diff --git a/mission/chapter04/mission/src/components/category/popular.jsx b/mission/chapter04/mission/src/components/category/popular.jsx new file mode 100644 index 0000000..0c96717 --- /dev/null +++ b/mission/chapter04/mission/src/components/category/popular.jsx @@ -0,0 +1,42 @@ +import { useState } from "react"; +import Card from "../Card.jsx"; +import * as S from '../../styles/movies.style.jsx'; +import useCustomFetch from "../../hooks/useCustomFetch.js"; + +const Popular = () => { + const [clickedMovie, setClickedMovie] = useState(null); + + const handleClicked = (movieId) => { + setClickedMovie(movieId); + }; + + + const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc`); + + if (isLoading) { + return
+

loading...

+
; + } + + if (isError) { + return
+

Error...

+
; + } + + return ( + + {Array.isArray(movies) && movies.map((movie) => ( + + ))} + + ); +}; + +export default Popular; \ No newline at end of file diff --git a/mission/chapter04/mission/src/components/category/toprated.jsx b/mission/chapter04/mission/src/components/category/toprated.jsx new file mode 100644 index 0000000..a99925a --- /dev/null +++ b/mission/chapter04/mission/src/components/category/toprated.jsx @@ -0,0 +1,41 @@ +import { useState } from "react"; +import Card from "../Card.jsx"; +import * as S from '../../styles/movies.style.jsx'; +import useCustomFetch from "../../hooks/useCustomFetch.js"; + +const Toprated = () => { + const [clickedMovie, setClickedMovie] = useState(null); + + const handleClicked = (movieId) => { + setClickedMovie(movieId); + }; + + const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=vote_average.desc&without_genres=99,10755&vote_count.gte=200`); + + if (isLoading) { + return
+

loading...

+
; + } + + if (isError) { + return
+

Error...

+
; + } + + return ( + + {Array.isArray(movies) && movies.map((movie) => ( + + ))} + + ); +}; + +export default Toprated; \ No newline at end of file diff --git a/mission/chapter04/mission/src/components/category/upcoming.jsx b/mission/chapter04/mission/src/components/category/upcoming.jsx new file mode 100644 index 0000000..8afd588 --- /dev/null +++ b/mission/chapter04/mission/src/components/category/upcoming.jsx @@ -0,0 +1,41 @@ +import { useState } from "react"; +import Card from "../Card.jsx"; +import * as S from '../../styles/movies.style.jsx'; +import useCustomFetch from "../../hooks/useCustomFetch.js"; + +const Upcoming = () => { + const [clickedMovie, setClickedMovie] = useState(null); + + const handleClicked = (movieId) => { + setClickedMovie(movieId); + }; + + const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc&with_release_type=2|3&release_date.gte={min_date}&release_date.lte={max_date}`); + + if (isLoading) { + return
+

loading...

+
; + } + + if (isError) { + return
+

Error...

+
; + } + + return ( + + {Array.isArray(movies) && movies.map((movie) => ( + + ))} + + ); +}; + +export default Upcoming; \ No newline at end of file diff --git a/mission/chapter04/mission/src/components/categorypage.jsx b/mission/chapter04/mission/src/components/categorypage.jsx new file mode 100644 index 0000000..815248e --- /dev/null +++ b/mission/chapter04/mission/src/components/categorypage.jsx @@ -0,0 +1,40 @@ +import * as S from '../styles/category.style.jsx'; +import { useNavigate } from 'react-router-dom'; +import nowPlayingImg from '../img/blue.jpg' +import popularImg from '../img/green.jpg'; +import topRatedImg from '../img/purple.jpg'; +import upcomingImg from '../img/yellow.jpg'; + +const categories = [ + { id: 1, title: "ํ˜„์žฌ ์ƒ์˜์ค‘์ธ", image: nowPlayingImg, path: "/movies/now-playing" }, + { id: 2, title: "์ธ๊ธฐ์žˆ๋Š”", image: popularImg, path: "/movies/popular" }, + { id: 3, title: "๋†’์€ ํ‰๊ฐ€๋ฅผ ๋ฐ›์€", image: topRatedImg, path: "/movies/top-rated" }, + { id: 4, title: "๊ฐœ๋ด‰ ์˜ˆ์ •์ค‘์ธ", image: upcomingImg, path: "/movies/up-coming" } +]; + +const CategoryPage = () => { + const navigate = useNavigate(); + + const handleCategoryClick = (path) => { + navigate(path); + }; + + return ( + +

์นดํ…Œ๊ณ ๋ฆฌ

+ + {categories.map((category) => ( + handleCategoryClick(category.path)} + > + {category.title} + + ))} + +
+ ); +}; + +export default CategoryPage; diff --git a/mission/chapter04/mission/src/components/loginpage.jsx b/mission/chapter04/mission/src/components/loginpage.jsx new file mode 100644 index 0000000..c6b7cdb --- /dev/null +++ b/mission/chapter04/mission/src/components/loginpage.jsx @@ -0,0 +1,20 @@ +import styled from 'styled-components'; + +const LoginPage = () => { + return ( + +

๋กœ๊ทธ์ธ ํŽ˜์ด์ง€

+
+ ); +}; + +export default LoginPage; + +const Content = styled.div` + flex: 1; + display: flex; + justify-content: left; + align-items: center; + font-size: 20px; + color: white; +`; diff --git a/mission/chapter04/mission/src/components/movieidpage.jsx b/mission/chapter04/mission/src/components/movieidpage.jsx new file mode 100644 index 0000000..1b97677 --- /dev/null +++ b/mission/chapter04/mission/src/components/movieidpage.jsx @@ -0,0 +1,146 @@ +// MovieIdPage.jsx +import { useParams } from 'react-router-dom'; +import styled from 'styled-components'; +import useCustomFetch from "../hooks/useCustomFetch.js"; + +const MovieDetailContainer = styled.div` + color: white; + padding: 20px; +`; + +const HeaderContainer = styled.div` + display: flex; + align-items: center; + gap: 20px; + background-image: url(${props => props.backdrop}); + background-size: cover; + background-position: center; + padding: 40px; + border-radius: 10px; + filter: brightness(80%); +`; + +const MovieInfo = styled.div` + display: flex; + flex-direction: column; +`; + +const MovieTitle = styled.h1` + font-size: 36px; + margin: 0; +`; + +const MovieDetails = styled.p` + margin: 5px 0; + font-size: 16px; +`; + +const MovieOverview = styled.p` + margin-top: 15px; + line-height: 1.5; +`; + +const CastContainer = styled.div` + margin-top: 40px; +`; + +const CastTitle = styled.h2` + font-size: 24px; + margin-bottom: 20px; +`; + +const CastList = styled.div` + display: flex; + flex-wrap: wrap; + gap: 15px; +`; + +const CastItem = styled.div` + display: flex; + flex-direction: column; + align-items: center; + width: 100px; +`; + +const CastImage = styled.img` + width: 100px; + height: 100px; + border-radius: 50%; + object-fit: cover; + margin-bottom: 10px; +`; + +const CastName = styled.p` + font-size: 14px; + margin: 0; + text-align: center; +`; + +const CastCharacter = styled.p` + font-size: 12px; + color: #aaa; + margin: 0; + text-align: center; +`; + +const MovieIdPage = () => { + const { movieId } = useParams(); + console.log('Movie Id:', movieId); + const { data: movie, isLoading, isError } = useCustomFetch(`/movie/${movieId}?language=ko-KR`); + console.log('Movie data:', movie); + const { data: movie_credits, isLoading_credits, isError_credits } = useCustomFetch(`/movie/${movieId}/credits?language=ko-KR`); + console.log('Movie credits:', movie_credits); + + if (isLoading || isLoading_credits) { + return

loading...

; + } + + if (isError || isError_credits) { + return

Error...

; + } + + if (!movie || Object.keys(movie).length === 0) { + return

No movie data found

; + } + + return ( + + + + {movie.title || movie.original_title} + โญ{movie.vote_average} + {new Date(movie.release_date).getFullYear()} + ์ƒ์˜ ์‹œ๊ฐ„: {movie.runtime}๋ถ„ + {movie.overview} + + + + + ๊ฐ๋…/์ถœ์—ฐ + {movie_credits && movie_credits.cast ? ( + + {movie_credits.cast.slice(0, 12).map((castMember) => ( + + + {castMember.name} + ({castMember.character}) + + ))} + + ) : ( +

์ถœ์—ฐ์ง„ ์ •๋ณด๊ฐ€ ์—†์Šต๋‹ˆ๋‹ค.

+ )} +
+ +
+ ); +}; + +export default MovieIdPage; diff --git a/mission/chapter04/mission/src/components/navbar.jsx b/mission/chapter04/mission/src/components/navbar.jsx new file mode 100644 index 0000000..ffa133b --- /dev/null +++ b/mission/chapter04/mission/src/components/navbar.jsx @@ -0,0 +1,30 @@ +import * as S from '../styles/navbar.style.jsx'; +import { useNavigate } from 'react-router-dom'; + +const Navbar = () => { + const navigate = useNavigate(); + + const handleBrandClick = () => { + navigate('/'); + }; + + const handleLoginClick = () => { + navigate('/login'); + }; + + const handleSignupClick = () => { + navigate('/signup'); + }; + + return ( + + YONGCHA + + ๋กœ๊ทธ์ธ + ํšŒ์›๊ฐ€์ž… + + + ); +}; + +export default Navbar; diff --git a/mission/chapter04/mission/src/components/searchpage.jsx b/mission/chapter04/mission/src/components/searchpage.jsx new file mode 100644 index 0000000..c93cbbd --- /dev/null +++ b/mission/chapter04/mission/src/components/searchpage.jsx @@ -0,0 +1,20 @@ +import styled from 'styled-components'; + +const SearchPage = () => { + return ( + +

๊ฒ€์ƒ‰ ํŽ˜์ด์ง€

+
+ ); +}; + +export default SearchPage; + +const Content = styled.div` + flex: 1; + display: flex; + justify-content: left; + align-items: center; + font-size: 20px; + color: white; +`; diff --git a/mission/chapter04/mission/src/components/sidebar.jsx b/mission/chapter04/mission/src/components/sidebar.jsx new file mode 100644 index 0000000..3cfe3d4 --- /dev/null +++ b/mission/chapter04/mission/src/components/sidebar.jsx @@ -0,0 +1,31 @@ +import * as S from '../styles/sidebar.style.jsx'; +import { IoIosSearch } from "react-icons/io"; +import { BiSolidMovie } from "react-icons/bi"; +import { useNavigate } from 'react-router-dom'; + +const Sidebar = () => { + const navigate = useNavigate(); + + const handleSearchClick = () => { + navigate('/search'); + }; + + const handleCategoryClick = () => { + navigate('/category'); + }; + + return ( + +
    +
  • + ๊ฒ€์ƒ‰ +
  • +
  • + ์˜ํ™” +
  • +
+
+ ); +}; + +export default Sidebar; diff --git a/mission/chapter04/mission/src/components/signuppage.jsx b/mission/chapter04/mission/src/components/signuppage.jsx new file mode 100644 index 0000000..197f980 --- /dev/null +++ b/mission/chapter04/mission/src/components/signuppage.jsx @@ -0,0 +1,20 @@ +import styled from 'styled-components'; + +const SignupPage = () => { + return ( + +

ํšŒ์›๊ฐ€์ž… ํŽ˜์ด์ง€

+
+ ); +}; + +export default SignupPage; + +const Content = styled.div` + flex: 1; + display: flex; + justify-content: left; + align-items: center; + font-size: 20px; + color: white; +`; diff --git a/mission/chapter04/mission/src/hooks/useCustomFetch.js b/mission/chapter04/mission/src/hooks/useCustomFetch.js new file mode 100644 index 0000000..b230809 --- /dev/null +++ b/mission/chapter04/mission/src/hooks/useCustomFetch.js @@ -0,0 +1,37 @@ +import { useEffect, useState } from "react"; +import { axiosInstance } from "../apis/axios-instance.js"; + +const useCustomFetch = (url) => { + const [data, setData] = useState(null); + const [isLoading, setIsLoading] = useState(false); + const [isError, setIsError] = useState(false); + + useEffect(() => { + const fetchData = async () => { + setIsLoading(true); + setIsError(false); + try { + console.log("Fetching data from:", url); + const response = await axiosInstance.get(url); + console.log("Full API Response:", response); + console.log("Response Data:", response.data); + + if (response.data.results) { + setData(response.data.results); + } else { + setData(response.data); + } + } catch (error) { + console.error("Error fetching data:", error); + setIsError(true); + } finally { + setIsLoading(false); + } + }; + fetchData(); + }, [url]); + + return { data, isLoading, isError }; +}; + +export default useCustomFetch; diff --git a/mission/chapter04/mission/src/img/blue.jpg b/mission/chapter04/mission/src/img/blue.jpg new file mode 100644 index 0000000000000000000000000000000000000000..704d2c8e8126b14f772c2e2e82054ce82626e335 GIT binary patch literal 1609 zcmeH{%}N6?5XWbd=A)r#Lf5peN>@v3wpeJPSJ{J5{CF!b9`zA?1fM~C2tO`;lbF{>)7N{22f4SDblgX?%&~G!AQI$3yNnz z3{r#s4Gu!9P!1Na;|I#Y{3moM0?||h;Pd3J{N9`z2YwwW0z-+eBJ>gvk^wAaWd0Zx zrmA>aD=1=ti*=3~1=%WUtMFn|rB;E(Y3O5vHPFz#mf3x?8wdV$AkIZoos07=vU>cm R1L}yZ{(*W2kU9YQ@eS9i$OHfY literal 0 HcmV?d00001 diff --git a/mission/chapter04/mission/src/img/green.jpg b/mission/chapter04/mission/src/img/green.jpg new file mode 100644 index 0000000000000000000000000000000000000000..6734ea68bcff37f8680cb596978d0c1d17e872c8 GIT binary patch literal 1605 zcmeH_-AcnS7>2(uX_GVzOh>n_2%?ayaw?i{5kPXvSbux#dYkw zZ;p~YBp)x2{jfivo|?x75D^~S0{ad3z=Dv40b?QKoC&F!RPSgGf3~fwtDH&yAKd& zWkI^o6>k+f$tA;=%w+!Gulxq+VSYacM1(tD;NRgEWEjaPlroY^$yk%tt(HzZ-8S{p z!JwZSV~3NGJsF=GlU--yi_82fKORkIQ#YHq+?9`@QcB0Vr*+R+W8I&_zd{mYhF;(~ z1PO`+{Q{1-RoD*6X~Q3=up3ENjeSV-!%g zB$7Ju^i2rF0;y;qf*)dM6YyWE+ZR={BuV*=niHiiH;XTK1t()Nd2?Cw%uC#EStqL_{}4zl+uarYTfnDI)8A5S4b0FvIWOWU@7tx z!yEL7Dr}dcv84~x=3InN=x_vPxB%+xFdFJz&FjD>>DA2*1! zj(GY-aKsW9Wdnl!BX(|)Wwm7|0?P~HQP~ + + , +) diff --git a/mission/chapter04/mission/src/mocks/movies.js b/mission/chapter04/mission/src/mocks/movies.js new file mode 100644 index 0000000..e8add22 --- /dev/null +++ b/mission/chapter04/mission/src/mocks/movies.js @@ -0,0 +1,399 @@ +export const MOVIES = { + "dates": { + "maximum": "2023-09-17", + "minimum": "2023-07-31" + }, + "page": 1, + "results": [ + { + "adult": false, + "backdrop_path": "/8pjWz2lt29KyVGoq1mXYu6Br7dE.jpg", + "genre_ids": [ + 28, + 878, + 27 + ], + "id": 615656, + "original_language": "en", + "original_title": "Meg 2: The Trench", + "overview": "์ „ ์„ธ๊ณ„์—์„œ ๊ฐ€์žฅ ๊นŠ์€ ๋งˆ๋ฆฌ์•„๋‚˜ ํ•ด๊ตฌ, ์—ญ์‚ฌ์ƒ ๊ฐ€์žฅ ๊ฑฐ๋Œ€ํ•˜๊ณ  ๋ฌด์ž๋น„ํ•œ ํฌ์‹์ž๊ฐ€ ๋„์‚ฌ๋ฆฌ๋Š” ๊ทธ๊ณณ์—์„œ ๊ฐ•์ฒ  ๋‹ค์ด๋ฒ„ โ€˜์กฐ๋‚˜์Šคโ€™(์ œ์ด์Šจ ์Šคํƒ€๋Ž€)๊ฐ€ ๋” ๋งน๋ ฌํ•˜๊ฒŒ ๋Œ์•„์˜จ โ€˜๋ฉ”๊ฐ€๋กœ๋ˆโ€™๊ณผ ์งœ๋ฆฟํ•œ ๋Œ€๊ฒฐ์„ ํŽผ์น˜๋Š” ์•ก์…˜ ์–ด๋“œ๋ฒค์ฒ˜", + "popularity": 2429.447, + "poster_path": "/cbAHK6Vrt0GClMRUxH8TsgC2JqL.jpg", + "release_date": "2023-08-15", + "title": "๋ฉ”๊ฐ€๋กœ๋ˆ 2", + "video": false, + "vote_average": 7, + "vote_count": 1790 + }, + { + "adult": false, + "backdrop_path": "/w2nFc2Rsm93PDkvjY4LTn17ePO0.jpg", + "genre_ids": [ + 16, + 35, + 28 + ], + "id": 614930, + "original_language": "en", + "original_title": "Teenage Mutant Ninja Turtles: Mutant Mayhem", + "overview": "๋‰ด์š•์˜ ํ•˜์ˆ˜๊ตฌ๋กœ ์Šค๋ฉฐ๋“  ๋ฏธ์Šคํ„ฐ๋ฆฌํ•œ ๋…น์ƒ‰ ์•ก์ฒด, โ€˜์šฐ์ฆˆโ€™๋กœ ์ธํ•ด ์•„๊ธฐ ๊ฑฐ๋ถ์ด ๋„ค ๋งˆ๋ฆฌ์™€ ์ฒญ๋…„ ์ฅ ์Šคํ”Œ๋ฆฐํ„ฐ๋Š” ์‚ฌ๋žŒ๊ณผ ๋น„์Šทํ•œ ๋ชจ์Šต์˜ ๋Œ์—ฐ๋ณ€์ด๊ฐ€ ๋œ๋‹ค. 15๋…„ ํ›„, 10๋Œ€ ์ฒญ์†Œ๋…„์ด ๋œ ๋ ˆ์˜ค๋‚˜๋ฅด๋„, ๋ฏธ์ผˆ๋ž€์ ค๋กœ, ๋ผํŒŒ์—˜, ๋„๋‚˜ํ…”๋กœ๋Š” ํ•˜์ˆ˜๊ตฌ์— ์ˆจ์–ด ์‚ฌ๋Š” ์ƒํ™œ์—์„œ ๋ฒ—์–ด๋‚˜ ์ธ๊ฐ„ ์„ธ์ƒ์—์„œ ํ‰๋ฒ”ํ•œ ์‚ถ์„ ์‚ด๊ณ  ์‹ถ์–ดํ•˜๊ณ  ์šฐ์—ฐํžˆ ๋งŒ๋‚œ ํ•™์ƒ ๊ธฐ์ž ์—์ดํ”„๋ฆด๊ณผ ํ•จ๊ป˜ ๋„์‹œ๋ฅผ ์œ„ํ˜‘ํ•˜๋Š” '์Šˆํผํ”Œ๋ผ์ด'์™€ ๊ทธ ์ผ๋‹น์„ ๋ฌผ๋ฆฌ์น˜๋ฉด ๋‰ด์š•์˜ ํžˆ์–ด๋กœ๊ฐ€ ๋˜์–ด ๋‹น๋‹นํžˆ ์„ธ์ƒ์— ๋‚˜๊ฐˆ ์ˆ˜ ์žˆ์„ ๊ฑฐ๋ผ๋Š” ๊ฟˆ์„ ๊พธ๋Š”๋ฐโ€ฆ ์ธ๊ฐ„๋“ค์„ ๋ชจ๋‘ ๋Œ์—ฐ๋ณ€์ด๋กœ ๋งŒ๋“ค๊ฒ ๋‹ค๋Š” โ€˜์Šˆํผํ”Œ๋ผ์ดโ€™์˜ ์Œ๋ชจ๋กœ ์œ„ํ—˜์— ๋น ์ง„ ๋‰ด์š•! ํ‹ด์—์ด์ € ํžˆ์–ด๋กœ๋กœ ๋‹ค์‹œ ํƒœ์–ด๋‚œ โ€˜๋‹Œ์žํ„ฐํ‹€โ€™ ํ˜•์ œ๋“ค์˜ ์ŠคํŠธ๋ฆฟ ์•ก์…˜ ์–ด๋“œ๋ฒค์ฒ˜๊ฐ€ ํŽผ์ณ์ง„๋‹ค!", + "popularity": 800.947, + "poster_path": "/6xORIhe6cP3iM5RYTHs7MTOH1qa.jpg", + "release_date": "2023-09-14", + "title": "๋‹Œ์žํ„ฐํ‹€: ๋ฎคํ„ดํŠธ ๋Œ€์†Œ๋™", + "video": false, + "vote_average": 7.3, + "vote_count": 512 + }, + { + "adult": false, + "backdrop_path": "/fm6KqXpk3M2HVveHwCrBSSBaO0V.jpg", + "genre_ids": [ + 18, + 36 + ], + "id": 872585, + "original_language": "en", + "original_title": "Oppenheimer", + "overview": "์„ธ์ƒ์„ ๊ตฌํ•˜๊ธฐ ์œ„ํ•ด ์„ธ์ƒ์„ ํŒŒ๊ดดํ•  ์ง€๋„ ๋ชจ๋ฅด๋Š” ์„ ํƒ์„ ํ•ด์•ผ ํ•˜๋Š” ์ฒœ์žฌ ๊ณผํ•™์ž์˜ ํ•ต๊ฐœ๋ฐœ ํ”„๋กœ์ ํŠธ.", + "popularity": 530.049, + "poster_path": "/4ZLnVUfiCe3wX8Ut9eyujndpyvA.jpg", + "release_date": "2023-08-15", + "title": "์˜คํŽœํ•˜์ด๋จธ", + "video": false, + "vote_average": 8.3, + "vote_count": 3566 + }, + { + "adult": false, + "backdrop_path": "/2zzaJ9jzyK1Am8XoS0dFjmP8V0L.jpg", + "genre_ids": [ + 28, + 53, + 27 + ], + "id": 1135229, + "original_language": "en", + "original_title": "I Am Rage", + "overview": "์—๋ฆฐ์€ ์ƒˆ๋กœ์šด ๋‚จ์ž์นœ๊ตฌ์˜ ๊ณ ํ–ฅ์ธ ์–ด๋Š ํ•œ์ ํ•œ ์‹œ๊ณจ๋งˆ์„์„ ๋ฐฉ๋ฌธํ•œ๋‹ค. ๊ทธ๊ณณ์—์„œ ๋น„์Šทํ•˜๊ฒŒ ์—ฌํ–‰์„ ์˜จ ์ปคํ”Œ๋“ค์„ ๋งŒ๋‚˜๊ฒŒ ๋˜๊ณ  ๊ทธ๋“ค์€ ์‹ค์ข…์ด ๋˜์–ด๋„ ๋ˆ„๊ตฌ๋„ ์ฐพ์ง€ ์•Š์€ ์™ธ๋กœ์šด ์‚ฌ๋žŒ๋“ค์ด๋ผ๋Š” ๊ณตํ†ต์ ์ด ์žˆ๋‹ค๋Š” ๊ฒƒ์„ ์•Œ๊ฒŒ ๋œ๋‹ค. ๊ทธ๋“ค์€ ์ธ๊ฐ„์˜ ํ”ผ๋ฅผ ๊ฑฐ๋ž˜ํ•˜๊ณ  ๋งˆ์‹œ๋ฉฐ ์ดˆ์ž์—ฐ์ ์ธ ํž˜์„ ์–ป๋Š” ์‚ฌ์ด๋น„ ์‚ด์ธ๋งˆ ์ง‘๋‹จ์— ๋‚ฉ์น˜๋œ ๊ฒƒ. ํ•˜์ง€๋งŒ ์—๋ฆฐ์€ ์œ„๊ธฐ์— ๋ชฐ๋ฆฌ๊ฑฐ๋‚˜ ๋ถ„๋…ธํ•˜๊ฒŒ ๋˜๋ฉด ๊ทนํ•œ์˜ ์ž”์ธํ•จ๊ณผ ํญ๋ ฅ์„ฑ์ด ์ดˆ์ธ์ ์œผ๋กœ ๋ฐœํ˜„๋˜๋Š” ํŠน์ดํ•œ ํ˜ˆํ†ต์„ ๊ฐ€์ง„ ์ฒด์งˆ์ด๋‹ค. ์—๋ฆฐ์˜ ๋ถ„๋…ธ๊ฐ€ ํญ๋ฐœํ•˜๊ณ  ๊ทธ๋…€๋ฅผ ์‚ฌ๋ƒฅํ•œ ์•…์ธ๋“ค์— ๋Œ€ํ•œ ๋”์šฑ ์ž”ํ˜นํ•œ ์‚ฌ๋ƒฅ์ด ์‹œ์ž‘๋œ๋‹ค.", + "popularity": 425.756, + "poster_path": "/z1nFd03qoiCrHlGSxBlumkF9uZh.jpg", + "release_date": "2023-09-14", + "title": "๋ก  ์„œ๋ฐ”์ด๋ฒ„ : ์•„์ด ์—  ๋ฆฌ๋ฒค์ง€", + "video": false, + "vote_average": 6.5, + "vote_count": 11 + }, + { + "adult": false, + "backdrop_path": "/kHlX3oqdD4VGaLpB8O78M25KfdS.jpg", + "genre_ids": [ + 9648, + 18, + 80 + ], + "id": 945729, + "original_language": "en", + "original_title": "A Haunting in Venice", + "overview": "์„ธ๊ณ„์  ๋ช…ํƒ์ • '์—๋ฅดํ˜ ํฌ์™€๋กœ'๋Š” ์˜ค๋žœ ํƒ์ • ์ƒํ™œ์—์„œ ์€ํ‡ดํ•˜์—ฌ ์•„๋ฆ„๋‹ค์šด ๋„์‹œ ๋ฒ ๋‹ˆ์Šค์—์„œ ํ‰๋ฒ”ํ•œ ์‚ถ์„ ์‚ด์•„๊ฐ€๊ณ  ์žˆ๋‹ค. ๊ทธ๋Ÿฐ ๊ทธ์—๊ฒŒ ์˜ค๋žœ ์นœ๊ตฌ์ด์ž ๋ฒ ์ŠคํŠธ์…€๋Ÿฌ ์ž‘๊ฐ€์ธ '์•„๋ฆฌ์•„๋“œ๋„ค ์˜ฌ๋ฆฌ๋ฒ„'๊ฐ€ ์ฐพ์•„์™€ ์ฃฝ์€ ์˜ํ˜ผ์„ ๋ถ€๋ฅผ ์ˆ˜ ์žˆ๋‹ค๊ณ  ์•Œ๋ ค์ง„ ์˜ํ—˜ํ•œ ์‹ฌ๋ น์ˆ ์‚ฌ์˜ ์‹ค์ฒด๋ฅผ ๋ฐํ˜€๋‹ฌ๋ผ๊ณ  ๋ถ€ํƒํ•˜๊ฒŒ ๋œ๋‹ค.ํ•ผ๋Ÿฌ์œˆ ๋ฐค, ๋ฒ ๋‹ˆ์Šค ์šดํ•˜ ์œ„ ์œ„์น˜ํ•œ ๊ณ ํ’์Šค๋Ÿฌ์šด ์ €ํƒ์˜ ์ฃผ์ธ์ด์ž 1๋…„ ์ „ ์‚ฌ๋ž‘ํ•˜๋Š” ๋”ธ์„ ์žƒ๊ณ  ๊นŠ์€ ์ƒ์‹ค์— ๋น ์ง„ '๋กœ์›จ๋‚˜ ๋“œ๋ ˆ์ดํฌ'์˜ ์ดˆ๋Œ€๋กœ ๊ต๋ นํšŒ์— ์ฐธ์„ํ•œ ์ด๋“ค์€ ๋ฏธ์Šคํ„ฐ๋ฆฌํ•œ ์‹ฌ๋ น์ˆ ์‚ฌ '์กฐ์ด์Šค ๋ ˆ์ด๋†€์ฆˆ'๊ฐ€ ์ฃฝ์€ ์˜ํ˜ผ์˜ ๋ชฉ์†Œ๋ฆฌ๋ฅผ ์ „ํ•˜๋Š” ๊ด‘๊ฒฝ์„ ๋ณด๋ฉฐ ํ˜ผ๋ž€์— ๋น ์ง€๊ฒŒ ๋œ๋‹ค. ๊ฐ‘์ž๊ธฐ ๋ฐœ์ƒํ•œ ๋”์ฐํ•œ ์‚ด์ธ ์‚ฌ๊ฑด์— ์‹ค์ฒด ์—†๋Š” ์šฉ์˜์ž๋ฅผ ์ซ“๋˜ '์—๋ฅดํ˜ ํฌ์™€๋กœ'๋Š” ์ž์‹ ์˜ ๋ชจ๋“  ๋ฏฟ์Œ์ด ํ”๋“ค๋ฆฌ๋Š” ๊ฒฝํ—˜์„ ํ•˜๋ฉฐ ์ถฉ๊ฒฉ์— ๋น ์ง€๊ฒŒ ๋˜๋Š”๋ฐ....", + "popularity": 348.761, + "poster_path": "/dUQdookYulZV9sTIEvAuAu1Ptxv.jpg", + "release_date": "2023-09-13", + "title": "๋ฒ ๋‹ˆ์Šค ์œ ๋ น ์‚ด์ธ์‚ฌ๊ฑด", + "video": false, + "vote_average": 6.8, + "vote_count": 203 + }, + { + "adult": false, + "backdrop_path": "/5Jfk2p3iGrChUKkl0cBD5krr2u8.jpg", + "genre_ids": [ + 16, + 10749 + ], + "id": 998731, + "original_language": "ja", + "original_title": "ๆ˜ ็”ป ไฝใ€…ๆœจใจๅฎฎ้‡Žใƒผๅ’ๆฅญ็ทจใƒผ", + "overview": "์—ฌ์„ฑ์Šค๋Ÿฌ์šด ์–ผ๊ตด์ด ์ฝคํ”Œ๋ ‰์Šค์ธ ๊ณ ๋“ฑํ•™๊ต 2ํ•™๋…„ โ€˜๋ฏธ์•ผ๋…ธโ€™์™€ ๋ถˆ๋Ÿ‰ํ•ด ๋ณด์ด๋Š” 3ํ•™๋…„ ์„ ๋ฐฐ โ€˜์‚ฌ์‚ฌํ‚คโ€™. BL ๋งŒํ™”๋ฅผ ๋นŒ๋ ค ์ฃผ๋ฉด์„œ ์‹œ์ž‘๋œ ๋‘ ์‚ฌ๋žŒ์€ ๋งˆ์นจ๋‚ด ์‚ฌ๋ž‘์— ๋น ์ง„๋‹ค. ์–ด๋Š๋ง ๊ณ„์ ˆ์€ ๊ฒจ์šธ๋กœ ๋ฐ”๋€Œ๊ณ  โ€˜์‚ฌ์‚ฌํ‚คโ€™์˜ ์กธ์—…์ด ์ฝ” ์•ž์œผ๋กœ ๋‹ค๊ฐ€์˜จ๋‹ค ๋‘ ์‚ฌ๋žŒ์€ ํ•จ๊ป˜ํ•˜๋Š” ๊ณ ๊ต ์ƒํ™œ์„ ์†Œ์ค‘ํ•˜๊ฒŒ ๋ณด๋‚ด์ง€๋งŒ, ์กธ์—…์ด ๋‹ค๊ฐ€์˜ฌ์ˆ˜๋ก ์• ํ‹‹ํ•œ ๋งˆ์Œ์€ ์ปค์ ธ๋งŒ ๊ฐ€๋Š”๋ฐโ€ฆ ๊ณ ๋ฏผ๋„ ๋ถˆ์•ˆ๋„ ๋‚ ๋ ค ๋ฒ„๋ฆฌ๊ณ , ์–ธ์ œ๋‚˜ ์•„๊ปด ์ฃผ๊ณ  ์‹ถ์€ ๋งˆ์Œ์„ ์ „ํ•˜๊ณ  ์‹ถ์–ด!", + "popularity": 204.668, + "poster_path": "/4XeVvKoPKl5Mbiu6ZN3esMt51e7.jpg", + "release_date": "2023-09-06", + "title": "๊ทน์žฅํŒ ์‚ฌ์‚ฌํ‚ค์™€ ๋ฏธ์•ผ๋…ธ - ์กธ์—…ํŽธ", + "video": false, + "vote_average": 6.3, + "vote_count": 15 + }, + { + "adult": false, + "backdrop_path": "/urDWNffjwmNi5IQaezw9GwqkUXa.jpg", + "genre_ids": [ + 12, + 14 + ], + "id": 767, + "original_language": "en", + "original_title": "Harry Potter and the Half-Blood Prince", + "overview": "์–ด๋‘ ์˜ ์„ธ๋ ฅ์ด ๋”์šฑ ๊ฐ•๋ ฅํ•ด์ ธ ๋จธ๊ธ€ ์„ธ๊ณ„์™€ ํ˜ธ๊ทธ์™€ํŠธ๊นŒ์ง€ ์œ„ํ˜‘ํ•ด์˜จ๋‹ค. ์œ„ํ—˜ํ•œ ๊ธฐ์šด์„ ๊ฐ์ง€ํ•œ ๋ค๋ธ”๋„์–ด ๊ต์ˆ˜๋Š” ๋‹ค๊ฐ€์˜ฌ ์ „ํˆฌ์— ๋Œ€๋น„ํ•˜๊ธฐ ์œ„ํ•ด ํ•ด๋ฆฌ ํฌํ„ฐ์™€ ํ•จ๊ป˜ ๋Œ€์žฅ์ •์˜ ๊ธธ์„ ๋‚˜์„ ๋‹ค. ๋ณผ๋“œ๋ชจํŠธ๋ฅผ ๋ฌผ๋ฆฌ์น  ์ˆ˜ ์žˆ๋Š” ์œ ์ผํ•œ ๋‹จ์„œ์ด์ž ๊ทธ์˜ ์˜ํ˜ผ์„ ๋‚˜๋ˆ„์–ด ๋†“์€ 7๊ฐœ์˜ ํ˜ธํฌ๋ฃฉ์Šค๋ฅผ ํŒŒ๊ดดํ•˜๋Š” ๋ฏธ์…˜์„ ์ˆ˜ํ–‰ํ•ด์•ผ๋งŒ ํ•˜๋Š” ๊ฒƒ! ๋˜ํ•œ ๋ค๋ธ”๋„์–ด ๊ต์ˆ˜๋Š” ํ˜ธํฌ๋ฃฉ์Šค๋ฅผ ์ฐพ๋Š” ๊ธฐ์–ต์—ฌํ–‰์— ๊ฒฐ์ •์  ๋„์›€์„ ์ค„ ์Šฌ๋Ÿฌ๊ทธํ˜ผ ๊ต์ˆ˜๋ฅผ ํ˜ธ๊ทธ์™€ํŠธ๋กœ ์ดˆ์ฒญํ•œ๋‹ค. ํ•œํŽธ ํ•™๊ต์—์„œ๋Š” ๊ณ„์†๋œ ์ˆ˜์—…๊ณผ ํ•จ๊ป˜ ๋กœ๋งจ์Šค์˜ ๊ธฐ์šด๋„ ๋ฌด๋ฅด์ต๋Š”๋‹ค. ํ•ด๋ฆฌ๋Š” ์ž์‹ ๋„ ๋ชจ๋ฅด๊ฒŒ ์ง€๋‹ˆ์—๊ฒŒ ์ ์  ๋Œ๋ฆฌ๊ฒŒ ๋˜๊ณ , ์ƒˆ๋กœ์šด ์—ฌ์ž ์นœ๊ตฌ๊ฐ€ ์ƒ๊ธด ๋ก ์—๊ฒŒ ํ—ค๋ฅด๋ฏธ์˜จ๋Š๋Š” ๋ฌ˜ํ•œ ์งˆํˆฌ์‹ฌ์„ ๋Š๋ผ๋Š”๋ฐ...", + "popularity": 143.657, + "poster_path": "/yrGlb3HLtjGp39mv4MJ5UuIHcj4.jpg", + "release_date": "2023-09-06", + "title": "ํ•ด๋ฆฌ ํฌํ„ฐ์™€ ํ˜ผํ˜ˆ์™•์ž", + "video": false, + "vote_average": 7.7, + "vote_count": 18104 + }, + { + "adult": false, + "backdrop_path": "/lUPz9zW0uf0bHfYsRRID8RtBHEU.jpg", + "genre_ids": [ + 18, + 36 + ], + "id": 457232, + "original_language": "en", + "original_title": "Lamborghini: The Man Behind the Legend", + "overview": "2์ฐจ ์„ธ๊ณ„๋Œ€์ „์ด ์ข…์‹๋œ ํ›„ ๊ณ ํ–ฅ์œผ๋กœ ๋Œ์•„์˜จ โ€˜ํŽ˜๋ฃจ์น˜์˜ค ๋žŒ๋ณด๋ฅด๊ธฐ๋‹ˆโ€™ ๊ทธ๋Š” ํŠธ๋ž™ํ„ฐ ํšŒ์‚ฌ๋ฅผ ์„ธ์›Œ ์ž์‹ ์˜ ์ด๋ฆ„์„ ๋„๋ฆฌ ์•Œ๋ฆฌ๊ฒ ๋‹ค๋Š” ์•ผ๋ง์„ ํ’ˆ๊ณ ์žˆ๋‹ค. ํƒ€ํ˜‘ ์—†๋Š” ๋…ธ๋ ฅ ๋์— ๊ฒฐ๊ตญ ํŠธ๋ž™ํ„ฐ ๊ฐœ๋ฐœ์— ์„ฑ๊ณตํ•˜์˜€์ง€๋งŒ, ๊ทธ์˜ ๊ฟˆ์€ ์—ฌ๊ธฐ์„œ ๋ฉˆ์ถ”์ง€ ์•Š๋Š”๋‹ค. ํŽ˜๋ฃจ์น˜์˜ค๋Š” ๋™๊ฒฝํ•˜๋Š” ์ž๋™์ฐจ ์ œ์กฐ์‚ฌ ํšŒ์žฅ โ€˜์—”์ดˆ ํŽ˜๋ผ๋ฆฌโ€™๋ฅผ ์ฐพ์•„๊ฐ€ ๋™์—…์„ ์ œ์•ˆํ•˜์ง€๋งŒ, ์‹œ๊ณจ ์ดŒ๋†ˆ ์ทจ๊ธ‰์„ ๋ฐ›์œผ๋ฉฐ ๊ฑฐ์ ˆ๋‹นํ•˜๋Š” ๊ตด์š•์„ ๋‹นํ•œ๋‹ค. ์ด์— ๊ฒฉ๋ถ„ํ•œ ํŽ˜๋ฃจ์น˜์˜ค๋Š” ์—…๊ณ„์—์„œ ์œ ๋Šฅํ•˜๋‹ค๊ณ  ์•Œ๋ ค์ง„ ์ž๋™์ฐจ ์—”์ง€๋‹ˆ์–ด๋ฅผ ์Šค์นด์šฐํŠธํ•˜๋ฉฐ, ํ™ฉ์†Œ๊ฐ™์ด ๊ฐ•๋ ฅํ•œ ์ฐจ๋ฅผ ๋งŒ๋“ค๊ธฐ์œ„ํ•ด ์˜๊ธฐํˆฌํ•ฉํ•œ๋‹ค. ์ œ๋„ค๋ฐ” ๋ชจํ„ฐ์‡ผ๊นŒ์ง€ 6๊ฐœ์›”๋ฐ–์— ๋‚จ์ง€ ์•Š์€ ์ƒํ™ฉ์—์„œ ํŽ˜๋ฃจ์น˜์˜ค๋Š” ์ •๋ง ์„ธ์ƒ์— ์„ ๋ณด์ธ ์  ์—†๋˜ ์ตœ๊ณ ์˜ ์ฐจ๋ฅผ ๋งŒ๋“ค์–ด ๋‚ผ ์ˆ˜ ์žˆ์„๊นŒ?", + "popularity": 112.035, + "poster_path": "/1z6EUqJn07mtfmYGzu8LmHfiOJW.jpg", + "release_date": "2023-08-23", + "title": "๋žŒ๋ณด๋ฅด๊ธฐ๋‹ˆ: ์ „์„ค์ด ๋œ ๋‚จ์ž", + "video": false, + "vote_average": 6.3, + "vote_count": 300 + }, + { + "adult": false, + "backdrop_path": "/fIQfdZ6fqf9mIbqBaexbgIEIk5K.jpg", + "genre_ids": [ + 35 + ], + "id": 864168, + "original_language": "en", + "original_title": "Joy Ride", + "overview": "์„ฑ๊ณต ๊ฐ€๋„๋ฅผ ๋‹ฌ๋ฆฌ๋˜ ์•ŒํŒŒ๊ฑธ ๋ณ€ํ˜ธ์‚ฌ '์˜ค๋“œ๋ฆฌ'(์• ์Š๋ฆฌ ๋ฐ•)๋Š” ์ดˆ๊ณ ์† ์Šน์ง„์„ ์œ„ํ•ด ์–ด๋ฆด ์  ํ—ค์–ด์ง„ ์ƒ๋ชจ๋ฅผ ์ฐพ์•„์˜ค๋ผ๋Š” ํ™ฉ๋‹นํ•œ ๋ฏธ์…˜์„ ๋ฐ›๋Š”๋‹ค. ๊ฝƒ๋ฏธ๋‚จ ์ „๋ฌธ๊ฐ€์ธ ์Œ๋ž€๋งˆ๊ท€ ์•„ํ‹ฐ์ŠคํŠธ '๋กค๋กœ'(์…ฐ๋ฆฌ ์ฝœ๋ผ), ํ‘์—ญ์‚ฌ ์ˆจ๊ธฐ๊ณ  ํ• ๋ฆฌ์šฐ๋“œ ์ง„์ถœ ์•ž๋‘” ํ†ฑ๋ฐฐ์šฐ '์บฃ'(์Šคํ…ŒํŒŒ๋‹ˆ ์ˆ˜), ํ๋ฆฐ ๋ˆˆ์˜ ์ผ€์ดํŒ ๊ด‘์ธ '๋ฐ๋“œ์•„์ด'(์‚ฌ๋ธŒ๋ฆฌ๋‚˜ ์šฐ)๊ฐ€ ํ•ฉ๋ฅ˜ํ•˜๋ฉด์„œ ๋„ค ์นœ๊ตฌ๋“ค์˜ ํฌ๋ ˆ์ด์ง€ํ•œ ์›”๋“œํˆฌ์–ด๊ฐ€ ์‹œ์ž‘๋œ๋‹ค! ์ง€๊ตฌ ๋ฐ˜ ๋ฐ”ํ€ด๋ฅผ ๋Œ๊ณ  ๋„๋Š” ๊ณ ์ƒ๊ธธ ๋์— ๋ฐํ˜€์ง„ ์˜ค๋“œ๋ฆฌ์˜ ์ถœ์ƒ์˜ ๋น„๋ฐ€์€โ€ฆ", + "popularity": 102.202, + "poster_path": "/dY2HZ0yAMhYqwHkuKM5HU7zxoJ9.jpg", + "release_date": "2023-08-30", + "title": "์กฐ์ด ๋ผ์ด๋“œ", + "video": false, + "vote_average": 6.6, + "vote_count": 160 + }, + { + "adult": false, + "backdrop_path": "/dvHKdXijoN1OEzGcPhd0eRvkfMd.jpg", + "genre_ids": [ + 27, + 53, + 28, + 12 + ], + "id": 960258, + "original_language": "en", + "original_title": "Shark Bait", + "overview": "๋งˆ์ง€๋ง‰ ๋ด„ ๋ฐฉํ•™์„ ๊ธฐ๋…ํ•˜๋Ÿฌ ํ•ด๋ณ€์—์„œ ํŒŒํ‹ฐ๋ฅผ ๋ฒŒ์ด๋˜ ์ Š์€์ด๋“ค์€ ์šฐ์—ฐํžˆ ์ฃผ์ธ ์—†์ด ๋ฐฉ์น˜๋œ ์ œํŠธ์Šคํ‚ค ๋‘ ๋Œ€๋ฅผ ๋ฐœ๊ฒฌํ•˜๊ณ  ํ‚ค๋ฅผ ํ›”์นœ๋‹ค. ๊ทธ๋“ค์€ ์ œํŠธ์Šคํ‚ค๊ฐ€ ์ฒ˜์ฐธํ•œ ๊ฒฐ๊ณผ๋ฅผ ๋ชฐ๊ณ  ์˜ฌ ์žฌ์•™์˜ ์›์ธ์ด ๋ ์ง€ ๋ชจ๋ฅธ ์ฑ„ ์Šน์„ ํ•œ๋‹ค. ์ฒ ์—†๋Š” ์น˜ํ‚จ๊ฒŒ์ž„์„ ํ•˜๋‹ค ๊ณ ์žฅ ๋‚œ ์ œํŠธ์Šคํ‚ค๋Š” ๋ฐ”๋‹ค ํ•œ ๊ฐ€์šด๋ฐ ๊ณ ๋ฆฝ๋˜๊ณ  ๊ฑฐ๋Œ€ํ•œ ๋ฐฑ์ƒ์–ด์˜ ๊ทธ๋ฆผ์ž๊ฐ€ ์„œ์„œํžˆ ๊ทธ๋“ค ์ฃผ์œ„๋ฅผ ๋งด๋ˆ๋‹ค. ์ƒ์–ด์˜ ํฌ์ƒ์ž๊ฐ€ ํ•œ ๋ช…์”ฉ ๋Š˜์–ด๊ฐ€๋Š” ๊ฐ€์šด๋ฐ ๋‚จ์€ ์‚ฌ๋žŒ๋“ค์€ ํ•ด๋ณ€์œผ๋กœ ๋Œ์•„๊ฐ€๊ธฐ ์œ„ํ•ด ๊ณ ๊ตฐ๋ถ„ํˆฌํ•œ๋‹ค.", + "popularity": 69.423, + "poster_path": "/pxsn8GtNHbN01iWkD2cV8CMuGzm.jpg", + "release_date": "2023-08-03", + "title": "47์‹œ๊ฐ„: ์ƒคํฌ๋ฒ ์ดํŠธ", + "video": false, + "vote_average": 5.8, + "vote_count": 261 + }, + { + "adult": false, + "backdrop_path": "/7TdVWAO7vV9j1OLDq1hQJS3pb4U.jpg", + "genre_ids": [ + 28, + 35, + 12, + 53 + ], + "id": 739405, + "original_language": "en", + "original_title": "Operation Fortune: Ruse de Guerre", + "overview": "์ „ ์„ธ๊ณ„ ๊ฒ€์€ ๋ฌด๊ธฐ ๊ฑฐ๋ž˜ ์™•, ์Šˆํผ ๋นŒ๋Ÿฐ โ€˜๊ทธ๋ ‰โ€™ ๊ทธ๊ฐ€ ์ •์ฒด๋ฅผ ํŒŒ์•…์กฐ์ฐจ ๋ถˆ๊ฐ€๋Šฅํ•œ โ€˜ํ•ธ๋“คโ€™์„ ๊ฑฐ๋ž˜ํ•œ๋‹ค๋Š” ์ฒฉ๋ณด ๋‚ด์šฉ์ด ์ž…์ˆ˜๋œ๋‹ค. ๊ตญ๊ฐ€ ์ •๋ณด๊ตญ์€ ์ „์„ธ๊ณ„๋ฅผ ๋ถ•๊ดด์‹œํ‚ฌ ์ˆ˜๋„ ์žˆ๋Š” ์ด๊ฒƒ์ด ๋ฌด์—‡์ธ์ง€ ๋Œ€ํ˜ผ๋ˆ์— ๋น ์ง€๊ฒŒ ๋˜๊ณ โ€ฆ ์ด ํ˜ผ๋ˆ์„ ํ•ด๊ฒฐํ•  ์ž๋Š” ์˜ค์ง ํ•˜๋‚˜! ์•ก์…˜ ๋งŒ๋žฉ, ์ˆ˜ํŠธ ํ•๊ณผ ๊ฟ€์„ฑ๋Œ€๊นŒ์ง€! ๋ชจ๋“  ๊ฒƒ์ด ์™„๋ฒฝํ•œ ์—…๊ณ„ ์ตœ๊ณ ์˜ ์ŠคํŒŒ์ด โ€˜ํฌ์ถ˜โ€™ ๋ฌด๋น„ ์Šคํƒ€, ํ…Œํฌ ์ „๋ฌธ๊ฐ€์™€ ์ƒท๊ฑด ๋งˆ์Šคํ„ฐ๊นŒ์ง€ ํŒ€ โ€˜ํฌ์ถ˜โ€™์„ ์กฐํ•ฉํ•œ ํ›„ ์ผ์ƒ์ผ๋Œ€์˜ ์œ„ํ—˜ํ•œ ์ž„๋ฌด์— ๋‚˜์„œ๊ฒŒ ๋˜๋Š”๋ฐโ€ฆ", + "popularity": 58.973, + "poster_path": "/5QXoAgO905YGucMJmeDb4CmjEUT.jpg", + "release_date": "2023-08-30", + "title": "์ŠคํŒŒ์ด ์ฝ”๋“œ๋ช… ํฌ์ถ˜", + "video": false, + "vote_average": 6.6, + "vote_count": 1031 + }, + { + "adult": false, + "backdrop_path": "/63CDysgJZb38ZXdw2yF1UuDJgDN.jpg", + "genre_ids": [ + 53 + ], + "id": 979924, + "original_language": "en", + "original_title": "On the Line", + "overview": "์‹ฌ์•ผ ๋ผ๋””์˜ค '์˜จ ๋” ๋ผ์ธ'์˜ ์ง„ํ–‰์ž ์—˜๋ฆฌ์Šค๊ฐ€ ์ƒ๋ฐฉ์†ก ์ค‘ ์˜๋ฌธ์˜ ์ „ํ™”๋ฅผ ๋ฐ›๊ฒŒ ๋˜๊ณ , ์‡ผ๋งจ์€ ๊ทธ์˜ ์˜จ ๊ฐ€์กฑ์„ ์ฃฝ์ด๊ฒ ๋‹ค๊ณ  ํ˜‘๋ฐ•์„ ํ•œ๋‹ค. ๋ชจ๋“  ๊ฒƒ์ด ์‹ค์‹œ๊ฐ„์œผ๋กœ ์ง„ํ–‰๋˜๋Š” ๋ผ๋””์˜ค์—์„œ ์‚ฌ๋ž‘ํ•˜๋Š” ์‚ฌ๋žŒ์„ ๊ตฌํ•˜๊ธฐ ์œ„ํ•œ ์—˜๋ฆฌ์Šค์˜ ๊ณ ๊ตฐ๋ถ„ํˆฌ ์ƒ์กด๊ฒŒ์ž„์ด ์‹œ์ž‘๋˜๋Š”๋ฐ...", + "popularity": 50.437, + "poster_path": "/o04KUuO9Zoi1L8KxH5Z4jJF7iXb.jpg", + "release_date": "2023-08-02", + "title": "์˜จ ๋” ๋ผ์ธ", + "video": false, + "vote_average": 6.1, + "vote_count": 382 + }, + { + "adult": false, + "backdrop_path": "/qAvou7F5P4VcIR72JzzrnKEQSN3.jpg", + "genre_ids": [ + 12, + 14, + 10751 + ], + "id": 630, + "original_language": "en", + "original_title": "The Wizard of Oz", + "overview": "ํšŒ์˜ค๋ฆฌ ๋ฐ”๋žŒ์— ํœฉ์“ธ๋ ค ์˜ค์ฆˆ์˜ ๋‚˜๋ผ๋กœ ๋‚ด๋˜์ ธ์ง„ ๋„๋กœ์‹œ๋Š” ์ง‘์œผ๋กœ ๋˜๋Œ์•„๊ฐˆ ์ˆ˜ ์žˆ๋Š” ์œ ์ผํ•œ ๊ธธ์ด ์œ„๋Œ€ํ•œ ์˜ค์ฆˆ์˜ ๋งˆ๋ฒ•์‚ฌ๋ฅผ ๋งŒ๋‚˜๋Š” ๊ฒƒ์ž„์„ ์•Œ๊ณ  ๊ทธ๋ฅผ ์ฐพ์•„ ๊ธด ์—ฌ์ •์ด ์‹œ์ž‘๋œ๋‹ค. ๋„๋กœ์‹œ๋Š” ์• ๊ฒฌ ํ† ํ† ์™€ ํ•จ๊ป˜ ๋…ธ๋ž€ ๊ธธ์„ ๋”ฐ๋ผ ์˜ค์ฆˆ์˜ ๋งˆ๋ฒ•์‚ฌ๊ฐ€ ์‚ฌ๋Š” ์—๋ฉ”๋ž„๋“œ ์‹œํ‹ฐ๋กœ ํ–ฅํ•œ๋‹ค. ๋„์ค‘์— ๋งŒ๋‚œ ์„ธ ๋ช…์˜ ์นœ๊ตฌ๋“ค, ์ง€๋Šฅ์„ ์–ป๊ณ ์ž ํ•˜๋Š” ํ—ˆ์ˆ˜์•„๋น„์™€ ์‹ฌ์žฅ์„ ์›ํ•˜๋Š” ์–‘์ฒ  ๋‚˜๋ญ‡๊พผ, ์šฉ๊ธฐ๋ฅผ ๊ฐ€์ง€๊ณ  ์‹ถ์–ดํ•˜๋Š” ๊ฒ์žฅ์ด ์‚ฌ์ž์™€ ํ•จ๊ป˜ ์˜ค์ฆˆ์˜ ๋งˆ๋ฒ•์‚ฌ์—๊ฒŒ ์ž์‹ ์˜ ์†Œ์›์ด ์ด๋ฃจ์–ด์ง€๋„๋ก ๋ถ€ํƒํ•˜๊ธฐ ์œ„ํ•ด ๋„๋กœ์‹œ์™€ ํ•จ๊ป˜ ๊ฒฝ์พŒํ•œ ๋ฐœ๊ฑธ์Œ์„ ์˜ฎ๊ธด๋‹ค. ๊ทธ๋Ÿฌ๋‚˜ ๋„๋กœ์‹œ ์ผํ–‰์„ ๋ฐฉํ•ดํ•˜๊ธฐ ์œ„ํ•ด ๋’ค์ซ“์•„์˜ค๋Š” ์„œ์ชฝ ๋‚˜๋ผ ๋งˆ๋…€์˜ ๊ฒ€์€ ๊ทธ๋ฆผ์ž.", + "popularity": 53.375, + "poster_path": "/9FzHxca1OybjwOdTmWLfhdD4u0g.jpg", + "release_date": "2012-05-03", + "title": "์˜ค์ฆˆ์˜ ๋งˆ๋ฒ•์‚ฌ", + "video": false, + "vote_average": 7.6, + "vote_count": 5105 + }, + { + "adult": false, + "backdrop_path": "/rHnANzYUmV3WZw3n0yWOLiR3pen.jpg", + "genre_ids": [ + 53 + ], + "id": 976912, + "original_language": "en", + "original_title": "Graphic Desires", + "overview": "์นœ๊ตฌ์˜ ์†Œ๊ฐœ๋กœ ๋ฐ์ดํŒ… ์•ฑ์— ๊ฐ€์ž…ํ•œ 'ํ”„๋žญํฌ' ์—ฐ์ธ ๋ชฐ๋ž˜ ์•ฑ์„ ํ†ตํ•ด ๋งŒ๋‚œ ์—ฌ์„ฑ์—๊ฒŒ ๊ฐ•ํ•œ ์„ฑ์  ๋Œ๋ฆผ์„ ๋Š๋‚€ ๊ทธ๋Š” ๋‹ค์‹œ ๊ทธ๋…€๋ฅผ ์ฐพ์ง€๋งŒ ์—ฌ์ž๋Š” ์‚ฌ๋ผ์ง€๊ณ  ๊ณ„์ •๋„ ๋น„ํ™œ์„ฑํ™”๋œ๋‹ค. ํ˜„์‹ค๊ณผ ๊ฐ€์ƒ์„ ๋„˜๋‚˜๋“ค๋ฉฐ ๊ทธ๋…€๋ฅผ ์ฐพ์•„ ํ—ค๋งค๋Š” ๋™์•ˆ ๊ทธ๋Š” ์ ์  ๋ฐ์ดํŒ… ์•ฑ์— ์ค‘๋…๋˜๊ณ  ๊ฒฐ๊ตญ ์˜ˆ๊ธฐ์น˜ ๋ชปํ•œ ์‚ฌ๊ฑด์— ํœ˜๋ง๋ฆฌ๊ณ  ๋งˆ๋Š”๋ฐโˆ™โˆ™โˆ™", + "popularity": 46.565, + "poster_path": "/8EHehEMsJVIPp2n2ROhZU8dbpJC.jpg", + "release_date": "2023-08-31", + "title": "๊ทธ๋ž˜ํ”ฝ ๋””์ž์ด์–ด", + "video": false, + "vote_average": 1, + "vote_count": 1 + }, + { + "adult": false, + "backdrop_path": "/wNYUv8u5Z0AI4dkyxGyet7eLEWm.jpg", + "genre_ids": [ + 18 + ], + "id": 945675, + "original_language": "zh", + "original_title": "ไธ€ๅ‘จ็š„ๆœ‹ๅ‹", + "overview": "์ผ์ฃผ์ผ๋งˆ๋‹ค ์นœ๊ตฌ์— ๋Œ€ํ•œ ๊ธฐ์–ต์„ ์žƒ๋Š” ์ „ํ•™์ƒ โ€˜๋ฆฐ์ƒน์ฆˆโ€™ ๋ณ‘ ๋•Œ๋ฌธ์— ์ž๋ฐœ์  ์•„์‹ธ๊ฐ€ ๋ผ๋ฒ„๋ฆฐ ๊ทธ๋…€์—๊ฒŒ ์„ฑํ™” ์žฌ์ˆ˜ํ•™์› ์ตœ๊ณ  ์ธ์‹ธ 3์ธ๋ฐฉ โ€˜์‰ฌ์œ ์ˆ˜โ€™, โ€˜์†ก์ƒค์˜ค๋‚œโ€™, โ€˜์žฅ์šฐ'๊ฐ€ ๋‹ค๊ฐ€์˜จ๋‹ค. โ€œ์ผ์ฃผ์ผ๋งŒ ๊ธฐ์–ตํ•ด๋„ ์ƒ๊ด€์—†์–ด. ์ผ์ฃผ์ผ๊ฐ„ ์นœ๊ตฌ ํ•˜๋ฉด ๋˜์ž–์•„!โ€ ๋จธ๋ฆฌ๊ฐ€ ์ข‹์•„์ง€๋Š” ํ˜ธ๋ฐ•์ฃฝ, ๊ธฐ์–ต๋ ฅ ์ฆ์ง„ ๋Œ„์Šค, ๊นœ์ฐํ•œ ์œ ์ˆ˜ํ‘œ ์—„์ง€ ์ธํ˜•๊นŒ์ง€! ์„ธ ์‚ฌ๋žŒ์€ ์ƒน์ฆˆ์˜ ๋‹จ ํ•˜๋‚˜๋ฟ์ธ โ€˜์ผ์ฃผ์ผ๊ฐ„ ์นœ๊ตฌโ€™๊ฐ€ ๋˜๊ธฐ ์œ„ํ•ด ๊ณ ๊ตฐ๋ถ„ํˆฌํ•˜๊ณ , ์ƒน์ฆˆ๋Š” ๊ทธ๋“ค๊ณผ์˜ ์ถ”์–ต์„ ์ผ๊ธฐ์žฅ์— ์ฑ„์›Œ ๋‚˜๊ฐ€๊ธฐ ์‹œ์ž‘ํ•œ๋‹ค.", + "popularity": 51.949, + "poster_path": "/bCp45FrpSWD0mEx2EGHkvxOs2OK.jpg", + "release_date": "2023-09-06", + "title": "์ผ์ฃผ์ผ๊ฐ„ ์นœ๊ตฌ", + "video": false, + "vote_average": 5.7, + "vote_count": 110 + }, + { + "adult": false, + "backdrop_path": "/z6GxNP2Z5AyoFfrYKxZWJypfZXJ.jpg", + "genre_ids": [ + 16, + 10751 + ], + "id": 823609, + "original_language": "en", + "original_title": "Monster Family 2", + "overview": "๋ชฌ์Šคํ„ฐ์—์„œ ์ธ๊ฐ„์œผ๋กœ ๊ฒจ์šฐ ๋Œ์•„์˜จ โ€˜์œ„์‹œ๋ณธโ€™ ํŒจ๋ฐ€๋ฆฌ! ์ƒˆ ๊ฐ€์กฑ์ด ๋œ ์ „์„ค ์† ๋ชฌ์Šคํ„ฐ โ€˜๋ฐ”๋ฐ” ์•ผ๊ฐ€โ€™์™€ โ€˜๋ Œํ•„๋“œโ€™์˜ ๊ฒฐํ˜ผ์‹ ๋‚ , ๊ทธ๋“ค์€ ์Šˆํผ ์†Œ๋…€ โ€˜๋ฐ€๋ผโ€™์—๊ฒŒ ๋‚ฉ์น˜๋‹นํ•œ๋‹ค. ์ด๋“ค๋ฟ ์•„๋‹ˆ๋ผ ๋“œ๋ผํ˜๋ผ, ์˜ˆํ‹ฐ, ๋„ค์‹œ, ๊ทธ๋ฆฌ๊ณ  ํ‚น ์ฝฉ๊ฐ€๊นŒ์ง€!! โ€˜์œ„์‹œ๋ณธโ€™ ํŒจ๋ฐ€๋ฆฌ๋Š” โ€˜๋ฐ€๋ผโ€™์— ์˜ํ•ด ์ „ ์„ธ๊ณ„ ๋ชฌ์Šคํ„ฐ๋“ค์ด ๋‚ฉ์น˜๋œ ๊ฒƒ์„ ์•Œ๊ฒŒ ๋˜๋Š”๋ฐโ€ฆ ๋ชฌ์Šคํ„ฐ๋“ค์„ ๊ตฌํ•˜๊ธฐ ์œ„ํ•ด ๋‹ค์‹œ ๋ชฌ์Šคํ„ฐ๋กœ ๋ณ€ํ•œ โ€˜์œ„์‹œ๋ณธโ€™ ํŒจ๋ฐ€๋ฆฌ! ๊ณผ์—ฐ โ€˜์œ„์‹œ๋ณธโ€™ ๊ฐ€์กฑ์€ ๋ชฌ์Šคํ„ฐ๋“ค์„ ๊ตฌํ•˜๊ณ  ๋‹ค์‹œ ์ธ๊ฐ„์œผ๋กœ ๋Œ์•„๊ฐˆ ์ˆ˜ ์žˆ์„๊นŒ?", + "popularity": 21.008, + "poster_path": "/9kPiLqqWlwCVL0KGJeM4kcZA9q9.jpg", + "release_date": "2023-08-02", + "title": "๋ชฌ์Šคํ„ฐ ํŒจ๋ฐ€๋ฆฌ 2", + "video": false, + "vote_average": 6.6, + "vote_count": 63 + }, + { + "adult": false, + "backdrop_path": "/6Lqs0Bw2L2ZoVgx9XpmeN7vBcr0.jpg", + "genre_ids": [ + 18 + ], + "id": 960275, + "original_language": "fr", + "original_title": "Maestro(s)", + "overview": "๊ถŒ์œ„ ์žˆ๋Š” ๋น…ํˆฌ์•„๋ฅด ์Œ์•…์ƒ์„ ์ˆ˜์ƒํ•˜๋ฉฐ ์ฐจ์„ธ๋Œ€ ๊ฑฐ์žฅ์œผ๋กœ ์ž๋ฆฌ๋งค๊น€ํ•œ ์ง€ํœ˜์ž โ€˜๋“œ๋‹ˆ ๋’ค๋งˆ๋ฅดโ€™. ๊ทธ๊ฐ€ ๋„˜์–ด์•ผ ํ•  ๊ฐ€์žฅ ํฐ ์‚ฐ์€ ๋‹ค๋ฆ„ ์•„๋‹Œ ๊ฐ™์€ ์ง€ํœ˜์ž์ด์ž ์Œ์•…๊ณ„์˜ ๊ฑฐ์žฅ์ธ ์•„๋ฒ„์ง€ โ€˜ํ”„๋ž‘์ˆ˜์•„ ๋’ค๋งˆ๋ฅดโ€™์ด๋‹ค. ํ•œํŽธ, ์•„๋ฒ„์ง€ โ€˜ํ”„๋ž‘์ˆ˜์•„โ€™๋Š” ์กด๊ฒฝ๋ฐ›๋Š” ์ตœ๊ณ ์˜ ์ง€ํœ˜์ž์ง€๋งŒ ๊ณง ์ •์ƒ์˜ ์œ„์น˜์—์„œ ๋ฐ€๋ ค๋‚ ์ง€๋„ ๋ชจ๋ฅธ๋‹ค๋Š” ์œ„๊ธฐ๊ฐ๊ณผ ํ•จ๊ป˜, ๊ฐ™์€ ๋ถ„์•ผ์—์„œ ์Šน์Šน์žฅ๊ตฌํ•˜๋Š” ์•„๋“ค โ€˜๋“œ๋‹ˆโ€™์—๊ฒŒ ๋ฌ˜ํ•œ ๊ฒฝ์Ÿ์‹ฌ์„ ๋Š๋ผ๊ณ  ์žˆ๋‹ค. ๊ทธ๋Ÿฌ๋˜ ์ค‘ โ€˜ํ”„๋ž‘์ˆ˜์•„โ€™๋Š” ํ‰์ƒ์„ ์†Œ๋งํ•˜๋˜, ์ดํƒˆ๋ฆฌ์•„ โ€˜๋ผ ์Šค์นผ๋ผโ€™ ๊ทน์žฅ์˜ ์ง€ํœ˜์ž ์ž๋ฆฌ๋ฅผ ์ œ์•ˆํ•˜๋Š” ์ „ํ™”๋ฅผ ๋ฐ›๊ณ  ๋›ธ ๋“ฏ์ด ๊ธฐ๋ปํ•œ๋‹ค. ํ•˜์ง€๋งŒ ์•„๋“ค โ€˜๋“œ๋‹ˆโ€™๋Š” ์ž์‹ ์—๊ฒŒ ๊ฐ€์•ผ ํ•  ์ œ์•ˆ์ด ์•„๋ฒ„์ง€์—๊ฒŒ ์ž˜๋ชป ์ „๋‹ฌ๋˜์—ˆ์Œ์„ ์•Œ๊ฒŒ ๋˜๊ณ , ์ธ์ƒ ์ตœ๋Œ€์˜ ๊ณ ๋ฏผ๊ณผ ๋งˆ์ฃผํ•œ๋‹ค. ๊ฟˆ์˜ ๋ฌด๋Œ€๋ฅผ ๋‘๊ณ  ๋งˆ์ฃผํ•œ ์•„๋ฒ„์ง€์™€ ์•„๋“ค! โ€˜๋ผ ์Šค์นผ๋ผโ€™ ๋ฌด๋Œ€์— ์„œ๊ฒŒ ๋  ์ฃผ์ธ๊ณต์€ ๊ณผ์—ฐ ๋ˆ„๊ตฌ์ผ๊นŒ?", + "popularity": 36.246, + "poster_path": "/8CNn2HuBMQYOA425MbAoc3oeTNO.jpg", + "release_date": "2023-08-09", + "title": "๋งˆ์—์ŠคํŠธ๋กœ", + "video": false, + "vote_average": 5.7, + "vote_count": 36 + }, + { + "adult": false, + "backdrop_path": "/8nLiWpgxOfH15FjBgTvvcah3ZUb.jpg", + "genre_ids": [ + 28, + 53, + 80, + 35 + ], + "id": 1015963, + "original_language": "en", + "original_title": "High Heat", + "overview": "์ „์ง ํŠน์ˆ˜์š”์› ์ถœ์‹  ์Šคํƒ€ ์…ฐํ”„ '์•„๋‚˜'(์˜ฌ๊ฐ€ ์ฟ ๋ฆด๋ Œ์ฝ”)๊ฐ€ ๋งˆํ”ผ์•„์˜ ํƒ€๊ฒŸ์ด ๋œ ๋ ˆ์Šคํ† ๋ž‘์„ ๊ตฌํ•˜๊ธฐ ์œ„ํ•ด ํ‚ฌ๋Ÿฌ ๋ณธ๋Šฅ์„ ๋‹ค์‹œ ์ผ๊นจ์šด๋‹ค.", + "popularity": 24.199, + "poster_path": "/wIFYnvvdwsjD0Wjeg8MjIIp58rR.jpg", + "release_date": "2023-08-17", + "title": "ํ‚ฌ๋Ÿฌ์˜ ๋ ˆ์Šคํ† ๋ž‘", + "video": false, + "vote_average": 5.6, + "vote_count": 98 + }, + { + "adult": false, + "backdrop_path": "/4hAhZ66n5iasGtSYHTFg6oGdJk0.jpg", + "genre_ids": [ + 53, + 27, + 878 + ], + "id": 660942, + "original_language": "no", + "original_title": "De uskyldige", + "overview": "์ด๋‹ค์™€ ์•ˆ๋‚˜๋Š” ์ƒˆ๋กœ์šด ์•„ํŒŒํŠธ๋กœ ์ด์‚ฌํ•œ ์งํ›„, ๋˜๋ž˜์ธ ๋ฒค์ž๋ฏผ, ์•„์ด์ƒค์™€ ์นœ๊ตฌ๊ฐ€ ๋œ๋‹ค. ๋„ค ๋ช…์˜ ์•„์ด๋“ค์€ ์–ด๋ฅธ์ด ๊ฐœ์ž…ํ•˜์ง€ ์•Š๋Š” ์ˆœ๊ฐ„, ํŠน๋ณ„ํ•œ ์ž ์žฌ๋ ฅ์„ ๊นจ์›Œ๋‚˜๊ฐ€๊ธฐ ์‹œ์ž‘ํ•˜๊ณ  ๋ฒค์ž๋ฏผ์€ ๋Šฅ๋ ฅ์„ ์ด์šฉํ•ด ์‚ฌ๋žŒ๋“ค์„ ์กฐ์ •ํ•  ์ˆ˜ ์žˆ๊ฒŒ ๋œ๋‹ค. ๋‹จ์ˆœํ•œ ํ˜ธ๊ธฐ์‹ฌ๊ณผ ์žฅ๋‚œ์œผ๋กœ ํ–‰ํ•ด์ง€๋˜ ์–ด๋–ค ์ผ๋“ค์ด, ๊ธ‰๊ธฐ์•ผ ๋ถ„๋…ธ๋ผ๋Š” ๊ฐ์ •๊ณผ ์ด์–ด์ง€๊ณ  ๊ฒฐ๊ตญ ์นœ๊ตฌ๋“ค์„ ๋น„๋กฏํ•ด ์ฃผ๋ณ€์— ์œ„ํ˜‘์„ ๊ฐ€ํ•˜๊ธฐ ์‹œ์ž‘ํ•˜๋Š” ๋ฒค์ž๋ฏผ. ๊ฐ€์žฅ ์ˆœ์ˆ˜ํ•˜๊ณ , ๋ณธ๋Šฅ์ ์ด์—ˆ๋˜, ๊ทธ๋ž˜์„œ ๋”์šฑ ํŒŒ๊ดด์ ์ด๊ณ  ์ž”์ธํ•  ์ˆ˜ ์žˆ์—ˆ๋˜ ์ž”ํ˜นํ•œ ๋™์‹ฌ์˜ ์„ธ๊ณ„๊ฐ€ ํŽผ์ณ์ง„๋‹ค!", + "popularity": 22.179, + "poster_path": "/tNJ2oOuTPHny3x633DwwKDnc5mQ.jpg", + "release_date": "2023-09-06", + "title": "์ด๋…ธ์„ผํŠธ", + "video": false, + "vote_average": 7, + "vote_count": 439 + }, + { + "adult": false, + "backdrop_path": "/g8kCHQzfogy1t1dE9nPBtiFkz64.jpg", + "genre_ids": [ + 53, + 878, + 18 + ], + "id": 729854, + "original_language": "ko", + "original_title": "์ฝ˜ํฌ๋ฆฌํŠธ ์œ ํ† ํ”ผ์•„", + "overview": "๋Œ€์ง€์ง„์œผ๋กœ ํ•˜๋ฃจ์•„์นจ์— ํํ—ˆ๊ฐ€ ๋œ ์„œ์šธ. ๋ชจ๋“  ๊ฒƒ์ด ๋ฌด๋„ˆ์กŒ์ง€๋งŒ ๋‹จ ํ•œ ๊ณณ, ํ™ฉ๊ถ ์•„ํŒŒํŠธ๋งŒ์€ ๊ทธ๋Œ€๋กœ๋‹ค. ์†Œ๋ฌธ์„ ๋“ค์€ ์™ธ๋ถ€ ์ƒ์กด์ž๋“ค์ด ํ™ฉ๊ถ ์•„ํŒŒํŠธ๋กœ ๋ชฐ๋ ค๋“ค์ž ์œ„ํ˜‘์„ ๋Š๋ผ๊ธฐ ์‹œ์ž‘ํ•˜๋Š” ์ž…์ฃผ๋ฏผ๋“ค. ์ƒ์กด์„ ์œ„ํ•ด ํ•˜๋‚˜๊ฐ€ ๋œ ๊ทธ๋“ค์€ ์ƒˆ๋กœ์šด ์ฃผ๋ฏผ ๋Œ€ํ‘œ ์˜ํƒ์„ ์ค‘์‹ฌ์œผ๋กœ ์™ธ๋ถ€์ธ์˜ ์ถœ์ž…์„ ์ฒ ์ €ํžˆ ๋ง‰์•„์„  ์ฑ„ ์•„ํŒŒํŠธ ์ฃผ๋ฏผ๋งŒ์„ ์œ„ํ•œ ์ƒˆ๋กœ์šด ๊ทœ์น™์„ ๋งŒ๋“ ๋‹ค. ๋•๋ถ„์— ์ง€์˜ฅ ๊ฐ™์€ ๋ฐ”๊นฅ ์„ธ์ƒ๊ณผ ๋‹ฌ๋ฆฌ ์ฃผ๋ฏผ๋“ค์—๊ฒ ๋” ์—†์ด ์•ˆ์ „ํ•˜๊ณ  ํ‰ํ™”๋กœ์šด ์œ ํ† ํ”ผ์•„ ํ™ฉ๊ถ ์•„ํŒŒํŠธ. ํ•˜์ง€๋งŒ ๋์ด ์—†๋Š” ์ƒ์กด์˜ ์œ„๊ธฐ ์† ๊ทธ๋“ค ์‚ฌ์ด์—์„œ๋„ ์˜ˆ์ƒ์น˜ ๋ชปํ•œ ๊ฐˆ๋“ฑ์ด ์‹œ์ž‘๋˜๋Š”๋ฐ...", + "popularity": 22.278, + "poster_path": "/9dENCKupUckoT1WgOohHMZfVl61.jpg", + "release_date": "2023-08-09", + "title": "์ฝ˜ํฌ๋ฆฌํŠธ ์œ ํ† ํ”ผ์•„", + "video": false, + "vote_average": 8, + "vote_count": 3 + } + ], + "total_pages": 5, + "total_results": 83 + } \ No newline at end of file diff --git a/mission/chapter04/mission/src/rootlayout.jsx b/mission/chapter04/mission/src/rootlayout.jsx new file mode 100644 index 0000000..79341e5 --- /dev/null +++ b/mission/chapter04/mission/src/rootlayout.jsx @@ -0,0 +1,20 @@ +import Navbar from './components/navbar.jsx'; +import Sidebar from './components/sidebar.jsx'; +import * as S from './styles/layout.style.jsx'; +import { Outlet } from 'react-router-dom'; + +const RootLayout = () => { + return ( + + + + + + + + + + ); +}; + +export default RootLayout; diff --git a/mission/chapter04/mission/src/styles/category.style.jsx b/mission/chapter04/mission/src/styles/category.style.jsx new file mode 100644 index 0000000..459a496 --- /dev/null +++ b/mission/chapter04/mission/src/styles/category.style.jsx @@ -0,0 +1,38 @@ +import styled from 'styled-components'; + +export const Container = styled.div` + padding: 10px; + h2 { + color: white; + margin-bottom: 10px; + font-size: 20px; + } +`; + +export const CategoryList = styled.div` + display: flex; + gap: 30px; +`; + +export const CategoryBox = styled.div` + width: 250px; + height: 150px; + background-image: url(${({ image }) => image}); + background-size: cover; + background-position: center; + border-radius: 10px; + position: relative; +`; + +export const CategoryTitle = styled.div` + position: absolute; + bottom: 7px; + left: 7px; + width: cover; + padding: 8px; + background-color: rgba(0, 0, 0, 0.6); + color: white; + font-weight: bold; + font-size: 15px; + border-radius: 10px; +`; diff --git a/mission/chapter04/mission/src/styles/layout.style.jsx b/mission/chapter04/mission/src/styles/layout.style.jsx new file mode 100644 index 0000000..e8767a1 --- /dev/null +++ b/mission/chapter04/mission/src/styles/layout.style.jsx @@ -0,0 +1,27 @@ +import styled from 'styled-components'; + +export const Container = styled.div` + display: flex; + flex-direction: column; + height: 100vh; + background-color: black; +`; + +export const Main = styled.div` + display: flex; + flex: 1; + overflow: hidden; +`; + +export const Sidebar = styled.div` + width: 250px; + background-color: white; + padding: 20px; + box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1); +`; + +export const Content = styled.div` + flex: 1; + padding: 20px; + overflow-y: auto; +`; diff --git a/mission/chapter04/mission/src/styles/movies.style.jsx b/mission/chapter04/mission/src/styles/movies.style.jsx new file mode 100644 index 0000000..b2bc1ac --- /dev/null +++ b/mission/chapter04/mission/src/styles/movies.style.jsx @@ -0,0 +1,9 @@ +import styled from 'styled-components'; + +export const CardList = styled.div` + display: grid; + grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); + gap: 2px; + padding: 5px; + justify-items: center; +`; diff --git a/mission/chapter04/mission/src/styles/navbar.style.jsx b/mission/chapter04/mission/src/styles/navbar.style.jsx new file mode 100644 index 0000000..7f0bf40 --- /dev/null +++ b/mission/chapter04/mission/src/styles/navbar.style.jsx @@ -0,0 +1,53 @@ +import styled from 'styled-components'; + +export const Navbar = styled.nav` + background-color: #1a2c43; + color: white; + padding: 15px 30px; + display: flex; + justify-content: space-between; + align-items: center; +`; + +export const BrandButton = styled.button` + background: none; + border: none; + color: red; + font-size: 1.5em; + cursor: pointer; + + &:hover { + color: white; + } +`; + +export const Wrapper = styled.div` + display: flex; + align-items: center; +`; + +export const LoginButton = styled.button` + background: none; + border: none; + font-size: 1em; + color: #b0b5c1; + cursor: pointer; + margin-right: 20px; + + &:hover { + color: white; + } +`; + +export const SignupButton = styled.button` + background-color: red; + color: white; + border: none; + padding: 8px 15px; + border-radius: 20px; + font-size: 0.9em; + + &:hover { + background-color: #e73636; + } +`; diff --git a/mission/chapter04/mission/src/styles/sidebar.style.jsx b/mission/chapter04/mission/src/styles/sidebar.style.jsx new file mode 100644 index 0000000..89a1d01 --- /dev/null +++ b/mission/chapter04/mission/src/styles/sidebar.style.jsx @@ -0,0 +1,20 @@ +import styled from 'styled-components'; + +export const Sidebar = styled.div` + width: 15%; + height: 100%; + background-color: #1a2c43; + padding: 10px; + + ul { + list-style: none; + padding: 0; + + li { + margin-bottom: 20px; + margin-left: 10px; + font-size: 1.2em; + color: #ffffff; + } + } +`; diff --git a/mission/chapter04/mission/vite.config.js b/mission/chapter04/mission/vite.config.js new file mode 100644 index 0000000..5a33944 --- /dev/null +++ b/mission/chapter04/mission/vite.config.js @@ -0,0 +1,7 @@ +import { defineConfig } from 'vite' +import react from '@vitejs/plugin-react' + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [react()], +}) From fe98209fb5ac77f7cebdfd127deae432912e0f6d Mon Sep 17 00:00:00 2001 From: hyuke81 Date: Sat, 2 Nov 2024 04:25:30 +0900 Subject: [PATCH 3/5] feat: chapter04 nowplaying --- .../mission/src/components/category/nowplaying.jsx | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/mission/chapter04/mission/src/components/category/nowplaying.jsx b/mission/chapter04/mission/src/components/category/nowplaying.jsx index 3186d95..d1905c2 100644 --- a/mission/chapter04/mission/src/components/category/nowplaying.jsx +++ b/mission/chapter04/mission/src/components/category/nowplaying.jsx @@ -13,13 +13,16 @@ const Nowplaying = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc&with_release_type=2|3&release_date.gte={min_date}&release_date.lte={max_date}`); if (isLoading) { - return

๋กœ๋”ฉ์ค‘ ์ž…๋‹ˆ๋‹ค...

; + return
+

loading...

+
; } if (isError) { - return

์—๋Ÿฌ ๋ฐœ์ƒ

; + return
+

Error...

+
; } - return ( {Array.isArray(movies) && movies.map((movie) => ( From aa103eefc49be537e5c256df30a25861ddfcc6c0 Mon Sep 17 00:00:00 2001 From: hyuke81 Date: Sat, 2 Nov 2024 22:04:31 +0900 Subject: [PATCH 4/5] feat: chapter04 mission movie detail page --- .../mission/src/components/movieidpage.jsx | 52 +++++++++++-------- 1 file changed, 30 insertions(+), 22 deletions(-) diff --git a/mission/chapter04/mission/src/components/movieidpage.jsx b/mission/chapter04/mission/src/components/movieidpage.jsx index 1b97677..9c80894 100644 --- a/mission/chapter04/mission/src/components/movieidpage.jsx +++ b/mission/chapter04/mission/src/components/movieidpage.jsx @@ -37,22 +37,21 @@ const MovieDetails = styled.p` const MovieOverview = styled.p` margin-top: 15px; - line-height: 1.5; `; const CastContainer = styled.div` - margin-top: 40px; + margin-top: 30px; `; const CastTitle = styled.h2` - font-size: 24px; + font-size: 22px; margin-bottom: 20px; `; const CastList = styled.div` display: flex; flex-wrap: wrap; - gap: 15px; + gap: 13px; `; const CastItem = styled.div` @@ -63,26 +62,34 @@ const CastItem = styled.div` `; const CastImage = styled.img` - width: 100px; - height: 100px; + width: 80px; + height: 80px; border-radius: 50%; object-fit: cover; margin-bottom: 10px; `; const CastName = styled.p` - font-size: 14px; + font-size: 12px; margin: 0; text-align: center; `; const CastCharacter = styled.p` - font-size: 12px; - color: #aaa; + font-size: 10px; + color: gray; margin: 0; text-align: center; `; +const NoneCastPlace = styled.div` + width: 80px; + height: 80px; + border-radius: 50%; + background-color: gray; + margin-bottom: 10px; +` + const MovieIdPage = () => { const { movieId } = useParams(); console.log('Movie Id:', movieId); @@ -99,6 +106,7 @@ const MovieIdPage = () => { return

Error...

; } + //๋นˆ ๋ฐ์ดํ„ฐ ๋ฐ˜ํ™˜์‹œ ์˜ˆ์™ธ ์ฒ˜๋ฆฌ if (!movie || Object.keys(movie).length === 0) { return

No movie data found

; } @@ -110,7 +118,7 @@ const MovieIdPage = () => { {movie.title || movie.original_title} โญ{movie.vote_average} {new Date(movie.release_date).getFullYear()} - ์ƒ์˜ ์‹œ๊ฐ„: {movie.runtime}๋ถ„ + {movie.runtime}๋ถ„ {movie.overview} @@ -119,21 +127,21 @@ const MovieIdPage = () => { ๊ฐ๋…/์ถœ์—ฐ {movie_credits && movie_credits.cast ? ( - {movie_credits.cast.slice(0, 12).map((castMember) => ( - + {movie_credits.cast.slice(0, 12).map((castMember) => ( + + {castMember.profile_path ? ( - {castMember.name} - ({castMember.character}) - - ))} - + ) : ( + + )} + {castMember.name} + ({castMember.character}) + + ))} + ) : (

์ถœ์—ฐ์ง„ ์ •๋ณด๊ฐ€ ์—†์Šต๋‹ˆ๋‹ค.

)} From 0bc38698f176d8b108a7995d183ab3ae9090770b Mon Sep 17 00:00:00 2001 From: hyuke81 Date: Sat, 2 Nov 2024 23:34:01 +0900 Subject: [PATCH 5/5] feat: chapter04 mission loading & error change useCustom hook --- .../mission/src/components/MoviesPage.jsx | 16 ++++++---------- .../src/components/category/nowplaying.jsx | 17 +++++++---------- .../mission/src/components/category/popular.jsx | 16 ++++++---------- .../src/components/category/toprated.jsx | 16 ++++++---------- .../src/components/category/upcoming.jsx | 16 ++++++---------- .../mission/src/components/movieidpage.jsx | 15 +++++++-------- .../mission/src/hooks/useCustomError.js | 13 +++++++++++++ .../mission/src/hooks/useCustomLoading.js | 13 +++++++++++++ 8 files changed, 64 insertions(+), 58 deletions(-) create mode 100644 mission/chapter04/mission/src/hooks/useCustomError.js create mode 100644 mission/chapter04/mission/src/hooks/useCustomLoading.js diff --git a/mission/chapter04/mission/src/components/MoviesPage.jsx b/mission/chapter04/mission/src/components/MoviesPage.jsx index 25fb73d..66fef57 100644 --- a/mission/chapter04/mission/src/components/MoviesPage.jsx +++ b/mission/chapter04/mission/src/components/MoviesPage.jsx @@ -2,6 +2,8 @@ import { useState } from "react"; import Card from "../components/Card.jsx"; import * as S from '../styles/movies.style.jsx'; import useCustomFetch from "../hooks/useCustomFetch.js"; +import useCustomLoading from "../hooks/useCustomLoading.js"; +import useCustomError from "../hooks/useCustomError.js"; const MoviesPage = () => { const [clickedMovie, setClickedMovie] = useState(null); @@ -12,17 +14,11 @@ const MoviesPage = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/movie/popular?language=ko-KR&page=1`); - if (isLoading) { - return
-

loading...

-
; - } + const loadingComponent = useCustomLoading(isLoading); + const errorComponent = useCustomError(isError); - if (isError) { - return
-

Error...

-
; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; return ( diff --git a/mission/chapter04/mission/src/components/category/nowplaying.jsx b/mission/chapter04/mission/src/components/category/nowplaying.jsx index d1905c2..781d8ef 100644 --- a/mission/chapter04/mission/src/components/category/nowplaying.jsx +++ b/mission/chapter04/mission/src/components/category/nowplaying.jsx @@ -2,6 +2,8 @@ import { useState } from "react"; import Card from "../Card.jsx"; import * as S from '../../styles/movies.style.jsx'; import useCustomFetch from "../../hooks/useCustomFetch.js"; +import useCustomLoading from "../../hooks/useCustomLoading.js"; +import useCustomError from "../../hooks/useCustomError.js"; const Nowplaying = () => { const [clickedMovie, setClickedMovie] = useState(null); @@ -12,17 +14,12 @@ const Nowplaying = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc&with_release_type=2|3&release_date.gte={min_date}&release_date.lte={max_date}`); - if (isLoading) { - return
-

loading...

-
; - } + const loadingComponent = useCustomLoading(isLoading); + const errorComponent = useCustomError(isError); - if (isError) { - return
-

Error...

-
; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; + return ( {Array.isArray(movies) && movies.map((movie) => ( diff --git a/mission/chapter04/mission/src/components/category/popular.jsx b/mission/chapter04/mission/src/components/category/popular.jsx index 0c96717..82715ea 100644 --- a/mission/chapter04/mission/src/components/category/popular.jsx +++ b/mission/chapter04/mission/src/components/category/popular.jsx @@ -2,6 +2,8 @@ import { useState } from "react"; import Card from "../Card.jsx"; import * as S from '../../styles/movies.style.jsx'; import useCustomFetch from "../../hooks/useCustomFetch.js"; +import useCustomLoading from "../../hooks/useCustomLoading.js"; +import useCustomError from "../../hooks/useCustomError.js"; const Popular = () => { const [clickedMovie, setClickedMovie] = useState(null); @@ -13,17 +15,11 @@ const Popular = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc`); - if (isLoading) { - return
-

loading...

-
; - } + const loadingComponent = useCustomLoading(isLoading); + const errorComponent = useCustomError(isError); - if (isError) { - return
-

Error...

-
; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; return ( diff --git a/mission/chapter04/mission/src/components/category/toprated.jsx b/mission/chapter04/mission/src/components/category/toprated.jsx index a99925a..995ac3c 100644 --- a/mission/chapter04/mission/src/components/category/toprated.jsx +++ b/mission/chapter04/mission/src/components/category/toprated.jsx @@ -2,6 +2,8 @@ import { useState } from "react"; import Card from "../Card.jsx"; import * as S from '../../styles/movies.style.jsx'; import useCustomFetch from "../../hooks/useCustomFetch.js"; +import useCustomLoading from "../../hooks/useCustomLoading.js"; +import useCustomError from "../../hooks/useCustomError.js"; const Toprated = () => { const [clickedMovie, setClickedMovie] = useState(null); @@ -12,17 +14,11 @@ const Toprated = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=vote_average.desc&without_genres=99,10755&vote_count.gte=200`); - if (isLoading) { - return
-

loading...

-
; - } + const loadingComponent = useCustomLoading(isLoading); + const errorComponent = useCustomError(isError); - if (isError) { - return
-

Error...

-
; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; return ( diff --git a/mission/chapter04/mission/src/components/category/upcoming.jsx b/mission/chapter04/mission/src/components/category/upcoming.jsx index 8afd588..05d2ebb 100644 --- a/mission/chapter04/mission/src/components/category/upcoming.jsx +++ b/mission/chapter04/mission/src/components/category/upcoming.jsx @@ -2,6 +2,8 @@ import { useState } from "react"; import Card from "../Card.jsx"; import * as S from '../../styles/movies.style.jsx'; import useCustomFetch from "../../hooks/useCustomFetch.js"; +import useCustomLoading from "../../hooks/useCustomLoading.js"; +import useCustomError from "../../hooks/useCustomError.js"; const Upcoming = () => { const [clickedMovie, setClickedMovie] = useState(null); @@ -12,17 +14,11 @@ const Upcoming = () => { const { data: movies, isLoading, isError } = useCustomFetch(`/discover/movie?include_adult=false&include_video=false&language=ko-KR&page=1&sort_by=popularity.desc&with_release_type=2|3&release_date.gte={min_date}&release_date.lte={max_date}`); - if (isLoading) { - return
-

loading...

-
; - } + const loadingComponent = useCustomLoading(isLoading); + const errorComponent = useCustomError(isError); - if (isError) { - return
-

Error...

-
; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; return ( diff --git a/mission/chapter04/mission/src/components/movieidpage.jsx b/mission/chapter04/mission/src/components/movieidpage.jsx index 9c80894..40862f4 100644 --- a/mission/chapter04/mission/src/components/movieidpage.jsx +++ b/mission/chapter04/mission/src/components/movieidpage.jsx @@ -1,7 +1,8 @@ -// MovieIdPage.jsx import { useParams } from 'react-router-dom'; import styled from 'styled-components'; import useCustomFetch from "../hooks/useCustomFetch.js"; +import useCustomLoading from "../hooks/useCustomLoading.js"; +import useCustomError from "../hooks/useCustomError.js"; const MovieDetailContainer = styled.div` color: white; @@ -98,13 +99,11 @@ const MovieIdPage = () => { const { data: movie_credits, isLoading_credits, isError_credits } = useCustomFetch(`/movie/${movieId}/credits?language=ko-KR`); console.log('Movie credits:', movie_credits); - if (isLoading || isLoading_credits) { - return

loading...

; - } + const loadingComponent = useCustomLoading(isLoading || isLoading_credits); + const errorComponent = useCustomError(isError || isError_credits); - if (isError || isError_credits) { - return

Error...

; - } + if (loadingComponent) return loadingComponent; + if (errorComponent) return errorComponent; //๋นˆ ๋ฐ์ดํ„ฐ ๋ฐ˜ํ™˜์‹œ ์˜ˆ์™ธ ์ฒ˜๋ฆฌ if (!movie || Object.keys(movie).length === 0) { @@ -135,7 +134,7 @@ const MovieIdPage = () => { alt={castMember.name} /> ) : ( - + //๋ฐ์ดํ„ฐ ์—†์œผ๋ฉด ๋‹ค๋ฅธ css ์ ์šฉ )} {castMember.name} ({castMember.character}) diff --git a/mission/chapter04/mission/src/hooks/useCustomError.js b/mission/chapter04/mission/src/hooks/useCustomError.js new file mode 100644 index 0000000..78c29ed --- /dev/null +++ b/mission/chapter04/mission/src/hooks/useCustomError.js @@ -0,0 +1,13 @@ +import { useState, useEffect } from "react"; + +const useCustomError = (isError) => { + const [error, setError] = useState(false); + + useEffect(() => { + setError(isError); + }, [isError]); + + return error ?

Error...

: null; +}; + +export default useCustomError; diff --git a/mission/chapter04/mission/src/hooks/useCustomLoading.js b/mission/chapter04/mission/src/hooks/useCustomLoading.js new file mode 100644 index 0000000..df3423b --- /dev/null +++ b/mission/chapter04/mission/src/hooks/useCustomLoading.js @@ -0,0 +1,13 @@ +import { useState, useEffect } from "react"; + +const useCustomLoading = (isLoading) => { + const [loading, setLoading] = useState(false); + + useEffect(() => { + setLoading(isLoading); + }, [isLoading]); + + return loading ?

loading...

: null; +}; + +export default useCustomLoading;