'use client'; import { useState, useEffect } from 'react'; import { useParams } from 'next/navigation'; import Card from '@/components/ui/Card'; import Button from '@/components/ui/Button'; import Breadcrumbs from '@/components/layout/Breadcrumbs'; import TeamRoster from '@/components/teams/TeamRoster'; import TeamStandings from '@/components/teams/TeamStandings'; import TeamAdmin from '@/components/teams/TeamAdmin'; import JoinTeamButton from '@/components/teams/JoinTeamButton'; import { Team, getTeam, getTeamMembers, getCurrentDriverId, isTeamOwnerOrManager, TeamMembership, removeTeamMember, updateTeamMemberRole, TeamRole, } from '@gridpilot/racing/application'; type Tab = 'overview' | 'roster' | 'standings' | 'admin'; export default function TeamDetailPage() { const params = useParams(); const teamId = params.id as string; const [team, setTeam] = useState(null); const [memberships, setMemberships] = useState([]); const [activeTab, setActiveTab] = useState('overview'); const [loading, setLoading] = useState(true); const [isAdmin, setIsAdmin] = useState(false); const loadTeamData = () => { const teamData = getTeam(teamId); if (!teamData) { setLoading(false); return; } const teamMemberships = getTeamMembers(teamId); const currentDriverId = getCurrentDriverId(); const adminStatus = isTeamOwnerOrManager(teamId, currentDriverId); setTeam(teamData); setMemberships(teamMemberships); setIsAdmin(adminStatus); setLoading(false); }; useEffect(() => { loadTeamData(); }, [teamId]); const handleUpdate = () => { loadTeamData(); }; const handleRemoveMember = (driverId: string) => { if (!confirm('Are you sure you want to remove this member?')) { return; } try { const currentDriverId = getCurrentDriverId(); removeTeamMember(teamId, driverId, currentDriverId); handleUpdate(); } catch (error) { alert(error instanceof Error ? error.message : 'Failed to remove member'); } }; const handleChangeRole = (driverId: string, newRole: TeamRole) => { try { const currentDriverId = getCurrentDriverId(); updateTeamMemberRole(teamId, driverId, newRole, currentDriverId); handleUpdate(); } catch (error) { alert(error instanceof Error ? error.message : 'Failed to change role'); } }; if (loading) { return (
Loading team...
); } if (!team) { return (

Team Not Found

The team you're looking for doesn't exist or has been disbanded.

); } const tabs: { id: Tab; label: string; visible: boolean }[] = [ { id: 'overview', label: 'Overview', visible: true }, { id: 'roster', label: 'Roster', visible: true }, { id: 'standings', label: 'Standings', visible: true }, { id: 'admin', label: 'Admin', visible: isAdmin }, ]; const visibleTabs = tabs.filter(tab => tab.visible); return (
{/* Breadcrumb */}
{team.tag}

{team.name}

{team.tag}

{team.description}

{memberships.length} {memberships.length === 1 ? 'member' : 'members'} Created {new Date(team.createdAt).toLocaleDateString()} {team.leagues.length > 0 && ( <> {team.leagues.length} {team.leagues.length === 1 ? 'league' : 'leagues'} )}
{visibleTabs.map((tab) => ( ))}
{activeTab === 'overview' && (

About

{team.description}

Quick Stats

Recent Activity

No recent activity to display
)} {activeTab === 'roster' && ( )} {activeTab === 'standings' && ( )} {activeTab === 'admin' && isAdmin && ( )}
); } function StatItem({ label, value, color }: { label: string; value: string; color: string }) { return (
{label} {value}
); }