47 lines
1.2 KiB
Dart
47 lines
1.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'app_theme.dart';
|
|
import 'model/repositories/local_repository.dart';
|
|
import 'pages/task_edit_page.dart';
|
|
import 'pages/task_overview_page.dart';
|
|
import 'service/controller_scope.dart';
|
|
import 'service/controllers/alarm_controller.dart';
|
|
import 'service/controllers/location_controller.dart';
|
|
import 'service/controllers/task_controller.dart';
|
|
|
|
void main() async {
|
|
final repository = LocalRepository();
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await repository.initialize();
|
|
|
|
runApp(
|
|
ControllerScope(
|
|
controller: LocationController(repository),
|
|
child: ControllerScope(
|
|
controller: AlarmController(repository),
|
|
child: ControllerScope(
|
|
controller: TaskController(repository),
|
|
child: const MainApp(),
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
class MainApp extends StatelessWidget {
|
|
const MainApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MaterialApp(
|
|
theme: AppTheme.lightTheme,
|
|
darkTheme: AppTheme.darkTheme,
|
|
routes: {
|
|
TaskOverviewPage.routeName: (context) => TaskOverviewPage(),
|
|
TaskEditPage.routeName: (context) => TaskEditPage(),
|
|
},
|
|
initialRoute: TaskOverviewPage.routeName,
|
|
);
|
|
}
|
|
}
|