From cd3eb7c8cf09833be0db55bc84d3f913a1783a8a Mon Sep 17 00:00:00 2001 From: Bartosz Prusinowski Date: Thu, 5 Dec 2024 10:49:56 +0100 Subject: [PATCH] fix: Use React 18's createRoot to render additional screenshot elements ...as we use some old libraries that weren't updated to support React 18's new FC definition, we need to have a custom declaration file for react-dom/client. --- app/components/chart-shared.tsx | 15 +++++++++------ app/typings/react-dom.d.ts | 5 +++++ 2 files changed, 14 insertions(+), 6 deletions(-) create mode 100644 app/typings/react-dom.d.ts diff --git a/app/components/chart-shared.tsx b/app/components/chart-shared.tsx index 50fd13d66..731d411a3 100644 --- a/app/components/chart-shared.tsx +++ b/app/components/chart-shared.tsx @@ -9,7 +9,7 @@ import { import { makeStyles } from "@mui/styles"; import { select } from "d3-selection"; import { ComponentProps, useCallback, useEffect, useState } from "react"; -import ReactDOM from "react-dom"; +import { createRoot } from "react-dom/client"; import { ChartDataFiltersList, @@ -155,17 +155,20 @@ export const ChartMoreButton = ({ chartConfig.chartType === "table"; const modifyNode = useCallback( - (node: HTMLElement) => { + async (node: HTMLElement) => { const footnotes = node.querySelector(`.${CHART_FOOTNOTES_CLASS_NAME}`); if (footnotes) { - const container = footnotes.appendChild(document.createElement("div")); - ReactDOM.render( + const container = document.createElement("div"); + footnotes.appendChild(container); + const root = createRoot(container); + root.render( , - container + /> ); + // Wait for the component to render before taking the screenshot. + await new Promise((resolve) => setTimeout(resolve, 0)); } // Every text element should be dark-grey (currently we use primary.main to diff --git a/app/typings/react-dom.d.ts b/app/typings/react-dom.d.ts new file mode 100644 index 000000000..6d35a29cc --- /dev/null +++ b/app/typings/react-dom.d.ts @@ -0,0 +1,5 @@ +declare module "react-dom/client" { + export function createRoot(container: Element): { + render(element: JSX.Element): void; + }; +}