UNPKG

@angular/core

Version:

Angular - the core framework

311 lines 37.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { assertDataInRange } from '../util/assert'; import { assertComponentType } from './assert'; import { getComponentDef } from './definition'; import { diPublicInInjector, getOrCreateNodeInjectorForNode } from './di'; import { registerPostOrderHooks, registerPreOrderHooks } from './hooks'; import { CLEAN_PROMISE, addToViewTree, createLView, createTView, getOrCreateTNode, getOrCreateTView, initNodeFlags, instantiateRootComponent, invokeHostBindingsInCreationMode, locateHostElement, queueComponentIndexForCheck, refreshDescendantViews } from './instructions/shared'; import { domRendererFactory3 } from './interfaces/renderer'; import { CONTEXT, FLAGS, HEADER_OFFSET, HOST, RENDERER, TVIEW } from './interfaces/view'; import { applyOnCreateInstructions } from './node_util'; import { enterView, getPreviousOrParentTNode, leaveView, resetComponentState, setActiveHostElement } from './state'; import { renderInitialClasses, renderInitialStyles } from './styling/class_and_style_bindings'; import { publishDefaultGlobalUtils } from './util/global_utils'; import { defaultScheduler, stringifyForError } from './util/misc_utils'; import { getRootContext } from './util/view_traversal_utils'; import { readPatchedLView, resetPreOrderHookFlags } from './util/view_utils'; /** * Options that control how the component should be bootstrapped. * @record */ export function CreateComponentOptions() { } if (false) { /** * Which renderer factory to use. * @type {?|undefined} */ CreateComponentOptions.prototype.rendererFactory; /** * A custom sanitizer instance * @type {?|undefined} */ CreateComponentOptions.prototype.sanitizer; /** * A custom animation player handler * @type {?|undefined} */ CreateComponentOptions.prototype.playerHandler; /** * Host element on which the component will be bootstrapped. If not specified, * the component definition's `tag` is used to query the existing DOM for the * element to bootstrap. * @type {?|undefined} */ CreateComponentOptions.prototype.host; /** * Module injector for the component. If unspecified, the injector will be NULL_INJECTOR. * @type {?|undefined} */ CreateComponentOptions.prototype.injector; /** * List of features to be applied to the created component. Features are simply * functions that decorate a component with a certain behavior. * * Typically, the features in this list are features that cannot be added to the * other features list in the component definition because they rely on other factors. * * Example: `LifecycleHooksFeature` is a function that adds lifecycle hook capabilities * to root components in a tree-shakable way. It cannot be added to the component * features list because there's no way of knowing when the component will be used as * a root component. * @type {?|undefined} */ CreateComponentOptions.prototype.hostFeatures; /** * A function which is used to schedule change detection work in the future. * * When marking components as dirty, it is necessary to schedule the work of * change detection in the future. This is done to coalesce multiple * {\@link markDirty} calls into a single changed detection processing. * * The default value of the scheduler is the `requestAnimationFrame` function. * * It is also useful to override this function for testing purposes. * @type {?|undefined} */ CreateComponentOptions.prototype.scheduler; } // TODO: A hack to not pull in the NullInjector from @angular/core. const ɵ0 = /** * @param {?} token * @param {?=} notFoundValue * @return {?} */ (token, notFoundValue) => { throw new Error('NullInjector: Not found: ' + stringifyForError(token)); }; /** @type {?} */ export const NULL_INJECTOR = { get: (ɵ0) }; /** * Bootstraps a Component into an existing host element and returns an instance * of the component. * * Use this function to bootstrap a component into the DOM tree. Each invocation * of this function will create a separate tree of components, injectors and * change detection cycles and lifetimes. To dynamically insert a new component * into an existing tree such that it shares the same injection, change detection * and object lifetime, use {\@link ViewContainer#createComponent}. * * @template T * @param {?} componentType Component to bootstrap * @param {?=} opts * @return {?} */ export function renderComponent(componentType /* Type as workaround for: Microsoft/TypeScript/issues/4881 */, opts = {}) { ngDevMode && publishDefaultGlobalUtils(); ngDevMode && assertComponentType(componentType); // this is preemptively set to avoid having test and debug code accidentally // read data from a previous application state... setActiveHostElement(null); /** @type {?} */ const rendererFactory = opts.rendererFactory || domRendererFactory3; /** @type {?} */ const sanitizer = opts.sanitizer || null; /** @type {?} */ const componentDef = (/** @type {?} */ (getComponentDef(componentType))); if (componentDef.type != componentType) componentDef.type = componentType; // The first index of the first selector is the tag name. /** @type {?} */ const componentTag = (/** @type {?} */ ((/** @type {?} */ ((/** @type {?} */ (componentDef.selectors))[0]))[0])); /** @type {?} */ const hostRNode = locateHostElement(rendererFactory, opts.host || componentTag); /** @type {?} */ const rootFlags = componentDef.onPush ? 64 /* Dirty */ | 512 /* IsRoot */ : 16 /* CheckAlways */ | 512 /* IsRoot */; /** @type {?} */ const rootContext = createRootContext(opts.scheduler, opts.playerHandler); /** @type {?} */ const renderer = rendererFactory.createRenderer(hostRNode, componentDef); /** @type {?} */ const rootView = createLView(null, createTView(-1, null, 1, 0, null, null, null, null), rootContext, rootFlags, null, null, rendererFactory, renderer, undefined, opts.injector || null); /** @type {?} */ const oldView = enterView(rootView, null); /** @type {?} */ let component; // Will become true if the `try` block executes with no errors. /** @type {?} */ let safeToRunHooks = false; try { if (rendererFactory.begin) rendererFactory.begin(); /** @type {?} */ const componentView = createRootComponentView(hostRNode, componentDef, rootView, rendererFactory, renderer, sanitizer); component = createRootComponent(componentView, componentDef, rootView, rootContext, opts.hostFeatures || null); addToViewTree(rootView, componentView); refreshDescendantViews(rootView); // creation mode pass rootView[FLAGS] &= ~4 /* CreationMode */; resetPreOrderHookFlags(rootView); refreshDescendantViews(rootView); // update mode pass safeToRunHooks = true; } finally { leaveView(oldView, safeToRunHooks); if (rendererFactory.end) rendererFactory.end(); } return component; } /** * Creates the root component view and the root component node. * * @param {?} rNode Render host element. * @param {?} def ComponentDef * @param {?} rootView The parent view where the host node is stored * @param {?} rendererFactory * @param {?} renderer The current renderer * @param {?=} sanitizer The sanitizer, if provided * * @return {?} Component view created */ export function createRootComponentView(rNode, def, rootView, rendererFactory, renderer, sanitizer) { resetComponentState(); /** @type {?} */ const tView = rootView[TVIEW]; ngDevMode && assertDataInRange(rootView, 0 + HEADER_OFFSET); rootView[0 + HEADER_OFFSET] = rNode; /** @type {?} */ const tNode = getOrCreateTNode(tView, null, 0, 3 /* Element */, null, null); /** @type {?} */ const componentView = createLView(rootView, getOrCreateTView(def), null, def.onPush ? 64 /* Dirty */ : 16 /* CheckAlways */, rootView[HEADER_OFFSET], tNode, rendererFactory, renderer, sanitizer); if (tView.firstTemplatePass) { diPublicInInjector(getOrCreateNodeInjectorForNode(tNode, rootView), rootView, def.type); tNode.flags = 1 /* isComponent */; initNodeFlags(tNode, rootView.length, 1); queueComponentIndexForCheck(tNode); } // Store component view at node index, with node as the HOST return rootView[HEADER_OFFSET] = componentView; } /** * Creates a root component and sets it up with features and host bindings. Shared by * renderComponent() and ViewContainerRef.createComponent(). * @template T * @param {?} componentView * @param {?} componentDef * @param {?} rootView * @param {?} rootContext * @param {?} hostFeatures * @return {?} */ export function createRootComponent(componentView, componentDef, rootView, rootContext, hostFeatures) { /** @type {?} */ const tView = rootView[TVIEW]; // Create directive instance with factory() and store at next index in viewData /** @type {?} */ const component = instantiateRootComponent(tView, rootView, componentDef); rootContext.components.push(component); componentView[CONTEXT] = component; hostFeatures && hostFeatures.forEach((/** * @param {?} feature * @return {?} */ (feature) => feature(component, componentDef))); // We want to generate an empty QueryList for root content queries for backwards // compatibility with ViewEngine. if (componentDef.contentQueries) { componentDef.contentQueries(1 /* Create */, component, rootView.length - 1); } /** @type {?} */ const rootTNode = getPreviousOrParentTNode(); if (tView.firstTemplatePass && componentDef.hostBindings) { /** @type {?} */ const elementIndex = rootTNode.index - HEADER_OFFSET; setActiveHostElement(elementIndex); /** @type {?} */ const expando = (/** @type {?} */ (tView.expandoInstructions)); invokeHostBindingsInCreationMode(componentDef, expando, component, rootTNode, tView.firstTemplatePass); rootTNode.onElementCreationFns && applyOnCreateInstructions(rootTNode); setActiveHostElement(null); } if (rootTNode.stylingTemplate) { /** @type {?} */ const native = (/** @type {?} */ ((/** @type {?} */ (componentView[HOST])))); renderInitialClasses(native, rootTNode.stylingTemplate, componentView[RENDERER]); renderInitialStyles(native, rootTNode.stylingTemplate, componentView[RENDERER]); } return component; } /** * @param {?=} scheduler * @param {?=} playerHandler * @return {?} */ export function createRootContext(scheduler, playerHandler) { return { components: [], scheduler: scheduler || defaultScheduler, clean: CLEAN_PROMISE, playerHandler: playerHandler || null, flags: 0 /* Empty */ }; } /** * Used to enable lifecycle hooks on the root component. * * Include this feature when calling `renderComponent` if the root component * you are rendering has lifecycle hooks defined. Otherwise, the hooks won't * be called properly. * * Example: * * ``` * renderComponent(AppComponent, {features: [RootLifecycleHooks]}); * ``` * @param {?} component * @param {?} def * @return {?} */ export function LifecycleHooksFeature(component, def) { /** @type {?} */ const rootTView = (/** @type {?} */ (readPatchedLView(component)))[TVIEW]; /** @type {?} */ const dirIndex = rootTView.data.length - 1; registerPreOrderHooks(dirIndex, def, rootTView, -1, -1, -1); // TODO(misko): replace `as TNode` with createTNode call. (needs refactoring to lose dep on // LNode). registerPostOrderHooks(rootTView, (/** @type {?} */ ({ directiveStart: dirIndex, directiveEnd: dirIndex + 1 }))); } /** * Wait on component until it is rendered. * * This function returns a `Promise` which is resolved when the component's * change detection is executed. This is determined by finding the scheduler * associated with the `component`'s render tree and waiting until the scheduler * flushes. If nothing is scheduled, the function returns a resolved promise. * * Example: * ``` * await whenRendered(myComponent); * ``` * * @param {?} component Component to wait upon * @return {?} Promise which resolves when the component is rendered. */ export function whenRendered(component) { return getRootContext(component).clean; } export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/render3/component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n// We are temporarily importing the existing viewEngine from core so we can be sure we are\n// correctly implementing its interfaces for backwards compatibility.\nimport {Type} from '../core';\nimport {Injector} from '../di/injector';\nimport {Sanitizer} from '../sanitization/security';\nimport {assertDataInRange, assertEqual} from '../util/assert';\n\nimport {assertComponentType} from './assert';\nimport {getComponentDef} from './definition';\nimport {diPublicInInjector, getOrCreateNodeInjectorForNode} from './di';\nimport {registerPostOrderHooks, registerPreOrderHooks} from './hooks';\nimport {CLEAN_PROMISE, addToViewTree, createLView, createTView, getOrCreateTNode, getOrCreateTView, initNodeFlags, instantiateRootComponent, invokeHostBindingsInCreationMode, locateHostElement, queueComponentIndexForCheck, refreshDescendantViews} from './instructions/shared';\nimport {ComponentDef, ComponentType, RenderFlags} from './interfaces/definition';\nimport {TElementNode, TNode, TNodeFlags, TNodeType} from './interfaces/node';\nimport {PlayerHandler} from './interfaces/player';\nimport {RElement, Renderer3, RendererFactory3, domRendererFactory3} from './interfaces/renderer';\nimport {CONTEXT, FLAGS, HEADER_OFFSET, HOST, LView, LViewFlags, RENDERER, RootContext, RootContextFlags, TVIEW} from './interfaces/view';\nimport {applyOnCreateInstructions} from './node_util';\nimport {enterView, getPreviousOrParentTNode, leaveView, resetComponentState, setActiveHostElement} from './state';\nimport {renderInitialClasses, renderInitialStyles} from './styling/class_and_style_bindings';\nimport {publishDefaultGlobalUtils} from './util/global_utils';\nimport {defaultScheduler, stringifyForError} from './util/misc_utils';\nimport {getRootContext} from './util/view_traversal_utils';\nimport {readPatchedLView, resetPreOrderHookFlags} from './util/view_utils';\n\n\n\n/** Options that control how the component should be bootstrapped. */\nexport interface CreateComponentOptions {\n  /** Which renderer factory to use. */\n  rendererFactory?: RendererFactory3;\n\n  /** A custom sanitizer instance */\n  sanitizer?: Sanitizer;\n\n  /** A custom animation player handler */\n  playerHandler?: PlayerHandler;\n\n  /**\n   * Host element on which the component will be bootstrapped. If not specified,\n   * the component definition's `tag` is used to query the existing DOM for the\n   * element to bootstrap.\n   */\n  host?: RElement|string;\n\n  /** Module injector for the component. If unspecified, the injector will be NULL_INJECTOR. */\n  injector?: Injector;\n\n  /**\n   * List of features to be applied to the created component. Features are simply\n   * functions that decorate a component with a certain behavior.\n   *\n   * Typically, the features in this list are features that cannot be added to the\n   * other features list in the component definition because they rely on other factors.\n   *\n   * Example: `LifecycleHooksFeature` is a function that adds lifecycle hook capabilities\n   * to root components in a tree-shakable way. It cannot be added to the component\n   * features list because there's no way of knowing when the component will be used as\n   * a root component.\n   */\n  hostFeatures?: HostFeature[];\n\n  /**\n   * A function which is used to schedule change detection work in the future.\n   *\n   * When marking components as dirty, it is necessary to schedule the work of\n   * change detection in the future. This is done to coalesce multiple\n   * {@link markDirty} calls into a single changed detection processing.\n   *\n   * The default value of the scheduler is the `requestAnimationFrame` function.\n   *\n   * It is also useful to override this function for testing purposes.\n   */\n  scheduler?: (work: () => void) => void;\n}\n\n/** See CreateComponentOptions.hostFeatures */\ntype HostFeature = (<T>(component: T, componentDef: ComponentDef<T>) => void);\n\n// TODO: A hack to not pull in the NullInjector from @angular/core.\nexport const NULL_INJECTOR: Injector = {\n  get: (token: any, notFoundValue?: any) => {\n    throw new Error('NullInjector: Not found: ' + stringifyForError(token));\n  }\n};\n\n/**\n * Bootstraps a Component into an existing host element and returns an instance\n * of the component.\n *\n * Use this function to bootstrap a component into the DOM tree. Each invocation\n * of this function will create a separate tree of components, injectors and\n * change detection cycles and lifetimes. To dynamically insert a new component\n * into an existing tree such that it shares the same injection, change detection\n * and object lifetime, use {@link ViewContainer#createComponent}.\n *\n * @param componentType Component to bootstrap\n * @param options Optional parameters which control bootstrapping\n */\nexport function renderComponent<T>(\n    componentType: ComponentType<T>|\n        Type<T>/* Type as workaround for: Microsoft/TypeScript/issues/4881 */\n    ,\n    opts: CreateComponentOptions = {}): T {\n  ngDevMode && publishDefaultGlobalUtils();\n  ngDevMode && assertComponentType(componentType);\n\n  // this is preemptively set to avoid having test and debug code accidentally\n  // read data from a previous application state...\n  setActiveHostElement(null);\n\n  const rendererFactory = opts.rendererFactory || domRendererFactory3;\n  const sanitizer = opts.sanitizer || null;\n  const componentDef = getComponentDef<T>(componentType) !;\n  if (componentDef.type != componentType) componentDef.type = componentType;\n\n  // The first index of the first selector is the tag name.\n  const componentTag = componentDef.selectors ![0] ![0] as string;\n  const hostRNode = locateHostElement(rendererFactory, opts.host || componentTag);\n  const rootFlags = componentDef.onPush ? LViewFlags.Dirty | LViewFlags.IsRoot :\n                                          LViewFlags.CheckAlways | LViewFlags.IsRoot;\n  const rootContext = createRootContext(opts.scheduler, opts.playerHandler);\n\n  const renderer = rendererFactory.createRenderer(hostRNode, componentDef);\n  const rootView: LView = createLView(\n      null, createTView(-1, null, 1, 0, null, null, null, null), rootContext, rootFlags, null, null,\n      rendererFactory, renderer, undefined, opts.injector || null);\n\n  const oldView = enterView(rootView, null);\n  let component: T;\n\n  // Will become true if the `try` block executes with no errors.\n  let safeToRunHooks = false;\n  try {\n    if (rendererFactory.begin) rendererFactory.begin();\n    const componentView = createRootComponentView(\n        hostRNode, componentDef, rootView, rendererFactory, renderer, sanitizer);\n    component = createRootComponent(\n        componentView, componentDef, rootView, rootContext, opts.hostFeatures || null);\n\n    addToViewTree(rootView, componentView);\n\n    refreshDescendantViews(rootView);  // creation mode pass\n    rootView[FLAGS] &= ~LViewFlags.CreationMode;\n    resetPreOrderHookFlags(rootView);\n    refreshDescendantViews(rootView);  // update mode pass\n    safeToRunHooks = true;\n  } finally {\n    leaveView(oldView, safeToRunHooks);\n    if (rendererFactory.end) rendererFactory.end();\n  }\n\n  return component;\n}\n\n/**\n * Creates the root component view and the root component node.\n *\n * @param rNode Render host element.\n * @param def ComponentDef\n * @param rootView The parent view where the host node is stored\n * @param renderer The current renderer\n * @param sanitizer The sanitizer, if provided\n *\n * @returns Component view created\n */\nexport function createRootComponentView(\n    rNode: RElement | null, def: ComponentDef<any>, rootView: LView,\n    rendererFactory: RendererFactory3, renderer: Renderer3, sanitizer?: Sanitizer | null): LView {\n  resetComponentState();\n  const tView = rootView[TVIEW];\n  ngDevMode && assertDataInRange(rootView, 0 + HEADER_OFFSET);\n  rootView[0 + HEADER_OFFSET] = rNode;\n  const tNode: TElementNode = getOrCreateTNode(tView, null, 0, TNodeType.Element, null, null);\n  const componentView = createLView(\n      rootView, getOrCreateTView(def), null, def.onPush ? LViewFlags.Dirty : LViewFlags.CheckAlways,\n      rootView[HEADER_OFFSET], tNode, rendererFactory, renderer, sanitizer);\n\n  if (tView.firstTemplatePass) {\n    diPublicInInjector(getOrCreateNodeInjectorForNode(tNode, rootView), rootView, def.type);\n    tNode.flags = TNodeFlags.isComponent;\n    initNodeFlags(tNode, rootView.length, 1);\n    queueComponentIndexForCheck(tNode);\n  }\n\n  // Store component view at node index, with node as the HOST\n  return rootView[HEADER_OFFSET] = componentView;\n}\n\n/**\n * Creates a root component and sets it up with features and host bindings. Shared by\n * renderComponent() and ViewContainerRef.createComponent().\n */\nexport function createRootComponent<T>(\n    componentView: LView, componentDef: ComponentDef<T>, rootView: LView, rootContext: RootContext,\n    hostFeatures: HostFeature[] | null): any {\n  const tView = rootView[TVIEW];\n  // Create directive instance with factory() and store at next index in viewData\n  const component = instantiateRootComponent(tView, rootView, componentDef);\n\n  rootContext.components.push(component);\n  componentView[CONTEXT] = component;\n\n  hostFeatures && hostFeatures.forEach((feature) => feature(component, componentDef));\n\n  // We want to generate an empty QueryList for root content queries for backwards\n  // compatibility with ViewEngine.\n  if (componentDef.contentQueries) {\n    componentDef.contentQueries(RenderFlags.Create, component, rootView.length - 1);\n  }\n\n  const rootTNode = getPreviousOrParentTNode();\n  if (tView.firstTemplatePass && componentDef.hostBindings) {\n    const elementIndex = rootTNode.index - HEADER_OFFSET;\n    setActiveHostElement(elementIndex);\n\n    const expando = tView.expandoInstructions !;\n    invokeHostBindingsInCreationMode(\n        componentDef, expando, component, rootTNode, tView.firstTemplatePass);\n    rootTNode.onElementCreationFns && applyOnCreateInstructions(rootTNode);\n\n    setActiveHostElement(null);\n  }\n\n  if (rootTNode.stylingTemplate) {\n    const native = componentView[HOST] !as RElement;\n    renderInitialClasses(native, rootTNode.stylingTemplate, componentView[RENDERER]);\n    renderInitialStyles(native, rootTNode.stylingTemplate, componentView[RENDERER]);\n  }\n\n  return component;\n}\n\n\nexport function createRootContext(\n    scheduler?: (workFn: () => void) => void, playerHandler?: PlayerHandler|null): RootContext {\n  return {\n    components: [],\n    scheduler: scheduler || defaultScheduler,\n    clean: CLEAN_PROMISE,\n    playerHandler: playerHandler || null,\n    flags: RootContextFlags.Empty\n  };\n}\n\n/**\n * Used to enable lifecycle hooks on the root component.\n *\n * Include this feature when calling `renderComponent` if the root component\n * you are rendering has lifecycle hooks defined. Otherwise, the hooks won't\n * be called properly.\n *\n * Example:\n *\n * ```\n * renderComponent(AppComponent, {features: [RootLifecycleHooks]});\n * ```\n */\nexport function LifecycleHooksFeature(component: any, def: ComponentDef<any>): void {\n  const rootTView = readPatchedLView(component) ![TVIEW];\n  const dirIndex = rootTView.data.length - 1;\n\n  registerPreOrderHooks(dirIndex, def, rootTView, -1, -1, -1);\n  // TODO(misko): replace `as TNode` with createTNode call. (needs refactoring to lose dep on\n  // LNode).\n  registerPostOrderHooks(\n      rootTView, { directiveStart: dirIndex, directiveEnd: dirIndex + 1 } as TNode);\n}\n\n/**\n * Wait on component until it is rendered.\n *\n * This function returns a `Promise` which is resolved when the component's\n * change detection is executed. This is determined by finding the scheduler\n * associated with the `component`'s render tree and waiting until the scheduler\n * flushes. If nothing is scheduled, the function returns a resolved promise.\n *\n * Example:\n * ```\n * await whenRendered(myComponent);\n * ```\n *\n * @param component Component to wait upon\n * @returns Promise which resolves when the component is rendered.\n */\nexport function whenRendered(component: any): Promise<null> {\n  return getRootContext(component).clean;\n}\n"]}