From 4586f2cd95f1cd7112cbec80399da8817df0d289 Mon Sep 17 00:00:00 2001 From: joonhoekim <26rote@gmail.com> Date: Tue, 25 Nov 2025 15:42:00 +0900 Subject: (김준회) dolce: i18n 적용, 상세도면 수정 적용 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/dolce/table/detail-drawing-columns.tsx | 112 +++++++++++++++++++++++++---- 1 file changed, 100 insertions(+), 12 deletions(-) (limited to 'lib/dolce/table') diff --git a/lib/dolce/table/detail-drawing-columns.tsx b/lib/dolce/table/detail-drawing-columns.tsx index c082333d..747173af 100644 --- a/lib/dolce/table/detail-drawing-columns.tsx +++ b/lib/dolce/table/detail-drawing-columns.tsx @@ -3,13 +3,25 @@ import { ColumnDef } from "@tanstack/react-table"; import { DetailDwgReceiptItem } from "../actions"; import { formatDolceDateTime } from "../utils/date-formatter"; +import { useState } from "react"; +import { + Dialog, + DialogContent, + DialogHeader, + DialogTitle, +} from "@/components/ui/dialog"; +import { Button } from "@/components/ui/button"; +import { Edit } from "lucide-react"; // DOLCE API ENM 필드가 제대로 번역되지 않아 직접 매핑 const DRAWING_USAGE_MAP: Record = { APP: { ko: "승인용", en: "Approval" }, WOR: { ko: "작업용", en: "Working" }, + // 참조용은 eVCP에서 사용하지 않으나 추가해둠 + REF: { ko: "참조용", en: "Reference" }, REC: { ko: "입수용", en: "GTT→SHI" }, SUB: { ko: "제출용", en: "SHI→GTT" }, + CMT: { ko: "코멘트", en: "Comment" }, }; const REGISTER_KIND_MAP: Record = { @@ -19,6 +31,19 @@ const REGISTER_KIND_MAP: Record = { WORP: { ko: "작업용 입수도면(Partial)", en: "For Working(Partial)" }, RECW: { ko: "Working 도면입수(GTT→SHI)", en: "Working Dwg(GTT→SHI)" }, RECP: { ko: "Pre. 도면입수(GTT→SHI)", en: "Pre. Dwg(GTT→SHI)" }, + GSUB: { ko: "SHI 입력 문서 (SHI→GTT)", en: "SHI Input Document(SHI→GTT)" }, + CMTQ: { ko: "Comment-TQ", en: "Comment-TQ" }, + CMTM: { ko: "MARK-UP", en: "MARK-UP" }, + // FMEA는 미사용 코드 + "FMEA-R1": { ko: "FMEA 1st Receipt", en: "FMEA 1st Receipt" }, + "FMEA-R2": { ko: "FMEA 2nd Receipt", en: "FMEA 2nd Receipt" }, + "FMEA-1": { ko: "FMEA 1st Submission", en: "FMEA 1st Submission" }, + "FMEA-2": { ko: "FMEA 2nd Submission", en: "FMEA 2nd Submission" }, + // 참조용 도면도 미사용 코드, 번역 받아야 적용 가능 + PREF: { ko: "본선용 참조도면", en: "본선용 참조도면" }, + RREF: { ko: "실적선 참조도면", en: "실적선 참조도면" }, + "PREP-P": { ko: "본선용 참조도면(Partial)", en: "본선용 참조도면(Partial)" }, + "RREP-P": { ko: "실적선 참조도면(Partial)", en: "실적선 참조도면(Partial)" }, }; // 카테고리는 API에서 ENM이 제공되는 것으로 가정 (필요시 추가) @@ -36,11 +61,39 @@ const translateRegisterKind = (code: string | null, lng: string): string => { return lng === "en" ? mapped.en : mapped.ko; }; +// Comment Dialog Component +function CommentDialog({ comment }: { comment: string }) { + const [open, setOpen] = useState(false); + + return ( + <> + + + + + Comment + +
+

{comment || "코멘트가 없습니다."}

+
+
+
+ + ); +} + // 다국어 지원 컬럼 생성 함수 export function createDetailDrawingColumns( lng: string, // eslint-disable-next-line @typescript-eslint/no-explicit-any - t: any + t: any, + onEdit?: (detailDrawing: DetailDwgReceiptItem) => void ): ColumnDef[] { return [ { @@ -78,17 +131,18 @@ export function createDetailDrawingColumns( return
{lng === "en" ? (categoryENM || categoryNM) : (categoryNM || categoryENM)}
; }, }, - { - accessorKey: "DrawingUsage", - header: t("detailDrawing.columns.drawingUsage"), - minSize: 100, - cell: ({ row }) => { - // API 응답의 DrawingUsage는 코드값이므로 직접 매핑하여 번역 - const usageCode = row.getValue("DrawingUsage") as string; - const translated = translateDrawingUsage(usageCode, lng); - return
{translated}
; - }, - }, + // RegisterKind 로 DrawingUsage를 알 수 있으므로 주석 처리 + // { + // accessorKey: "DrawingUsage", + // header: t("detailDrawing.columns.drawingUsage"), + // minSize: 100, + // cell: ({ row }) => { + // // API 응답의 DrawingUsage는 코드값이므로 직접 매핑하여 번역 + // const usageCode = row.getValue("DrawingUsage") as string; + // const translated = translateDrawingUsage(usageCode, lng); + // return
{translated}
; + // }, + // }, { accessorKey: "RegisterKind", header: t("detailDrawing.columns.registerKind"), @@ -119,5 +173,39 @@ export function createDetailDrawingColumns( return
{formatDolceDateTime(date)}
; }, }, + { + accessorKey: "RegisterDesc", + header: "Comment", + minSize: 200, + maxSize: 200, + cell: ({ row }) => { + const comment = row.getValue("RegisterDesc") as string; + return ; + }, + }, + { + id: "actions", + header: t("detailDrawing.columns.actions"), + minSize: 100, + maxSize: 100, + cell: ({ row }) => { + const status = row.getValue("Status") as string; + const isEditable = status === "Submitted"; + + return ( +
+ +
+ ); + }, + }, ]; } -- cgit v1.2.3