From 4343f793e989b54e25de7089f5dea1bd7573bc77 Mon Sep 17 00:00:00 2001 From: matttdawson <89495499+matttdawson@users.noreply.github.com> Date: Fri, 24 May 2024 10:47:10 +1200 Subject: [PATCH] FIX: failed to render in 1000ms warning (#464) FIX: failed to render in 1000ms warning (#464) --- src/components/GridNoRowsOverlay.tsx | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) diff --git a/src/components/GridNoRowsOverlay.tsx b/src/components/GridNoRowsOverlay.tsx index f5c74415..3e6b0e88 100644 --- a/src/components/GridNoRowsOverlay.tsx +++ b/src/components/GridNoRowsOverlay.tsx @@ -1,7 +1,12 @@ import { LuiStatusSpinner } from "@linzjs/lui"; +import { ForwardedRef, forwardRef } from "react"; -const GridLoadingOverlayComponent = (props: { headerRowHeight: number }) => ( +const GridLoadingOverlayComponentFr = ( + props: { headerRowHeight: number }, + externalRef: ForwardedRef, +) => (
(
); +const GridLoadingOverlayComponent = forwardRef(GridLoadingOverlayComponentFr); + export interface GridNoRowsOverlayProps { loading: boolean; rowCount: number | undefined | null; @@ -28,10 +35,17 @@ export interface GridNoRowsOverlayProps { headerRowHeight: number; } -export const GridNoRowsOverlay = (props: GridNoRowsOverlayProps) => { - if (props.loading) return ; - if (props.rowCount === 0) return
{props.noRowsOverlayText ?? "There are currently no rows"}
; - if (props.filteredRowCount === 0) - return
{props.noRowsMatchingOverlayText ?? "All rows have been filtered"}
; - return ; +export const GridNoRowsOverlayFr = (props: GridNoRowsOverlayProps, externalRef: ForwardedRef) => { + if (props.loading) { + return ; + } + if (props.rowCount === 0) { + return
{props.noRowsOverlayText ?? "There are currently no rows"}
; + } + if (props.filteredRowCount === 0) { + return
{props.noRowsMatchingOverlayText ?? "All rows have been filtered"}
; + } + return
; }; + +export const GridNoRowsOverlay = forwardRef(GridNoRowsOverlayFr);