From 1744c0137371276f3397af6c19011afcf8cfdffa Mon Sep 17 00:00:00 2001 From: Ruslan Lesiutin Date: Thu, 20 Jun 2024 20:20:41 +0100 Subject: [PATCH] refactor[react-devtools/extensions]: dont debounce cleanup logic on navigation --- .../react-devtools-extensions/src/main/index.js | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/packages/react-devtools-extensions/src/main/index.js b/packages/react-devtools-extensions/src/main/index.js index 5422567db79fc..8ed84dd8fb5e0 100644 --- a/packages/react-devtools-extensions/src/main/index.js +++ b/packages/react-devtools-extensions/src/main/index.js @@ -412,13 +412,19 @@ chrome.devtools.network.onNavigated.addListener(syncSavedPreferences); // into subscribing to the same events from Bridge and window multiple times // In this case, we will handle `operations` event twice or more and user will see // `Cannot add node "1" because a node with that id is already in the Store.` -const debouncedOnNavigatedListener = debounce(() => { +const debouncedMountReactDevToolsCallback = debounce( + mountReactDevToolsWhenReactHasLoaded, + 500, +); + +// Clean up everything, but start mounting React DevTools panels if user stays at this page +function onNavigatedToOtherPage() { performInTabNavigationCleanup(); - mountReactDevToolsWhenReactHasLoaded(); -}, 500); + debouncedMountReactDevToolsCallback(); +} // Cleanup previous page state and remount everything -chrome.devtools.network.onNavigated.addListener(debouncedOnNavigatedListener); +chrome.devtools.network.onNavigated.addListener(onNavigatedToOtherPage); // Should be emitted when browser DevTools are closed if (__IS_FIREFOX__) {