feat: TBM 중복 배정 방지, 설비 배치도 좌표계 통일, 구역 상세 CSS 수정
- TBM 팀원 추가 시 중복 배정 검증 및 409 에러 처리 (tbmController, tbmModel, tbm-create.js, tbm.js, tbm/api.js) - tkuser/tkfb 설비 배치도 좌표계를 좌상단 기준으로 통일 (CSS left/top 방식) - tkuser 설비 배치도에 드래그 이동, 코너 리사이즈, 배치 버튼 추가 - 대분류 지도 영역 수정 버튼 추가 (workplace-layout-map.js, tkuser-layout-map.js) - tkfb workplace-status 캔버스 maxWidth 800 통일 - zone-detail.css object-fit:contain 제거 → height:auto로 마커 위치 정확도 개선 - imageUploadService 업로드 경로 Docker 볼륨 마운트 경로로 수정 - repair-management 카테고리 필터 nonconformity → facility 수정 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -848,6 +848,27 @@ const TbmModel = {
|
||||
[checkId]
|
||||
);
|
||||
return { affectedRows: result.affectedRows };
|
||||
},
|
||||
|
||||
// ==================== 중복 배정 검증 ====================
|
||||
|
||||
checkDuplicateAssignments: async (date, userIds, excludeSessionId) => {
|
||||
if (!userIds || userIds.length === 0) return [];
|
||||
const db = await getDb();
|
||||
const placeholders = userIds.map(() => '?').join(',');
|
||||
const [rows] = await db.query(
|
||||
`SELECT ta.user_id, w.worker_name, lw.worker_name AS leader_name
|
||||
FROM tbm_team_assignments ta
|
||||
INNER JOIN tbm_sessions s ON ta.session_id = s.session_id
|
||||
INNER JOIN workers w ON ta.user_id = w.user_id
|
||||
LEFT JOIN workers lw ON s.leader_user_id = lw.user_id
|
||||
WHERE s.session_date = ?
|
||||
AND ta.session_id != ?
|
||||
AND ta.user_id IN (${placeholders})
|
||||
GROUP BY ta.user_id`,
|
||||
[date, excludeSessionId, ...userIds]
|
||||
);
|
||||
return rows;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user