[6a3a178] | 1 | /**
|
---|
| 2 | * @license
|
---|
| 3 | * Copyright Google LLC All Rights Reserved.
|
---|
| 4 | *
|
---|
| 5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
| 6 | * found in the LICENSE file at https://angular.io/license
|
---|
| 7 | */
|
---|
| 8 | import { assertLContainer } from '../render3/assert';
|
---|
| 9 | import { createLView, renderView } from '../render3/instructions/shared';
|
---|
| 10 | import { DECLARATION_LCONTAINER, QUERIES } from '../render3/interfaces/view';
|
---|
| 11 | import { getCurrentTNode, getLView } from '../render3/state';
|
---|
| 12 | import { ViewRef as R3_ViewRef } from '../render3/view_ref';
|
---|
| 13 | import { assertDefined } from '../util/assert';
|
---|
| 14 | import { noop } from '../util/noop';
|
---|
| 15 | import { createElementRef } from './element_ref';
|
---|
| 16 | export const SWITCH_TEMPLATE_REF_FACTORY__POST_R3__ = injectTemplateRef;
|
---|
| 17 | const SWITCH_TEMPLATE_REF_FACTORY__PRE_R3__ = noop;
|
---|
| 18 | const SWITCH_TEMPLATE_REF_FACTORY = SWITCH_TEMPLATE_REF_FACTORY__PRE_R3__;
|
---|
| 19 | /**
|
---|
| 20 | * Represents an embedded template that can be used to instantiate embedded views.
|
---|
| 21 | * To instantiate embedded views based on a template, use the `ViewContainerRef`
|
---|
| 22 | * method `createEmbeddedView()`.
|
---|
| 23 | *
|
---|
| 24 | * Access a `TemplateRef` instance by placing a directive on an `<ng-template>`
|
---|
| 25 | * element (or directive prefixed with `*`). The `TemplateRef` for the embedded view
|
---|
| 26 | * is injected into the constructor of the directive,
|
---|
| 27 | * using the `TemplateRef` token.
|
---|
| 28 | *
|
---|
| 29 | * You can also use a `Query` to find a `TemplateRef` associated with
|
---|
| 30 | * a component or a directive.
|
---|
| 31 | *
|
---|
| 32 | * @see `ViewContainerRef`
|
---|
| 33 | * @see [Navigate the Component Tree with DI](guide/dependency-injection-navtree)
|
---|
| 34 | *
|
---|
| 35 | * @publicApi
|
---|
| 36 | */
|
---|
| 37 | export class TemplateRef {
|
---|
| 38 | }
|
---|
| 39 | /**
|
---|
| 40 | * @internal
|
---|
| 41 | * @nocollapse
|
---|
| 42 | */
|
---|
| 43 | TemplateRef.__NG_ELEMENT_ID__ = SWITCH_TEMPLATE_REF_FACTORY;
|
---|
| 44 | const ViewEngineTemplateRef = TemplateRef;
|
---|
| 45 | const R3TemplateRef = class TemplateRef extends ViewEngineTemplateRef {
|
---|
| 46 | constructor(_declarationLView, _declarationTContainer, elementRef) {
|
---|
| 47 | super();
|
---|
| 48 | this._declarationLView = _declarationLView;
|
---|
| 49 | this._declarationTContainer = _declarationTContainer;
|
---|
| 50 | this.elementRef = elementRef;
|
---|
| 51 | }
|
---|
| 52 | createEmbeddedView(context) {
|
---|
| 53 | const embeddedTView = this._declarationTContainer.tViews;
|
---|
| 54 | const embeddedLView = createLView(this._declarationLView, embeddedTView, context, 16 /* CheckAlways */, null, embeddedTView.declTNode, null, null, null, null);
|
---|
| 55 | const declarationLContainer = this._declarationLView[this._declarationTContainer.index];
|
---|
| 56 | ngDevMode && assertLContainer(declarationLContainer);
|
---|
| 57 | embeddedLView[DECLARATION_LCONTAINER] = declarationLContainer;
|
---|
| 58 | const declarationViewLQueries = this._declarationLView[QUERIES];
|
---|
| 59 | if (declarationViewLQueries !== null) {
|
---|
| 60 | embeddedLView[QUERIES] = declarationViewLQueries.createEmbeddedView(embeddedTView);
|
---|
| 61 | }
|
---|
| 62 | renderView(embeddedTView, embeddedLView, context);
|
---|
| 63 | return new R3_ViewRef(embeddedLView);
|
---|
| 64 | }
|
---|
| 65 | };
|
---|
| 66 | /**
|
---|
| 67 | * Creates a TemplateRef given a node.
|
---|
| 68 | *
|
---|
| 69 | * @returns The TemplateRef instance to use
|
---|
| 70 | */
|
---|
| 71 | export function injectTemplateRef() {
|
---|
| 72 | return createTemplateRef(getCurrentTNode(), getLView());
|
---|
| 73 | }
|
---|
| 74 | /**
|
---|
| 75 | * Creates a TemplateRef and stores it on the injector.
|
---|
| 76 | *
|
---|
| 77 | * @param hostTNode The node on which a TemplateRef is requested
|
---|
| 78 | * @param hostLView The `LView` to which the node belongs
|
---|
| 79 | * @returns The TemplateRef instance or null if we can't create a TemplateRef on a given node type
|
---|
| 80 | */
|
---|
| 81 | export function createTemplateRef(hostTNode, hostLView) {
|
---|
| 82 | if (hostTNode.type & 4 /* Container */) {
|
---|
| 83 | ngDevMode && assertDefined(hostTNode.tViews, 'TView must be allocated');
|
---|
| 84 | return new R3TemplateRef(hostLView, hostTNode, createElementRef(hostTNode, hostLView));
|
---|
| 85 | }
|
---|
| 86 | return null;
|
---|
| 87 | }
|
---|
| 88 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template_ref.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/linker/template_ref.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,gBAAgB,EAAC,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAC,WAAW,EAAE,UAAU,EAAC,MAAM,gCAAgC,CAAC;AAEvE,OAAO,EAAC,sBAAsB,EAAqB,OAAO,EAAQ,MAAM,4BAA4B,CAAC;AACrG,OAAO,EAAC,eAAe,EAAE,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAC,OAAO,IAAI,UAAU,EAAC,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAC,aAAa,EAAC,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAC,IAAI,EAAC,MAAM,cAAc,CAAC;AAClC,OAAO,EAAC,gBAAgB,EAAa,MAAM,eAAe,CAAC;AAK3D,MAAM,CAAC,MAAM,sCAAsC,GAAG,iBAAiB,CAAC;AACxE,MAAM,qCAAqC,GAAG,IAAI,CAAC;AACnD,MAAM,2BAA2B,GAA6B,qCAAqC,CAAC;AAEpG;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,OAAgB,WAAW;;AAwB/B;;;GAGG;AACI,6BAAiB,GAAiC,2BAA2B,CAAC;AAGvF,MAAM,qBAAqB,GAAG,WAAW,CAAC;AAE1C,MAAM,aAAa,GAAG,MAAM,WAAe,SAAQ,qBAAwB;IACzE,YACY,iBAAwB,EAAU,sBAAsC,EACzE,UAAsB;QAC/B,KAAK,EAAE,CAAC;QAFE,sBAAiB,GAAjB,iBAAiB,CAAO;QAAU,2BAAsB,GAAtB,sBAAsB,CAAgB;QACzE,eAAU,GAAV,UAAU,CAAY;IAEjC,CAAC;IAEQ,kBAAkB,CAAC,OAAU;QACpC,MAAM,aAAa,GAAG,IAAI,CAAC,sBAAsB,CAAC,MAAe,CAAC;QAClE,MAAM,aAAa,GAAG,WAAW,CAC7B,IAAI,CAAC,iBAAiB,EAAE,aAAa,EAAE,OAAO,wBAA0B,IAAI,EAC5E,aAAa,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAErD,MAAM,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;QACxF,SAAS,IAAI,gBAAgB,CAAC,qBAAqB,CAAC,CAAC;QACrD,aAAa,CAAC,sBAAsB,CAAC,GAAG,qBAAqB,CAAC;QAE9D,MAAM,uBAAuB,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QAChE,IAAI,uBAAuB,KAAK,IAAI,EAAE;YACpC,aAAa,CAAC,OAAO,CAAC,GAAG,uBAAuB,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;SACpF;QAED,UAAU,CAAC,aAAa,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;QAElD,OAAO,IAAI,UAAU,CAAI,aAAa,CAAC,CAAC;IAC1C,CAAC;CACF,CAAC;AAEF;;;;GAIG;AACH,MAAM,UAAU,iBAAiB;IAC/B,OAAO,iBAAiB,CAAI,eAAe,EAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC9D,CAAC;AAED;;;;;;GAMG;AACH,MAAM,UAAU,iBAAiB,CAAI,SAAgB,EAAE,SAAgB;IACrE,IAAI,SAAS,CAAC,IAAI,oBAAsB,EAAE;QACxC,SAAS,IAAI,aAAa,CAAC,SAAS,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAC;QACxE,OAAO,IAAI,aAAa,CACpB,SAAS,EAAE,SAA2B,EAAE,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;KACrF;IACD,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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\nimport {assertLContainer} from '../render3/assert';\nimport {createLView, renderView} from '../render3/instructions/shared';\nimport {TContainerNode, TNode, TNodeType} from '../render3/interfaces/node';\nimport {DECLARATION_LCONTAINER, LView, LViewFlags, QUERIES, TView} from '../render3/interfaces/view';\nimport {getCurrentTNode, getLView} from '../render3/state';\nimport {ViewRef as R3_ViewRef} from '../render3/view_ref';\nimport {assertDefined} from '../util/assert';\nimport {noop} from '../util/noop';\nimport {createElementRef, ElementRef} from './element_ref';\nimport {EmbeddedViewRef} from './view_ref';\n\n\n\nexport const SWITCH_TEMPLATE_REF_FACTORY__POST_R3__ = injectTemplateRef;\nconst SWITCH_TEMPLATE_REF_FACTORY__PRE_R3__ = noop;\nconst SWITCH_TEMPLATE_REF_FACTORY: typeof injectTemplateRef = SWITCH_TEMPLATE_REF_FACTORY__PRE_R3__;\n\n/**\n * Represents an embedded template that can be used to instantiate embedded views.\n * To instantiate embedded views based on a template, use the `ViewContainerRef`\n * method `createEmbeddedView()`.\n *\n * Access a `TemplateRef` instance by placing a directive on an `<ng-template>`\n * element (or directive prefixed with `*`). The `TemplateRef` for the embedded view\n * is injected into the constructor of the directive,\n * using the `TemplateRef` token.\n *\n * You can also use a `Query` to find a `TemplateRef` associated with\n * a component or a directive.\n *\n * @see `ViewContainerRef`\n * @see [Navigate the Component Tree with DI](guide/dependency-injection-navtree)\n *\n * @publicApi\n */\nexport abstract class TemplateRef<C> {\n  /**\n   * The anchor element in the parent view for this embedded view.\n   *\n   * The data-binding and injection contexts of embedded views created from this `TemplateRef`\n   * inherit from the contexts of this location.\n   *\n   * Typically new embedded views are attached to the view container of this location, but in\n   * advanced use-cases, the view can be attached to a different container while keeping the\n   * data-binding and injection context from the original location.\n   *\n   */\n  // TODO(i): rename to anchor or location\n  abstract get elementRef(): ElementRef;\n\n  /**\n   * Instantiates an embedded view based on this template,\n   * and attaches it to the view container.\n   * @param context The data-binding context of the embedded view, as declared\n   * in the `<ng-template>` usage.\n   * @returns The new embedded view object.\n   */\n  abstract createEmbeddedView(context: C): EmbeddedViewRef<C>;\n\n  /**\n   * @internal\n   * @nocollapse\n   */\n  static __NG_ELEMENT_ID__: () => TemplateRef<any>| null = SWITCH_TEMPLATE_REF_FACTORY;\n}\n\nconst ViewEngineTemplateRef = TemplateRef;\n\nconst R3TemplateRef = class TemplateRef<T> extends ViewEngineTemplateRef<T> {\n  constructor(\n      private _declarationLView: LView, private _declarationTContainer: TContainerNode,\n      public elementRef: ElementRef) {\n    super();\n  }\n\n  override createEmbeddedView(context: T): EmbeddedViewRef<T> {\n    const embeddedTView = this._declarationTContainer.tViews as TView;\n    const embeddedLView = createLView(\n        this._declarationLView, embeddedTView, context, LViewFlags.CheckAlways, null,\n        embeddedTView.declTNode, null, null, null, null);\n\n    const declarationLContainer = this._declarationLView[this._declarationTContainer.index];\n    ngDevMode && assertLContainer(declarationLContainer);\n    embeddedLView[DECLARATION_LCONTAINER] = declarationLContainer;\n\n    const declarationViewLQueries = this._declarationLView[QUERIES];\n    if (declarationViewLQueries !== null) {\n      embeddedLView[QUERIES] = declarationViewLQueries.createEmbeddedView(embeddedTView);\n    }\n\n    renderView(embeddedTView, embeddedLView, context);\n\n    return new R3_ViewRef<T>(embeddedLView);\n  }\n};\n\n/**\n * Creates a TemplateRef given a node.\n *\n * @returns The TemplateRef instance to use\n */\nexport function injectTemplateRef<T>(): TemplateRef<T>|null {\n  return createTemplateRef<T>(getCurrentTNode()!, getLView());\n}\n\n/**\n * Creates a TemplateRef and stores it on the injector.\n *\n * @param hostTNode The node on which a TemplateRef is requested\n * @param hostLView The `LView` to which the node belongs\n * @returns The TemplateRef instance or null if we can't create a TemplateRef on a given node type\n */\nexport function createTemplateRef<T>(hostTNode: TNode, hostLView: LView): TemplateRef<T>|null {\n  if (hostTNode.type & TNodeType.Container) {\n    ngDevMode && assertDefined(hostTNode.tViews, 'TView must be allocated');\n    return new R3TemplateRef(\n        hostLView, hostTNode as TContainerNode, createElementRef(hostTNode, hostLView));\n  }\n  return null;\n}\n"]} |
---|