'use client'; import Breadcrumbs from '@/components/layout/Breadcrumbs'; import SponsorInsightsCard, { MetricBuilders, SlotTemplates, useSponsorMode } from '@/components/sponsors/SponsorInsightsCard'; import Button from '@/components/ui/Button'; import Card from '@/components/ui/Card'; import Image from 'next/image'; import { useParams } from 'next/navigation'; import { useCallback, useEffect, useState, useMemo } from 'react'; import JoinTeamButton from '@/components/teams/JoinTeamButton'; import TeamAdmin from '@/components/teams/TeamAdmin'; import TeamRoster from '@/components/teams/TeamRoster'; import TeamStandings from '@/components/teams/TeamStandings'; import { useServices } from '@/lib/services/ServiceProvider'; import { TeamDetailsViewModel } from '@/lib/view-models/TeamDetailsViewModel'; import { TeamMemberViewModel } from '@/lib/view-models/TeamMemberViewModel'; import { useEffectiveDriverId } from '@/hooks/useEffectiveDriverId'; type TeamRole = 'owner' | 'manager' | 'driver'; interface TeamMembership { driverId: string; role: TeamRole; joinedAt: Date; } type Tab = 'overview' | 'roster' | 'standings' | 'admin'; export default function TeamDetailPage() { const params = useParams(); const teamId = params.id as string; const { teamService, mediaService } = useServices(); 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 currentDriverId = useEffectiveDriverId(); const isSponsorMode = useSponsorMode(); const loadTeamData = useCallback(async () => { setLoading(true); try { const teamDetails = await teamService.getTeamDetails(teamId, currentDriverId); if (!teamDetails) { setTeam(null); setMemberships([]); setIsAdmin(false); return; } const teamMembers = await teamService.getTeamMembers(teamId, currentDriverId, teamDetails.ownerId); const adminStatus = teamDetails.isOwner || teamMembers.some(m => m.driverId === currentDriverId && (m.role === 'manager' || m.role === 'owner')); setTeam(teamDetails); setMemberships(teamMembers); setIsAdmin(adminStatus); } finally { setLoading(false); } }, [teamId, currentDriverId, teamService]); useEffect(() => { void loadTeamData(); }, [loadTeamData]); const handleUpdate = () => { loadTeamData(); }; const handleRemoveMember = async (driverId: string) => { if (!confirm('Are you sure you want to remove this member?')) { return; } try { const performer = await teamService.getMembership(teamId, currentDriverId); if (!performer || (performer.role !== 'owner' && performer.role !== 'manager')) { throw new Error('Only owners or managers can remove members'); } const membership = await teamService.getMembership(teamId, driverId); if (!membership) { throw new Error('Member not found'); } if (membership.role === 'owner') { throw new Error('Cannot remove the team owner'); } await teamService.removeMembership(teamId, driverId); handleUpdate(); } catch (error) { alert(error instanceof Error ? error.message : 'Failed to remove member'); } }; const handleChangeRole = async (driverId: string, newRole: TeamRole) => { try { const performer = await teamService.getMembership(teamId, currentDriverId); if (!performer || (performer.role !== 'owner' && performer.role !== 'manager')) { throw new Error('Only owners or managers can update roles'); } const membership = await teamService.getMembership(teamId, driverId); if (!membership) { throw new Error('Member not found'); } if (membership.role === 'owner') { throw new Error('Cannot change the owner role'); } await teamService.updateMembership(teamId, driverId, newRole); 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); // Build sponsor insights for team const teamMetrics = [ MetricBuilders.members(memberships.length), MetricBuilders.reach(memberships.length * 15), MetricBuilders.races(0), // TODO: Get league count from team data MetricBuilders.engagement(82), ]; return (
{/* Breadcrumb */} {/* Sponsor Insights Card - Consistent placement at top */} {isSponsorMode && team && ( )}
{team.name}

{team.name}

{/* TODO: Add team tag when available */}

{team.description}

{memberships.length} {memberships.length === 1 ? 'member' : 'members'} {/* TODO: Add created date when available */} {/* TODO: Add league count when available */}
{visibleTabs.map((tab) => ( ))}
{activeTab === 'overview' && (

About

{team.description}

Quick Stats

{/* TODO: Get league count */} {/* TODO: Get founded date */}

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}
); }