'use client'; import { useRouter, useParams } from 'next/navigation'; import { DataTable } from '@/components/shared/data-table'; import { FilterBar } from '@/components/shared/filter-bar'; import { PageHeader } from '@/components/shared/page-header'; import { SavedViewsDropdown } from '@/components/shared/saved-views-dropdown'; import { EmptyState } from '@/components/shared/empty-state'; import { usePaginatedQuery } from '@/hooks/use-paginated-query'; import { useRealtimeInvalidation } from '@/hooks/use-realtime-invalidation'; import { berthColumns, type BerthRow } from './berth-columns'; import { berthFilterDefinitions } from './berth-filters'; import { Anchor } from 'lucide-react'; export function BerthList() { const router = useRouter(); const params = useParams<{ portSlug: string }>(); const { data, pagination, isLoading, sort, setSort, filters, setFilter, clearFilters, setPage, } = usePaginatedQuery({ queryKey: ['berths'], endpoint: '/api/v1/berths', filterDefinitions: berthFilterDefinitions, }); useRealtimeInvalidation({ 'berth:updated': [['berths']], 'berth:statusChanged': [['berths']], }); return (
{ clearFilters(); Object.entries(savedFilters).forEach(([key, value]) => setFilter(key, value)); }} />
columns={berthColumns} data={data} isLoading={isLoading} pagination={{ page: pagination.page, pageSize: pagination.pageSize, total: pagination.total, totalPages: pagination.totalPages, }} onPaginationChange={(page) => setPage(page)} sort={sort} onSortChange={setSort} getRowId={(row) => row.id} onRowClick={(row) => router.push(`/${params.portSlug}/berths/${row.id}`)} emptyState={ } />
); }