품질관리/고객CS/ECR — wace_plm 1:1 이식 + 견적관리 그리드 패턴 통일
Build and Push Images / build-and-push (push) Has been cancelled
Build and Push Images / build-and-push (push) Has been cancelled
신규 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건이므로 스키마만 정합.
This commit is contained in:
@@ -0,0 +1,91 @@
|
||||
-- 품질관리 — ilshin DB 운영 스키마와 동일하게 vexplor_rps 에 6 개 테이블 정합.
|
||||
-- 원본: 211.115.91.141:11132/ilshin (wace_plm 운영 DB)
|
||||
-- 컬럼 정의는 information_schema.columns 에서 그대로 추출.
|
||||
|
||||
-- 1) 고객 CS 마스터 (wace_plm 의 실제 운영 테이블)
|
||||
CREATE TABLE IF NOT EXISTS public.customer_service_mgmt (
|
||||
objid varchar PRIMARY KEY,
|
||||
service_no varchar,
|
||||
product varchar,
|
||||
contract_objid varchar,
|
||||
cs_category varchar,
|
||||
warranty varchar,
|
||||
manager_id varchar,
|
||||
act_date varchar,
|
||||
category_h varchar,
|
||||
category_m varchar,
|
||||
category_l varchar,
|
||||
title varchar,
|
||||
before_contents text,
|
||||
after_contents text,
|
||||
writer varchar,
|
||||
regdate timestamp,
|
||||
status varchar,
|
||||
total_sup_price varchar,
|
||||
total_work_day varchar,
|
||||
total_work_person varchar,
|
||||
total_work_day_m varchar,
|
||||
total_labor_cost varchar,
|
||||
total_expenses varchar
|
||||
);
|
||||
|
||||
-- 2) 고객 CS 부품 (CS 마스터 자식)
|
||||
CREATE TABLE IF NOT EXISTS public.customer_service_part (
|
||||
objid varchar PRIMARY KEY,
|
||||
parent_objid varchar,
|
||||
part_no varchar,
|
||||
part_name varchar,
|
||||
spec varchar,
|
||||
qty varchar,
|
||||
cur_qty varchar,
|
||||
price varchar,
|
||||
sup_price varchar
|
||||
);
|
||||
|
||||
-- 3) 고객 CS 작업시간 (CS 부품 자식 — 인건/경비 산정)
|
||||
CREATE TABLE IF NOT EXISTS public.customer_service_workingtime (
|
||||
objid varchar PRIMARY KEY,
|
||||
parent_objid varchar,
|
||||
supply_objid varchar,
|
||||
form_date varchar,
|
||||
to_date varchar,
|
||||
work_day varchar,
|
||||
work_person varchar,
|
||||
work_day_m varchar,
|
||||
labor_cost varchar,
|
||||
expenses varchar
|
||||
);
|
||||
|
||||
-- 4) 검사관리 — 내부검사 + 입고검사를 단일 테이블로 통합 보관
|
||||
CREATE TABLE IF NOT EXISTS public.inspection_mgmt (
|
||||
objid varchar PRIMARY KEY,
|
||||
parent_objid varchar,
|
||||
unit_code varchar,
|
||||
internal_inspection_date varchar,
|
||||
internal_inspection_result varchar,
|
||||
internal_inspection_id varchar,
|
||||
admission_inspection_date varchar,
|
||||
admission_inspection_result varchar,
|
||||
admission_inspection_id varchar,
|
||||
regdate timestamp,
|
||||
writer varchar
|
||||
);
|
||||
|
||||
-- 5) 출하 불량 이력
|
||||
CREATE TABLE IF NOT EXISTS public.delivery_history_defect (
|
||||
objid varchar PRIMARY KEY,
|
||||
purchase_order_part_objid varchar,
|
||||
defect_qty varchar,
|
||||
defect_reason_cd varchar,
|
||||
writer varchar,
|
||||
regdate timestamp
|
||||
);
|
||||
|
||||
-- 6) ecr_mng 컬럼 동기화 (ilshin 에는 있지만 vexplor_rps 에는 없는 컬럼)
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS project_no varchar;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS customer_cd varchar;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS equip_name varchar;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS design_dept varchar;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS unit_cd varchar;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS memo text;
|
||||
ALTER TABLE public.ecr_mng ADD COLUMN IF NOT EXISTS check_result varchar;
|
||||
@@ -0,0 +1,116 @@
|
||||
-- 품질관리 — wace_plm 의 quality.xml MyBatis 매퍼가 참조하는 5개 테이블을
|
||||
-- vexplor_rps 에 그대로 생성. 컬럼 정의는 INSERT/UPDATE/ResultMap 에서 추출.
|
||||
--
|
||||
-- ilshin DB 의 운영 환경에는 이 이름들이 존재하지 않고, ilshin은 inspection_mgmt
|
||||
-- 단일 테이블로 통합 보관함. 본 5개 테이블은 wace_plm 코드 호환을 위한 신규 추가.
|
||||
|
||||
CREATE TABLE IF NOT EXISTS public.incoming_inspection_detail (
|
||||
objid bigserial PRIMARY KEY,
|
||||
inventory_in_objid bigint,
|
||||
purchase_order_master_objid varchar,
|
||||
request_date date,
|
||||
request_user_id varchar,
|
||||
inspection_date date,
|
||||
inspector_id varchar,
|
||||
inspection_type varchar,
|
||||
inspection_yn varchar(1),
|
||||
defect_type varchar,
|
||||
defect_reason varchar,
|
||||
action_status varchar,
|
||||
inspection_qty numeric(18,2),
|
||||
defect_qty numeric(18,2),
|
||||
inspection_result varchar,
|
||||
attach_file_objid bigint,
|
||||
remark text,
|
||||
writer varchar NOT NULL,
|
||||
reg_date timestamp NOT NULL DEFAULT NOW()
|
||||
);
|
||||
CREATE INDEX IF NOT EXISTS idx_incoming_inspection_detail_po
|
||||
ON public.incoming_inspection_detail (purchase_order_master_objid);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS public.incoming_inspection_defect (
|
||||
objid bigserial PRIMARY KEY,
|
||||
inspection_detail_objid bigint NOT NULL,
|
||||
inspection_type varchar,
|
||||
inspection_date date,
|
||||
inspector_id varchar,
|
||||
defect_type varchar,
|
||||
defect_reason varchar,
|
||||
action_status varchar,
|
||||
action_result varchar,
|
||||
inspection_qty numeric(18,2),
|
||||
defect_qty numeric(18,2),
|
||||
inspection_result varchar,
|
||||
remark text,
|
||||
writer varchar NOT NULL,
|
||||
reg_date timestamp NOT NULL DEFAULT NOW()
|
||||
);
|
||||
CREATE INDEX IF NOT EXISTS idx_incoming_inspection_defect_detail
|
||||
ON public.incoming_inspection_defect (inspection_detail_objid);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS public.process_inspection_master (
|
||||
objid bigserial PRIMARY KEY,
|
||||
inspection_date date,
|
||||
inspector_id varchar,
|
||||
remark text,
|
||||
writer varchar NOT NULL,
|
||||
reg_date timestamp NOT NULL DEFAULT NOW(),
|
||||
mod_date timestamp
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS public.process_inspection_detail (
|
||||
objid bigserial PRIMARY KEY,
|
||||
master_objid bigint NOT NULL,
|
||||
process_cd varchar,
|
||||
project_objid bigint,
|
||||
part_objid bigint,
|
||||
part_no varchar,
|
||||
part_name varchar,
|
||||
inspection_qty numeric(18,2),
|
||||
defect_qty numeric(18,2),
|
||||
work_env_status varchar,
|
||||
measuring_device varchar,
|
||||
dept_cd varchar,
|
||||
user_id varchar,
|
||||
inspection_date date,
|
||||
inspector_id varchar,
|
||||
remark text,
|
||||
action_status varchar,
|
||||
inspection_result varchar,
|
||||
writer varchar NOT NULL,
|
||||
reg_date timestamp NOT NULL DEFAULT NOW(),
|
||||
mod_date timestamp
|
||||
);
|
||||
CREATE INDEX IF NOT EXISTS idx_process_inspection_detail_master
|
||||
ON public.process_inspection_detail (master_objid);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS public.pms_quality_semi_product_inspection (
|
||||
objid bigserial PRIMARY KEY,
|
||||
project_no varchar,
|
||||
work_order_no varchar,
|
||||
part_no varchar,
|
||||
part_name varchar,
|
||||
receipt_qty numeric(18,2),
|
||||
good_qty numeric(18,2),
|
||||
defect_qty numeric(18,2),
|
||||
disposition_type varchar,
|
||||
remark text,
|
||||
writer varchar NOT NULL,
|
||||
reg_date timestamp NOT NULL DEFAULT NOW(),
|
||||
inspection_group_id bigint,
|
||||
data_type varchar(20),
|
||||
defect_type varchar,
|
||||
defect_cause varchar,
|
||||
responsible_dept varchar,
|
||||
worker varchar,
|
||||
process_status varchar,
|
||||
inspection_date date,
|
||||
inspector varchar,
|
||||
model_name varchar,
|
||||
product_type varchar,
|
||||
is_locked varchar(1) DEFAULT 'N'
|
||||
);
|
||||
CREATE INDEX IF NOT EXISTS idx_semi_product_inspection_group
|
||||
ON public.pms_quality_semi_product_inspection (inspection_group_id);
|
||||
CREATE INDEX IF NOT EXISTS idx_semi_product_inspection_date
|
||||
ON public.pms_quality_semi_product_inspection (inspection_date);
|
||||
Reference in New Issue
Block a user