trcr/lib/main.dart
2026-02-21 07:01:36 -08:00

95 lines
2.7 KiB
Dart

import 'dart:async';
import 'dart:developer' as developer;
import 'package:firebase_core/firebase_core.dart';
import 'package:firebase_crashlytics/firebase_crashlytics.dart';
import 'package:flutter/material.dart';
import 'package:app_links/app_links.dart';
import 'package:rate_my_app/rate_my_app.dart';
import 'package:traccar_client/geolocation_service.dart';
import 'package:traccar_client/password_service.dart';
import 'package:traccar_client/push_service.dart';
import 'package:traccar_client/quick_actions.dart';
import 'l10n/app_localizations.dart';
import 'main_screen.dart';
import 'preferences.dart';
import 'configuration_service.dart';
final messengerKey = GlobalKey<ScaffoldMessengerState>();
void main() async {
WidgetsFlutterBinding.ensureInitialized();
await Firebase.initializeApp();
FlutterError.onError = FirebaseCrashlytics.instance.recordFlutterFatalError;
await Preferences.init();
await PasswordService.migrate();
await GeolocationService.init();
await PushService.init();
runApp(const MainApp());
}
class MainApp extends StatefulWidget {
const MainApp({super.key});
@override
State<MainApp> createState() => _MainAppState();
}
class _MainAppState extends State<MainApp> {
RateMyApp rateMyApp = RateMyApp(minDays: 0, minLaunches: 0);
@override
void initState() {
super.initState();
_initLinks();
WidgetsBinding.instance.addPostFrameCallback((_) async {
await rateMyApp.init();
if (mounted && rateMyApp.shouldOpenDialog) {
try {
await rateMyApp.showRateDialog(context);
} catch (error) {
developer.log('Failed to show rate dialog', error: error);
}
}
});
}
Future<void> _initLinks() async {
final appLinks = AppLinks();
final uri = await appLinks.getInitialLink();
if (uri != null) {
await ConfigurationService.applyUri(uri);
}
appLinks.uriLinkStream.listen((uri) async {
await ConfigurationService.applyUri(uri);
});
}
@override
Widget build(BuildContext context) {
return MaterialApp(
scaffoldMessengerKey: messengerKey,
localizationsDelegates: AppLocalizations.localizationsDelegates,
supportedLocales: AppLocalizations.supportedLocales,
theme: ThemeData(
colorScheme: ColorScheme.fromSeed(
seedColor: Colors.green,
brightness: Brightness.light,
),
),
darkTheme: ThemeData(
colorScheme: ColorScheme.fromSeed(
seedColor: Colors.green,
brightness: Brightness.dark,
),
),
home: Stack(
children: const [
QuickActionsInitializer(),
MainScreen(),
],
),
);
}
}