import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
-export interface DataColumn<T> {
+export interface DataColumn<T, F extends DataTableFilterItem = DataTableFilterItem> {
name: string;
selected: boolean;
configurable?: boolean;
key?: React.Key;
sortDirection?: SortDirection;
- filters?: DataTableFilterItem[];
+ filters?: F[];
render: (item: T) => React.ReactElement<void>;
renderHeader?: () => React.ReactElement<void> | null;
width?: string;
}
-export type SortDirection = "asc" | "desc" | "none";
+export enum SortDirection {
+ Asc = "asc",
+ Desc = "desc",
+ None = "none"
+}
export const isColumnConfigurable = <T>(column: DataColumn<T>) => {
return column.configurable === undefined || column.configurable;
export const toggleSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
return column.sortDirection
- ? column.sortDirection === "asc"
- ? { ...column, sortDirection: "desc" }
- : { ...column, sortDirection: "asc" }
+ ? 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: "none" } : column;
+ return column.sortDirection ? { ...column, sortDirection: SortDirection.None } : column;
};