remove width attr from DataColumn, move styles to data-explorer
[arvados-workbench2.git] / src / components / data-table / data-column.ts
index a5000b935bcea4b1420b14408516d03718dacb67..a5f95506a816da0decfd4754705ea4cb8c0cddc6 100644 (file)
@@ -2,18 +2,18 @@
 //
 // SPDX-License-Identifier: AGPL-3.0
 
+import * as React from "react";
 import { DataTableFilterItem } from "../data-table-filters/data-table-filters";
 
 export interface DataColumn<T, F extends DataTableFilterItem = DataTableFilterItem> {
+    key?: React.Key;
     name: string;
     selected: boolean;
     configurable: boolean;
-    key?: React.Key;
     sortDirection?: SortDirection;
-    filters?: F[];
+    filters: F[];
     render: (item: T) => React.ReactElement<any>;
     renderHeader?: () => React.ReactElement<any>;
-    width?: string;
 }
 
 export enum SortDirection {
@@ -33,3 +33,14 @@ export const toggleSortDirection = <T>(column: DataColumn<T>): DataColumn<T> =>
 export const resetSortDirection = <T>(column: DataColumn<T>): DataColumn<T> => {
     return column.sortDirection ? { ...column, sortDirection: SortDirection.NONE } : column;
 };
+
+export const createDataColumn = <T, F extends DataTableFilterItem>(dataColumn: Partial<DataColumn<T, F>>): DataColumn<T, F> => ({
+    key: '',
+    name: '',
+    selected: true,
+    configurable: true,
+    sortDirection: SortDirection.NONE,
+    filters: [],
+    render: () => React.createElement('span'),
+    ...dataColumn,
+});