mirror of
https://github.com/DRYTRIX/TimeTracker.git
synced 2026-05-21 22:00:07 -05:00
9066089a34
- Align app theme with webapp (AppColors, light/dark ColorScheme); move to core/theme - Add app config, theme mode provider, empty_state and error_view widgets - Improve API client, sync service, and repository for time entries - Add login screen, settings (theme toggle, logout), SSL utils for dev certs - Android/iOS project config, Gradle wrapper, and generated launcher icons - Add flutter_launcher_icons and icon assets (app_icon.png, README) Co-authored-by: Cursor <cursoragent@cursor.com>
42 lines
1.5 KiB
Dart
42 lines
1.5 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
import 'package:timetracker_mobile/core/constants/app_constants.dart';
|
|
import 'package:timetracker_mobile/core/theme/app_theme.dart';
|
|
import 'package:timetracker_mobile/data/storage/local_storage.dart';
|
|
import 'package:timetracker_mobile/presentation/providers/theme_mode_provider.dart';
|
|
import 'package:timetracker_mobile/presentation/screens/splash_screen.dart';
|
|
import 'package:timetracker_mobile/presentation/screens/login_screen.dart';
|
|
import 'package:timetracker_mobile/presentation/screens/home_screen.dart';
|
|
|
|
void main() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await LocalStorage.init();
|
|
runApp(
|
|
const ProviderScope(
|
|
child: TimeTrackerApp(),
|
|
),
|
|
);
|
|
}
|
|
|
|
class TimeTrackerApp extends ConsumerWidget {
|
|
const TimeTrackerApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
final themeModeString = ref.watch(themeModeProvider);
|
|
final themeMode = themeModeFromString(themeModeString);
|
|
return MaterialApp(
|
|
title: 'TimeTracker',
|
|
theme: AppTheme.lightTheme,
|
|
darkTheme: AppTheme.darkTheme,
|
|
themeMode: themeMode,
|
|
initialRoute: AppConstants.routeSplash,
|
|
routes: {
|
|
AppConstants.routeSplash: (context) => const SplashScreen(),
|
|
AppConstants.routeLogin: (context) => const LoginScreen(),
|
|
AppConstants.routeHome: (context) => const HomeScreen(),
|
|
},
|
|
);
|
|
}
|
|
}
|