import { VNode, normalizeVNode } from './vnode' import { ShapeFlags } from '.' import { isFunction } from '@vue/shared' export const SuspenseSymbol = __DEV__ ? Symbol('Suspense key') : Symbol() export interface SuspenseBoundary< HostNode, HostElement, HostVNode = VNode > { vnode: HostVNode parent: SuspenseBoundary | null container: HostElement subTree: HostVNode | null oldSubTree: HostVNode | null fallbackTree: HostVNode | null oldFallbackTree: HostVNode | null deps: number isResolved: boolean effects: Function[] resolve(): void } export function createSuspenseBoundary( vnode: VNode, parent: SuspenseBoundary | null, container: HostElement, resolve: () => void ): SuspenseBoundary { return { vnode, parent, container, deps: 0, subTree: null, oldSubTree: null, fallbackTree: null, oldFallbackTree: null, isResolved: false, effects: [], resolve } } export function normalizeSuspenseChildren( vnode: VNode ): { content: VNode fallback: VNode } { const { shapeFlag, children } = vnode if (shapeFlag & ShapeFlags.SLOTS_CHILDREN) { const { default: d, fallback } = children as any return { content: normalizeVNode(isFunction(d) ? d() : d), fallback: normalizeVNode(isFunction(fallback) ? fallback() : fallback) } } else { return { content: normalizeVNode(children as any), fallback: normalizeVNode(null) } } }