summaryrefslogtreecommitdiff
path: root/lib/pq/table/import-pq-handler.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pq/table/import-pq-handler.tsx')
-rw-r--r--lib/pq/table/import-pq-handler.tsx145
1 files changed, 0 insertions, 145 deletions
diff --git a/lib/pq/table/import-pq-handler.tsx b/lib/pq/table/import-pq-handler.tsx
deleted file mode 100644
index 13431ba7..00000000
--- a/lib/pq/table/import-pq-handler.tsx
+++ /dev/null
@@ -1,145 +0,0 @@
-"use client"
-
-import { z } from "zod"
-import { createPq } from "../service" // PQ 생성 서버 액션
-
-// PQ 데이터 검증을 위한 Zod 스키마
-const pqItemSchema = z.object({
- code: z.string().min(1, "Code is required"),
- checkPoint: z.string().min(1, "Check point is required"),
- groupName: z.string().min(1, "Group is required"),
- description: z.string().optional().nullable(),
- remarks: z.string().optional().nullable(),
- contractInfo: z.string().optional().nullable(),
- additionalRequirement: z.string().optional().nullable(),
-});
-
-// 지원하는 그룹 이름 목록
-const validGroupNames = [
- "GENERAL",
- "Quality Management System",
- "Workshop & Environment",
- "Warranty",
-];
-
-type ImportPqItem = z.infer<typeof pqItemSchema>;
-
-interface ProcessResult {
- successCount: number;
- errorCount: number;
- errors?: Array<{ row: number; message: string }>;
-}
-
-/**
- * Excel 파일에서 가져온 PQ 데이터를 처리하는 함수
- */
-export async function processFileImport(
- jsonData: any[],
- projectId: number | null | undefined,
- progressCallback?: (current: number, total: number) => void
-): Promise<ProcessResult> {
- // 결과 카운터 초기화
- let successCount = 0;
- let errorCount = 0;
- const errors: Array<{ row: number; message: string }> = [];
-
- // 헤더 행과 지침 행 건너뛰기
- const dataRows = jsonData.filter(row => {
- // 행이 문자열로만 구성된 경우 지침 행으로 간주
- if (Object.values(row).every(val => typeof val === 'string' && !val.includes(':'))) {
- return false;
- }
- // 빈 행 건너뛰기
- if (Object.values(row).every(val => !val)) {
- return false;
- }
- return true;
- });
-
- // 데이터 행이 없으면 빈 결과 반환
- if (dataRows.length === 0) {
- return { successCount: 0, errorCount: 0 };
- }
-
- // 각 행에 대해 처리
- for (let i = 0; i < dataRows.length; i++) {
- const row = dataRows[i];
- const rowIndex = i + 1; // 사용자에게 표시할 행 번호는 1부터 시작
-
- // 진행 상황 콜백 호출
- if (progressCallback) {
- progressCallback(i + 1, dataRows.length);
- }
-
- try {
- // 데이터 정제
- const cleanedRow: ImportPqItem = {
- code: row.Code?.toString().trim() ?? "",
- checkPoint: row["Check Point"]?.toString().trim() ?? "",
- groupName: row["Group Name"]?.toString().trim() ?? "",
- description: row.Description?.toString() ?? "",
- remarks: row.Remarks?.toString() ?? "",
- contractInfo: row["Contract Info"]?.toString() ?? "",
- additionalRequirement: row["Additional Requirements"]?.toString() ?? "",
- };
-
- // 데이터 유효성 검사
- const validationResult = pqItemSchema.safeParse(cleanedRow);
-
- if (!validationResult.success) {
- const errorMessage = validationResult.error.errors.map(
- err => `${err.path.join('.')}: ${err.message}`
- ).join(', ');
-
- errors.push({ row: rowIndex, message: errorMessage });
- errorCount++;
- continue;
- }
-
- // 그룹 이름 유효성 검사
- if (!validGroupNames.includes(cleanedRow.groupName)) {
- errors.push({
- row: rowIndex,
- message: `Invalid group name: ${cleanedRow.groupName}. Must be one of: ${validGroupNames.join(', ')}`
- });
- errorCount++;
- continue;
- }
-
- // PQ 생성 서버 액션 호출
- const createResult = await createPq({
- ...cleanedRow,
- projectId: projectId || 0
- });
-
- if (createResult.success) {
- successCount++;
- } else {
- errors.push({
- row: rowIndex,
- message: createResult.message || "Unknown error"
- });
- errorCount++;
- }
- } catch (error) {
- console.error(`Row ${rowIndex} processing error:`, error);
- errors.push({
- row: rowIndex,
- message: error instanceof Error ? error.message : "Unknown error"
- });
- errorCount++;
- }
-
- // 비동기 작업 쓰로틀링
- if (i % 5 === 0) {
- await new Promise(resolve => setTimeout(resolve, 10));
- }
- }
-
- // 처리 결과 반환
- return {
- successCount,
- errorCount,
- errors: errors.length > 0 ? errors : undefined
- };
-} \ No newline at end of file