|
1 | 1 | "use client"; |
2 | 2 |
|
| 3 | +import { useState } from "react"; |
3 | 4 | import { useSurveyRecommendation } from "./_hooks/useSurveyRecommendation"; |
| 5 | +import NavBar from "./_components/NavBar"; |
4 | 6 | import RecommendationPanel from "./_components/RecommendationPanel"; |
5 | 7 | import MapView from "./_components/MapView"; |
6 | 8 | import RetrySurveyButton from "./_components/RetrySurveyButton"; |
7 | 9 | import SatisfactionModalButton from "./_components/SatisfactionModalButton"; |
8 | 10 | import TransitionScreen from "@/app/_components/TransitionScreen"; |
9 | | -import NavBar from "./_components/NavBar"; |
| 11 | +import Modal from "@/components/Modal"; |
| 12 | +import SatisfactionModalContent from "./_components/MapView/SatisfactionModalContent"; |
10 | 13 |
|
11 | 14 | export default function RecommendPage() { |
| 15 | + const [isOpen, setIsOpen] = useState(false); |
| 16 | + |
12 | 17 | const { spaceData, isLoading, error } = useSurveyRecommendation(); |
13 | 18 |
|
14 | 19 | if (isLoading) return <TransitionScreen type="toRecommend" />; |
15 | | - |
16 | | - // 에러 페이지 시안 완성되면 변경 |
17 | | - if (error) return <div>{error}</div>; |
| 20 | + if (error) return <div>{error}</div>; // 에러 페이지 시안 완성되면 변경 |
18 | 21 |
|
19 | 22 | return ( |
20 | | - <div className="relative h-screen overflow-hidden bg-white"> |
21 | | - <div className="absolute inset-0 z-0 pt-10 sm:pt-0"> |
22 | | - <div className="flex h-[50vh] w-screen sm:ml-auto sm:h-screen sm:w-[50vw] sm:min-w-[calc(100vw-750px)]"> |
23 | | - <MapView spaceData={spaceData} /> |
24 | | - </div> |
25 | | - </div> |
26 | | - <div className="pointer-events-none relative z-10"> |
27 | | - <div className="flex h-screen flex-col sm:flex-row"> |
28 | | - <NavBar /> |
29 | | - <RecommendationPanel spaceData={spaceData} /> |
| 23 | + <> |
| 24 | + <div className="relative h-screen overflow-hidden bg-white"> |
| 25 | + <div className="absolute inset-0 z-0 pt-10 sm:pt-0"> |
| 26 | + <div className="flex h-[50vh] w-screen sm:ml-auto sm:h-screen sm:w-[50vw] sm:min-w-[calc(100vw-750px)]"> |
| 27 | + <MapView spaceData={spaceData} /> |
| 28 | + </div> |
30 | 29 | </div> |
31 | | - <div className="pointer-events-auto fixed top-14 right-4 flex gap-2 sm:top-5 sm:right-5 sm:gap-5"> |
32 | | - <RetrySurveyButton /> |
33 | | - <SatisfactionModalButton /> |
| 30 | + <div className="pointer-events-none relative z-10"> |
| 31 | + <div className="flex h-screen flex-col sm:flex-row"> |
| 32 | + <NavBar /> |
| 33 | + <RecommendationPanel spaceData={spaceData} /> |
| 34 | + </div> |
| 35 | + <div className="pointer-events-auto fixed top-14 right-4 flex gap-2 sm:top-5 sm:right-5 sm:gap-5"> |
| 36 | + <RetrySurveyButton /> |
| 37 | + <SatisfactionModalButton onOpen={() => setIsOpen(true)} /> |
| 38 | + </div> |
34 | 39 | </div> |
35 | 40 | </div> |
36 | | - </div> |
| 41 | + <Modal isOpen={isOpen} onClose={() => setIsOpen(false)}> |
| 42 | + <SatisfactionModalContent onClose={() => setIsOpen(false)} /> |
| 43 | + </Modal> |
| 44 | + </> |
37 | 45 | ); |
38 | 46 | } |
0 commit comments