Files
minhthu/lib/main.dart
2025-09-16 23:14:35 +07:00

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,
);
}
}