From aca03a1db158eff6bbba9d8e7cae710d685c8cd8 Mon Sep 17 00:00:00 2001 From: Karan Mehta <95593651+KaranAtTeamForm@users.noreply.github.com> Date: Wed, 11 Dec 2024 18:03:19 +1100 Subject: [PATCH] fix table design --- lib/components/Table/index.js | 16 ++++- lib/components/Table/muiStyleOverrides.js | 79 +++++++++++++++++------ package-lock.json | 4 +- package.json | 2 +- 4 files changed, 75 insertions(+), 26 deletions(-) diff --git a/lib/components/Table/index.js b/lib/components/Table/index.js index 92dde08e..fd9ee39f 100644 --- a/lib/components/Table/index.js +++ b/lib/components/Table/index.js @@ -3,16 +3,27 @@ import { useMaterialReactTable, MaterialReactTable } from "material-react-table"; -import { merge } from "lodash"; +import { merge, map } from "lodash"; import muiStyleOverrides from "./muiStyleOverrides"; import getExpandColumnConfig from "./getExpandColumnConfig"; import { PropTypes } from "prop-types"; -const Table = ({ data, columns, ...tableConfig }) => { +const Table = ({ data, columns: columnOverrides, ...tableConfig }) => { const otherConfig = {}; const columnVisibility = {}; + const columns = useMemo(() => { + return tableConfig?.enableSorting + ? columnOverrides + : map(columnOverrides, (col) => { + return { + ...col, + enableSorting: false + }; + }); + }, [columnOverrides, tableConfig?.enableSorting]); + const firstCol = useMemo(() => columns[0], [columns]); if (tableConfig.enableExpanding) { @@ -33,6 +44,7 @@ const Table = ({ data, columns, ...tableConfig }) => { ...tableConfig, columns, data, + enableExpanding: true, initialState: merge( { density: "compact", columnVisibility }, tableConfig.initialState || {} diff --git a/lib/components/Table/muiStyleOverrides.js b/lib/components/Table/muiStyleOverrides.js index 623bd61e..e3ca9a08 100644 --- a/lib/components/Table/muiStyleOverrides.js +++ b/lib/components/Table/muiStyleOverrides.js @@ -1,25 +1,39 @@ +import React from "react"; +import Icon from "../Icon"; +import Box from "../Box"; + const muiStyleOverrides = { - muiBottomToolbarProps: { sx: { boxShadow: "none" } }, + muiExpandButtonProps: ({ row }) => { + return { + children: row?.getIsExpanded() ? ( + + + + ) : ( + + + + ) + }; + }, + muiBottomToolbarProps: { + sx: { + display: "none" // Remove bottom toolbar + } + }, muiTableHeadProps: { sx: { - height: "32px", - borderRadius: "5px", + backgroundColor: "transparent", // No background for header "& .MuiTableCell-root": { - borderBottom: "none", - paddingTop: 0, - paddingBottom: 0, - verticalAlign: "middle" - }, - "& .MuiTableRow-root": { - borderRadius: "5px", - background: "#F2F5F5", - boxShadow: "none" - }, - "& th:nth-child(1)": { - borderRadius: "5px 0px 0px 5px" + color: "#6b7280", // Subtle text color (gray tone) + fontWeight: "500", // Slightly bold for clarity + padding: "0 0 6px 0", // Consistent padding + borderBottom: "1px solid #e0e0e0", // Subtle header-row separation + textAlign: "left", // Ensure text alignment is consistent + lineHeight: "1.5" // Enhance readability }, - "& th:nth-last-child(1)": { - borderRadius: "0px 5px 5px 0px" + "& button": { + display: "none" // Explicitly hide any buttons in the header } } }, @@ -37,7 +51,6 @@ const muiStyleOverrides = { borderBottomStyle = "none"; } else { const lastSubRowOfParent = subRows[subRows.length - 1]; - borderBottomStyle = lastSubRowOfParent.id === row.id ? "solid" : "none"; } } @@ -54,10 +67,34 @@ const muiStyleOverrides = { sx: { borderCollapse: "separate !important", tableLayout: "fixed", - - fontSize: "12px", + fontFamily: "inherit", + fontSize: "inherit", + fontWeight: "normal", + "& th, .MuiTableCell-root": { + fontWeight: "normal", + fontSize: "inherit", + fontFamily: "inherit" + }, + "& td": { + fontFamily: "inherit", + fontSize: "inherit", + fontWeight: "normal" + }, "& td, .MuiTableCell-root": { - fontSize: "12px" + padding: "6px 0 6px 0", + marginLeft: "0" + } + } + }, + muiTableBodyCellProps: { + sx: { + fontWeight: "normal", // Remove bold when expanded + // Default row cell style + "&.MuiTableRow-root": { + fontWeight: "normal" // Ensure the font is not bold by default + }, + "&.expanded": { + fontWeight: "normal" // Remove bold when expanded } } }, diff --git a/package-lock.json b/package-lock.json index 5986dc66..c81e27f4 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "orcs-design-system", - "version": "3.2.44", + "version": "3.2.45", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "orcs-design-system", - "version": "3.2.44", + "version": "3.2.45", "dependencies": { "@emotion/react": "^11.11.4", "@emotion/styled": "^11.11.5", diff --git a/package.json b/package.json index 315fadb7..7372fbf4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "orcs-design-system", - "version": "3.2.44", + "version": "3.2.45", "engines": { "node": "20.12.2" },