217 lines
13 KiB
Dart
217 lines
13 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'; // Remplacé
|
|
import '../../models/user_registration_data.dart'; // Import du vrai modèle
|
|
import '../../utils/data_generator.dart'; // Import du générateur
|
|
import '../../models/card_assets.dart'; // Import des enums de cartes
|
|
|
|
class ParentRegisterStep4Screen extends StatefulWidget {
|
|
final UserRegistrationData registrationData; // Accepte les données
|
|
|
|
const ParentRegisterStep4Screen({super.key, required this.registrationData});
|
|
|
|
@override
|
|
State<ParentRegisterStep4Screen> createState() => _ParentRegisterStep4ScreenState();
|
|
}
|
|
|
|
class _ParentRegisterStep4ScreenState extends State<ParentRegisterStep4Screen> {
|
|
late UserRegistrationData _registrationData; // État local
|
|
final _motivationController = TextEditingController();
|
|
bool _cguAccepted = true; // Pour le test, CGU acceptées par défaut
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
_registrationData = widget.registrationData;
|
|
_motivationController.text = DataGenerator.motivation(); // Générer la motivation
|
|
}
|
|
|
|
@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;
|
|
final cardWidth = screenSize.width * 0.6; // Largeur de la carte (60% de l'écran)
|
|
final double imageAspectRatio = 2.0; // Ratio corrigé (1024/512 = 2.0)
|
|
final cardHeight = cardWidth / imageAspectRatio;
|
|
|
|
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',
|
|
style: GoogleFonts.merienda(fontSize: 16, color: Colors.black54),
|
|
),
|
|
const SizedBox(height: 20),
|
|
Text(
|
|
'Motivation de votre demande',
|
|
style: GoogleFonts.merienda(fontSize: 22, fontWeight: FontWeight.bold, color: Colors.black87),
|
|
textAlign: TextAlign.center,
|
|
),
|
|
const SizedBox(height: 30),
|
|
Container(
|
|
width: cardWidth,
|
|
height: cardHeight,
|
|
decoration: BoxDecoration(
|
|
image: DecorationImage(
|
|
image: AssetImage(CardColorHorizontal.green.path),
|
|
fit: BoxFit.fill,
|
|
),
|
|
),
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(40.0),
|
|
child: Column(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
children: [
|
|
Expanded(
|
|
child: CustomDecoratedTextField(
|
|
controller: _motivationController,
|
|
hintText: 'Écrivez ici pour motiver votre demande...',
|
|
fieldHeight: cardHeight * 0.6,
|
|
maxLines: 10,
|
|
expandDynamically: true,
|
|
fontSize: 18.0,
|
|
),
|
|
),
|
|
const SizedBox(height: 20),
|
|
GestureDetector(
|
|
onTap: () {
|
|
if (!_cguAccepted) {
|
|
_showCGUModal();
|
|
}
|
|
},
|
|
child: AppCustomCheckbox(
|
|
label: 'J\'accepte les conditions générales d\'utilisation',
|
|
value: _cguAccepted,
|
|
onChanged: (newValue) {
|
|
if (!_cguAccepted) {
|
|
_showCGUModal();
|
|
} else {
|
|
setState(() => _cguAccepted = false);
|
|
}
|
|
},
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
// 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
|
|
? () {
|
|
_registrationData.updateMotivation(_motivationController.text);
|
|
_registrationData.acceptCGU();
|
|
|
|
Navigator.pushNamed(
|
|
context,
|
|
'/parent-register/step5',
|
|
arguments: _registrationData
|
|
);
|
|
}
|
|
: null,
|
|
tooltip: 'Suivant',
|
|
),
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
} |