diff --git a/centrifuge-app/src/components/DataTable.tsx b/centrifuge-app/src/components/DataTable.tsx index 048645e871..d9bdfaec2d 100644 --- a/centrifuge-app/src/components/DataTable.tsx +++ b/centrifuge-app/src/components/DataTable.tsx @@ -95,7 +95,7 @@ export const DataTable = >({ minWidth={scrollWidth > 0 ? scrollWidth : 'auto'} > {showHeader && ( - + {columns.map((col, i) => ( @@ -117,6 +117,7 @@ export const DataTable = >({ to={onRowClicked && (() => onRowClicked(row))} key={keyField ? row[keyField] : i} tabIndex={onRowClicked ? 0 : undefined} + templateColumns={templateColumns} > {columns.map((col, index) => ( @@ -127,7 +128,7 @@ export const DataTable = >({ ))} {/* summary row is not included in sorting */} {summary && ( - + {columns.map((col, i) => ( {col.cell(summary, i)} @@ -146,14 +147,18 @@ export const DataTable = >({ const TableGrid = styled(Grid)`` -const Row = styled('div')` +const Row = styled('div')` display: grid; + // Fallback for browsers that don't support subgrid + // Tables will look a bit wonky in those browsers + // TODO: Remove when browser support is sufficient + grid-template-columns: ${(props) => props.templateColumns}; grid-template-columns: subgrid; grid-column: start / end; box-shadow: ${({ theme }) => `-1px 0 0 0 ${theme.colors.borderSecondary}, 1px 0 0 0 ${theme.colors.borderSecondary}`}; ` -const HeaderRow = styled(Row)( +const HeaderRow = styled(Row)( css({ backgroundColor: 'backgroundSecondary', borderStyle: 'solid',