Files
wace_rps/frontend/lib/api/ecrMng.ts
T
chpark d7c645d24c
Build and Push Images / build-and-push (push) Has been cancelled
품질관리/고객CS/ECR — wace_plm 1:1 이식 + 견적관리 그리드 패턴 통일
신규 4개 메뉴 (PageHeader + CompactFilterBar + DataGrid 통일):
 - 품질관리/수입검사 요청 (/quality/incoming-request)
 - 품질관리/수입검사 관리 (/quality/incoming-mgmt)
 - 품질관리/공정검사 관리 (/quality/process-inspection)
 - 품질관리/반제품검사 관리 (/quality/semi-product-inspection)

DB 마이그레이션 (docs/migration/quality/):
 - 01_quality_tables_from_ilshin.sql — ilshin 운영 5개 테이블 vexplor_rps 정합
   (customer_service_mgmt/part/workingtime, inspection_mgmt, delivery_history_defect)
   + ecr_mng 7개 컬럼 동기화 (project_no, customer_cd, equip_name,
     design_dept, unit_cd, memo, check_result)
 - 02_wace_plm_quality_tables.sql — wace_plm quality.xml 매퍼 호환 신규 5개 테이블
   (incoming_inspection_detail/defect, process_inspection_master/detail,
    pms_quality_semi_product_inspection) + 인덱스 정의

백엔드:
 - qualityRoutes.ts — 4개 메뉴 list 엔드포인트 (실 테이블 조회)
 - ecrMngService SELECT_BASE 에 ilshin 신규 7컬럼 노출
 - app.ts 라우팅 등록 (/api/quality/*)

프론트:
 - DataGrid 4개 신규 페이지 + 그리드 툴바 (차트/엑셀/새로고침/컬럼설정/페이지사이즈)
 - customer-cs/cs, ecr/ecr — 견적관리와 동일한 PageHeader + CompactFilterBar
   + DataGrid 패턴으로 리팩토링 (다이얼로그/기존 API 유지)
 - ECR 그리드에 신규 6개 컬럼 추가 (설비명/프로젝트번호/고객사/설계부서/조치결과 등)
 - AdminPageRenderer 4개 라우트 등록

데이터 복사: ilshin → vexplor_rps (workingtime 5건, inspection_mgmt 1건,
ecr_mng 1건). 나머지 ilshin 운영 테이블은 0건이므로 스키마만 정합.
2026-05-14 19:08:15 +09:00

102 lines
3.0 KiB
TypeScript

/**
* ECR(Engineering Change Request) 관리 API 클라이언트
* - 백엔드: backend-node/src/routes/ecrMngRoutes.ts
*/
import { apiClient } from "./client";
export interface EcrItem {
objid: string;
ecr_no: string;
product_name?: string;
product_objid?: string;
upg_no?: string;
part_no?: string;
part_name?: string;
part_objid?: string;
request_cd?: string;
request_name?: string;
title: string;
writer?: string;
writer_name?: string;
status_cd?: string;
status_name?: string;
check_user_id?: string;
check_name?: string;
before_contents?: string;
after_contents?: string;
reg_date?: string;
check_date?: string;
/* ilshin 운영 ecr_mng 동기화로 추가된 컬럼 */
project_no?: string;
customer_cd?: string;
equip_name?: string;
design_dept?: string;
unit_cd?: string;
memo?: string;
check_result?: string;
}
export interface EcrListResponse {
success: boolean;
list: EcrItem[];
pagination: { page: number; pageSize: number; total: number; totalPages: number };
}
export interface EcrListParams {
year?: string;
productCode?: string;
requestCode?: string;
writer?: string;
statusCode?: string;
page?: number;
pageSize?: number;
}
export const ecrMngApi = {
list: async (params: EcrListParams = {}): Promise<EcrListResponse> => {
const { data } = await apiClient.get("/ecr", { params });
return data;
},
detail: async (objId: string | number): Promise<EcrItem> => {
const { data } = await apiClient.get(`/ecr/${objId}`);
return data.data;
},
/** 등록/수정 (objId 가 있으면 update) */
merge: async (payload: {
objId?: string | number;
title: string;
product_objid?: string | number | null;
part_objid?: string | number | null;
request_codeArr?: string;
before_contents?: string;
after_contents?: string;
}): Promise<{ objid: string; ecr_no: string; status_cd: string }> => {
const { data } = await apiClient.post("/ecr", payload);
return data.data;
},
/** 조치완료 — status → 0000102 */
complete: async (objId: string | number, after_contents: string) => {
const { data } = await apiClient.post(`/ecr/${objId}/complete`, { after_contents });
return data;
},
remove: async (objIds: string[]) => {
const { data } = await apiClient.delete("/ecr", { data: { objIds } });
return data;
},
// 옵션 — 드롭다운/체크박스용
writerOptions: async (): Promise<Array<{ value: string; label: string }>> =>
(await apiClient.get("/ecr/options/writers")).data.data,
productOptions: async (): Promise<Array<{ value: string; label: string }>> =>
(await apiClient.get("/ecr/options/products")).data.data,
partOptions: async (): Promise<Array<{ value: string; label: string }>> =>
(await apiClient.get("/ecr/options/parts")).data.data,
/** parentCodeId='0000090' (요청코드) / '0000099' (상태) */
commCodeOptions: async (parentCodeId: string): Promise<Array<{ value: string; label: string }>> =>
(await apiClient.get(`/ecr/options/codes/${parentCodeId}`)).data.data,
};