From 6630c2de2a578aba0b61cb2e61e58a1466e80ca2 Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Mon, 4 Jan 2021 06:32:03 -0800 Subject: [PATCH] Add rudimentary support for Cache to DevTools (#20458) --- .../__snapshots__/store-test.js.snap | 1 + .../src/__tests__/store-test.js | 1 + .../src/backend/renderer.js | 19 ++++++++++++++--- .../src/backend/types.js | 1 + .../src/app/ElementTypes/index.js | 21 +++++++++++-------- 5 files changed, 31 insertions(+), 12 deletions(-) diff --git a/packages/react-devtools-shared/src/__tests__/__snapshots__/store-test.js.snap b/packages/react-devtools-shared/src/__tests__/__snapshots__/store-test.js.snap index cc3c9b6c3cc2d..5ff48f317f479 100644 --- a/packages/react-devtools-shared/src/__tests__/__snapshots__/store-test.js.snap +++ b/packages/react-devtools-shared/src/__tests__/__snapshots__/store-test.js.snap @@ -685,4 +685,5 @@ exports[`Store should show the right display names for special component types 1 [withFoo][withBar] [Memo][withFoo][withBar] [ForwardRef][withFoo][withBar] + `; diff --git a/packages/react-devtools-shared/src/__tests__/store-test.js b/packages/react-devtools-shared/src/__tests__/store-test.js index 33d3bc0a072a3..d219f3cba7def 100644 --- a/packages/react-devtools-shared/src/__tests__/store-test.js +++ b/packages/react-devtools-shared/src/__tests__/store-test.js @@ -888,6 +888,7 @@ describe('Store', () => { + ); diff --git a/packages/react-devtools-shared/src/backend/renderer.js b/packages/react-devtools-shared/src/backend/renderer.js index e44b58f71009e..b942b7561b7b8 100644 --- a/packages/react-devtools-shared/src/backend/renderer.js +++ b/packages/react-devtools-shared/src/backend/renderer.js @@ -176,6 +176,7 @@ export function getInternalReactConstants( // Currently the version in Git is 17.0.2 (but that version has not been/may not end up being released). if (gt(version, '17.0.1')) { ReactTypeOfWork = { + CacheComponent: 24, // Experimental ClassComponent: 1, ContextConsumer: 9, ContextProvider: 10, @@ -205,6 +206,7 @@ export function getInternalReactConstants( }; } else if (gte(version, '17.0.0-alpha')) { ReactTypeOfWork = { + CacheComponent: -1, // Doesn't exist yet ClassComponent: 1, ContextConsumer: 9, ContextProvider: 10, @@ -234,6 +236,7 @@ export function getInternalReactConstants( }; } else if (gte(version, '16.6.0-beta.0')) { ReactTypeOfWork = { + CacheComponent: -1, // Doens't exist yet ClassComponent: 1, ContextConsumer: 9, ContextProvider: 10, @@ -263,6 +266,7 @@ export function getInternalReactConstants( }; } else if (gte(version, '16.4.3-alpha')) { ReactTypeOfWork = { + CacheComponent: -1, // Doens't exist yet ClassComponent: 2, ContextConsumer: 11, ContextProvider: 12, @@ -292,6 +296,7 @@ export function getInternalReactConstants( }; } else { ReactTypeOfWork = { + CacheComponent: -1, // Doens't exist yet ClassComponent: 2, ContextConsumer: 12, ContextProvider: 13, @@ -335,6 +340,7 @@ export function getInternalReactConstants( } const { + CacheComponent, ClassComponent, IncompleteClassComponent, FunctionComponent, @@ -382,6 +388,8 @@ export function getInternalReactConstants( let resolvedContext: any = null; switch (tag) { + case CacheComponent: + return 'Cache'; case ClassComponent: case IncompleteClassComponent: return getDisplayName(resolvedType); @@ -486,12 +494,13 @@ export function attach( } = getInternalReactConstants(renderer.version); const {Incomplete, NoFlags, PerformedWork, Placement} = ReactTypeOfSideEffect; const { - FunctionComponent, + CacheComponent, ClassComponent, ContextConsumer, DehydratedSuspenseComponent, - Fragment, ForwardRef, + Fragment, + FunctionComponent, HostRoot, HostPortal, HostComponent, @@ -2518,6 +2527,10 @@ export function attach( tag === ForwardRef) && (!!memoizedState || !!dependencies); + // TODO Show custom UI for Cache like we do for Suspense + // For now, just hide state data entirely since it's not meant to be inspected. + const showState = !usesHooks && tag !== CacheComponent; + const typeSymbol = getTypeSymbol(type); let canViewSource = false; @@ -2687,7 +2700,7 @@ export function attach( context, hooks, props: memoizedProps, - state: usesHooks ? null : memoizedState, + state: showState ? memoizedState : null, errors: Array.from(errors.entries()), warnings: Array.from(warnings.entries()), diff --git a/packages/react-devtools-shared/src/backend/types.js b/packages/react-devtools-shared/src/backend/types.js index 93ac3c7827e8b..4cecf59df2983 100644 --- a/packages/react-devtools-shared/src/backend/types.js +++ b/packages/react-devtools-shared/src/backend/types.js @@ -26,6 +26,7 @@ export type WorkFlags = number; export type ExpirationTime = number; export type WorkTagMap = {| + CacheComponent: WorkTag, ClassComponent: WorkTag, ContextConsumer: WorkTag, ContextProvider: WorkTag, diff --git a/packages/react-devtools-shell/src/app/ElementTypes/index.js b/packages/react-devtools-shell/src/app/ElementTypes/index.js index cc3905457a996..4b44a50a6653e 100644 --- a/packages/react-devtools-shell/src/app/ElementTypes/index.js +++ b/packages/react-devtools-shell/src/app/ElementTypes/index.js @@ -19,6 +19,7 @@ import { Profiler, StrictMode, Suspense, + unstable_Cache as Cache, } from 'react'; const Context = createContext('abc'); @@ -61,15 +62,17 @@ export default function ElementTypes() { {value => null} - Loading...}> - - - - - - - - + + Loading...}> + + + + + + + + +