feat(#44): UserManagementPanel + masquer onglet Administrateurs (dashboard gestionnaire)
Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
parent
e990d576cf
commit
defa438edf
@ -106,6 +106,6 @@ class _AdminDashboardScreenState extends State<AdminDashboardScreen> {
|
|||||||
selectedSettingsTabIndex: settingsSubIndex,
|
selectedSettingsTabIndex: settingsSubIndex,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
return const AdminUserManagementPanel();
|
return const UserManagementPanel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -4,7 +4,7 @@ import 'package:p_tits_pas/widgets/admin/user_management_panel.dart';
|
|||||||
import 'package:p_tits_pas/widgets/app_footer.dart';
|
import 'package:p_tits_pas/widgets/app_footer.dart';
|
||||||
|
|
||||||
/// Dashboard gestionnaire – même shell que l'admin, sans onglet Paramètres.
|
/// Dashboard gestionnaire – même shell que l'admin, sans onglet Paramètres.
|
||||||
/// Réutilise [AdminUserManagementPanel].
|
/// Réutilise [UserManagementPanel].
|
||||||
class GestionnaireDashboardScreen extends StatefulWidget {
|
class GestionnaireDashboardScreen extends StatefulWidget {
|
||||||
const GestionnaireDashboardScreen({super.key});
|
const GestionnaireDashboardScreen({super.key});
|
||||||
|
|
||||||
@ -36,7 +36,9 @@ class _GestionnaireDashboardScreenState extends State<GestionnaireDashboardScree
|
|||||||
),
|
),
|
||||||
body: Column(
|
body: Column(
|
||||||
children: [
|
children: [
|
||||||
const Expanded(child: AdminUserManagementPanel()),
|
Expanded(
|
||||||
|
child: UserManagementPanel(showAdministrateursTab: false),
|
||||||
|
),
|
||||||
const AppFooter(),
|
const AppFooter(),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|||||||
@ -139,7 +139,8 @@ class DashboardAppBarAdmin extends StatelessWidget
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Sous-barre : Gestionnaires | Parents | Assistantes maternelles | Administrateurs.
|
/// Sous-barre : Gestionnaires | Parents | Assistantes maternelles | [Administrateurs].
|
||||||
|
/// [subTabCount] = 3 pour masquer l'onglet Administrateurs (dashboard gestionnaire).
|
||||||
class DashboardUserManagementSubBar extends StatelessWidget {
|
class DashboardUserManagementSubBar extends StatelessWidget {
|
||||||
final int selectedSubIndex;
|
final int selectedSubIndex;
|
||||||
final ValueChanged<int> onSubTabChange;
|
final ValueChanged<int> onSubTabChange;
|
||||||
@ -148,6 +149,14 @@ class DashboardUserManagementSubBar extends StatelessWidget {
|
|||||||
final Widget? filterControl;
|
final Widget? filterControl;
|
||||||
final VoidCallback? onAddPressed;
|
final VoidCallback? onAddPressed;
|
||||||
final String addLabel;
|
final String addLabel;
|
||||||
|
final int subTabCount;
|
||||||
|
|
||||||
|
static const List<String> _tabLabels = [
|
||||||
|
'Gestionnaires',
|
||||||
|
'Parents',
|
||||||
|
'Assistantes maternelles',
|
||||||
|
'Administrateurs',
|
||||||
|
];
|
||||||
|
|
||||||
const DashboardUserManagementSubBar({
|
const DashboardUserManagementSubBar({
|
||||||
Key? key,
|
Key? key,
|
||||||
@ -158,6 +167,7 @@ class DashboardUserManagementSubBar extends StatelessWidget {
|
|||||||
this.filterControl,
|
this.filterControl,
|
||||||
this.onAddPressed,
|
this.onAddPressed,
|
||||||
this.addLabel = '+ Ajouter',
|
this.addLabel = '+ Ajouter',
|
||||||
|
this.subTabCount = 4,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
@ -171,13 +181,10 @@ class DashboardUserManagementSubBar extends StatelessWidget {
|
|||||||
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 6),
|
padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 6),
|
||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
_buildSubNavItem(context, 'Gestionnaires', 0),
|
for (int i = 0; i < subTabCount; i++) ...[
|
||||||
const SizedBox(width: 12),
|
if (i > 0) const SizedBox(width: 12),
|
||||||
_buildSubNavItem(context, 'Parents', 1),
|
_buildSubNavItem(context, _tabLabels[i], i),
|
||||||
const SizedBox(width: 12),
|
],
|
||||||
_buildSubNavItem(context, 'Assistantes maternelles', 2),
|
|
||||||
const SizedBox(width: 12),
|
|
||||||
_buildSubNavItem(context, 'Administrateurs', 3),
|
|
||||||
const SizedBox(width: 36),
|
const SizedBox(width: 36),
|
||||||
_pillField(
|
_pillField(
|
||||||
width: 320,
|
width: 320,
|
||||||
|
|||||||
@ -6,15 +6,20 @@ import 'package:p_tits_pas/widgets/admin/dashboard_admin.dart';
|
|||||||
import 'package:p_tits_pas/widgets/admin/gestionnaire_management_widget.dart';
|
import 'package:p_tits_pas/widgets/admin/gestionnaire_management_widget.dart';
|
||||||
import 'package:p_tits_pas/widgets/admin/parent_managmant_widget.dart';
|
import 'package:p_tits_pas/widgets/admin/parent_managmant_widget.dart';
|
||||||
|
|
||||||
class AdminUserManagementPanel extends StatefulWidget {
|
class UserManagementPanel extends StatefulWidget {
|
||||||
const AdminUserManagementPanel({super.key});
|
/// Afficher l'onglet Administrateurs (sinon 3 onglets : Gestionnaires, Parents, AM).
|
||||||
|
final bool showAdministrateursTab;
|
||||||
|
|
||||||
|
const UserManagementPanel({
|
||||||
|
super.key,
|
||||||
|
this.showAdministrateursTab = true,
|
||||||
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
State<AdminUserManagementPanel> createState() =>
|
State<UserManagementPanel> createState() => _UserManagementPanelState();
|
||||||
_AdminUserManagementPanelState();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class _AdminUserManagementPanelState extends State<AdminUserManagementPanel> {
|
class _UserManagementPanelState extends State<UserManagementPanel> {
|
||||||
int _subIndex = 0;
|
int _subIndex = 0;
|
||||||
int _gestionnaireRefreshTick = 0;
|
int _gestionnaireRefreshTick = 0;
|
||||||
int _adminRefreshTick = 0;
|
int _adminRefreshTick = 0;
|
||||||
@ -44,8 +49,9 @@ class _AdminUserManagementPanelState extends State<AdminUserManagementPanel> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void _onSubTabChange(int index) {
|
void _onSubTabChange(int index) {
|
||||||
|
final maxIndex = widget.showAdministrateursTab ? 3 : 2;
|
||||||
setState(() {
|
setState(() {
|
||||||
_subIndex = index;
|
_subIndex = index.clamp(0, maxIndex);
|
||||||
_searchController.clear();
|
_searchController.clear();
|
||||||
_parentStatus = null;
|
_parentStatus = null;
|
||||||
_amCapacityController.clear();
|
_amCapacityController.clear();
|
||||||
@ -161,6 +167,7 @@ class _AdminUserManagementPanelState extends State<AdminUserManagementPanel> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
final subTabCount = widget.showAdministrateursTab ? 4 : 3;
|
||||||
return Column(
|
return Column(
|
||||||
children: [
|
children: [
|
||||||
DashboardUserManagementSubBar(
|
DashboardUserManagementSubBar(
|
||||||
@ -171,6 +178,7 @@ class _AdminUserManagementPanelState extends State<AdminUserManagementPanel> {
|
|||||||
filterControl: _subBarFilterControl(),
|
filterControl: _subBarFilterControl(),
|
||||||
onAddPressed: _handleAddPressed,
|
onAddPressed: _handleAddPressed,
|
||||||
addLabel: 'Ajouter',
|
addLabel: 'Ajouter',
|
||||||
|
subTabCount: subTabCount,
|
||||||
),
|
),
|
||||||
Expanded(child: _buildBody()),
|
Expanded(child: _buildBody()),
|
||||||
],
|
],
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user