Create data table filter component
[arvados-workbench2.git] / src / components / data-table / data-column.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
6
7 export interface DataColumn<T> {
8     name: string;
9     selected: boolean;
10     configurable?: boolean;
11     key?: React.Key;
12     sortDirection?: SortDirection;
13     onSortToggle?: () => void;
14     filters?: DataTableFilterItem[];
15     onFiltersChange?: (filters: DataTableFilterItem[]) => void;
16     render: (item: T) => React.ReactElement<void>;
17     renderHeader?: () => React.ReactElement<void> | null;
18 }
19
20 export type SortDirection = "asc" | "desc";
21
22 export const isColumnConfigurable = <T>(column: DataColumn<T>) => {
23     return column.configurable === undefined || column.configurable;
24 };
25
26 export const toggleSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
27     const sortDirection = column.sortDirection === undefined || column.sortDirection === "desc" ? "asc" : "desc";
28     return { ...column, sortDirection };
29 };
30
31 export const resetSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
32     return { ...column, sortDirection: undefined };
33 };