From d437d7b4bfcfecff9fb33fdbaa6902de7cd0cc3b Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Mon, 14 Dec 2020 13:11:46 -0500 Subject: [PATCH] Add useRefresh hook to react-debug-tools This prevents DevTools from throwing an error when inspecting a component that uses the new refresh hook. --- packages/react-debug-tools/src/ReactDebugHooks.js | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/packages/react-debug-tools/src/ReactDebugHooks.js b/packages/react-debug-tools/src/ReactDebugHooks.js index ce62b5ce8b9ef..7ad315db20210 100644 --- a/packages/react-debug-tools/src/ReactDebugHooks.js +++ b/packages/react-debug-tools/src/ReactDebugHooks.js @@ -73,6 +73,10 @@ function getPrimitiveStackCache(): Map> { Dispatcher.useState(null); Dispatcher.useReducer((s, a) => s, null); Dispatcher.useRef(null); + if (typeof Dispatcher.useRefresh === 'function') { + // This type check is for Flow only. + Dispatcher.useRefresh(); + } Dispatcher.useLayoutEffect(() => {}); Dispatcher.useEffect(() => {}); Dispatcher.useImperativeHandle(undefined, () => null); @@ -171,6 +175,16 @@ function useRef(initialValue: T): {|current: T|} { return ref; } +function useRefresh(): () => void { + const hook = nextHook(); + hookLog.push({ + primitive: 'Refresh', + stackError: new Error(), + value: hook !== null ? hook.memoizedState[0] : function refresh() {}, + }); + return () => {}; +} + function useLayoutEffect( create: () => (() => void) | void, inputs: Array | void | null, @@ -314,6 +328,7 @@ const Dispatcher: DispatcherType = { useMemo, useReducer, useRef, + useRefresh, useState, useTransition, useMutableSource,