## 주요 변경사항: ### UI/UX 개선 - shadcn/ui 스타일 기반의 새로운 디자인 시스템 도입 - 모든 주요 화면에 대한 리디자인 구현 완료 - 로그인 화면: 모던한 카드 스타일 적용 - 대시보드: 통계 카드와 차트를 활용한 개요 화면 - 리스트 화면들: 일관된 테이블 디자인과 검색/필터 기능 - 다크모드 지원을 위한 테마 시스템 구축 ### 기능 개선 - Equipment List: 고급 필터링 (상태, 담당자별) - Company List: 검색 및 정렬 기능 강화 - User List: 역할별 필터링 추가 - License List: 만료일 기반 상태 표시 - Warehouse Location: 재고 수준 시각화 ### 기술적 개선 - 재사용 가능한 컴포넌트 라이브러리 구축 - 일관된 코드 패턴 가이드라인 작성 - 프로젝트 구조 분석 및 문서화 ### 문서화 - 프로젝트 분석 문서 추가 - UI 리디자인 진행 상황 문서 - 코드 패턴 가이드 작성 - Equipment 기능 격차 분석 및 구현 계획 ### 삭제/리팩토링 - goods_list.dart 제거 (equipment_list로 통합) - 불필요한 import 및 코드 정리 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
181 lines
7.0 KiB
Dart
181 lines
7.0 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:superport/models/equipment_unified_model.dart';
|
|
import 'package:superport/screens/common/app_layout_redesign.dart';
|
|
import 'package:superport/screens/common/theme_shadcn.dart';
|
|
import 'package:superport/screens/company/company_form.dart';
|
|
import 'package:superport/screens/equipment/equipment_in_form.dart';
|
|
import 'package:superport/screens/equipment/equipment_out_form.dart';
|
|
import 'package:superport/screens/license/license_form.dart'; // MaintenanceFormScreen으로 사용
|
|
import 'package:superport/screens/user/user_form.dart';
|
|
import 'package:superport/screens/warehouse_location/warehouse_location_form.dart';
|
|
import 'package:superport/utils/constants.dart';
|
|
import 'package:flutter_localizations/flutter_localizations.dart';
|
|
import 'package:superport/screens/login/login_screen.dart';
|
|
|
|
void main() {
|
|
// MockDataService는 싱글톤으로 자동 초기화됨
|
|
runApp(const SuperportApp());
|
|
}
|
|
|
|
class SuperportApp extends StatelessWidget {
|
|
const SuperportApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MaterialApp(
|
|
title: 'supERPort',
|
|
theme: ShadcnTheme.lightTheme,
|
|
localizationsDelegates: const [
|
|
GlobalMaterialLocalizations.delegate,
|
|
GlobalWidgetsLocalizations.delegate,
|
|
GlobalCupertinoLocalizations.delegate,
|
|
],
|
|
supportedLocales: const [Locale('ko', 'KR'), Locale('en', 'US')],
|
|
locale: const Locale('ko', 'KR'),
|
|
initialRoute: '/login',
|
|
onGenerateRoute: (settings) {
|
|
// 로그인 라우트 처리
|
|
if (settings.name == '/login') {
|
|
return MaterialPageRoute(builder: (context) => const LoginScreen());
|
|
}
|
|
// 기본 AppLayout으로 라우팅할 경로 (홈, 목록 화면들)
|
|
if (settings.name == Routes.home ||
|
|
settings.name == Routes.equipment ||
|
|
settings.name == Routes.equipmentInList ||
|
|
settings.name == Routes.equipmentOutList ||
|
|
settings.name == Routes.equipmentRentList ||
|
|
settings.name == Routes.company ||
|
|
settings.name == Routes.user ||
|
|
settings.name == Routes.license) {
|
|
return MaterialPageRoute(
|
|
builder:
|
|
(context) => AppLayoutRedesign(initialRoute: settings.name!),
|
|
);
|
|
}
|
|
|
|
// 기존 라우팅 처리 (폼 화면들)
|
|
switch (settings.name) {
|
|
// 장비 입고 관련 라우트
|
|
case Routes.equipmentInAdd:
|
|
return MaterialPageRoute(
|
|
builder: (context) => const EquipmentInFormScreen(),
|
|
);
|
|
case Routes.equipmentInEdit:
|
|
final id = settings.arguments as int;
|
|
return MaterialPageRoute(
|
|
builder: (context) => EquipmentInFormScreen(equipmentInId: id),
|
|
);
|
|
|
|
// 장비 출고 관련 라우트
|
|
case Routes.equipmentOutAdd:
|
|
// 선택된 장비 정보와 입고 ID가 전달되었는지 확인
|
|
final args = settings.arguments;
|
|
Equipment? equipment;
|
|
int? equipmentInId;
|
|
List<Map<String, dynamic>>? selectedEquipments;
|
|
|
|
// 인자 처리
|
|
if (args is Map<String, dynamic>) {
|
|
// 다중 선택 장비 처리
|
|
if (args.containsKey('selectedEquipments')) {
|
|
selectedEquipments =
|
|
args['selectedEquipments'] as List<Map<String, dynamic>>;
|
|
debugPrint('선택된 장비 목록: ${selectedEquipments.length}개');
|
|
} else {
|
|
// 단일 장비 선택 (기존 방식)
|
|
equipment = args['equipment'] as Equipment?;
|
|
equipmentInId = args['equipmentInId'] as int?;
|
|
debugPrint('단일 장비 선택');
|
|
}
|
|
} else if (args is List<Map<String, dynamic>>) {
|
|
// 직접 리스트가 전달된 경우
|
|
selectedEquipments = args;
|
|
debugPrint('직접 리스트로 전달된 장비 목록: ${selectedEquipments.length}개');
|
|
} else if (args is Equipment) {
|
|
equipment = args; // 기존 방식 대응 (하위 호환)
|
|
debugPrint('단일 Equipment 객체 전달');
|
|
} else {
|
|
debugPrint('알 수 없는 인자 타입: ${args.runtimeType}');
|
|
}
|
|
|
|
return MaterialPageRoute(
|
|
builder:
|
|
(context) => EquipmentOutFormScreen(
|
|
selectedEquipment: equipment,
|
|
selectedEquipmentInId: equipmentInId,
|
|
selectedEquipments: selectedEquipments,
|
|
),
|
|
);
|
|
case Routes.equipmentOutEdit:
|
|
final id = settings.arguments as int;
|
|
return MaterialPageRoute(
|
|
builder: (context) => EquipmentOutFormScreen(equipmentOutId: id),
|
|
);
|
|
|
|
// 회사 관련 라우트
|
|
case Routes.companyAdd:
|
|
return MaterialPageRoute(
|
|
builder: (context) => const CompanyFormScreen(),
|
|
);
|
|
case Routes.companyEdit:
|
|
final args = settings.arguments;
|
|
if (args is Map) {
|
|
return MaterialPageRoute(
|
|
builder: (context) => CompanyFormScreen(args: args),
|
|
);
|
|
} else if (args is int) {
|
|
// 하위 호환: int만 넘어오는 경우
|
|
return MaterialPageRoute(
|
|
builder:
|
|
(context) => CompanyFormScreen(args: {'companyId': args}),
|
|
);
|
|
} else {
|
|
return MaterialPageRoute(
|
|
builder: (context) => CompanyFormScreen(),
|
|
);
|
|
}
|
|
|
|
// 사용자 관련 라우트
|
|
case Routes.userAdd:
|
|
return MaterialPageRoute(
|
|
builder: (context) => const UserFormScreen(),
|
|
);
|
|
case Routes.userEdit:
|
|
final id = settings.arguments as int;
|
|
return MaterialPageRoute(
|
|
builder: (context) => UserFormScreen(userId: id),
|
|
);
|
|
|
|
// 라이센스 관련 라우트
|
|
case Routes.licenseAdd:
|
|
return MaterialPageRoute(
|
|
builder: (context) => const MaintenanceFormScreen(),
|
|
);
|
|
case Routes.licenseEdit:
|
|
final id = settings.arguments as int;
|
|
return MaterialPageRoute(
|
|
builder: (context) => MaintenanceFormScreen(maintenanceId: id),
|
|
);
|
|
|
|
// 입고지 관련 라우트
|
|
case Routes.warehouseLocationAdd:
|
|
return MaterialPageRoute(
|
|
builder: (context) => const WarehouseLocationFormScreen(),
|
|
);
|
|
case Routes.warehouseLocationEdit:
|
|
final id = settings.arguments as int;
|
|
return MaterialPageRoute(
|
|
builder: (context) => WarehouseLocationFormScreen(id: id),
|
|
);
|
|
|
|
default:
|
|
return MaterialPageRoute(
|
|
builder:
|
|
(context) => AppLayoutRedesign(initialRoute: Routes.home),
|
|
);
|
|
}
|
|
},
|
|
);
|
|
}
|
|
}
|