fix: TBM 관리 탭 데스크탑-모바일 데이터 불일치 해결

- TBM 관리 탭의 비관리자 클라이언트 필터링 제거 (모바일과 동일하게 전체 표시)
- tbm.js의 state.js 프록시 변수 중복 선언 제거 (mapRegions, mapCanvas 등)
- 누락된 common/utils.js, common/base-state.js 추가
- 캐시 버스팅을 위한 버전 쿼리 스트링 업데이트

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
Hyungi Ahn
2026-03-04 15:42:29 +09:00
parent e7272b0688
commit 22a37ac4d9
5 changed files with 537 additions and 2414 deletions

File diff suppressed because it is too large Load Diff

View File

@@ -10,8 +10,8 @@
<link rel="stylesheet" href="/css/mobile.css?v=1">
<link rel="icon" type="image/png" href="/img/favicon.png">
<!-- 최적화된 로딩: API 설정 → 앱 초기화 (병렬 컴포넌트 로딩) -->
<script src="/js/api-base.js"></script>
<script src="/js/app-init.js?v=5" defer></script>
<script src="/js/api-base.js?v=2"></script>
<script src="/js/app-init.js?v=9" defer></script>
<!-- instant.page: 링크 호버 시 페이지 프리로딩 -->
<script src="https://instant.page/5.2.0" type="module"></script>
</head>
@@ -692,17 +692,55 @@
</div>
</div>
<!-- 분할 모달 -->
<div id="splitModal" class="tbm-modal-overlay" style="display:none;">
<div class="tbm-modal-container" style="max-width:500px;">
<div class="tbm-modal-header">
<h2>작업 분할</h2>
<button type="button" class="tbm-modal-close" onclick="closeSplitModal()">×</button>
</div>
<div class="tbm-modal-body">
<p style="font-size:0.8125rem; color:#6b7280; margin-bottom:0.75rem;">작업자의 배정 시간을 분할합니다.</p>
<div id="splitMemberList" style="display:flex; flex-direction:column; gap:0.5rem;"></div>
</div>
<div class="tbm-modal-footer">
<button type="button" class="tbm-btn tbm-btn-secondary" onclick="closeSplitModal()">닫기</button>
</div>
</div>
</div>
<!-- 빼오기 모달 -->
<div id="pullModal" class="tbm-modal-overlay" style="display:none;">
<div class="tbm-modal-container" style="max-width:500px;">
<div class="tbm-modal-header">
<h2>빼오기</h2>
<button type="button" class="tbm-modal-close" onclick="closePullModal()">×</button>
</div>
<div class="tbm-modal-body">
<p style="font-size:0.8125rem; color:#6b7280; margin-bottom:0.75rem;">다른 반장의 TBM에서 작업자를 빼옵니다.</p>
<div id="pullSessionList"></div>
</div>
<div class="tbm-modal-footer">
<button type="button" class="tbm-btn tbm-btn-secondary" onclick="closePullModal()">닫기</button>
</div>
</div>
</div>
<!-- 토스트 알림 -->
<div class="toast-container" id="toastContainer"></div>
</div>
<!-- 공통 모듈 -->
<script src="/js/common/utils.js?v=1"></script>
<script src="/js/common/base-state.js?v=1"></script>
<!-- TBM 모듈 (리팩토링된 구조) -->
<script src="/js/tbm/state.js?v=1"></script>
<script src="/js/tbm/utils.js?v=1"></script>
<script src="/js/tbm/api.js?v=1"></script>
<script src="/js/tbm/state.js?v=2"></script>
<script src="/js/tbm/utils.js?v=2"></script>
<script src="/js/tbm/api.js?v=4"></script>
<!-- 기존 UI 로직 (점진적 마이그레이션) -->
<script type="module" src="/js/tbm.js?v=10"></script>
<script defer src="/js/tbm.js?v=13"></script>
<!-- 모바일 하단 네비게이션 -->
<div id="mobile-nav-container"></div>