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 { ComponentFactoryResolver, Directive, EventEmitter, NgModule, Output, TemplateRef, ViewContainerRef, Inject, } from '@angular/core';
|
9 | import { DOCUMENT } from '@angular/common';
|
10 | import { BasePortalOutlet, TemplatePortal } from './portal';
|
11 | import * as i0 from "@angular/core";
|
12 | /**
|
13 | * Directive version of a `TemplatePortal`. Because the directive *is* a TemplatePortal,
|
14 | * the directive instance itself can be attached to a host, enabling declarative use of portals.
|
15 | */
|
16 | class CdkPortal extends TemplatePortal {
|
17 | constructor(templateRef, viewContainerRef) {
|
18 | super(templateRef, viewContainerRef);
|
19 | }
|
20 | static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CdkPortal, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
21 | static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: CdkPortal, selector: "[cdkPortal]", exportAs: ["cdkPortal"], usesInheritance: true, ngImport: i0 }); }
|
22 | }
|
23 | export { CdkPortal };
|
24 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CdkPortal, decorators: [{
|
25 | type: Directive,
|
26 | args: [{
|
27 | selector: '[cdkPortal]',
|
28 | exportAs: 'cdkPortal',
|
29 | }]
|
30 | }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
|
31 | /**
|
32 | * @deprecated Use `CdkPortal` instead.
|
33 | * @breaking-change 9.0.0
|
34 | */
|
35 | class TemplatePortalDirective extends CdkPortal {
|
36 | static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TemplatePortalDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
37 | static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: TemplatePortalDirective, selector: "[cdk-portal], [portal]", providers: [
|
38 | {
|
39 | provide: CdkPortal,
|
40 | useExisting: TemplatePortalDirective,
|
41 | },
|
42 | ], exportAs: ["cdkPortal"], usesInheritance: true, ngImport: i0 }); }
|
43 | }
|
44 | export { TemplatePortalDirective };
|
45 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: TemplatePortalDirective, decorators: [{
|
46 | type: Directive,
|
47 | args: [{
|
48 | selector: '[cdk-portal], [portal]',
|
49 | exportAs: 'cdkPortal',
|
50 | providers: [
|
51 | {
|
52 | provide: CdkPortal,
|
53 | useExisting: TemplatePortalDirective,
|
54 | },
|
55 | ],
|
56 | }]
|
57 | }] });
|
58 | /**
|
59 | * Directive version of a PortalOutlet. Because the directive *is* a PortalOutlet, portals can be
|
60 | * directly attached to it, enabling declarative use.
|
61 | *
|
62 | * Usage:
|
63 | * `<ng-template [cdkPortalOutlet]="greeting"></ng-template>`
|
64 | */
|
65 | class CdkPortalOutlet extends BasePortalOutlet {
|
66 | constructor(_componentFactoryResolver, _viewContainerRef,
|
67 | /**
|
68 | * @deprecated `_document` parameter to be made required.
|
69 | * @breaking-change 9.0.0
|
70 | */
|
71 | _document) {
|
72 | super();
|
73 | this._componentFactoryResolver = _componentFactoryResolver;
|
74 | this._viewContainerRef = _viewContainerRef;
|
75 | /** Whether the portal component is initialized. */
|
76 | this._isInitialized = false;
|
77 | /** Emits when a portal is attached to the outlet. */
|
78 | this.attached = new EventEmitter();
|
79 | /**
|
80 | * Attaches the given DomPortal to this PortalHost by moving all of the portal content into it.
|
81 | * @param portal Portal to be attached.
|
82 | * @deprecated To be turned into a method.
|
83 | * @breaking-change 10.0.0
|
84 | */
|
85 | this.attachDomPortal = (portal) => {
|
86 | // @breaking-change 9.0.0 Remove check and error once the
|
87 | // `_document` constructor parameter is required.
|
88 | if (!this._document && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
89 | throw Error('Cannot attach DOM portal without _document constructor parameter');
|
90 | }
|
91 | const element = portal.element;
|
92 | if (!element.parentNode && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
93 | throw Error('DOM portal content must be attached to a parent node.');
|
94 | }
|
95 | // Anchor used to save the element's previous position so
|
96 | // that we can restore it when the portal is detached.
|
97 | const anchorNode = this._document.createComment('dom-portal');
|
98 | portal.setAttachedHost(this);
|
99 | element.parentNode.insertBefore(anchorNode, element);
|
100 | this._getRootNode().appendChild(element);
|
101 | this._attachedPortal = portal;
|
102 | super.setDisposeFn(() => {
|
103 | if (anchorNode.parentNode) {
|
104 | anchorNode.parentNode.replaceChild(element, anchorNode);
|
105 | }
|
106 | });
|
107 | };
|
108 | this._document = _document;
|
109 | }
|
110 | /** Portal associated with the Portal outlet. */
|
111 | get portal() {
|
112 | return this._attachedPortal;
|
113 | }
|
114 | set portal(portal) {
|
115 | // Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have
|
116 | // run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`
|
117 | // and attach a portal programmatically in the parent component. When Angular does the first CD
|
118 | // round, it will fire the setter with empty string, causing the user's content to be cleared.
|
119 | if (this.hasAttached() && !portal && !this._isInitialized) {
|
120 | return;
|
121 | }
|
122 | if (this.hasAttached()) {
|
123 | super.detach();
|
124 | }
|
125 | if (portal) {
|
126 | super.attach(portal);
|
127 | }
|
128 | this._attachedPortal = portal || null;
|
129 | }
|
130 | /** Component or view reference that is attached to the portal. */
|
131 | get attachedRef() {
|
132 | return this._attachedRef;
|
133 | }
|
134 | ngOnInit() {
|
135 | this._isInitialized = true;
|
136 | }
|
137 | ngOnDestroy() {
|
138 | super.dispose();
|
139 | this._attachedRef = this._attachedPortal = null;
|
140 | }
|
141 | /**
|
142 | * Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.
|
143 | *
|
144 | * @param portal Portal to be attached to the portal outlet.
|
145 | * @returns Reference to the created component.
|
146 | */
|
147 | attachComponentPortal(portal) {
|
148 | portal.setAttachedHost(this);
|
149 | // If the portal specifies an origin, use that as the logical location of the component
|
150 | // in the application tree. Otherwise use the location of this PortalOutlet.
|
151 | const viewContainerRef = portal.viewContainerRef != null ? portal.viewContainerRef : this._viewContainerRef;
|
152 | const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;
|
153 | const componentFactory = resolver.resolveComponentFactory(portal.component);
|
154 | const ref = viewContainerRef.createComponent(componentFactory, viewContainerRef.length, portal.injector || viewContainerRef.injector, portal.projectableNodes || undefined);
|
155 | // If we're using a view container that's different from the injected one (e.g. when the portal
|
156 | // specifies its own) we need to move the component into the outlet, otherwise it'll be rendered
|
157 | // inside of the alternate view container.
|
158 | if (viewContainerRef !== this._viewContainerRef) {
|
159 | this._getRootNode().appendChild(ref.hostView.rootNodes[0]);
|
160 | }
|
161 | super.setDisposeFn(() => ref.destroy());
|
162 | this._attachedPortal = portal;
|
163 | this._attachedRef = ref;
|
164 | this.attached.emit(ref);
|
165 | return ref;
|
166 | }
|
167 | /**
|
168 | * Attach the given TemplatePortal to this PortalHost as an embedded View.
|
169 | * @param portal Portal to be attached.
|
170 | * @returns Reference to the created embedded view.
|
171 | */
|
172 | attachTemplatePortal(portal) {
|
173 | portal.setAttachedHost(this);
|
174 | const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context, {
|
175 | injector: portal.injector,
|
176 | });
|
177 | super.setDisposeFn(() => this._viewContainerRef.clear());
|
178 | this._attachedPortal = portal;
|
179 | this._attachedRef = viewRef;
|
180 | this.attached.emit(viewRef);
|
181 | return viewRef;
|
182 | }
|
183 | /** Gets the root node of the portal outlet. */
|
184 | _getRootNode() {
|
185 | const nativeElement = this._viewContainerRef.element.nativeElement;
|
186 | // The directive could be set on a template which will result in a comment
|
187 | // node being the root. Use the comment's parent node if that is the case.
|
188 | return (nativeElement.nodeType === nativeElement.ELEMENT_NODE
|
189 | ? nativeElement
|
190 | : nativeElement.parentNode);
|
191 | }
|
192 | static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CdkPortalOutlet, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ViewContainerRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive }); }
|
193 | static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: { portal: ["cdkPortalOutlet", "portal"] }, outputs: { attached: "attached" }, exportAs: ["cdkPortalOutlet"], usesInheritance: true, ngImport: i0 }); }
|
194 | }
|
195 | export { CdkPortalOutlet };
|
196 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: CdkPortalOutlet, decorators: [{
|
197 | type: Directive,
|
198 | args: [{
|
199 | selector: '[cdkPortalOutlet]',
|
200 | exportAs: 'cdkPortalOutlet',
|
201 | inputs: ['portal: cdkPortalOutlet'],
|
202 | }]
|
203 | }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
204 | type: Inject,
|
205 | args: [DOCUMENT]
|
206 | }] }]; }, propDecorators: { attached: [{
|
207 | type: Output
|
208 | }] } });
|
209 | /**
|
210 | * @deprecated Use `CdkPortalOutlet` instead.
|
211 | * @breaking-change 9.0.0
|
212 | */
|
213 | class PortalHostDirective extends CdkPortalOutlet {
|
214 | static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PortalHostDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
215 | static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: PortalHostDirective, selector: "[cdkPortalHost], [portalHost]", inputs: { portal: ["cdkPortalHost", "portal"] }, providers: [
|
216 | {
|
217 | provide: CdkPortalOutlet,
|
218 | useExisting: PortalHostDirective,
|
219 | },
|
220 | ], exportAs: ["cdkPortalHost"], usesInheritance: true, ngImport: i0 }); }
|
221 | }
|
222 | export { PortalHostDirective };
|
223 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PortalHostDirective, decorators: [{
|
224 | type: Directive,
|
225 | args: [{
|
226 | selector: '[cdkPortalHost], [portalHost]',
|
227 | exportAs: 'cdkPortalHost',
|
228 | inputs: ['portal: cdkPortalHost'],
|
229 | providers: [
|
230 | {
|
231 | provide: CdkPortalOutlet,
|
232 | useExisting: PortalHostDirective,
|
233 | },
|
234 | ],
|
235 | }]
|
236 | }] });
|
237 | class PortalModule {
|
238 | static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PortalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
239 | static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: PortalModule, declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective], exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective] }); }
|
240 | static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PortalModule }); }
|
241 | }
|
242 | export { PortalModule };
|
243 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PortalModule, decorators: [{
|
244 | type: NgModule,
|
245 | args: [{
|
246 | exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
247 | declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
248 | }]
|
249 | }] });
|
250 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"portal-directives.js","sourceRoot":"","sources":["../../../../../../src/cdk/portal/portal-directives.ts"],"names":[],"mappings":"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","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 {\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  EmbeddedViewRef,\n  EventEmitter,\n  NgModule,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewContainerRef,\n  Inject,\n} from '@angular/core';\nimport {DOCUMENT} from '@angular/common';\nimport {BasePortalOutlet, ComponentPortal, Portal, TemplatePortal, DomPortal} from './portal';\n\n/**\n * Directive version of a `TemplatePortal`. Because the directive *is* a TemplatePortal,\n * the directive instance itself can be attached to a host, enabling declarative use of portals.\n */\n@Directive({\n  selector: '[cdkPortal]',\n  exportAs: 'cdkPortal',\n})\nexport class CdkPortal extends TemplatePortal {\n  constructor(templateRef: TemplateRef<any>, viewContainerRef: ViewContainerRef) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n/**\n * @deprecated Use `CdkPortal` instead.\n * @breaking-change 9.0.0\n */\n@Directive({\n  selector: '[cdk-portal], [portal]',\n  exportAs: 'cdkPortal',\n  providers: [\n    {\n      provide: CdkPortal,\n      useExisting: TemplatePortalDirective,\n    },\n  ],\n})\nexport class TemplatePortalDirective extends CdkPortal {}\n\n/**\n * Possible attached references to the CdkPortalOutlet.\n */\nexport type CdkPortalOutletAttachedRef = ComponentRef<any> | EmbeddedViewRef<any> | null;\n\n/**\n * Directive version of a PortalOutlet. Because the directive *is* a PortalOutlet, portals can be\n * directly attached to it, enabling declarative use.\n *\n * Usage:\n * `<ng-template [cdkPortalOutlet]=\"greeting\"></ng-template>`\n */\n@Directive({\n  selector: '[cdkPortalOutlet]',\n  exportAs: 'cdkPortalOutlet',\n  inputs: ['portal: cdkPortalOutlet'],\n})\nexport class CdkPortalOutlet extends BasePortalOutlet implements OnInit, OnDestroy {\n  private _document: Document;\n\n  /** Whether the portal component is initialized. */\n  private _isInitialized = false;\n\n  /** Reference to the currently-attached component/view ref. */\n  private _attachedRef: CdkPortalOutletAttachedRef;\n\n  constructor(\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _viewContainerRef: ViewContainerRef,\n\n    /**\n     * @deprecated `_document` parameter to be made required.\n     * @breaking-change 9.0.0\n     */\n    @Inject(DOCUMENT) _document?: any,\n  ) {\n    super();\n    this._document = _document;\n  }\n\n  /** Portal associated with the Portal outlet. */\n  get portal(): Portal<any> | null {\n    return this._attachedPortal;\n  }\n\n  set portal(portal: Portal<any> | null | undefined | '') {\n    // Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have\n    // run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`\n    // and attach a portal programmatically in the parent component. When Angular does the first CD\n    // round, it will fire the setter with empty string, causing the user's content to be cleared.\n    if (this.hasAttached() && !portal && !this._isInitialized) {\n      return;\n    }\n\n    if (this.hasAttached()) {\n      super.detach();\n    }\n\n    if (portal) {\n      super.attach(portal);\n    }\n\n    this._attachedPortal = portal || null;\n  }\n\n  /** Emits when a portal is attached to the outlet. */\n  @Output() readonly attached: EventEmitter<CdkPortalOutletAttachedRef> =\n    new EventEmitter<CdkPortalOutletAttachedRef>();\n\n  /** Component or view reference that is attached to the portal. */\n  get attachedRef(): CdkPortalOutletAttachedRef {\n    return this._attachedRef;\n  }\n\n  ngOnInit() {\n    this._isInitialized = true;\n  }\n\n  ngOnDestroy() {\n    super.dispose();\n    this._attachedRef = this._attachedPortal = null;\n  }\n\n  /**\n   * Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.\n   *\n   * @param portal Portal to be attached to the portal outlet.\n   * @returns Reference to the created component.\n   */\n  attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\n    portal.setAttachedHost(this);\n\n    // If the portal specifies an origin, use that as the logical location of the component\n    // in the application tree. Otherwise use the location of this PortalOutlet.\n    const viewContainerRef =\n      portal.viewContainerRef != null ? portal.viewContainerRef : this._viewContainerRef;\n\n    const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;\n    const componentFactory = resolver.resolveComponentFactory(portal.component);\n    const ref = viewContainerRef.createComponent(\n      componentFactory,\n      viewContainerRef.length,\n      portal.injector || viewContainerRef.injector,\n      portal.projectableNodes || undefined,\n    );\n\n    // If we're using a view container that's different from the injected one (e.g. when the portal\n    // specifies its own) we need to move the component into the outlet, otherwise it'll be rendered\n    // inside of the alternate view container.\n    if (viewContainerRef !== this._viewContainerRef) {\n      this._getRootNode().appendChild((ref.hostView as EmbeddedViewRef<any>).rootNodes[0]);\n    }\n\n    super.setDisposeFn(() => ref.destroy());\n    this._attachedPortal = portal;\n    this._attachedRef = ref;\n    this.attached.emit(ref);\n\n    return ref;\n  }\n\n  /**\n   * Attach the given TemplatePortal to this PortalHost as an embedded View.\n   * @param portal Portal to be attached.\n   * @returns Reference to the created embedded view.\n   */\n  attachTemplatePortal<C>(portal: TemplatePortal<C>): EmbeddedViewRef<C> {\n    portal.setAttachedHost(this);\n    const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context, {\n      injector: portal.injector,\n    });\n    super.setDisposeFn(() => this._viewContainerRef.clear());\n\n    this._attachedPortal = portal;\n    this._attachedRef = viewRef;\n    this.attached.emit(viewRef);\n\n    return viewRef;\n  }\n\n  /**\n   * Attaches the given DomPortal to this PortalHost by moving all of the portal content into it.\n   * @param portal Portal to be attached.\n   * @deprecated To be turned into a method.\n   * @breaking-change 10.0.0\n   */\n  override attachDomPortal = (portal: DomPortal) => {\n    // @breaking-change 9.0.0 Remove check and error once the\n    // `_document` constructor parameter is required.\n    if (!this._document && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw Error('Cannot attach DOM portal without _document constructor parameter');\n    }\n\n    const element = portal.element;\n    if (!element.parentNode && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw Error('DOM portal content must be attached to a parent node.');\n    }\n\n    // Anchor used to save the element's previous position so\n    // that we can restore it when the portal is detached.\n    const anchorNode = this._document.createComment('dom-portal');\n\n    portal.setAttachedHost(this);\n    element.parentNode!.insertBefore(anchorNode, element);\n    this._getRootNode().appendChild(element);\n    this._attachedPortal = portal;\n\n    super.setDisposeFn(() => {\n      if (anchorNode.parentNode) {\n        anchorNode.parentNode!.replaceChild(element, anchorNode);\n      }\n    });\n  };\n\n  /** Gets the root node of the portal outlet. */\n  private _getRootNode(): HTMLElement {\n    const nativeElement: Node = this._viewContainerRef.element.nativeElement;\n\n    // The directive could be set on a template which will result in a comment\n    // node being the root. Use the comment's parent node if that is the case.\n    return (\n      nativeElement.nodeType === nativeElement.ELEMENT_NODE\n        ? nativeElement\n        : nativeElement.parentNode!\n    ) as HTMLElement;\n  }\n}\n\n/**\n * @deprecated Use `CdkPortalOutlet` instead.\n * @breaking-change 9.0.0\n */\n@Directive({\n  selector: '[cdkPortalHost], [portalHost]',\n  exportAs: 'cdkPortalHost',\n  inputs: ['portal: cdkPortalHost'],\n  providers: [\n    {\n      provide: CdkPortalOutlet,\n      useExisting: PortalHostDirective,\n    },\n  ],\n})\nexport class PortalHostDirective extends CdkPortalOutlet {}\n\n@NgModule({\n  exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n  declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n})\nexport class PortalModule {}\n"]} |
\ | No newline at end of file |