Début refacto en MVVM (Login, drawer OK

This commit is contained in:
2025-03-10 23:40:54 +01:00
parent b6f169e5f7
commit 2b8e7085aa
15 changed files with 509 additions and 330 deletions

View File

@ -1,4 +1,5 @@
import 'package:em2rp/utils/auth_guard_widget.dart';
import 'package:em2rp/view_model/user_management_view_model.dart';
import 'package:em2rp/views/calendar_page.dart';
import 'package:em2rp/views/login_page.dart';
import 'package:firebase_auth/firebase_auth.dart';
@ -10,6 +11,8 @@ import 'views/my_account_page.dart';
import 'views/user_management_page.dart';
import 'package:provider/provider.dart';
import 'providers/user_provider.dart';
import 'providers/local_auth_provider.dart'; // Ajout de l'AuthProvider
import 'services/user_service.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
@ -19,9 +22,25 @@ void main() async {
await FirebaseAuth.instance.setPersistence(Persistence.LOCAL);
runApp(
ChangeNotifierProvider(
// Wrap MyApp with ChangeNotifierProvider
create: (context) => UserProvider(), // Create UserProvider instance
MultiProvider(
providers: [
// Injection du service UserService
Provider<UserService>(create: (_) => UserService()),
// AuthProvider pour la gestion de l'authentification
ChangeNotifierProvider<LocalAuthProvider>(
create: (context) => LocalAuthProvider()),
// UserProvider déjà existant
ChangeNotifierProvider<UserProvider>(
create: (context) => UserProvider()),
// Injection des ViewModels en utilisant UserService et AuthProvider
ChangeNotifierProvider<UserManagementViewModel>(
create: (context) =>
UserManagementViewModel(context.read<UserService>()),
),
],
child: const MyApp(),
),
);
@ -43,43 +62,27 @@ class MyApp extends StatelessWidget {
textTheme: const TextTheme(
bodyMedium: TextStyle(color: AppColors.noir),
),
// Personnalisation de l'InputDecorationTheme pour les text fields
inputDecorationTheme: InputDecorationTheme(
focusedBorder: OutlineInputBorder(
// Bordure lorsqu'il est focus
borderSide:
BorderSide(color: AppColors.noir), // Couleur rouge quand focus
borderSide: BorderSide(color: AppColors.noir),
),
enabledBorder: OutlineInputBorder(
// Bordure par défaut (non focus)
borderSide:
BorderSide(color: AppColors.gris), // Couleur grise par défaut
borderSide: BorderSide(color: AppColors.gris),
),
labelStyle: TextStyle(color: AppColors.noir), // Couleur du label
hintStyle: TextStyle(color: AppColors.gris), // Couleur du hint text
// Tu peux personnaliser d'autres propriétés ici :
// fillColor, filled, iconColor, prefixStyle, suffixStyle, etc.
labelStyle: TextStyle(color: AppColors.noir),
hintStyle: TextStyle(color: AppColors.gris),
),
elevatedButtonTheme: ElevatedButtonThemeData(
style: ElevatedButton.styleFrom(
foregroundColor:
AppColors.blanc, // Couleur du texte du bouton (ici blanc)
backgroundColor: AppColors
.noir, // Couleur de fond du bouton (si tu veux aussi changer le fond)
// Autres styles possibles pour les boutons :
// textStyle, padding, shape, elevation, etc.
foregroundColor: AppColors.blanc,
backgroundColor: AppColors.noir,
),
),
),
routes: {
//Pages accessibles à tous
'/login': (context) => const LoginPage(),
//Pages réservées aux UTILISATEURS CONNECTÉS
'/calendar': (context) => const AuthGuard(child: CalendarPage()),
'/my_account': (context) => const AuthGuard(child: MyAccountPage()),
//Pages réservées aux ADMIN
'/user_management': (context) =>
const AuthGuard(requiredRole: "ADMIN", child: UserManagementPage()),
},