- Updated Group, Trip, User, and other model classes to include comprehensive documentation for better understanding and maintainability. - Improved error handling and logging in services, including AuthService, ErrorService, and StorageService. - Added validation and business logic explanations in ExpenseService and TripService. - Refactored method comments to follow a consistent format across the codebase. - Translated error messages and comments from French to English for consistency.
200 lines
7.6 KiB
Dart
200 lines
7.6 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_bloc/flutter_bloc.dart';
|
|
import 'package:firebase_core/firebase_core.dart';
|
|
import 'package:travel_mate/blocs/balance/balance_bloc.dart';
|
|
import 'package:travel_mate/blocs/expense/expense_bloc.dart';
|
|
import 'package:travel_mate/blocs/message/message_bloc.dart';
|
|
import 'package:travel_mate/services/balance_service.dart';
|
|
import 'package:travel_mate/services/error_service.dart';
|
|
import 'package:flutter_dotenv/flutter_dotenv.dart';
|
|
import 'package:travel_mate/services/expense_service.dart';
|
|
import 'blocs/auth/auth_bloc.dart';
|
|
import 'blocs/auth/auth_event.dart';
|
|
import 'blocs/theme/theme_bloc.dart';
|
|
import 'blocs/theme/theme_event.dart';
|
|
import 'blocs/theme/theme_state.dart';
|
|
import 'blocs/group/group_bloc.dart';
|
|
import 'blocs/user/user_bloc.dart';
|
|
import 'blocs/trip/trip_bloc.dart';
|
|
import 'blocs/account/account_bloc.dart';
|
|
import 'repositories/auth_repository.dart';
|
|
import 'repositories/trip_repository.dart';
|
|
import 'repositories/user_repository.dart';
|
|
import 'repositories/group_repository.dart';
|
|
import 'repositories/message_repository.dart';
|
|
import 'repositories/account_repository.dart';
|
|
import 'repositories/expense_repository.dart';
|
|
import 'repositories/balance_repository.dart';
|
|
import 'pages/login.dart';
|
|
import 'pages/home.dart';
|
|
import 'pages/signup.dart';
|
|
import 'pages/resetpswd.dart';
|
|
|
|
/// Entry point of the Travel Mate application.
|
|
///
|
|
/// This function initializes Flutter widgets, loads environment variables,
|
|
/// initializes Firebase, and starts the application.
|
|
void main() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await dotenv.load(fileName: ".env");
|
|
await Firebase.initializeApp();
|
|
|
|
runApp(const MyApp());
|
|
}
|
|
|
|
/// The root widget of the Travel Mate application.
|
|
///
|
|
/// This widget sets up the BLoC providers, repositories, and MaterialApp
|
|
/// configuration. It manages the application's theme, routing, and global state.
|
|
class MyApp extends StatelessWidget {
|
|
/// Creates the main application widget.
|
|
const MyApp({super.key});
|
|
|
|
/// Builds the widget tree for the application.
|
|
///
|
|
/// Sets up repository providers for dependency injection, BLoC providers
|
|
/// for state management, and configures the MaterialApp with themes and routing.
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MultiRepositoryProvider(
|
|
providers: [
|
|
// Authentication repository for handling user authentication
|
|
RepositoryProvider<AuthRepository>(
|
|
create: (context) => AuthRepository(),
|
|
),
|
|
// User repository for managing user data
|
|
RepositoryProvider<UserRepository>(
|
|
create: (context) => UserRepository(),
|
|
),
|
|
// Trip repository for managing travel trips
|
|
RepositoryProvider<TripRepository>(
|
|
create: (context) => TripRepository(),
|
|
),
|
|
// Group repository for managing travel groups
|
|
RepositoryProvider<GroupRepository>(
|
|
create: (context) => GroupRepository(),
|
|
),
|
|
// Message repository for handling in-app messaging
|
|
RepositoryProvider<MessageRepository>(
|
|
create: (context) => MessageRepository(),
|
|
),
|
|
// Account repository for managing user account settings
|
|
RepositoryProvider<AccountRepository>(
|
|
create: (context) => AccountRepository(),
|
|
),
|
|
// Expense repository for managing trip expenses
|
|
RepositoryProvider<ExpenseRepository>(
|
|
create: (context) => ExpenseRepository(),
|
|
),
|
|
// Expense service for business logic related to expenses
|
|
RepositoryProvider<ExpenseService>(
|
|
create: (context) => ExpenseService(
|
|
expenseRepository: context.read<ExpenseRepository>(),
|
|
),
|
|
),
|
|
// Balance repository for calculating expense balances
|
|
RepositoryProvider<BalanceRepository>(
|
|
create: (context) => BalanceRepository(
|
|
expenseRepository: context.read<ExpenseRepository>(),
|
|
),
|
|
),
|
|
// Balance service for business logic related to balances
|
|
RepositoryProvider<BalanceService>(
|
|
create: (context) => BalanceService(
|
|
balanceRepository: context.read<BalanceRepository>(),
|
|
expenseRepository: context.read<ExpenseRepository>(),
|
|
),
|
|
),
|
|
|
|
],
|
|
child: MultiBlocProvider(
|
|
providers: [
|
|
// Theme BLoC for managing app theme preferences
|
|
BlocProvider<ThemeBloc>(
|
|
create: (context) => ThemeBloc()..add(ThemeLoadRequested()),
|
|
),
|
|
// Authentication BLoC for managing user authentication state
|
|
BlocProvider<AuthBloc>(
|
|
create: (context) =>
|
|
AuthBloc(authRepository: context.read<AuthRepository>())
|
|
..add(AuthCheckRequested()),
|
|
),
|
|
// Group BLoC for managing travel groups
|
|
BlocProvider(
|
|
create: (context) => GroupBloc(context.read<GroupRepository>()),
|
|
),
|
|
// Trip BLoC for managing travel trips
|
|
BlocProvider(
|
|
create: (context) =>
|
|
TripBloc(context.read<TripRepository>()),
|
|
),
|
|
// User BLoC for managing user data
|
|
BlocProvider(create: (context) => UserBloc()),
|
|
// Message BLoC for managing in-app messaging
|
|
BlocProvider(
|
|
create: (context) => MessageBloc(),
|
|
),
|
|
// Account BLoC for managing user account settings
|
|
BlocProvider(
|
|
create: (context) => AccountBloc(
|
|
context.read<AccountRepository>(),
|
|
),
|
|
),
|
|
|
|
// Expense BLoC for managing trip expenses
|
|
BlocProvider<ExpenseBloc>(
|
|
create: (context) => ExpenseBloc(
|
|
expenseRepository: context.read<ExpenseRepository>(),
|
|
expenseService: context.read<ExpenseService>(),
|
|
),
|
|
),
|
|
// Balance BLoC for managing expense balances and calculations
|
|
BlocProvider<BalanceBloc>(
|
|
create: (context) => BalanceBloc(
|
|
balanceRepository: context.read<BalanceRepository>(),
|
|
balanceService: context.read<BalanceService>(),
|
|
expenseRepository: context.read<ExpenseRepository>(),
|
|
),
|
|
),
|
|
|
|
],
|
|
child: BlocBuilder<ThemeBloc, ThemeState>(
|
|
builder: (context, themeState) {
|
|
return MaterialApp(
|
|
title: 'Travel Mate',
|
|
navigatorKey: ErrorService.navigatorKey,
|
|
themeMode: themeState.themeMode,
|
|
// Light theme configuration
|
|
theme: ThemeData(
|
|
colorScheme: ColorScheme.fromSeed(
|
|
seedColor: const Color.fromARGB(255, 180, 180, 180),
|
|
brightness: Brightness.light,
|
|
),
|
|
useMaterial3: true,
|
|
),
|
|
// Dark theme configuration
|
|
darkTheme: ThemeData(
|
|
colorScheme: ColorScheme.fromSeed(
|
|
seedColor: const Color.fromARGB(255, 43, 43, 43),
|
|
brightness: Brightness.dark,
|
|
),
|
|
useMaterial3: true,
|
|
),
|
|
// Default page when app starts
|
|
home: const LoginPage(),
|
|
// Named routes for navigation
|
|
routes: {
|
|
'/login': (context) => const LoginPage(),
|
|
'/signup': (context) => const SignUpPage(),
|
|
'/home': (context) => const HomePage(),
|
|
'/forgot': (context) => const ForgotPasswordPage(),
|
|
},
|
|
debugShowCheckedModeBanner: false,
|
|
);
|
|
},
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|