refactoring and checkpoint

This commit is contained in:
DahoudG
2024-09-24 00:32:20 +00:00
parent dc73ba7dcc
commit 6b12cfeb41
159 changed files with 8119 additions and 1535 deletions

View File

@@ -5,18 +5,31 @@ import '../../data/datasources/user_remote_data_source.dart';
import '../../data/repositories/user_repository_impl.dart';
import '../../domain/usecases/get_user.dart';
/// Instance globale pour gérer l'injection des dépendances via GetIt
final sl = GetIt.instance;
/// Fonction d'initialisation pour enregistrer toutes les dépendances.
/// Utilisée pour fournir des services, des data sources, des repositories et des use cases.
void init() {
// Log de démarrage de l'injection des dépendances
print("Démarrage de l'initialisation des dépendances.");
// Register Http Client
sl.registerLazySingleton(() => http.Client());
print("Client HTTP enregistré.");
// Register Data Sources
sl.registerLazySingleton(() => UserRemoteDataSource(sl()));
print("DataSource pour UserRemoteDataSource enregistré.");
// Register Repositories
sl.registerLazySingleton(() => UserRepositoryImpl(remoteDataSource: sl()));
print("Repository pour UserRepositoryImpl enregistré.");
// Register Use Cases
sl.registerLazySingleton(() => GetUser(sl()));
print("UseCase pour GetUser enregistré.");
// Log de fin d'initialisation des dépendances
print("Initialisation des dépendances terminée.");
}

View File

@@ -1,30 +1,39 @@
import 'package:flutter/material.dart';
import 'package:afterwork/presentation/screens/login/login_screen.dart';
import 'package:afterwork/presentation/screens/home/home_screen.dart';
import 'package:afterwork/presentation/screens/event/event_screen.dart';
import 'package:afterwork/presentation/screens/story/story_screen.dart';
import 'package:afterwork/presentation/screens/profile/profile_screen.dart';
import 'package:afterwork/presentation/screens/settings/settings_screen.dart';
import 'package:afterwork/presentation/screens/home/home_screen.dart';
import 'package:afterwork/data/datasources/event_remote_data_source.dart';
import '../presentation/reservations/reservations_screen.dart';
/// Router personnalisé pour gérer la navigation dans l'application.
/// Les logs permettent de tracer chaque navigation dans la console.
class AppRouter {
final EventRemoteDataSource eventRemoteDataSource;
final String userId;
final String userName;
final String userLastName;
/// Initialisation des informations utilisateur et source de données
AppRouter({
required this.eventRemoteDataSource,
required this.userId,
required this.userName,
required this.userLastName,
});
}) {
print("AppRouter initialisé avec les infos utilisateur : $userId, $userName, $userLastName");
}
/// Génération des routes pour l'application
Route<dynamic> generateRoute(RouteSettings settings) {
print("Navigation vers la route : ${settings.name}");
switch (settings.name) {
case '/':
return MaterialPageRoute(builder: (_) => const LoginScreen());
case '/home':
return MaterialPageRoute(
builder: (_) => HomeScreen(
@@ -32,25 +41,31 @@ class AppRouter {
userId: userId,
userName: userName,
userLastName: userLastName,
userProfileImage: 'lib/assets/images/profile_picture.png',
),
);
case '/event':
return MaterialPageRoute(
builder: (_) => EventScreen(
eventRemoteDataSource: eventRemoteDataSource,
userId: userId,
userName: userName,
userLastName: userLastName,
),
);
case '/story':
return MaterialPageRoute(builder: (_) => const StoryScreen());
case '/profile':
return MaterialPageRoute(builder: (_) => const ProfileScreen());
case '/settings':
return MaterialPageRoute(builder: (_) => const SettingsScreen());
case '/reservations':
return MaterialPageRoute(builder: (_) => const ReservationsScreen());
default:
return MaterialPageRoute(
builder: (_) => const Scaffold(