Section A (Backend): - POST /api/proxy-input: TBM 세션+팀배정+작업보고서 일괄 생성 (트랜잭션) - GET /api/proxy-input/daily-status: 일별 TBM/보고서 입력 현황 - GET /api/proxy-input/daily-status/detail: 작업자별 상세 - tbm_sessions에 is_proxy_input, proxy_input_by 컬럼 추가 - system1/system2/tkuser requireMinLevel → shared requirePage 전환 - permissionModel에 factory_proxy_input, factory_daily_status 키 등록 Section B (Frontend): - daily-status.html: 날짜 네비 + 요약 카드 + 필터 탭 + 작업자 리스트 + 바텀시트 - proxy-input.html: 미입력자 카드 + 확장 폼 + 일괄 설정 + 저장 - tkfb-core.js NAV_MENU에 입력 현황/대리입력 추가 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
127 lines
5.2 KiB
JavaScript
127 lines
5.2 KiB
JavaScript
// routes/tbmRoutes.js - TBM 시스템 라우트
|
|
const express = require('express');
|
|
const router = express.Router();
|
|
const TbmController = require('../controllers/tbmController');
|
|
const { requireAuth } = require('../middlewares/auth');
|
|
const { createRequirePage } = require('../../../shared/middleware/pagePermission');
|
|
const { getDb } = require('../dbPool');
|
|
const requirePage = createRequirePage(getDb);
|
|
|
|
// ==================== TBM 세션 관련 ====================
|
|
|
|
// TBM 세션 생성
|
|
router.post('/sessions', requireAuth, TbmController.createSession);
|
|
|
|
// 작업보고서가 작성되지 않은 TBM 팀 배정 조회 (구체적인 경로이므로 먼저 정의)
|
|
router.get('/sessions/incomplete-reports', requireAuth, TbmController.getIncompleteWorkReports);
|
|
|
|
// 당일 전 작업자 배정 현황 (더 구체적인 경로이므로 먼저 정의)
|
|
router.get('/sessions/date/:date/assignments', requireAuth, TbmController.getWorkerAssignmentsByDate);
|
|
|
|
// 특정 날짜의 TBM 세션 목록 조회
|
|
router.get('/sessions/date/:date', requireAuth, TbmController.getSessionsByDate);
|
|
|
|
// TBM 세션 상세 조회
|
|
router.get('/sessions/:sessionId', requireAuth, TbmController.getSessionById);
|
|
|
|
// TBM 세션 수정
|
|
router.put('/sessions/:sessionId', requireAuth, TbmController.updateSession);
|
|
|
|
// TBM 세션 완료 처리
|
|
router.post('/sessions/:sessionId/complete', requireAuth, TbmController.completeSession);
|
|
|
|
// TBM 세션 삭제 (draft 상태만)
|
|
router.delete('/sessions/:sessionId', requireAuth, TbmController.deleteSession);
|
|
|
|
// ==================== 팀 구성 관련 ====================
|
|
|
|
// 팀원 추가 (단일)
|
|
router.post('/sessions/:sessionId/team', requireAuth, TbmController.addTeamMember);
|
|
|
|
// 분할 항목 추가 (같은 작업자의 추가 배정)
|
|
router.post('/sessions/:sessionId/team/split', requireAuth, TbmController.addSplitAssignment);
|
|
|
|
// 팀 구성 일괄 추가
|
|
router.post('/sessions/:sessionId/team/batch', requireAuth, TbmController.addTeamMembers);
|
|
|
|
// TBM 세션의 팀 구성 조회
|
|
router.get('/sessions/:sessionId/team', requireAuth, TbmController.getTeamMembers);
|
|
|
|
// 팀원 전체 삭제 (수정 시 사용) - 더 구체적인 경로이므로 먼저 정의
|
|
router.delete('/sessions/:sessionId/team/clear', requireAuth, TbmController.clearAllTeamMembers);
|
|
|
|
// 팀원 제거
|
|
router.delete('/sessions/:sessionId/team/:userId', requireAuth, TbmController.removeTeamMember);
|
|
|
|
// ==================== 안전 체크리스트 관련 ====================
|
|
|
|
// 모든 안전 체크 항목 조회
|
|
router.get('/safety-checks', requireAuth, TbmController.getAllSafetyChecks);
|
|
|
|
// 안전 체크 항목 생성 (관리자용)
|
|
router.post('/safety-checks', requireAuth, requirePage('factory_tbm'), TbmController.createSafetyCheck);
|
|
|
|
// 안전 체크 항목 수정 (관리자용)
|
|
router.put('/safety-checks/:checkId', requireAuth, requirePage('factory_tbm'), TbmController.updateSafetyCheck);
|
|
|
|
// 안전 체크 항목 삭제 (관리자용)
|
|
router.delete('/safety-checks/:checkId', requireAuth, requirePage('factory_tbm'), TbmController.deleteSafetyCheck);
|
|
|
|
// TBM 세션의 안전 체크 기록 조회
|
|
router.get('/sessions/:sessionId/safety', requireAuth, TbmController.getSafetyRecords);
|
|
|
|
// 안전 체크 일괄 저장
|
|
router.post('/sessions/:sessionId/safety', requireAuth, TbmController.saveSafetyRecords);
|
|
|
|
// 필터링된 안전 체크리스트 조회 (기본 + 날씨 + 작업별)
|
|
router.get('/sessions/:sessionId/safety-checks/filtered', requireAuth, TbmController.getFilteredSafetyChecks);
|
|
|
|
// ==================== 날씨 관련 ====================
|
|
|
|
// 현재 날씨 조회
|
|
router.get('/weather/current', requireAuth, TbmController.getCurrentWeather);
|
|
|
|
// 날씨 조건 목록 조회
|
|
router.get('/weather/conditions', requireAuth, TbmController.getWeatherConditions);
|
|
|
|
// 세션 날씨 정보 조회
|
|
router.get('/sessions/:sessionId/weather', requireAuth, TbmController.getSessionWeather);
|
|
|
|
// 세션 날씨 정보 저장
|
|
router.post('/sessions/:sessionId/weather', requireAuth, TbmController.saveSessionWeather);
|
|
|
|
// ==================== 작업자 이동 관련 ====================
|
|
|
|
// 이동 실행 (보내기/빼오기)
|
|
router.post('/transfers', requireAuth, TbmController.createTransfer);
|
|
|
|
// 당일 이동 내역 조회
|
|
router.get('/transfers/date/:date', requireAuth, TbmController.getTransfersByDate);
|
|
|
|
// 이동 취소 (원복)
|
|
router.delete('/transfers/:transferId', requireAuth, TbmController.cancelTransfer);
|
|
|
|
// ==================== 작업 인계 관련 ====================
|
|
|
|
// 작업 인계 생성
|
|
router.post('/handovers', requireAuth, TbmController.createHandover);
|
|
|
|
// 작업 인계 확인
|
|
router.post('/handovers/:handoverId/confirm', requireAuth, TbmController.confirmHandover);
|
|
|
|
// 특정 날짜의 작업 인계 목록 조회
|
|
router.get('/handovers/date/:date', requireAuth, TbmController.getHandoversByDate);
|
|
|
|
// 나에게 온 미확인 인계 건 조회
|
|
router.get('/handovers/pending', requireAuth, TbmController.getMyPendingHandovers);
|
|
|
|
// ==================== 통계 및 리포트 ====================
|
|
|
|
// TBM 통계 조회
|
|
router.get('/statistics/tbm', requireAuth, TbmController.getTbmStatistics);
|
|
|
|
// 리더별 TBM 진행 현황 조회
|
|
router.get('/statistics/leaders', requireAuth, TbmController.getLeaderStatistics);
|
|
|
|
module.exports = router;
|