diff --git a/src/pages/nuguPatch/NuguPatch.jsx b/src/pages/nuguPatch/NuguPatch.jsx index 50fea09..6d81ed7 100644 --- a/src/pages/nuguPatch/NuguPatch.jsx +++ b/src/pages/nuguPatch/NuguPatch.jsx @@ -23,12 +23,6 @@ export const NuguPatch = () => { try { const userData = await getNugu(); setUpdateData(userData); - const initialSelectedChips = [ - userData.keyword1, - userData.keyword2, - userData.keyword3, - ]; - handleClickStatus(initialSelectedChips); } catch (err) { console.error("Patch-user정보 가져오기 실패", err); } diff --git a/src/pages/nuguPatch/_hooks/usePatchChip.js b/src/pages/nuguPatch/_hooks/usePatchChip.js index ef3712d..5d40f00 100644 --- a/src/pages/nuguPatch/_hooks/usePatchChip.js +++ b/src/pages/nuguPatch/_hooks/usePatchChip.js @@ -1,23 +1,38 @@ -import { useState } from "react"; +import { useState, useEffect } from "react"; import { useRecoilState } from "recoil"; import { signUpState } from "@atoms/signUpState"; import { CHIP_DATA } from "@constants/chip"; export const usePatchChip = () => { const [updateData, setUpdateData] = useRecoilState(signUpState); const [selectedChip, setSelectedChip] = useState( - CHIP_DATA.map( - (chip) => - updateData.keyword1 === chip || - updateData.keyword2 === chip || - updateData.keyword3 === chip - ) + new Array(CHIP_DATA.length).fill(false) ); const selectedCount = selectedChip.filter((chip) => chip).length; + useEffect(() => { + const initialSelectedChips = [ + updateData.keyword1, + updateData.keyword2, + updateData.keyword3, + ]; + + const updatedChip = [...selectedChip]; + + initialSelectedChips.forEach((keyword) => { + const index = CHIP_DATA.indexOf(keyword); + if (index !== -1) { + updatedChip[index] = true; + } + }); + + setSelectedChip(updatedChip); + }, [updateData]); + const handleClickStatus = (index) => { const updatedChip = [...selectedChip]; console.log(updatedChip); updatedChip[index] = !updatedChip[index]; + if (updatedChip.filter((chip) => chip).length > 3) { return; }