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.
129 lines
4.1 KiB
Dart
129 lines
4.1 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:google_fonts/google_fonts.dart';
|
|
|
|
// Définition de l'enum pour les styles de couleur/fond
|
|
enum CustomAppTextFieldStyle {
|
|
beige,
|
|
lavande,
|
|
jaune,
|
|
}
|
|
|
|
class CustomAppTextField extends StatefulWidget {
|
|
final TextEditingController controller;
|
|
final String labelText;
|
|
final String hintText;
|
|
final double fieldHeight;
|
|
final double fieldWidth;
|
|
final bool obscureText;
|
|
final TextInputType keyboardType;
|
|
final String? Function(String?)? validator;
|
|
final CustomAppTextFieldStyle style;
|
|
final bool isRequired;
|
|
final bool enabled;
|
|
final bool readOnly;
|
|
final VoidCallback? onTap;
|
|
final IconData? suffixIcon;
|
|
|
|
const CustomAppTextField({
|
|
super.key,
|
|
required this.controller,
|
|
required this.labelText,
|
|
this.hintText = '',
|
|
this.fieldHeight = 50.0,
|
|
this.fieldWidth = 300.0,
|
|
this.obscureText = false,
|
|
this.keyboardType = TextInputType.text,
|
|
this.validator,
|
|
this.style = CustomAppTextFieldStyle.beige,
|
|
this.isRequired = false,
|
|
this.enabled = true,
|
|
this.readOnly = false,
|
|
this.onTap,
|
|
this.suffixIcon,
|
|
});
|
|
|
|
@override
|
|
State<CustomAppTextField> createState() => _CustomAppTextFieldState();
|
|
}
|
|
|
|
class _CustomAppTextFieldState extends State<CustomAppTextField> {
|
|
String getBackgroundImagePath() {
|
|
switch (widget.style) {
|
|
case CustomAppTextFieldStyle.lavande:
|
|
return 'assets/images/input_field_lavande.png';
|
|
case CustomAppTextFieldStyle.jaune:
|
|
return 'assets/images/input_field_jaune.png';
|
|
case CustomAppTextFieldStyle.beige:
|
|
default:
|
|
return 'assets/images/input_field_bg.png';
|
|
}
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: [
|
|
Text(
|
|
widget.labelText,
|
|
style: GoogleFonts.merienda(
|
|
fontSize: 14,
|
|
color: Colors.black87,
|
|
fontWeight: FontWeight.w500,
|
|
),
|
|
),
|
|
const SizedBox(height: 6),
|
|
SizedBox(
|
|
width: widget.fieldWidth,
|
|
height: widget.fieldHeight,
|
|
child: Stack(
|
|
alignment: Alignment.centerLeft,
|
|
children: [
|
|
Positioned.fill(
|
|
child: Image.asset(
|
|
getBackgroundImagePath(),
|
|
fit: BoxFit.fill,
|
|
),
|
|
),
|
|
Padding(
|
|
padding: const EdgeInsets.only(left: 18.0, right: 18.0, bottom: 2.0),
|
|
child: TextFormField(
|
|
controller: widget.controller,
|
|
obscureText: widget.obscureText,
|
|
keyboardType: widget.keyboardType,
|
|
enabled: widget.enabled,
|
|
readOnly: widget.readOnly,
|
|
onTap: widget.onTap,
|
|
style: GoogleFonts.merienda(fontSize: 15, color: widget.enabled ? Colors.black87 : Colors.grey),
|
|
validator: widget.validator ??
|
|
(value) {
|
|
if (!widget.enabled || widget.readOnly) return null;
|
|
if (widget.isRequired && (value == null || value.isEmpty)) {
|
|
return 'Ce champ est obligatoire';
|
|
}
|
|
return null;
|
|
},
|
|
decoration: InputDecoration(
|
|
hintText: widget.hintText,
|
|
hintStyle: GoogleFonts.merienda(fontSize: 15, color: Colors.black54.withOpacity(0.7)),
|
|
border: InputBorder.none,
|
|
contentPadding: EdgeInsets.zero,
|
|
suffixIcon: widget.suffixIcon != null
|
|
? Padding(
|
|
padding: const EdgeInsets.only(right: 0.0),
|
|
child: Icon(widget.suffixIcon, color: Colors.black54, size: 20),
|
|
)
|
|
: null,
|
|
isDense: true,
|
|
),
|
|
textAlignVertical: TextAlignVertical.center,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
],
|
|
);
|
|
}
|
|
} |