"use client"; import React, { useEffect, useState } from "react"; import { useParams } from "next/navigation"; import { Button } from "@/components/ui/button"; import { Loader2 } from "lucide-react"; import { screenApi } from "@/lib/api/screen"; import { ScreenDefinition, LayoutData } from "@/types/screen"; import { useRouter } from "next/navigation"; import { toast } from "sonner"; import { initializeComponents } from "@/lib/registry/components"; import { EditModal } from "@/components/screen/EditModal"; import { ResponsiveLayoutEngine } from "@/components/screen/ResponsiveLayoutEngine"; import { useBreakpoint } from "@/hooks/useBreakpoint"; export default function ScreenViewPage() { const params = useParams(); const router = useRouter(); const screenId = parseInt(params.screenId as string); const [screen, setScreen] = useState(null); const [layout, setLayout] = useState(null); const [loading, setLoading] = useState(true); const [error, setError] = useState(null); const [formData, setFormData] = useState>({}); // 화면 너비에 따라 Y좌표 유지 여부 결정 const [preserveYPosition, setPreserveYPosition] = useState(true); const breakpoint = useBreakpoint(); // 편집 모달 상태 const [editModalOpen, setEditModalOpen] = useState(false); const [editModalConfig, setEditModalConfig] = useState<{ screenId?: number; modalSize?: "sm" | "md" | "lg" | "xl" | "full"; editData?: Record; onSave?: () => void; modalTitle?: string; modalDescription?: string; }>({}); useEffect(() => { const initComponents = async () => { try { console.log("🚀 할당된 화면에서 컴포넌트 시스템 초기화 시작..."); await initializeComponents(); console.log("✅ 할당된 화면에서 컴포넌트 시스템 초기화 완료"); } catch (error) { console.error("❌ 할당된 화면에서 컴포넌트 시스템 초기화 실패:", error); } }; initComponents(); }, []); // 편집 모달 이벤트 리스너 등록 useEffect(() => { const handleOpenEditModal = (event: CustomEvent) => { console.log("🎭 편집 모달 열기 이벤트 수신:", event.detail); setEditModalConfig({ screenId: event.detail.screenId, modalSize: event.detail.modalSize, editData: event.detail.editData, onSave: event.detail.onSave, modalTitle: event.detail.modalTitle, modalDescription: event.detail.modalDescription, }); setEditModalOpen(true); }; // @ts-expect-error - CustomEvent type window.addEventListener("openEditModal", handleOpenEditModal); return () => { // @ts-expect-error - CustomEvent type window.removeEventListener("openEditModal", handleOpenEditModal); }; }, []); useEffect(() => { const loadScreen = async () => { try { setLoading(true); setError(null); // 화면 정보 로드 const screenData = await screenApi.getScreen(screenId); setScreen(screenData); // 레이아웃 로드 try { const layoutData = await screenApi.getLayout(screenId); setLayout(layoutData); } catch (layoutError) { console.warn("레이아웃 로드 실패, 빈 레이아웃 사용:", layoutError); setLayout({ screenId, components: [], gridSettings: { columns: 12, gap: 16, padding: 16, enabled: true, size: 8, color: "#e0e0e0", opacity: 0.5, snapToGrid: true, }, }); } } catch (error) { console.error("화면 로드 실패:", error); setError("화면을 불러오는데 실패했습니다."); toast.error("화면을 불러오는데 실패했습니다."); } finally { setLoading(false); } }; if (screenId) { loadScreen(); } }, [screenId]); // 윈도우 크기 변경 감지 - layout이 로드된 후에만 실행 useEffect(() => { if (!layout) return; const screenWidth = layout?.screenResolution?.width || 1200; const handleResize = () => { const shouldPreserve = window.innerWidth >= screenWidth - 100; setPreserveYPosition(shouldPreserve); }; window.addEventListener("resize", handleResize); // 초기 값도 설정 handleResize(); return () => window.removeEventListener("resize", handleResize); }, [layout]); if (loading) { return (

화면을 불러오는 중...

); } if (error || !screen) { return (
⚠️

화면을 찾을 수 없습니다

{error || "요청하신 화면이 존재하지 않습니다."}

); } // 화면 해상도 정보가 있으면 해당 크기로, 없으면 기본 크기 사용 const screenWidth = layout?.screenResolution?.width || 1200; return (
{/* 항상 반응형 모드로 렌더링 */} {layout && layout.components.length > 0 ? ( { console.log("📝 page.tsx formData 업데이트:", fieldName, value); setFormData((prev) => ({ ...prev, [fieldName]: value })); }} screenInfo={{ id: screenId, tableName: screen?.tableName }} /> ) : ( // 빈 화면일 때
📄

화면이 비어있습니다

이 화면에는 아직 설계된 컴포넌트가 없습니다.

)}
{/* 편집 모달 */} { setEditModalOpen(false); setEditModalConfig({}); }} screenId={editModalConfig.screenId} modalSize={editModalConfig.modalSize} editData={editModalConfig.editData} onSave={editModalConfig.onSave} modalTitle={editModalConfig.modalTitle} modalDescription={editModalConfig.modalDescription} onDataChange={(changedFormData) => { console.log("📝 EditModal에서 데이터 변경 수신:", changedFormData); // 변경된 데이터를 메인 폼에 반영 setFormData((prev) => { const updatedFormData = { ...prev, ...changedFormData, // 변경된 필드들만 업데이트 }; console.log("📊 메인 폼 데이터 업데이트:", updatedFormData); return updatedFormData; }); }} />
); }