83 lines
3.1 KiB
TypeScript
83 lines
3.1 KiB
TypeScript
'use client';
|
|
|
|
import { useState } from 'react';
|
|
import { useQuery } from '@tanstack/react-query';
|
|
import { TransmittalList } from '@/components/transmittal/transmittal-list';
|
|
import { transmittalService } from '@/lib/services/transmittal.service';
|
|
import { projectService } from '@/lib/services/project.service';
|
|
import { Button } from '@/components/ui/button';
|
|
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select';
|
|
import { Plus, RefreshCw } from 'lucide-react';
|
|
import Link from 'next/link';
|
|
import { TransmittalListResponse } from '@/types/transmittal';
|
|
|
|
export default function TransmittalPage() {
|
|
// ADR-019: Dynamic project selection via UUID
|
|
const [selectedProjectUuid, setSelectedProjectUuid] = useState<string>('');
|
|
|
|
const { data: projectsData } = useQuery({
|
|
queryKey: ['projects-for-transmittals'],
|
|
queryFn: () => projectService.getAll(),
|
|
});
|
|
const projects = projectsData?.data || projectsData || [];
|
|
|
|
const { data, isLoading, error, refetch } = useQuery<TransmittalListResponse>({
|
|
queryKey: ['transmittals', selectedProjectUuid],
|
|
queryFn: () => transmittalService.getAll({ projectId: selectedProjectUuid }),
|
|
enabled: !!selectedProjectUuid,
|
|
});
|
|
|
|
return (
|
|
<section className="space-y-4">
|
|
<div className="flex items-center justify-between">
|
|
<div>
|
|
<h1 className="text-2xl font-bold">Transmittals</h1>
|
|
<p className="text-muted-foreground">Manage document transmittal slips</p>
|
|
</div>
|
|
<div className="flex gap-2">
|
|
<Button variant="outline" size="icon" onClick={() => refetch()} disabled={isLoading} title="Refresh">
|
|
<RefreshCw className={`h-4 w-4 ${isLoading ? 'animate-spin' : ''}`} />
|
|
</Button>
|
|
<Link href="/transmittals/new">
|
|
<Button>
|
|
<Plus className="h-4 w-4 mr-2" />
|
|
New Transmittal
|
|
</Button>
|
|
</Link>
|
|
</div>
|
|
</div>
|
|
|
|
{/* ADR-019: Project filter */}
|
|
<div className="flex items-center gap-3">
|
|
<span className="text-sm font-medium text-muted-foreground">Project:</span>
|
|
<Select value={selectedProjectUuid} onValueChange={setSelectedProjectUuid}>
|
|
<SelectTrigger className="w-[280px]">
|
|
<SelectValue placeholder="Select a project" />
|
|
</SelectTrigger>
|
|
<SelectContent>
|
|
{(Array.isArray(projects) ? projects : []).map(
|
|
(p: { publicId: string; projectName?: string; projectCode?: string }) => (
|
|
<SelectItem key={p.publicId} value={p.publicId}>
|
|
{p.projectName || p.projectCode}
|
|
</SelectItem>
|
|
)
|
|
)}
|
|
</SelectContent>
|
|
</Select>
|
|
</div>
|
|
|
|
{error && (
|
|
<div className="bg-destructive/10 text-destructive px-4 py-3 rounded-md">Failed to load transmittals.</div>
|
|
)}
|
|
|
|
{isLoading ? (
|
|
<div className="flex items-center justify-center py-12">
|
|
<RefreshCw className="h-8 w-8 animate-spin text-muted-foreground" />
|
|
</div>
|
|
) : (
|
|
<TransmittalList data={data?.data || []} />
|
|
)}
|
|
</section>
|
|
);
|
|
}
|