fix: 페이지네이션 로직 개선 및 상세 로그 추가
Some checks failed
Flutter Test & Quality Check / Build APK (push) Has been cancelled
Flutter Test & Quality Check / Test on macos-latest (push) Has been cancelled
Flutter Test & Quality Check / Test on ubuntu-latest (push) Has been cancelled

- 모든 관리 화면(회사, 장비, 입고지, 유지보수)의 페이지네이션 로직 통일
- Controller에서 전체 데이터 로드, View에서만 페이지네이션 처리
- 각 화면에 상세한 터미널 로그 추가로 데이터 로드 상태 추적 가능
- 회사 DTO에 지점 정보 포함 기능 추가
- 전체 79개 회사 중 14개만 표시되던 문제 해결
This commit is contained in:
JiWoong Sul
2025-08-09 19:40:39 +09:00
parent c49f6a1696
commit 7d0077cd57
16 changed files with 566 additions and 150 deletions

View File

@@ -44,13 +44,7 @@ class EquipmentListController extends ChangeNotifier {
// 데이터 로드 및 상태 필터 적용
Future<void> loadData({bool isRefresh = false, String? search}) async {
if (isRefresh) {
_currentPage = 1;
_hasMore = true;
equipments.clear();
}
if (_isLoading || (!_hasMore && !isRefresh)) return;
if (_isLoading) return;
_isLoading = true;
_error = null;
@@ -58,31 +52,42 @@ class EquipmentListController extends ChangeNotifier {
try {
if (_useApi) {
// API 호출
DebugLogger.log('장비 목록 API 호출 시작', tag: 'EQUIPMENT', data: {
'page': _currentPage,
'perPage': _perPage,
'statusFilter': selectedStatusFilter,
});
// API 호출 - 전체 데이터 로드
print('╔══════════════════════════════════════════════════════════');
print('║ 📦 장비 목록 API 호출 시작');
print('║ • 상태 필터: ${selectedStatusFilter ?? "전체"}');
print('║ • 검색어: ${search ?? searchKeyword}');
print('╚══════════════════════════════════════════════════════════');
// DTO 형태로 가져와서 status 정보 유지
// 전체 데이터를 가져오기 위해 큰 perPage 값 사용
final apiEquipmentDtos = await _equipmentService.getEquipmentsWithStatus(
page: _currentPage,
perPage: _perPage,
page: 1,
perPage: 1000, // 충분히 큰 값으로 전체 데이터 로드
status: selectedStatusFilter != null ? EquipmentStatusConverter.clientToServer(selectedStatusFilter) : null,
search: search ?? searchKeyword,
);
DebugLogger.log('장비 목록 API 응답', tag: 'EQUIPMENT', data: {
'count': apiEquipmentDtos.length,
'firstItem': apiEquipmentDtos.isNotEmpty ? {
'id': apiEquipmentDtos.first.id,
'equipmentNumber': apiEquipmentDtos.first.equipmentNumber,
'manufacturer': apiEquipmentDtos.first.manufacturer,
'status': apiEquipmentDtos.first.status,
} : null,
print('╔══════════════════════════════════════════════════════════');
print('║ 📊 장비 목록 로드 완료');
print('║ ▶ 총 장비 수: ${apiEquipmentDtos.length}');
print('╟──────────────────────────────────────────────────────────');
// 상태별 통계
Map<String, int> statusCount = {};
for (final dto in apiEquipmentDtos) {
final clientStatus = EquipmentStatusConverter.serverToClient(dto.status);
statusCount[clientStatus] = (statusCount[clientStatus] ?? 0) + 1;
}
statusCount.forEach((status, count) {
print('║ • $status: $count개');
});
print('╟──────────────────────────────────────────────────────────');
print('║ 📑 전체 데이터 로드 완료');
print('║ • View에서 페이지네이션 처리 예정');
print('╚══════════════════════════════════════════════════════════');
// DTO를 UnifiedEquipment로 변환 (status 정보 포함)
final List<UnifiedEquipment> unifiedEquipments = apiEquipmentDtos.map((dto) {
final equipment = Equipment(
@@ -105,14 +110,8 @@ class EquipmentListController extends ChangeNotifier {
);
}).toList();
if (isRefresh) {
equipments = unifiedEquipments;
} else {
equipments.addAll(unifiedEquipments);
}
_hasMore = unifiedEquipments.length == _perPage;
if (_hasMore) _currentPage++;
equipments = unifiedEquipments;
_hasMore = false; // 전체 데이터를 로드했으므로 더 이상 로드할 필요 없음
} else {
// Mock 데이터 사용
equipments = dataService.getAllEquipments();