Ce commit comprend plusieurs améliorations significatives :
Inscription Parent - Étape 5 (Récapitulatif) :
- Initialisation de l'écran pour l'étape 5/5 du parcours d'inscription parent.
- Mise en place de la structure de base de l'écran de récapitulatif (titre, fond, bouton de soumission initial, modale de confirmation).
- Intégration de la navigation vers l'étape 5 depuis l'étape 4, incluant le passage (actuellement factice) des données d'inscription.
- Correction des erreurs de navigation et de typage liées à l'introduction de `PlaceholderRegistrationData` pour cette nouvelle étape.
Refactorisation des Widgets UI :
- `CustomAppTextField` :
- Évolution majeure pour supporter différents styles de fond (beige, lavande, jaune) via un nouvel enum `CustomAppTextFieldStyle`.
- Les images de fond pour les styles lavande et jaune (`input_field_lavande.png`, `input_field_jaune.png`) ont été renommées et sont maintenant utilisées.
- Mise à jour de l'écran de login pour utiliser ce `CustomAppTextField` stylisé, remplaçant l'ancien widget privé `_ImageTextField`.
- Réintégration des paramètres `isRequired`, `enabled`, `readOnly`, `onTap`, et `suffixIcon` qui avaient été omis lors d'une refactorisation précédente, assurant la compatibilité avec l'étape 3.
- `ImageButton` :
- Extraction du widget privé `_ImageButton` de l'écran de login en un widget public `ImageButton` (dans `widgets/image_button.dart`) pour une réutilisation globale.
- Mise à jour de l'écran de login pour utiliser ce nouveau widget public.
- Utilisation du nouveau `ImageButton` pour le bouton "Soumettre ma demande" sur l'écran de l'étape 5.
Corrections :
- Correction d'une erreur de `RenderFlex overflowed` dans la carte enfant (`_ChildCardWidget`) de l'étape 3 de l'inscription parent, en ajustant les espacements internes.
- Résolution de diverses erreurs de compilation qui sont apparues pendant ces refactorisations.
205 lines
14 KiB
Dart
205 lines
14 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:google_fonts/google_fonts.dart';
|
|
import 'package:p_tits_pas/widgets/custom_decorated_text_field.dart'; // Import du nouveau widget
|
|
import 'dart:math' as math; // Pour la rotation du chevron
|
|
import 'package:p_tits_pas/widgets/app_custom_checkbox.dart'; // Import de la checkbox personnalisée
|
|
import 'package:p_tits_pas/models/placeholder_registration_data.dart';
|
|
|
|
class ParentRegisterStep4Screen extends StatefulWidget {
|
|
const ParentRegisterStep4Screen({super.key});
|
|
|
|
@override
|
|
State<ParentRegisterStep4Screen> createState() => _ParentRegisterStep4ScreenState();
|
|
}
|
|
|
|
class _ParentRegisterStep4ScreenState extends State<ParentRegisterStep4Screen> {
|
|
final _motivationController = TextEditingController();
|
|
bool _cguAccepted = false;
|
|
|
|
@override
|
|
void dispose() {
|
|
_motivationController.dispose();
|
|
super.dispose();
|
|
}
|
|
|
|
void _showCGUModal() {
|
|
// Un long texte Lorem Ipsum pour simuler les CGU
|
|
const String loremIpsumText = '''
|
|
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.
|
|
|
|
Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna.
|
|
|
|
Aliquam convallis sollicitudin purus. Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet.
|
|
|
|
Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.
|
|
|
|
Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, nunc turpis ullamcorper nibh, in tempus sapien eros vitae ligula. Pellentesque rhoncus nunc et augue. Integer id felis. Curabitur aliquet pellentesque diam. Integer quis metus vitae elit lobortis egestas. Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Morbi vel erat non mauris convallis vehicula. Nulla et sapien. Integer tortor tellus, aliquam faucibus, convallis id, congue eu, quam. Mauris ullamcorper felis vitae erat. Proin feugiat, augue non elementum posuere, metus purus iaculis lectus, et tristique ligula justo vitae magna. Etiam et felis dolor.
|
|
|
|
Praesent aliquam, enim at fermentum mollis, ligula massa adipiscing nisl, ac euismod nibh nisl eu lectus. Fusce vulputate sem at sapien. Vivamus leo. Aliquam euismod libero eu enim. Nulla nec felis sed leo placerat imperdiet. Aenean suscipit nulla in justo. Suspendisse cursus rutrum augue. Nulla tincidunt tincidunt mi. Curabitur iaculis, lorem vel rhoncus faucibus, felis magna fermentum augue, et ultricies lacus lorem varius purus. Curabitur eu amet. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
|
|
|
|
Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Nam liber tempor cum soluta nobis eleifend option congue nihil imperdiet doming id quod mazim placerat facer possim assum. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.
|
|
''';
|
|
|
|
showDialog<void>(
|
|
context: context,
|
|
barrierDismissible: false, // L'utilisateur doit utiliser le bouton
|
|
builder: (BuildContext dialogContext) {
|
|
return AlertDialog(
|
|
title: Text(
|
|
'Conditions Générales d\'Utilisation',
|
|
style: GoogleFonts.merienda(fontWeight: FontWeight.bold),
|
|
),
|
|
content: SizedBox(
|
|
width: MediaQuery.of(dialogContext).size.width * 0.7, // 70% de la largeur de l'écran
|
|
height: MediaQuery.of(dialogContext).size.height * 0.6, // 60% de la hauteur de l'écran
|
|
child: SingleChildScrollView(
|
|
child: Text(
|
|
loremIpsumText,
|
|
style: GoogleFonts.merienda(fontSize: 13),
|
|
textAlign: TextAlign.justify,
|
|
),
|
|
),
|
|
),
|
|
actionsPadding: const EdgeInsets.symmetric(horizontal: 16.0, vertical: 10.0),
|
|
actionsAlignment: MainAxisAlignment.center,
|
|
actions: <Widget>[
|
|
ElevatedButton(
|
|
style: ElevatedButton.styleFrom(
|
|
backgroundColor: Theme.of(dialogContext).primaryColor,
|
|
padding: const EdgeInsets.symmetric(horizontal: 30, vertical: 15),
|
|
),
|
|
child: Text(
|
|
'Valider et Accepter',
|
|
style: GoogleFonts.merienda(fontSize: 15, color: Colors.white, fontWeight: FontWeight.bold),
|
|
),
|
|
onPressed: () {
|
|
Navigator.of(dialogContext).pop(); // Ferme la modale
|
|
setState(() {
|
|
_cguAccepted = true; // Met à jour l'état
|
|
});
|
|
},
|
|
),
|
|
],
|
|
);
|
|
},
|
|
);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final screenSize = MediaQuery.of(context).size;
|
|
// Calculer la largeur disponible pour le contenu principal de la colonne
|
|
// La SingleChildScrollView a un padding horizontal de 50.0 de chaque côté.
|
|
final availableContentWidth = screenSize.width - (50.0 * 2);
|
|
// Définir la taille du champ de texte carré comme un pourcentage de cette largeur disponible
|
|
final textFieldSize = (availableContentWidth * 0.65) / 2; // Réduction de la taille par deux
|
|
|
|
return Scaffold(
|
|
body: Stack(
|
|
children: [
|
|
Positioned.fill(
|
|
child: Image.asset('assets/images/paper2.png', fit: BoxFit.cover, repeat: ImageRepeat.repeat),
|
|
),
|
|
Center(
|
|
child: SingleChildScrollView(
|
|
padding: const EdgeInsets.symmetric(vertical: 40.0, horizontal: 50.0),
|
|
child: Column(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
children: [
|
|
Text(
|
|
'Étape 4/5', // Supposant 5 étapes au total pour l'instant
|
|
style: GoogleFonts.merienda(fontSize: 16, color: Colors.black54),
|
|
),
|
|
const SizedBox(height: 20),
|
|
Text(
|
|
'Merci de motiver votre demande création de compte :',
|
|
style: GoogleFonts.merienda(fontSize: 22, fontWeight: FontWeight.bold, color: Colors.black87),
|
|
textAlign: TextAlign.center,
|
|
),
|
|
const SizedBox(height: 30),
|
|
SizedBox(
|
|
width: textFieldSize,
|
|
height: textFieldSize,
|
|
child: CustomDecoratedTextField(
|
|
controller: _motivationController,
|
|
hintText: 'Écrivez ici pour motiver votre demande...',
|
|
fieldHeight: textFieldSize,
|
|
maxLines: 10,
|
|
expandDynamically: true,
|
|
),
|
|
),
|
|
const SizedBox(height: 30),
|
|
GestureDetector(
|
|
onTap: () {
|
|
// Si on clique sur la zone et que ce n'est pas encore accepté,
|
|
// ou si c'est déjà accepté (l'utilisateur veut peut-être revoir les CGU)
|
|
_showCGUModal();
|
|
},
|
|
child: AppCustomCheckbox(
|
|
label: 'J\'accepte les conditions générales d\'utilisation',
|
|
value: _cguAccepted,
|
|
onChanged: (newValue) {
|
|
// La logique d'ouverture de la modale est déclenchée par le GestureDetector externe.
|
|
// La modale mettra à jour _cguAccepted et reconstruira le widget.
|
|
// Si newValue est true (ce qui signifie que la modale a été acceptée et _cguAccepted mis à jour),
|
|
// on n'a rien à faire de plus ici.
|
|
// Si newValue est false (l'utilisateur a réussi à la décocher d'une manière ou d'une autre,
|
|
// ce qui ne devrait pas arriver car on ouvre toujours la modale),
|
|
// on pourrait vouloir forcer l'affichage de la modale aussi.
|
|
// Pour l'instant, on se fie au fait que la modale gère l'acceptation.
|
|
if (!_cguAccepted) { // Si pas encore accepté, la modale doit s'ouvrir
|
|
_showCGUModal();
|
|
} else if (newValue == false) { // Si on essaie de décocher
|
|
// Optionnel: Forcer la non-acceptation et rouvrir la modale ?
|
|
// Pour l'instant, on ne fait rien, la modale gère.
|
|
}
|
|
},
|
|
// Vous pouvez ajuster checkboxSize et checkmarkSizeFactor si nécessaire
|
|
),
|
|
),
|
|
const SizedBox(height: 40),
|
|
// On ajoutera un Form et un bouton de soumission principal plus tard
|
|
// Pour l'instant, les chevrons servent à la navigation simple
|
|
],
|
|
),
|
|
),
|
|
),
|
|
// Chevrons de navigation
|
|
Positioned(
|
|
top: screenSize.height / 2 - 20,
|
|
left: 40,
|
|
child: IconButton(
|
|
icon: Transform(alignment: Alignment.center, transform: Matrix4.rotationY(math.pi), child: Image.asset('assets/images/chevron_right.png', height: 40)),
|
|
onPressed: () => Navigator.pop(context),
|
|
tooltip: 'Retour',
|
|
),
|
|
),
|
|
Positioned(
|
|
top: screenSize.height / 2 - 20,
|
|
right: 40,
|
|
child: IconButton(
|
|
icon: Image.asset('assets/images/chevron_right.png', height: 40),
|
|
onPressed: _cguAccepted
|
|
? () {
|
|
print('Motivation: ${_motivationController.text}');
|
|
print('CGU acceptées: $_cguAccepted');
|
|
|
|
// TODO: Rassembler toutes les données des étapes précédentes
|
|
final dummyData = PlaceholderRegistrationData(parent1Name: "Parent 1 Nom (Exemple)");
|
|
|
|
Navigator.pushNamed(
|
|
context,
|
|
'/parent-register/step5',
|
|
arguments: dummyData // Passer les données (ici factices)
|
|
);
|
|
}
|
|
: null, // Désactiver si les CGU ne sont pas acceptées
|
|
tooltip: 'Suivant',
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
} |