From bd76583fd8112445878136bb7dea5f434b7ec1ee Mon Sep 17 00:00:00 2001 From: Chris Stavitsky <12092849+cstavitsky@users.noreply.github.com> Date: Tue, 28 Nov 2023 09:46:28 -0800 Subject: [PATCH] add comment for reasoning behind change --- react/src/components/Products.js | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/react/src/components/Products.js b/react/src/components/Products.js index e71e8996..a9280e8f 100644 --- a/react/src/components/Products.js +++ b/react/src/components/Products.js @@ -66,6 +66,17 @@ function Products({ frontendSlowdown, backend }) { } } + /* + Fetching and setting the products used to be done in an + async componentDidMount function. We have (Nov 2023) changed the way of + doing this to be non-async, because the async function was getting minified in the + relevant browser profiling frame, and this made it hard to showcase profiling. + + Jonas B explained why switching away from async function helped: + "I think what you are seeing is unrelated to hooks and probably + related to the async keyword + babel transform, hence why it probably got + fixed with hooks (no transform on that class method anymore)" + */ useEffect(() => { // getProducts handles error responses differently, depending on the browser used function getProducts(frontendSlowdown) {