Files
superport/lib/main.dart
JiWoong Sul 2b31d3af5f feat: API 통합을 위한 기초 인프라 구축
- 네트워크 레이어 구현 (Dio 기반 ApiClient)
- 환경별 설정 관리 시스템 구축
- 의존성 주입 설정 (GetIt)
- API 엔드포인트 상수 정의
- 인터셉터 구현 (Auth, Error, Logging)
- 프로젝트 아키텍처 개선 (core, data, di 디렉토리 구조)
- API 통합 계획서 및 요구사항 문서 작성
- 필요 패키지 추가 (dio, flutter_secure_storage, get_it 등)
2025-07-24 14:54:28 +09:00

188 lines
7.2 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';
import 'package:superport/di/injection_container.dart' as di;
void main() async {
// Flutter 바인딩 초기화
WidgetsFlutterBinding.ensureInitialized();
// 의존성 주입 설정
await di.setupDependencies();
// 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),
);
}
},
);
}
}