사용하지 않는 파일 정리 전 백업 (Phase 10 완료 후 상태)
This commit is contained in:
168
lib/main.dart
168
lib/main.dart
@@ -1,5 +1,7 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:provider/provider.dart';
|
||||
import 'package:shadcn_ui/shadcn_ui.dart';
|
||||
import 'package:superport/models/equipment_unified_model.dart';
|
||||
import 'package:superport/screens/common/app_layout.dart';
|
||||
import 'package:superport/screens/common/theme_shadcn.dart';
|
||||
@@ -7,7 +9,7 @@ import 'package:superport/screens/company/company_form.dart';
|
||||
import 'package:superport/screens/company/branch_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으로 사용
|
||||
// MaintenanceFormScreen으로 사용
|
||||
import 'package:superport/screens/user/user_form.dart';
|
||||
import 'package:superport/screens/warehouse_location/warehouse_location_form.dart';
|
||||
import 'package:superport/services/auth_service.dart';
|
||||
@@ -15,6 +17,14 @@ import 'package:superport/utils/constants.dart';
|
||||
import 'package:flutter_localizations/flutter_localizations.dart';
|
||||
import 'package:superport/screens/login/login_screen.dart';
|
||||
import 'package:superport/injection_container.dart' as di;
|
||||
import 'package:superport/screens/inventory/stock_in_form.dart';
|
||||
import 'package:superport/screens/inventory/stock_out_form.dart';
|
||||
import 'package:superport/screens/maintenance/maintenance_form_dialog.dart';
|
||||
import 'package:superport/screens/vendor/controllers/vendor_controller.dart';
|
||||
import 'package:superport/screens/model/controllers/model_controller.dart';
|
||||
import 'package:superport/screens/equipment/controllers/equipment_history_controller.dart';
|
||||
import 'package:superport/screens/maintenance/controllers/maintenance_controller.dart';
|
||||
import 'package:superport/screens/rent/controllers/rent_controller.dart';
|
||||
|
||||
void main() async {
|
||||
// Flutter 바인딩 초기화
|
||||
@@ -43,59 +53,84 @@ class SuperportApp extends StatelessWidget {
|
||||
print('Failed to get AuthService: $e');
|
||||
}
|
||||
|
||||
return MaterialApp(
|
||||
title: 'supERPort',
|
||||
theme: ShadcnTheme.lightTheme,
|
||||
localizationsDelegates: const [
|
||||
GlobalMaterialLocalizations.delegate,
|
||||
GlobalWidgetsLocalizations.delegate,
|
||||
GlobalCupertinoLocalizations.delegate,
|
||||
return MultiProvider(
|
||||
providers: [
|
||||
ChangeNotifierProvider<VendorController>(
|
||||
create: (_) => GetIt.instance<VendorController>(),
|
||||
),
|
||||
ChangeNotifierProvider<ModelController>(
|
||||
create: (_) => GetIt.instance<ModelController>(),
|
||||
),
|
||||
ChangeNotifierProvider<EquipmentHistoryController>(
|
||||
create: (_) => GetIt.instance<EquipmentHistoryController>(),
|
||||
),
|
||||
ChangeNotifierProvider<MaintenanceController>(
|
||||
create: (_) => GetIt.instance<MaintenanceController>(),
|
||||
),
|
||||
ChangeNotifierProvider<RentController>(
|
||||
create: (_) => GetIt.instance<RentController>(),
|
||||
),
|
||||
],
|
||||
supportedLocales: const [Locale('ko', 'KR'), Locale('en', 'US')],
|
||||
locale: const Locale('ko', 'KR'),
|
||||
home: authService == null
|
||||
? const LoginScreen() // AuthService가 없으면 바로 로그인 화면
|
||||
: FutureBuilder<bool>(
|
||||
future: authService.isLoggedIn(),
|
||||
builder: (context, snapshot) {
|
||||
if (snapshot.connectionState == ConnectionState.waiting) {
|
||||
return const Scaffold(
|
||||
body: Center(
|
||||
child: CircularProgressIndicator(),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
// 에러 처리 추가
|
||||
if (snapshot.hasError) {
|
||||
print('Auth check error: ${snapshot.error}');
|
||||
// 에러가 발생해도 로그인 화면으로 이동
|
||||
return const LoginScreen();
|
||||
}
|
||||
|
||||
if (snapshot.hasData && snapshot.data!) {
|
||||
// 토큰이 유효하면 홈 화면으로
|
||||
return AppLayout(initialRoute: Routes.home);
|
||||
} else {
|
||||
// 토큰이 없거나 유효하지 않으면 로그인 화면으로
|
||||
return const LoginScreen();
|
||||
}
|
||||
},
|
||||
),
|
||||
onGenerateRoute: (settings) {
|
||||
child: ShadApp(
|
||||
title: 'supERPort',
|
||||
materialThemeBuilder: (context, theme) => ShadcnTheme.lightTheme,
|
||||
localizationsDelegates: const [
|
||||
GlobalMaterialLocalizations.delegate,
|
||||
GlobalWidgetsLocalizations.delegate,
|
||||
GlobalCupertinoLocalizations.delegate,
|
||||
],
|
||||
supportedLocales: const [Locale('ko', 'KR'), Locale('en', 'US')],
|
||||
locale: const Locale('ko', 'KR'),
|
||||
home: authService == null
|
||||
? const LoginScreen() // AuthService가 없으면 바로 로그인 화면
|
||||
: FutureBuilder<bool>(
|
||||
future: authService.isLoggedIn(),
|
||||
builder: (context, snapshot) {
|
||||
if (snapshot.connectionState == ConnectionState.waiting) {
|
||||
return const Scaffold(
|
||||
body: Center(
|
||||
child: CircularProgressIndicator(),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
// 에러 처리 추가
|
||||
if (snapshot.hasError) {
|
||||
print('Auth check error: ${snapshot.error}');
|
||||
// 에러가 발생해도 로그인 화면으로 이동
|
||||
return const LoginScreen();
|
||||
}
|
||||
|
||||
if (snapshot.hasData && snapshot.data!) {
|
||||
// 토큰이 유효하면 홈 화면으로
|
||||
return AppLayout(initialRoute: Routes.home);
|
||||
} else {
|
||||
// 토큰이 없거나 유효하지 않으면 로그인 화면으로
|
||||
return const LoginScreen();
|
||||
}
|
||||
},
|
||||
),
|
||||
onGenerateRoute: (settings) {
|
||||
// 로그인 라우트 처리
|
||||
if (settings.name == '/login') {
|
||||
return MaterialPageRoute(builder: (context) => const LoginScreen());
|
||||
}
|
||||
// 기본 AppLayout으로 라우팅할 경로 (홈, 목록 화면들)
|
||||
if (settings.name == Routes.home ||
|
||||
settings.name == Routes.vendor ||
|
||||
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) {
|
||||
settings.name == Routes.inventory ||
|
||||
settings.name == Routes.inventoryHistory ||
|
||||
settings.name == Routes.inventoryDashboard ||
|
||||
settings.name == Routes.maintenance ||
|
||||
settings.name == Routes.maintenanceSchedule ||
|
||||
settings.name == Routes.maintenanceAlert ||
|
||||
settings.name == Routes.maintenanceHistory) {
|
||||
return MaterialPageRoute(
|
||||
builder:
|
||||
(context) => AppLayout(initialRoute: settings.name!),
|
||||
@@ -213,20 +248,7 @@ class SuperportApp extends StatelessWidget {
|
||||
builder: (context) => UserFormScreen(userId: id),
|
||||
);
|
||||
|
||||
// 라이센스 관련 라우트
|
||||
case Routes.licenseAdd:
|
||||
final licenseId = settings.arguments as int?;
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => MaintenanceFormScreen(
|
||||
maintenanceId: licenseId,
|
||||
isExtension: licenseId != null, // 라이선스 ID가 있으면 연장 모드
|
||||
),
|
||||
);
|
||||
case Routes.licenseEdit:
|
||||
final id = settings.arguments as int;
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => MaintenanceFormScreen(maintenanceId: id),
|
||||
);
|
||||
// License 시스템이 Maintenance로 대체됨
|
||||
|
||||
// 입고지 관련 라우트
|
||||
case Routes.warehouseLocationAdd:
|
||||
@@ -238,14 +260,46 @@ class SuperportApp extends StatelessWidget {
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => WarehouseLocationFormScreen(id: id),
|
||||
);
|
||||
|
||||
// 재고 관리 관련 라우트
|
||||
case Routes.inventoryStockIn:
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => const StockInForm(),
|
||||
);
|
||||
case Routes.inventoryStockOut:
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => const StockOutForm(),
|
||||
);
|
||||
|
||||
// 유지보수 관리 관련 라우트
|
||||
case Routes.maintenanceAdd:
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => const Scaffold(
|
||||
body: Center(
|
||||
child: MaintenanceFormDialog(),
|
||||
),
|
||||
),
|
||||
);
|
||||
case Routes.maintenanceEdit:
|
||||
final _ = settings.arguments as int; // id will be used when edit mode is implemented
|
||||
// TODO: 수정 모드 구현 필요
|
||||
return MaterialPageRoute(
|
||||
builder: (context) => const Scaffold(
|
||||
body: Center(
|
||||
child: MaintenanceFormDialog(),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
default:
|
||||
return MaterialPageRoute(
|
||||
builder:
|
||||
(context) => AppLayout(initialRoute: Routes.home),
|
||||
);
|
||||
}
|
||||
},
|
||||
navigatorKey: GlobalKey<NavigatorState>(),
|
||||
},
|
||||
navigatorKey: GlobalKey<NavigatorState>(),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user