Skip to content

Commit

Permalink
fix: Fallback message for virtual table was exceeding table header width
Browse files Browse the repository at this point in the history
  • Loading branch information
Brandon Dow committed May 10, 2024
1 parent f3acfc0 commit 495cf6d
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 5 deletions.
13 changes: 12 additions & 1 deletion src/components/Table/GridTable.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,17 @@ export function InfiniteScrollWithLoader() {
export function NoRowsFallback() {
const nameColumn: GridColumn<Row> = { header: "Name", data: ({ name }) => name };
const valueColumn: GridColumn<Row> = { header: "Value", data: ({ value }) => value };
return <GridTable columns={[nameColumn, valueColumn]} rows={[simpleHeader]} fallbackMessage="There were no rows." />;
return (
<div css={Css.wPx(500).hPx(500).$}>
<GridTable
columns={[nameColumn, valueColumn]}
as={"virtual"}
style={{ bordered: true, allWhite: true }}
rows={[simpleHeader]}
fallbackMessage="There were no rows."
/>
</div>
);
}

// Make a `Row` ADT for a table with a header + 3 levels of nesting
Expand Down Expand Up @@ -2094,6 +2104,7 @@ export function MinColumnWidths() {
<GridTable
columns={[nameColumn, valueColumn, actionColumn]}
style={{ bordered: true, allWhite: true }}
as="virtual"
rows={[
simpleHeader,
{ kind: "data", id: "group", data: { name: "group", value: 0 } },
Expand Down
9 changes: 5 additions & 4 deletions src/components/Table/GridTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import memoizeOne from "memoize-one";
import { runInAction } from "mobx";
import React, { MutableRefObject, ReactElement, useEffect, useMemo, useRef, useState } from "react";
import { Components, Virtuoso, VirtuosoHandle } from "react-virtuoso";
import { Loader } from "src/components";
import { getTableRefWidthStyles, Loader } from "src/components";
import { DiscriminateUnion, GridRowKind } from "src/components/index";
import { PresentationFieldProps, PresentationProvider } from "src/components/PresentationContext";
import { GridTableApi, GridTableApiImpl } from "src/components/Table/GridTableApi";
Expand All @@ -20,7 +20,7 @@ import {
import { assignDefaultColumnIds } from "src/components/Table/utils/columns";
import { GridRowLookup } from "src/components/Table/utils/GridRowLookup";
import { TableStateContext } from "src/components/Table/utils/TableState";
import { EXPANDABLE_HEADER, KEPT_GROUP, isCursorBelowMidpoint, zIndices } from "src/components/Table/utils/utils";
import { EXPANDABLE_HEADER, isCursorBelowMidpoint, KEPT_GROUP, zIndices } from "src/components/Table/utils/utils";
import { Css, Only } from "src/Css";
import { useComputed } from "src/hooks";
import { useRenderCount } from "src/hooks/useRenderCount";
Expand Down Expand Up @@ -486,7 +486,7 @@ export function GridTable<R extends Kinded, X extends Only<GridTableXss, X> = an
<PresentationProvider fieldProps={fieldProps} wrap={style?.presentationSettings?.wrap}>
{/* If virtualized take some pixels off the width to accommodate when virtuoso's scrollbar is introduced. */}
{/* Otherwise a horizontal scrollbar will _always_ appear once the vertical scrollbar is needed */}
<div ref={resizeRef} css={Css.w100.if(as === "virtual").w("calc(100% - 20px)").$} />
<div ref={resizeRef} css={getTableRefWidthStyles(as === "virtual")} />
{renders[_as](
style,
id,
Expand Down Expand Up @@ -713,7 +713,8 @@ function renderVirtual<R extends Kinded>(
if (firstRowMessage) {
if (index === 0) {
return (
<div css={Css.add("gridColumn", `${columns.length} span`).$}>
// Ensure the fallback message is the same width as the table
<div css={getTableRefWidthStyles(true)}>
<div css={{ ...style.firstRowMessageCss }}>{firstRowMessage}</div>
</div>
);
Expand Down
4 changes: 4 additions & 0 deletions src/components/Table/utils/utils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -301,3 +301,7 @@ export function recursivelyGetContainingRow<R extends Kinded>(

return undefined;
}

export function getTableRefWidthStyles(isVirtual: boolean) {
return Css.w100.if(isVirtual).w("calc(100% - 20px)").$;
}

0 comments on commit 495cf6d

Please sign in to comment.