import 'package:flutter/material.dart'; import 'package:frontend_splatournament_manager/models/team.dart'; import 'package:frontend_splatournament_manager/providers/team_provider.dart'; import 'package:provider/provider.dart'; class MyTeamsWidget extends StatefulWidget { const MyTeamsWidget({super.key}); @override State createState() => _MyTeamsWidgetState(); } class _MyTeamsWidgetState extends State { late Future> _myTeamsFuture; @override void initState() { super.initState(); _loadMyTeams(); } void _loadMyTeams() { _myTeamsFuture = Provider.of(context, listen: false).getUserTeams(); } @override Widget build(BuildContext context) { return FutureBuilder>( future: _myTeamsFuture, builder: (context, snapshot) { if (snapshot.connectionState == ConnectionState.waiting) { return const Center(child: CircularProgressIndicator()); } if (snapshot.hasError) { return Center(child: Text('Error: ${snapshot.error}')); } final teams = snapshot.data ?? []; if (teams.isEmpty) { return const Center( child: Text('You are not in any teams yet\nJoin teams from the All Teams tab'), ); } return ListView.builder( padding: const EdgeInsets.all(16), itemCount: teams.length, itemBuilder: (context, index) => _buildTeamCard(teams[index]), ); }, ); } Widget _buildTeamCard(Team team) { final memberCountText = team.memberCount != null ? '${team.memberCount}/4 members' : 'No members'; final description = team.description.isEmpty ? 'No description' : team.description; return Card( margin: const EdgeInsets.only(bottom: 12), child: ListTile( leading: CircleAvatar(child: Text(team.tag)), title: Text(team.name), subtitle: Text( '$description\n$memberCountText', style: const TextStyle(fontSize: 14), ), trailing: IconButton( icon: const Icon(Icons.logout, color: Colors.red), onPressed: () => _leaveTeam(team), ), ), ); } Future _leaveTeam(Team team) async { final confirmed = await showDialog( context: context, builder: (context) => AlertDialog( title: const Text('Leave Team?'), content: Text('Leave "${team.name}"?'), actions: [ TextButton( onPressed: () => Navigator.pop(context, false), child: const Text('Cancel'), ), TextButton( onPressed: () => Navigator.pop(context, true), child: const Text('Leave', style: TextStyle(color: Colors.red)), ), ], ), ); if (confirmed == true && mounted) { try { await Provider.of(context, listen: false).leaveTeam(team.id); if (mounted) { ScaffoldMessenger.of(context).showSnackBar( const SnackBar(content: Text('Left team')), ); _loadMyTeams(); setState(() {}); } } catch (e) { if (mounted) { ScaffoldMessenger.of(context).showSnackBar( SnackBar(content: Text('Error: $e')), ); } } } } }