feat(schedule): 공정표 제품유형 + 표준공정 자동생성 백엔드
- product_types 참조 테이블 + projects.product_type_id FK (tkuser 마이그레이션) - schedule_entries에 work_type_id, risk_assessment_id, source 컬럼 추가 - schedule_phases에 product_type_id 추가 (phase 오염 방지) - generateFromTemplate: tksafety 템플릿 기반 공정 자동 생성 (트랜잭션) - phase 매칭 3단계 우선순위 (전용→범용→신규) - 간트 데이터 NULL 날짜 guard 추가 - system1 startup 마이그레이션 러너 추가 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -209,6 +209,37 @@ const ScheduleController = {
|
||||
}
|
||||
},
|
||||
|
||||
// === 제품유형 ===
|
||||
getProductTypes: async (req, res) => {
|
||||
try {
|
||||
const rows = await ScheduleModel.getProductTypes();
|
||||
res.json({ success: true, data: rows });
|
||||
} catch (err) {
|
||||
logger.error('Schedule getProductTypes error:', err);
|
||||
res.status(500).json({ success: false, message: '서버 오류가 발생했습니다.' });
|
||||
}
|
||||
},
|
||||
|
||||
// === 표준공정 자동 생성 ===
|
||||
generateFromTemplate: async (req, res) => {
|
||||
try {
|
||||
const { project_id, product_type_code } = req.body;
|
||||
if (!project_id || !product_type_code) {
|
||||
return res.status(400).json({ success: false, message: '프로젝트와 제품유형을 선택해주세요.' });
|
||||
}
|
||||
const result = await ScheduleModel.generateFromTemplate(
|
||||
project_id, product_type_code, req.user.user_id || req.user.id
|
||||
);
|
||||
if (result.error) {
|
||||
return res.status(409).json({ success: false, message: result.error });
|
||||
}
|
||||
res.status(201).json({ success: true, data: result, message: `${result.created}개 표준공정이 생성되었습니다.` });
|
||||
} catch (err) {
|
||||
logger.error('Schedule generateFromTemplate error:', err);
|
||||
res.status(500).json({ success: false, message: '서버 오류가 발생했습니다.' });
|
||||
}
|
||||
},
|
||||
|
||||
// === 부적합 연동 ===
|
||||
getNonconformance: async (req, res) => {
|
||||
try {
|
||||
|
||||
Reference in New Issue
Block a user