Move context menu to workbench component
[arvados-workbench2.git] / src / components / data-table / data-column.ts
index d3b147362651256d2c1cf546643ef2788de2c7f0..06744c3a21bce90b9246ed74c06c984f9020cdf7 100644 (file)
@@ -2,15 +2,38 @@
 //
 // SPDX-License-Identifier: AGPL-3.0
 
-export interface DataColumn<T> {
+import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
+
+export interface DataColumn<T, F extends DataTableFilterItem = DataTableFilterItem> {
     name: string;
     selected: boolean;
     configurable?: boolean;
     key?: React.Key;
+    sortDirection?: SortDirection;
+    filters?: F[];
     render: (item: T) => React.ReactElement<void>;
     renderHeader?: () => React.ReactElement<void> | null;
+    width?: string;
+}
+
+export enum SortDirection {
+    Asc = "asc",
+    Desc = "desc",
+    None = "none"
 }
 
 export const isColumnConfigurable = <T>(column: DataColumn<T>) => {
     return column.configurable === undefined || column.configurable;
-};
\ No newline at end of file
+};
+
+export const toggleSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
+    return column.sortDirection
+        ? column.sortDirection === SortDirection.Asc
+            ? { ...column, sortDirection: SortDirection.Desc }
+            : { ...column, sortDirection: SortDirection.Asc }
+        : column;
+};
+
+export const resetSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
+    return column.sortDirection ? { ...column, sortDirection: SortDirection.None } : column;
+};