diff options
| author | joonhoekim <26rote@gmail.com> | 2025-11-27 18:26:06 +0900 |
|---|---|---|
| committer | joonhoekim <26rote@gmail.com> | 2025-11-27 18:26:06 +0900 |
| commit | 5ca88c4869be338f4b0e506a679e4dc4e029d7aa (patch) | |
| tree | 058406a36ccb7090ae61ec686dbb007146818187 /app | |
| parent | 5870b73785715d1585531e655c06d8c068eb64ac (diff) | |
(김준회) dolce v2로 전환, 미사용 라우터들 비활성화 처리 (prefix: _)
Diffstat (limited to 'app')
| -rw-r--r-- | app/[lng]/partners/(partners)/_document-upload/page.tsx (renamed from app/[lng]/partners/(partners)/document-upload/page.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/_dolce-upload-v3/dolce-upload-page-v3.tsx (renamed from app/[lng]/partners/(partners)/dolce-upload-v3/dolce-upload-page-v3.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/_dolce-upload-v3/page.tsx (renamed from app/[lng]/partners/(partners)/dolce-upload-v3/page.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/_dolce-upload/dolce-upload-page.tsx (renamed from app/[lng]/partners/(partners)/dolce-upload/dolce-upload-page.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/_dolce-upload/page.tsx (renamed from app/[lng]/partners/(partners)/dolce-upload/page.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/document-list-ship-legacy/page.tsx | 145 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/document-list-ship/dolce-upload-page-v2.tsx (renamed from app/[lng]/partners/(partners)/dolce-upload-v2/dolce-upload-page-v2.tsx) | 0 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/document-list-ship/page.tsx | 200 | ||||
| -rw-r--r-- | app/[lng]/partners/(partners)/dolce-upload-v2/page.tsx | 69 |
9 files changed, 207 insertions, 207 deletions
diff --git a/app/[lng]/partners/(partners)/document-upload/page.tsx b/app/[lng]/partners/(partners)/_document-upload/page.tsx index c67a603c..c67a603c 100644 --- a/app/[lng]/partners/(partners)/document-upload/page.tsx +++ b/app/[lng]/partners/(partners)/_document-upload/page.tsx diff --git a/app/[lng]/partners/(partners)/dolce-upload-v3/dolce-upload-page-v3.tsx b/app/[lng]/partners/(partners)/_dolce-upload-v3/dolce-upload-page-v3.tsx index 55bedb38..55bedb38 100644 --- a/app/[lng]/partners/(partners)/dolce-upload-v3/dolce-upload-page-v3.tsx +++ b/app/[lng]/partners/(partners)/_dolce-upload-v3/dolce-upload-page-v3.tsx diff --git a/app/[lng]/partners/(partners)/dolce-upload-v3/page.tsx b/app/[lng]/partners/(partners)/_dolce-upload-v3/page.tsx index f62f486b..f62f486b 100644 --- a/app/[lng]/partners/(partners)/dolce-upload-v3/page.tsx +++ b/app/[lng]/partners/(partners)/_dolce-upload-v3/page.tsx diff --git a/app/[lng]/partners/(partners)/dolce-upload/dolce-upload-page.tsx b/app/[lng]/partners/(partners)/_dolce-upload/dolce-upload-page.tsx index 1bb876fb..1bb876fb 100644 --- a/app/[lng]/partners/(partners)/dolce-upload/dolce-upload-page.tsx +++ b/app/[lng]/partners/(partners)/_dolce-upload/dolce-upload-page.tsx diff --git a/app/[lng]/partners/(partners)/dolce-upload/page.tsx b/app/[lng]/partners/(partners)/_dolce-upload/page.tsx index 4d7b1a74..4d7b1a74 100644 --- a/app/[lng]/partners/(partners)/dolce-upload/page.tsx +++ b/app/[lng]/partners/(partners)/_dolce-upload/page.tsx diff --git a/app/[lng]/partners/(partners)/document-list-ship-legacy/page.tsx b/app/[lng]/partners/(partners)/document-list-ship-legacy/page.tsx new file mode 100644 index 00000000..c70a0c03 --- /dev/null +++ b/app/[lng]/partners/(partners)/document-list-ship-legacy/page.tsx @@ -0,0 +1,145 @@ +// page.tsx (간단한 Promise 생성과 로그인 처리) +import * as React from "react" +import { type SearchParams } from "@/types/table" +import { getValidFilters } from "@/lib/data-table" +import { Skeleton } from "@/components/ui/skeleton" +import { DataTableSkeleton } from "@/components/data-table/data-table-skeleton" +import { Shell } from "@/components/shell" +import { searchParamsShipDocuCache } from "@/lib/vendor-document-list/validations" +import { getServerSession } from "next-auth" +import { authOptions } from "@/app/api/auth/[...nextauth]/route" +import Link from "next/link" +import { Button } from "@/components/ui/button" +import { LogIn } from "lucide-react" +import { getUserVendorDocumentStats, getUserVendorDocuments } from "@/lib/vendor-document-list/enhanced-document-service" +import { UserVendorDocumentDisplay } from "@/components/ship-vendor-document/user-vendor-document-table-container" +import { InformationButton } from "@/components/information/information-button" +interface IndexPageProps { + searchParams: Promise<SearchParams> +} + +export default async function IndexPage(props: IndexPageProps) { + const searchParams = await props.searchParams + const search = searchParamsShipDocuCache.parse(searchParams) + const validFilters = getValidFilters(search.filters) + + // Get session + const session = await getServerSession(authOptions) + + // Check if user is logged in + if (!session || !session.user) { + return ( + <Shell className="gap-6"> + <div className="flex items-center justify-between"> + <div> + <div className="flex items-center gap-2"> + <h2 className="text-2xl font-bold tracking-tight"> + 문서 관리 + </h2> + </div> + {/* <p className="text-muted-foreground"> + 소속 회사의 모든 도서/도면을 확인하고 관리합니다. + </p> */} + </div> + </div> + + <div className="flex flex-col items-center justify-center py-12 text-center"> + <div className="rounded-lg border border-dashed p-10 shadow-sm"> + <h3 className="mb-2 text-xl font-semibold">로그인이 필요합니다</h3> + <p className="mb-6 text-muted-foreground"> + 문서를 확인하려면 먼저 로그인하세요. + </p> + <Button size="lg" asChild> + <Link href="/partners"> + <LogIn className="mr-2 h-4 w-4" /> + 로그인하기 + </Link> + </Button> + </div> + </div> + </Shell> + ) + } + + // User is logged in, get user ID + const requesterId = session.user.id ? Number(session.user.id) : null + + if (!requesterId) { + return ( + <Shell className="gap-6"> + <div className="flex items-center justify-between"> + <div> + <h2 className="text-2xl font-bold tracking-tight"> + Document Management + </h2> + </div> + </div> + <div className="flex flex-col items-center justify-center py-12 text-center"> + <div className="rounded-lg border border-dashed p-10 shadow-sm"> + <h3 className="mb-2 text-xl font-semibold">계정 오류</h3> + <p className="mb-6 text-muted-foreground"> + 사용자 정보가 올바르게 설정되지 않았습니다. 관리자에게 문의하세요. + </p> + </div> + </div> + </Shell> + ) + } + + // 검색 파라미터 정리 + const searchInput = { + ...search, + filters: validFilters, + } + + // Promise 생성 (모든 데이터를 페이지에서 처리) + const documentsPromise = getUserVendorDocuments(requesterId, searchInput) + const statsPromise = getUserVendorDocumentStats(requesterId) + + // Promise.all로 감싸서 전달 + const allPromises = Promise.all([documentsPromise, statsPromise]) + + const statsResult = await documentsPromise + const vendorName = statsResult.vendorInfo?.vendorName || "내 회사" + + + return ( + <Shell className="gap-2"> + <div className="flex items-center justify-between space-y-2"> + <div> + <div className="flex items-center gap-2"> + <h2 className="text-2xl font-bold tracking-tight"> + {vendorName} Document Management + </h2> + <InformationButton pagePath="partners/document-list-ship" /> + </div> + + <p className="text-muted-foreground"> + + </p> + </div> + </div> + + <React.Suspense fallback={<Skeleton className="h-7 w-52" />}> + {/* DateRangePicker can go here */} + </React.Suspense> + + <React.Suspense + fallback={ + <DataTableSkeleton + columnCount={8} + searchableColumnCount={1} + filterableColumnCount={3} + cellWidths={["10rem", "30rem", "15rem", "15rem", "15rem", "15rem", "8rem", "8rem"]} + shrinkZero + /> + } + > + <UserVendorDocumentDisplay + allPromises={allPromises} + /> + </React.Suspense> + </Shell> + ) +} + diff --git a/app/[lng]/partners/(partners)/dolce-upload-v2/dolce-upload-page-v2.tsx b/app/[lng]/partners/(partners)/document-list-ship/dolce-upload-page-v2.tsx index 29b41136..29b41136 100644 --- a/app/[lng]/partners/(partners)/dolce-upload-v2/dolce-upload-page-v2.tsx +++ b/app/[lng]/partners/(partners)/document-list-ship/dolce-upload-page-v2.tsx diff --git a/app/[lng]/partners/(partners)/document-list-ship/page.tsx b/app/[lng]/partners/(partners)/document-list-ship/page.tsx index c70a0c03..9ce7c6c6 100644 --- a/app/[lng]/partners/(partners)/document-list-ship/page.tsx +++ b/app/[lng]/partners/(partners)/document-list-ship/page.tsx @@ -1,145 +1,69 @@ -// page.tsx (간단한 Promise 생성과 로그인 처리) -import * as React from "react" -import { type SearchParams } from "@/types/table" -import { getValidFilters } from "@/lib/data-table" -import { Skeleton } from "@/components/ui/skeleton" -import { DataTableSkeleton } from "@/components/data-table/data-table-skeleton" -import { Shell } from "@/components/shell" -import { searchParamsShipDocuCache } from "@/lib/vendor-document-list/validations" -import { getServerSession } from "next-auth" -import { authOptions } from "@/app/api/auth/[...nextauth]/route" -import Link from "next/link" -import { Button } from "@/components/ui/button" -import { LogIn } from "lucide-react" -import { getUserVendorDocumentStats, getUserVendorDocuments } from "@/lib/vendor-document-list/enhanced-document-service" -import { UserVendorDocumentDisplay } from "@/components/ship-vendor-document/user-vendor-document-table-container" -import { InformationButton } from "@/components/information/information-button" -interface IndexPageProps { - searchParams: Promise<SearchParams> -} - -export default async function IndexPage(props: IndexPageProps) { - const searchParams = await props.searchParams - const search = searchParamsShipDocuCache.parse(searchParams) - const validFilters = getValidFilters(search.filters) - - // Get session - const session = await getServerSession(authOptions) - - // Check if user is logged in - if (!session || !session.user) { - return ( - <Shell className="gap-6"> - <div className="flex items-center justify-between"> - <div> - <div className="flex items-center gap-2"> - <h2 className="text-2xl font-bold tracking-tight"> - 문서 관리 - </h2> - </div> - {/* <p className="text-muted-foreground"> - 소속 회사의 모든 도서/도면을 확인하고 관리합니다. - </p> */} - </div> - </div> - - <div className="flex flex-col items-center justify-center py-12 text-center"> - <div className="rounded-lg border border-dashed p-10 shadow-sm"> - <h3 className="mb-2 text-xl font-semibold">로그인이 필요합니다</h3> - <p className="mb-6 text-muted-foreground"> - 문서를 확인하려면 먼저 로그인하세요. - </p> - <Button size="lg" asChild> - <Link href="/partners"> - <LogIn className="mr-2 h-4 w-4" /> - 로그인하기 - </Link> - </Button> - </div> - </div> - </Shell> - ) - } - - // User is logged in, get user ID - const requesterId = session.user.id ? Number(session.user.id) : null +import { Suspense } from "react"; +import { Skeleton } from "@/components/ui/skeleton"; +import { Card, CardContent, CardHeader } from "@/components/ui/card"; +import DolceUploadPageV2 from "./dolce-upload-page-v2"; +import { Shell } from "@/components/shell"; - if (!requesterId) { - return ( - <Shell className="gap-6"> - <div className="flex items-center justify-between"> - <div> - <h2 className="text-2xl font-bold tracking-tight"> - Document Management - </h2> - </div> - </div> - <div className="flex flex-col items-center justify-center py-12 text-center"> - <div className="rounded-lg border border-dashed p-10 shadow-sm"> - <h3 className="mb-2 text-xl font-semibold">계정 오류</h3> - <p className="mb-6 text-muted-foreground"> - 사용자 정보가 올바르게 설정되지 않았습니다. 관리자에게 문의하세요. - </p> - </div> - </div> - </Shell> - ) - } +export const metadata = { + title: "조선 벤더문서 업로드(DOLCE) V2", + description: "조선 설계문서 업로드 및 관리 - 분할 레이아웃", +}; - // 검색 파라미터 정리 - const searchInput = { - ...search, - filters: validFilters, - } +// ============================================================================ +// 로딩 스켈레톤 +// ============================================================================ - // Promise 생성 (모든 데이터를 페이지에서 처리) - const documentsPromise = getUserVendorDocuments(requesterId, searchInput) - const statsPromise = getUserVendorDocumentStats(requesterId) - - // Promise.all로 감싸서 전달 - const allPromises = Promise.all([documentsPromise, statsPromise]) - - const statsResult = await documentsPromise - const vendorName = statsResult.vendorInfo?.vendorName || "내 회사" - - - return ( - <Shell className="gap-2"> - <div className="flex items-center justify-between space-y-2"> - <div> - <div className="flex items-center gap-2"> - <h2 className="text-2xl font-bold tracking-tight"> - {vendorName} Document Management - </h2> - <InformationButton pagePath="partners/document-list-ship" /> - </div> - - <p className="text-muted-foreground"> - - </p> - </div> - </div> +function DolceUploadSkeleton() { + return ( + <div className="space-y-4"> + <Card> + <CardHeader> + <Skeleton className="h-8 w-48" /> + </CardHeader> + <CardContent> + <Skeleton className="h-32 w-full" /> + </CardContent> + </Card> + <Card> + <CardHeader> + <Skeleton className="h-8 w-48" /> + </CardHeader> + <CardContent> + <Skeleton className="h-96 w-full" /> + </CardContent> + </Card> + </div> + ); +} - <React.Suspense fallback={<Skeleton className="h-7 w-52" />}> - {/* DateRangePicker can go here */} - </React.Suspense> +export default async function DolceUploadPageWrapper({ + params, + searchParams, +}: { + params: Promise<{ lng: string }>; + searchParams: Promise<{ [key: string]: string | string[] | undefined }>; +}) { + const { lng } = await params; + const resolvedParams = await searchParams; + + return ( + <Shell variant="fullscreen"> + {/* 헤더 */} + <div className="flex items-center justify-between flex-shrink-0"> + <div> + <h2 className="text-2xl font-bold tracking-tight"> + {lng === "ko" + ? "조선 도면 업로드" + : "Shipbuilding Drawing Upload"} + </h2> + </div> + </div> - <React.Suspense - fallback={ - <DataTableSkeleton - columnCount={8} - searchableColumnCount={1} - filterableColumnCount={3} - cellWidths={["10rem", "30rem", "15rem", "15rem", "15rem", "15rem", "8rem", "8rem"]} - shrinkZero - /> - } - > - <UserVendorDocumentDisplay - allPromises={allPromises} - /> - </React.Suspense> - </Shell> - ) + {/* 메인 컨텐츠 */} + <Suspense fallback={<DolceUploadSkeleton />}> + <DolceUploadPageV2 searchParams={resolvedParams} /> + </Suspense> + </Shell> + ); } diff --git a/app/[lng]/partners/(partners)/dolce-upload-v2/page.tsx b/app/[lng]/partners/(partners)/dolce-upload-v2/page.tsx deleted file mode 100644 index 9ce7c6c6..00000000 --- a/app/[lng]/partners/(partners)/dolce-upload-v2/page.tsx +++ /dev/null @@ -1,69 +0,0 @@ -import { Suspense } from "react"; -import { Skeleton } from "@/components/ui/skeleton"; -import { Card, CardContent, CardHeader } from "@/components/ui/card"; -import DolceUploadPageV2 from "./dolce-upload-page-v2"; -import { Shell } from "@/components/shell"; - -export const metadata = { - title: "조선 벤더문서 업로드(DOLCE) V2", - description: "조선 설계문서 업로드 및 관리 - 분할 레이아웃", -}; - -// ============================================================================ -// 로딩 스켈레톤 -// ============================================================================ - -function DolceUploadSkeleton() { - return ( - <div className="space-y-4"> - <Card> - <CardHeader> - <Skeleton className="h-8 w-48" /> - </CardHeader> - <CardContent> - <Skeleton className="h-32 w-full" /> - </CardContent> - </Card> - <Card> - <CardHeader> - <Skeleton className="h-8 w-48" /> - </CardHeader> - <CardContent> - <Skeleton className="h-96 w-full" /> - </CardContent> - </Card> - </div> - ); -} - -export default async function DolceUploadPageWrapper({ - params, - searchParams, -}: { - params: Promise<{ lng: string }>; - searchParams: Promise<{ [key: string]: string | string[] | undefined }>; -}) { - const { lng } = await params; - const resolvedParams = await searchParams; - - return ( - <Shell variant="fullscreen"> - {/* 헤더 */} - <div className="flex items-center justify-between flex-shrink-0"> - <div> - <h2 className="text-2xl font-bold tracking-tight"> - {lng === "ko" - ? "조선 도면 업로드" - : "Shipbuilding Drawing Upload"} - </h2> - </div> - </div> - - {/* 메인 컨텐츠 */} - <Suspense fallback={<DolceUploadSkeleton />}> - <DolceUploadPageV2 searchParams={resolvedParams} /> - </Suspense> - </Shell> - ); -} - |
