62 lines
1.7 KiB
Dart
62 lines
1.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
import 'package:go_router/go_router.dart';
|
|
import 'package:hive_ce/hive.dart';
|
|
import 'package:hive_ce_flutter/adapters.dart';
|
|
import 'package:minhthu/core/constants/app_constants.dart';
|
|
import 'package:minhthu/core/theme/app_theme.dart';
|
|
import 'package:minhthu/features/scanner/data/models/scan_item.dart';
|
|
import 'package:minhthu/features/scanner/presentation/pages/home_page.dart';
|
|
import 'package:minhthu/features/scanner/presentation/pages/detail_page.dart';
|
|
|
|
void main() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
|
|
// Initialize Hive
|
|
await Hive.initFlutter();
|
|
|
|
// Register Hive adapters
|
|
Hive.registerAdapter(ScanItemAdapter());
|
|
|
|
// Open Hive boxes
|
|
await Hive.openBox<ScanItem>(AppConstants.scanHistoryBox);
|
|
|
|
runApp(
|
|
const ProviderScope(
|
|
child: MyApp(),
|
|
),
|
|
);
|
|
}
|
|
|
|
class MyApp extends StatelessWidget {
|
|
const MyApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final router = GoRouter(
|
|
initialLocation: '/',
|
|
routes: [
|
|
GoRoute(
|
|
path: '/',
|
|
builder: (context, state) => const HomePage(),
|
|
),
|
|
GoRoute(
|
|
path: '/detail/:barcode',
|
|
builder: (context, state) {
|
|
final barcode = state.pathParameters['barcode'] ?? '';
|
|
return DetailPage(barcode: barcode);
|
|
},
|
|
),
|
|
],
|
|
);
|
|
|
|
return MaterialApp.router(
|
|
title: 'Barcode Scanner',
|
|
theme: AppTheme.lightTheme,
|
|
darkTheme: AppTheme.darkTheme,
|
|
themeMode: ThemeMode.system,
|
|
routerConfig: router,
|
|
debugShowCheckedModeBanner: false,
|
|
);
|
|
}
|
|
} |