Create tests for data table filter
[arvados.git] / src / components / data-table / data-column.ts
index f991f62730d14d16b42c8bf81ffaac5c055c21dd..7ac568a25b5301901ffc95318f1581852dc8dfc5 100644 (file)
@@ -2,15 +2,32 @@
 //
 // SPDX-License-Identifier: AGPL-3.0
 
+import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
+
 export interface DataColumn<T> {
     name: string;
     selected: boolean;
     configurable?: boolean;
     key?: React.Key;
+    sortDirection?: SortDirection;
+    onSortToggle?: () => void;
+    filters?: DataTableFilterItem[];
+    onFiltersChange?: (filters: DataTableFilterItem[]) => void;
     render: (item: T) => React.ReactElement<void>;
-    renderHeader?: () => React.ReactElement<void>;
+    renderHeader?: () => React.ReactElement<void> | null;
 }
 
+export type SortDirection = "asc" | "desc";
+
 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> => {
+    const sortDirection = column.sortDirection === undefined || column.sortDirection === "desc" ? "asc" : "desc";
+    return { ...column, sortDirection };
+};
+
+export const resetSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
+    return { ...column, sortDirection: undefined };
+};