import { useCallback } from 'react'; import type { ViewFieldDefinition, ViewFieldMetadata, } from '@/ui/editable-field/types/ViewField'; import { FilterDropdownButton } from '@/ui/filter-n-sort/components/FilterDropdownButton'; import SortAndFilterBar from '@/ui/filter-n-sort/components/SortAndFilterBar'; import { SortDropdownButton } from '@/ui/filter-n-sort/components/SortDropdownButton'; import { sortsScopedState } from '@/ui/filter-n-sort/states/sortsScopedState'; import { FiltersHotkeyScope } from '@/ui/filter-n-sort/types/FiltersHotkeyScope'; import { SelectedSortType, SortType } from '@/ui/filter-n-sort/types/interface'; import { TableOptionsDropdownButton } from '@/ui/table/options/components/TableOptionsDropdownButton'; import { TopBar } from '@/ui/top-bar/TopBar'; import { useRecoilScopedState } from '@/ui/utilities/recoil-scope/hooks/useRecoilScopedState'; import { TableUpdateViewButtonGroup } from '../../options/components/TableUpdateViewButtonGroup'; import { TableViewsDropdownButton } from '../../options/components/TableViewsDropdownButton'; import { TableRecoilScopeContext } from '../../states/recoil-scope-contexts/TableRecoilScopeContext'; import type { TableView } from '../../states/tableViewsState'; import { TableOptionsHotkeyScope } from '../../types/TableOptionsHotkeyScope'; import { TableViewsHotkeyScope } from '../../types/TableViewsHotkeyScope'; type OwnProps = { viewName: string; availableSorts?: Array>; onColumnsChange?: (columns: ViewFieldDefinition[]) => void; onViewsChange?: (views: TableView[]) => void; onViewSubmit?: () => void; onImport?: () => void; }; export function TableHeader({ viewName, availableSorts, onColumnsChange, onViewsChange, onViewSubmit, onImport, }: OwnProps) { const [sorts, setSorts] = useRecoilScopedState[]>( sortsScopedState, TableRecoilScopeContext, ); const sortSelect = useCallback( (newSort: SelectedSortType) => { const newSorts = updateSortOrFilterByKey(sorts, newSort); setSorts(newSorts); }, [setSorts, sorts], ); const sortUnselect = useCallback( (sortKey: string) => { const newSorts = sorts.filter((sort) => sort.key !== sortKey); setSorts(newSorts); }, [setSorts, sorts], ); return ( } displayBottomBorder={false} rightComponent={ <> context={TableRecoilScopeContext} isSortSelected={sorts.length > 0} availableSorts={availableSorts || []} onSortSelect={sortSelect} HotkeyScope={FiltersHotkeyScope.FilterDropdownButton} isPrimaryButton /> } bottomComponent={ setSorts([])} hasFilterButton rightComponent={ } /> } /> ); } function updateSortOrFilterByKey( sorts: Readonly, newSort: SortOrFilter, ): SortOrFilter[] { const newSorts = [...sorts]; const existingSortIndex = sorts.findIndex((sort) => sort.key === newSort.key); if (existingSortIndex !== -1) { newSorts[existingSortIndex] = newSort; } else { newSorts.push(newSort); } return newSorts; }