From 3243916526684adb0fb6b2e83c8fd231033bcdea Mon Sep 17 00:00:00 2001 From: Sebastian Markbage Date: Mon, 12 Aug 2019 15:47:34 -0700 Subject: [PATCH] Add a comment explaining the type. Placing it in the type since that's the central point as opposed to spread out. --- .../react-reconciler/src/ReactFiberSuspenseComponent.js | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/packages/react-reconciler/src/ReactFiberSuspenseComponent.js b/packages/react-reconciler/src/ReactFiberSuspenseComponent.js index 8c8b24cac2edd..06f5aebc1b8de 100644 --- a/packages/react-reconciler/src/ReactFiberSuspenseComponent.js +++ b/packages/react-reconciler/src/ReactFiberSuspenseComponent.js @@ -12,6 +12,13 @@ import type {SuspenseInstance} from './ReactFiberHostConfig'; import {SuspenseComponent, SuspenseListComponent} from 'shared/ReactWorkTags'; import {NoEffect, DidCapture} from 'shared/ReactSideEffectTags'; +// A null SuspenseState represents an unsuspended normal Suspense boundary. +// A non-null SuspenseState means that it is blocked for one reason or another. +// - A non-null dehydrated field means it's blocked pending hydration. +// - A non-null dehydrated field can use isSuspenseInstancePending or +// isSuspenseInstanceFallback to query the reason for being dehydrated. +// - A null dehydrated field means it's blocked by something suspending and +// we're currently showing a fallback instead. export type SuspenseState = {| // If this boundary is still dehydrated, we store the SuspenseInstance // here to indicate that it is dehydrated (flag) and for quick access