Merge branch 'master' of git.curoverse.com:arvados-workbench2 into 14229-chips-field
[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 * as React from "react";
6 import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
7
8 export interface DataColumn<T, F extends DataTableFilterItem = DataTableFilterItem> {
9     key?: React.Key;
10     name: string;
11     selected: boolean;
12     configurable: boolean;
13     sortDirection?: SortDirection;
14     filters: F[];
15     render: (item: T) => React.ReactElement<any>;
16     renderHeader?: () => React.ReactElement<any>;
17 }
18
19 export enum SortDirection {
20     ASC = "asc",
21     DESC = "desc",
22     NONE = "none"
23 }
24
25 export const toggleSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
26     return column.sortDirection
27         ? column.sortDirection === SortDirection.ASC
28             ? { ...column, sortDirection: SortDirection.DESC }
29             : { ...column, sortDirection: SortDirection.ASC }
30         : column;
31 };
32
33 export const resetSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
34     return column.sortDirection ? { ...column, sortDirection: SortDirection.NONE } : column;
35 };
36
37 export const createDataColumn = <T, F extends DataTableFilterItem>(dataColumn: Partial<DataColumn<T, F>>): DataColumn<T, F> => ({
38     key: '',
39     name: '',
40     selected: true,
41     configurable: true,
42     sortDirection: SortDirection.NONE,
43     filters: [],
44     render: () => React.createElement('span'),
45     ...dataColumn,
46 });