@angular/cdk 10.0.0-rc.3 → 10.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/a11y/aria-describer/aria-describer.d.ts +10 -1
- package/a11y/focus-trap/focus-trap.d.ts +4 -2
- package/a11y/index.metadata.json +1 -1
- package/a11y/interactivity-checker/interactivity-checker.d.ts +11 -1
- package/a11y/key-manager/list-key-manager.d.ts +6 -0
- package/accordion/accordion.d.ts +7 -1
- package/accordion/index.d.ts +1 -0
- package/accordion/index.metadata.json +1 -1
- package/bundles/cdk-a11y.umd.js +78 -15
- package/bundles/cdk-a11y.umd.js.map +1 -1
- package/bundles/cdk-a11y.umd.min.js +11 -11
- package/bundles/cdk-a11y.umd.min.js.map +1 -1
- package/bundles/cdk-accordion.umd.js +12 -4
- package/bundles/cdk-accordion.umd.js.map +1 -1
- package/bundles/cdk-accordion.umd.min.js +2 -2
- package/bundles/cdk-accordion.umd.min.js.map +1 -1
- package/bundles/cdk-drag-drop.umd.js +717 -641
- package/bundles/cdk-drag-drop.umd.js.map +1 -1
- package/bundles/cdk-drag-drop.umd.min.js +8 -16
- package/bundles/cdk-drag-drop.umd.min.js.map +1 -1
- package/bundles/cdk-overlay.umd.js +199 -42
- package/bundles/cdk-overlay.umd.js.map +1 -1
- package/bundles/cdk-overlay.umd.min.js +11 -18
- package/bundles/cdk-overlay.umd.min.js.map +1 -1
- package/bundles/cdk-platform.umd.js +0 -1
- package/bundles/cdk-platform.umd.js.map +1 -1
- package/bundles/cdk-platform.umd.min.js +2 -2
- package/bundles/cdk-platform.umd.min.js.map +1 -1
- package/bundles/cdk-scrolling.umd.js +26 -4
- package/bundles/cdk-scrolling.umd.js.map +1 -1
- package/bundles/cdk-scrolling.umd.min.js +11 -4
- package/bundles/cdk-scrolling.umd.min.js.map +1 -1
- package/bundles/cdk-testing-protractor.umd.min.js +1 -1
- package/bundles/cdk-testing-protractor.umd.min.js.map +1 -1
- package/bundles/cdk-testing-testbed.umd.min.js +8 -8
- package/bundles/cdk-testing-testbed.umd.min.js.map +1 -1
- package/bundles/cdk-testing.umd.js +32 -0
- package/bundles/cdk-testing.umd.js.map +1 -1
- package/bundles/cdk-testing.umd.min.js +5 -5
- package/bundles/cdk-testing.umd.min.js.map +1 -1
- package/bundles/cdk-tree.umd.js +6 -2
- package/bundles/cdk-tree.umd.js.map +1 -1
- package/bundles/cdk-tree.umd.min.js +3 -3
- package/bundles/cdk-tree.umd.min.js.map +1 -1
- package/bundles/cdk.umd.js +1 -1
- package/bundles/cdk.umd.js.map +1 -1
- package/bundles/cdk.umd.min.js +1 -1
- package/bundles/cdk.umd.min.js.map +1 -1
- package/drag-drop/directives/drag-handle.d.ts +7 -1
- package/drag-drop/directives/drag-placeholder.d.ts +7 -1
- package/drag-drop/directives/drag-preview.d.ts +7 -1
- package/drag-drop/directives/drag.d.ts +4 -14
- package/drag-drop/directives/drop-list-group.d.ts +7 -1
- package/drag-drop/directives/drop-list.d.ts +7 -1
- package/drag-drop/drag-ref.d.ts +6 -0
- package/drag-drop/drop-list-ref.d.ts +3 -2
- package/drag-drop/index.d.ts +2 -2
- package/drag-drop/index.metadata.json +1 -1
- package/esm2015/a11y/a11y-module.js +15 -19
- package/esm2015/a11y/aria-describer/aria-describer.js +177 -167
- package/esm2015/a11y/focus-monitor/focus-monitor.js +337 -345
- package/esm2015/a11y/focus-trap/configurable-focus-trap-factory.js +30 -34
- package/esm2015/a11y/focus-trap/focus-trap-manager.js +36 -40
- package/esm2015/a11y/focus-trap/focus-trap.js +85 -82
- package/esm2015/a11y/high-contrast-mode/high-contrast-mode-detector.js +56 -60
- package/esm2015/a11y/interactivity-checker/interactivity-checker.js +113 -104
- package/esm2015/a11y/key-manager/list-key-manager.js +29 -4
- package/esm2015/a11y/live-announcer/live-announcer.js +138 -146
- package/esm2015/accordion/accordion-item.js +119 -123
- package/esm2015/accordion/accordion-module.js +9 -13
- package/esm2015/accordion/accordion.js +49 -46
- package/esm2015/accordion/index.js +2 -1
- package/esm2015/bidi/bidi-module.js +9 -13
- package/esm2015/bidi/dir.js +41 -45
- package/esm2015/bidi/directionality.js +27 -31
- package/esm2015/clipboard/clipboard-module.js +9 -13
- package/esm2015/clipboard/clipboard.js +36 -40
- package/esm2015/clipboard/copy-to-clipboard.js +71 -75
- package/esm2015/collections/unique-selection-dispatcher.js +33 -37
- package/esm2015/drag-drop/directives/drag-handle.js +42 -39
- package/esm2015/drag-drop/directives/drag-placeholder.js +24 -21
- package/esm2015/drag-drop/directives/drag-preview.js +29 -26
- package/esm2015/drag-drop/directives/drag.js +313 -319
- package/esm2015/drag-drop/directives/drop-list-group.js +32 -29
- package/esm2015/drag-drop/directives/drop-list.js +251 -250
- package/esm2015/drag-drop/drag-drop-module.js +27 -31
- package/esm2015/drag-drop/drag-drop-registry.js +139 -143
- package/esm2015/drag-drop/drag-drop.js +33 -37
- package/esm2015/drag-drop/drag-ref.js +59 -25
- package/esm2015/drag-drop/drop-list-ref.js +15 -9
- package/esm2015/drag-drop/index.js +3 -2
- package/esm2015/layout/breakpoints-observer.js +81 -85
- package/esm2015/layout/layout-module.js +6 -10
- package/esm2015/layout/media-matcher.js +28 -32
- package/esm2015/observers/observe-content.js +147 -163
- package/esm2015/overlay/dispatchers/base-overlay-dispatcher.js +51 -0
- package/esm2015/overlay/dispatchers/index.js +10 -0
- package/esm2015/overlay/dispatchers/overlay-keyboard-dispatcher.js +79 -0
- package/esm2015/overlay/dispatchers/overlay-outside-click-dispatcher.js +94 -0
- package/esm2015/overlay/fullscreen-overlay-container.js +70 -74
- package/esm2015/overlay/index.js +5 -4
- package/esm2015/overlay/overlay-config.js +5 -1
- package/esm2015/overlay/overlay-container.js +69 -73
- package/esm2015/overlay/overlay-directives.js +245 -243
- package/esm2015/overlay/overlay-module.js +15 -19
- package/esm2015/overlay/overlay-ref.js +24 -2
- package/esm2015/overlay/overlay-reference.js +1 -1
- package/esm2015/overlay/overlay.js +93 -92
- package/esm2015/overlay/position/connected-position.js +14 -18
- package/esm2015/overlay/position/overlay-position-builder.js +43 -47
- package/esm2015/overlay/public-api.js +2 -2
- package/esm2015/overlay/scroll/scroll-strategy-options.js +33 -37
- package/esm2015/platform/features/scrolling.js +1 -2
- package/esm2015/platform/platform-module.js +6 -10
- package/esm2015/platform/platform.js +48 -52
- package/esm2015/portal/portal-directives.js +181 -201
- package/esm2015/scrolling/fixed-size-virtual-scroll.js +57 -47
- package/esm2015/scrolling/public-api.js +2 -1
- package/esm2015/scrolling/scroll-dispatcher.js +139 -143
- package/esm2015/scrolling/scrollable.js +135 -139
- package/esm2015/scrolling/scrolling-module.js +32 -40
- package/esm2015/scrolling/viewport-ruler.js +105 -109
- package/esm2015/scrolling/virtual-for-of.js +264 -268
- package/esm2015/scrolling/virtual-scroll-repeater.js +8 -0
- package/esm2015/scrolling/virtual-scroll-viewport.js +318 -322
- package/esm2015/stepper/step-header.js +20 -24
- package/esm2015/stepper/step-label.js +13 -17
- package/esm2015/stepper/stepper-button.js +59 -67
- package/esm2015/stepper/stepper-module.js +24 -28
- package/esm2015/stepper/stepper.js +313 -321
- package/esm2015/table/cell.js +129 -157
- package/esm2015/table/row.js +183 -219
- package/esm2015/table/table-module.js +9 -13
- package/esm2015/table/table.js +765 -785
- package/esm2015/table/text-column.js +85 -89
- package/esm2015/testing/component-harness.js +19 -1
- package/esm2015/testing/harness-environment.js +7 -1
- package/esm2015/text-field/autofill.js +89 -97
- package/esm2015/text-field/autosize.js +225 -229
- package/esm2015/text-field/text-field-module.js +10 -14
- package/esm2015/tree/control/nested-tree-control.js +7 -3
- package/esm2015/tree/nested-node.js +79 -83
- package/esm2015/tree/node.js +17 -21
- package/esm2015/tree/outlet.js +15 -19
- package/esm2015/tree/padding.js +88 -92
- package/esm2015/tree/toggle.js +32 -36
- package/esm2015/tree/tree-module.js +10 -14
- package/esm2015/tree/tree.js +266 -274
- package/esm2015/version.js +1 -1
- package/fesm2015/a11y.js +1021 -996
- package/fesm2015/a11y.js.map +1 -1
- package/fesm2015/accordion.js +173 -175
- package/fesm2015/accordion.js.map +1 -1
- package/fesm2015/bidi.js +74 -83
- package/fesm2015/bidi.js.map +1 -1
- package/fesm2015/cdk.js +1 -1
- package/fesm2015/cdk.js.map +1 -1
- package/fesm2015/clipboard.js +113 -122
- package/fesm2015/clipboard.js.map +1 -1
- package/fesm2015/collections.js +32 -35
- package/fesm2015/collections.js.map +1 -1
- package/fesm2015/drag-drop.js +1005 -961
- package/fesm2015/drag-drop.js.map +1 -1
- package/fesm2015/layout.js +111 -120
- package/fesm2015/layout.js.map +1 -1
- package/fesm2015/observers.js +146 -158
- package/fesm2015/observers.js.map +1 -1
- package/fesm2015/overlay.js +793 -659
- package/fesm2015/overlay.js.map +1 -1
- package/fesm2015/platform.js +52 -59
- package/fesm2015/platform.js.map +1 -1
- package/fesm2015/portal.js +180 -195
- package/fesm2015/portal.js.map +1 -1
- package/fesm2015/scrolling.js +1058 -1060
- package/fesm2015/scrolling.js.map +1 -1
- package/fesm2015/stepper.js +424 -445
- package/fesm2015/stepper.js.map +1 -1
- package/fesm2015/table.js +1178 -1247
- package/fesm2015/table.js.map +1 -1
- package/fesm2015/testing.js +25 -1
- package/fesm2015/testing.js.map +1 -1
- package/fesm2015/text-field.js +318 -330
- package/fesm2015/text-field.js.map +1 -1
- package/fesm2015/tree.js +517 -537
- package/fesm2015/tree.js.map +1 -1
- package/overlay/dispatchers/base-overlay-dispatcher.d.ts +28 -0
- package/overlay/dispatchers/index.d.ts +9 -0
- package/overlay/{keyboard → dispatchers}/overlay-keyboard-dispatcher.d.ts +4 -10
- package/overlay/dispatchers/overlay-outside-click-dispatcher.d.ts +27 -0
- package/overlay/index.d.ts +4 -3
- package/overlay/index.metadata.json +1 -1
- package/overlay/overlay-config.d.ts +4 -0
- package/overlay/overlay-directives.d.ts +4 -0
- package/overlay/overlay-ref.d.ts +8 -2
- package/overlay/overlay-reference.d.ts +1 -0
- package/overlay/overlay.d.ts +4 -2
- package/overlay/public-api.d.ts +1 -1
- package/package.json +3 -3
- package/schematics/index.js +1 -1
- package/schematics/migration.json +5 -0
- package/schematics/ng-add/index.js +1 -1
- package/schematics/ng-update/data/index.js +1 -1
- package/schematics/ng-update/devkit-file-system.d.ts +5 -5
- package/schematics/ng-update/devkit-file-system.js +21 -16
- package/schematics/ng-update/devkit-migration-rule.js +13 -20
- package/schematics/ng-update/devkit-migration.d.ts +0 -2
- package/schematics/ng-update/devkit-migration.js +1 -1
- package/schematics/ng-update/find-stylesheets.d.ts +10 -0
- package/schematics/ng-update/find-stylesheets.js +31 -0
- package/schematics/ng-update/index.d.ts +2 -0
- package/schematics/ng-update/index.js +7 -2
- package/schematics/ng-update/migrations/attribute-selectors.js +3 -3
- package/schematics/ng-update/migrations/css-selectors.js +3 -3
- package/schematics/ng-update/migrations/element-selectors.js +3 -3
- package/schematics/ng-update/public-api.js +1 -1
- package/schematics/update-tool/component-resource-collector.d.ts +1 -1
- package/schematics/update-tool/component-resource-collector.js +18 -14
- package/schematics/update-tool/file-system.d.ts +19 -14
- package/schematics/update-tool/file-system.js +1 -1
- package/schematics/update-tool/index.d.ts +21 -3
- package/schematics/update-tool/index.js +29 -23
- package/schematics/update-tool/public-api.js +1 -1
- package/schematics/update-tool/target-version.d.ts +2 -1
- package/schematics/update-tool/target-version.js +5 -3
- package/schematics/update-tool/utils/parse-tsconfig.d.ts +2 -1
- package/schematics/update-tool/utils/parse-tsconfig.js +6 -10
- package/schematics/update-tool/utils/virtual-host.d.ts +34 -0
- package/schematics/update-tool/utils/virtual-host.js +62 -0
- package/schematics/update-tool/version-changes.js +4 -6
- package/schematics/utils/index.js +1 -1
- package/schematics/utils/project-tsconfig-paths.d.ts +2 -1
- package/schematics/utils/project-tsconfig-paths.js +1 -1
- package/scrolling/index.metadata.json +1 -1
- package/scrolling/public-api.d.ts +1 -0
- package/scrolling/virtual-for-of.d.ts +2 -1
- package/scrolling/virtual-scroll-repeater.d.ts +16 -0
- package/scrolling/virtual-scroll-viewport.d.ts +4 -4
- package/testing/component-harness.d.ts +12 -0
- package/testing/harness-environment.d.ts +1 -0
- package/tree/control/nested-tree-control.d.ts +7 -2
- package/tree/index.metadata.json +1 -1
- package/esm2015/overlay/keyboard/overlay-keyboard-dispatcher.js +0 -100
|
@@ -12,45 +12,37 @@ import { BasePortalOutlet, TemplatePortal } from './portal';
|
|
|
12
12
|
* Directive version of a `TemplatePortal`. Because the directive *is* a TemplatePortal,
|
|
13
13
|
* the directive instance itself can be attached to a host, enabling declarative use of portals.
|
|
14
14
|
*/
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
super(templateRef, viewContainerRef);
|
|
19
|
-
}
|
|
15
|
+
export class CdkPortal extends TemplatePortal {
|
|
16
|
+
constructor(templateRef, viewContainerRef) {
|
|
17
|
+
super(templateRef, viewContainerRef);
|
|
20
18
|
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
})();
|
|
33
|
-
export { CdkPortal };
|
|
19
|
+
}
|
|
20
|
+
CdkPortal.decorators = [
|
|
21
|
+
{ type: Directive, args: [{
|
|
22
|
+
selector: '[cdkPortal]',
|
|
23
|
+
exportAs: 'cdkPortal',
|
|
24
|
+
},] }
|
|
25
|
+
];
|
|
26
|
+
CdkPortal.ctorParameters = () => [
|
|
27
|
+
{ type: TemplateRef },
|
|
28
|
+
{ type: ViewContainerRef }
|
|
29
|
+
];
|
|
34
30
|
/**
|
|
35
31
|
* @deprecated Use `CdkPortal` instead.
|
|
36
32
|
* @breaking-change 9.0.0
|
|
37
33
|
*/
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
];
|
|
51
|
-
return TemplatePortalDirective;
|
|
52
|
-
})();
|
|
53
|
-
export { TemplatePortalDirective };
|
|
34
|
+
export class TemplatePortalDirective extends CdkPortal {
|
|
35
|
+
}
|
|
36
|
+
TemplatePortalDirective.decorators = [
|
|
37
|
+
{ type: Directive, args: [{
|
|
38
|
+
selector: '[cdk-portal], [portal]',
|
|
39
|
+
exportAs: 'cdkPortal',
|
|
40
|
+
providers: [{
|
|
41
|
+
provide: CdkPortal,
|
|
42
|
+
useExisting: TemplatePortalDirective
|
|
43
|
+
}]
|
|
44
|
+
},] }
|
|
45
|
+
];
|
|
54
46
|
/**
|
|
55
47
|
* Directive version of a PortalOutlet. Because the directive *is* a PortalOutlet, portals can be
|
|
56
48
|
* directly attached to it, enabling declarative use.
|
|
@@ -58,183 +50,171 @@ export { TemplatePortalDirective };
|
|
|
58
50
|
* Usage:
|
|
59
51
|
* `<ng-template [cdkPortalOutlet]="greeting"></ng-template>`
|
|
60
52
|
*/
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
53
|
+
export class CdkPortalOutlet extends BasePortalOutlet {
|
|
54
|
+
constructor(_componentFactoryResolver, _viewContainerRef,
|
|
55
|
+
/**
|
|
56
|
+
* @deprecated `_document` parameter to be made required.
|
|
57
|
+
* @breaking-change 9.0.0
|
|
58
|
+
*/
|
|
59
|
+
_document) {
|
|
60
|
+
super();
|
|
61
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
|
62
|
+
this._viewContainerRef = _viewContainerRef;
|
|
63
|
+
/** Whether the portal component is initialized. */
|
|
64
|
+
this._isInitialized = false;
|
|
65
|
+
/** Emits when a portal is attached to the outlet. */
|
|
66
|
+
this.attached = new EventEmitter();
|
|
64
67
|
/**
|
|
65
|
-
*
|
|
66
|
-
* @
|
|
68
|
+
* Attaches the given DomPortal to this PortalHost by moving all of the portal content into it.
|
|
69
|
+
* @param portal Portal to be attached.
|
|
70
|
+
* @deprecated To be turned into a method.
|
|
71
|
+
* @breaking-change 10.0.0
|
|
67
72
|
*/
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
this.
|
|
72
|
-
|
|
73
|
-
this._isInitialized = false;
|
|
74
|
-
/** Emits when a portal is attached to the outlet. */
|
|
75
|
-
this.attached = new EventEmitter();
|
|
76
|
-
/**
|
|
77
|
-
* Attaches the given DomPortal to this PortalHost by moving all of the portal content into it.
|
|
78
|
-
* @param portal Portal to be attached.
|
|
79
|
-
* @deprecated To be turned into a method.
|
|
80
|
-
* @breaking-change 10.0.0
|
|
81
|
-
*/
|
|
82
|
-
this.attachDomPortal = (portal) => {
|
|
83
|
-
// @breaking-change 9.0.0 Remove check and error once the
|
|
84
|
-
// `_document` constructor parameter is required.
|
|
85
|
-
if (!this._document) {
|
|
86
|
-
throw Error('Cannot attach DOM portal without _document constructor parameter');
|
|
87
|
-
}
|
|
88
|
-
const element = portal.element;
|
|
89
|
-
if (!element.parentNode) {
|
|
90
|
-
throw Error('DOM portal content must be attached to a parent node.');
|
|
91
|
-
}
|
|
92
|
-
// Anchor used to save the element's previous position so
|
|
93
|
-
// that we can restore it when the portal is detached.
|
|
94
|
-
const anchorNode = this._document.createComment('dom-portal');
|
|
95
|
-
portal.setAttachedHost(this);
|
|
96
|
-
element.parentNode.insertBefore(anchorNode, element);
|
|
97
|
-
this._getRootNode().appendChild(element);
|
|
98
|
-
super.setDisposeFn(() => {
|
|
99
|
-
if (anchorNode.parentNode) {
|
|
100
|
-
anchorNode.parentNode.replaceChild(element, anchorNode);
|
|
101
|
-
}
|
|
102
|
-
});
|
|
103
|
-
};
|
|
104
|
-
this._document = _document;
|
|
105
|
-
}
|
|
106
|
-
/** Portal associated with the Portal outlet. */
|
|
107
|
-
get portal() {
|
|
108
|
-
return this._attachedPortal;
|
|
109
|
-
}
|
|
110
|
-
set portal(portal) {
|
|
111
|
-
// Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have
|
|
112
|
-
// run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`
|
|
113
|
-
// and attach a portal programmatically in the parent component. When Angular does the first CD
|
|
114
|
-
// round, it will fire the setter with empty string, causing the user's content to be cleared.
|
|
115
|
-
if (this.hasAttached() && !portal && !this._isInitialized) {
|
|
116
|
-
return;
|
|
117
|
-
}
|
|
118
|
-
if (this.hasAttached()) {
|
|
119
|
-
super.detach();
|
|
73
|
+
this.attachDomPortal = (portal) => {
|
|
74
|
+
// @breaking-change 9.0.0 Remove check and error once the
|
|
75
|
+
// `_document` constructor parameter is required.
|
|
76
|
+
if (!this._document) {
|
|
77
|
+
throw Error('Cannot attach DOM portal without _document constructor parameter');
|
|
120
78
|
}
|
|
121
|
-
|
|
122
|
-
|
|
79
|
+
const element = portal.element;
|
|
80
|
+
if (!element.parentNode) {
|
|
81
|
+
throw Error('DOM portal content must be attached to a parent node.');
|
|
123
82
|
}
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
get attachedRef() {
|
|
128
|
-
return this._attachedRef;
|
|
129
|
-
}
|
|
130
|
-
ngOnInit() {
|
|
131
|
-
this._isInitialized = true;
|
|
132
|
-
}
|
|
133
|
-
ngOnDestroy() {
|
|
134
|
-
super.dispose();
|
|
135
|
-
this._attachedPortal = null;
|
|
136
|
-
this._attachedRef = null;
|
|
137
|
-
}
|
|
138
|
-
/**
|
|
139
|
-
* Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.
|
|
140
|
-
*
|
|
141
|
-
* @param portal Portal to be attached to the portal outlet.
|
|
142
|
-
* @returns Reference to the created component.
|
|
143
|
-
*/
|
|
144
|
-
attachComponentPortal(portal) {
|
|
83
|
+
// Anchor used to save the element's previous position so
|
|
84
|
+
// that we can restore it when the portal is detached.
|
|
85
|
+
const anchorNode = this._document.createComment('dom-portal');
|
|
145
86
|
portal.setAttachedHost(this);
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
87
|
+
element.parentNode.insertBefore(anchorNode, element);
|
|
88
|
+
this._getRootNode().appendChild(element);
|
|
89
|
+
super.setDisposeFn(() => {
|
|
90
|
+
if (anchorNode.parentNode) {
|
|
91
|
+
anchorNode.parentNode.replaceChild(element, anchorNode);
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
};
|
|
95
|
+
this._document = _document;
|
|
96
|
+
}
|
|
97
|
+
/** Portal associated with the Portal outlet. */
|
|
98
|
+
get portal() {
|
|
99
|
+
return this._attachedPortal;
|
|
100
|
+
}
|
|
101
|
+
set portal(portal) {
|
|
102
|
+
// Ignore the cases where the `portal` is set to a falsy value before the lifecycle hooks have
|
|
103
|
+
// run. This handles the cases where the user might do something like `<div cdkPortalOutlet>`
|
|
104
|
+
// and attach a portal programmatically in the parent component. When Angular does the first CD
|
|
105
|
+
// round, it will fire the setter with empty string, causing the user's content to be cleared.
|
|
106
|
+
if (this.hasAttached() && !portal && !this._isInitialized) {
|
|
107
|
+
return;
|
|
165
108
|
}
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
* @param portal Portal to be attached.
|
|
169
|
-
* @returns Reference to the created embedded view.
|
|
170
|
-
*/
|
|
171
|
-
attachTemplatePortal(portal) {
|
|
172
|
-
portal.setAttachedHost(this);
|
|
173
|
-
const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context);
|
|
174
|
-
super.setDisposeFn(() => this._viewContainerRef.clear());
|
|
175
|
-
this._attachedPortal = portal;
|
|
176
|
-
this._attachedRef = viewRef;
|
|
177
|
-
this.attached.emit(viewRef);
|
|
178
|
-
return viewRef;
|
|
109
|
+
if (this.hasAttached()) {
|
|
110
|
+
super.detach();
|
|
179
111
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
const nativeElement = this._viewContainerRef.element.nativeElement;
|
|
183
|
-
// The directive could be set on a template which will result in a comment
|
|
184
|
-
// node being the root. Use the comment's parent node if that is the case.
|
|
185
|
-
return (nativeElement.nodeType === nativeElement.ELEMENT_NODE ?
|
|
186
|
-
nativeElement : nativeElement.parentNode);
|
|
112
|
+
if (portal) {
|
|
113
|
+
super.attach(portal);
|
|
187
114
|
}
|
|
115
|
+
this._attachedPortal = portal;
|
|
116
|
+
}
|
|
117
|
+
/** Component or view reference that is attached to the portal. */
|
|
118
|
+
get attachedRef() {
|
|
119
|
+
return this._attachedRef;
|
|
120
|
+
}
|
|
121
|
+
ngOnInit() {
|
|
122
|
+
this._isInitialized = true;
|
|
188
123
|
}
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
124
|
+
ngOnDestroy() {
|
|
125
|
+
super.dispose();
|
|
126
|
+
this._attachedPortal = null;
|
|
127
|
+
this._attachedRef = null;
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Attach the given ComponentPortal to this PortalOutlet using the ComponentFactoryResolver.
|
|
131
|
+
*
|
|
132
|
+
* @param portal Portal to be attached to the portal outlet.
|
|
133
|
+
* @returns Reference to the created component.
|
|
134
|
+
*/
|
|
135
|
+
attachComponentPortal(portal) {
|
|
136
|
+
portal.setAttachedHost(this);
|
|
137
|
+
// If the portal specifies an origin, use that as the logical location of the component
|
|
138
|
+
// in the application tree. Otherwise use the location of this PortalOutlet.
|
|
139
|
+
const viewContainerRef = portal.viewContainerRef != null ?
|
|
140
|
+
portal.viewContainerRef :
|
|
141
|
+
this._viewContainerRef;
|
|
142
|
+
const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;
|
|
143
|
+
const componentFactory = resolver.resolveComponentFactory(portal.component);
|
|
144
|
+
const ref = viewContainerRef.createComponent(componentFactory, viewContainerRef.length, portal.injector || viewContainerRef.injector);
|
|
145
|
+
// If we're using a view container that's different from the injected one (e.g. when the portal
|
|
146
|
+
// specifies its own) we need to move the component into the outlet, otherwise it'll be rendered
|
|
147
|
+
// inside of the alternate view container.
|
|
148
|
+
if (viewContainerRef !== this._viewContainerRef) {
|
|
149
|
+
this._getRootNode().appendChild(ref.hostView.rootNodes[0]);
|
|
150
|
+
}
|
|
151
|
+
super.setDisposeFn(() => ref.destroy());
|
|
152
|
+
this._attachedPortal = portal;
|
|
153
|
+
this._attachedRef = ref;
|
|
154
|
+
this.attached.emit(ref);
|
|
155
|
+
return ref;
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Attach the given TemplatePortal to this PortalHost as an embedded View.
|
|
159
|
+
* @param portal Portal to be attached.
|
|
160
|
+
* @returns Reference to the created embedded view.
|
|
161
|
+
*/
|
|
162
|
+
attachTemplatePortal(portal) {
|
|
163
|
+
portal.setAttachedHost(this);
|
|
164
|
+
const viewRef = this._viewContainerRef.createEmbeddedView(portal.templateRef, portal.context);
|
|
165
|
+
super.setDisposeFn(() => this._viewContainerRef.clear());
|
|
166
|
+
this._attachedPortal = portal;
|
|
167
|
+
this._attachedRef = viewRef;
|
|
168
|
+
this.attached.emit(viewRef);
|
|
169
|
+
return viewRef;
|
|
170
|
+
}
|
|
171
|
+
/** Gets the root node of the portal outlet. */
|
|
172
|
+
_getRootNode() {
|
|
173
|
+
const nativeElement = this._viewContainerRef.element.nativeElement;
|
|
174
|
+
// The directive could be set on a template which will result in a comment
|
|
175
|
+
// node being the root. Use the comment's parent node if that is the case.
|
|
176
|
+
return (nativeElement.nodeType === nativeElement.ELEMENT_NODE ?
|
|
177
|
+
nativeElement : nativeElement.parentNode);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
CdkPortalOutlet.decorators = [
|
|
181
|
+
{ type: Directive, args: [{
|
|
182
|
+
selector: '[cdkPortalOutlet]',
|
|
183
|
+
exportAs: 'cdkPortalOutlet',
|
|
184
|
+
inputs: ['portal: cdkPortalOutlet']
|
|
185
|
+
},] }
|
|
186
|
+
];
|
|
187
|
+
CdkPortalOutlet.ctorParameters = () => [
|
|
188
|
+
{ type: ComponentFactoryResolver },
|
|
189
|
+
{ type: ViewContainerRef },
|
|
190
|
+
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
|
|
191
|
+
];
|
|
192
|
+
CdkPortalOutlet.propDecorators = {
|
|
193
|
+
attached: [{ type: Output }]
|
|
194
|
+
};
|
|
207
195
|
/**
|
|
208
196
|
* @deprecated Use `CdkPortalOutlet` instead.
|
|
209
197
|
* @breaking-change 9.0.0
|
|
210
198
|
*/
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
{ type: NgModule, args: [{
|
|
233
|
-
exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
|
234
|
-
declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
|
235
|
-
},] }
|
|
236
|
-
];
|
|
237
|
-
return PortalModule;
|
|
238
|
-
})();
|
|
239
|
-
export { PortalModule };
|
|
240
|
-
//# 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/**\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    provide: CdkPortal,\n    useExisting: TemplatePortalDirective\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/**\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    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) {\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;\n  }\n\n  /** Emits when a portal is attached to the outlet. */\n  @Output() 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._attachedPortal = null;\n    this._attachedRef = 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 = portal.viewContainerRef != null ?\n        portal.viewContainerRef :\n        this._viewContainerRef;\n\n    const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;\n    const componentFactory = resolver.resolveComponentFactory(portal.component);\n    const ref = viewContainerRef.createComponent(\n        componentFactory, viewContainerRef.length,\n        portal.injector || viewContainerRef.injector);\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    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  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) {\n      throw Error('Cannot attach DOM portal without _document constructor parameter');\n    }\n\n    const element = portal.element;\n    if (!element.parentNode) {\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\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 (nativeElement.nodeType === nativeElement.ELEMENT_NODE ?\n           nativeElement : nativeElement.parentNode!) as HTMLElement;\n  }\n\n  static ngAcceptInputType_portal: Portal<any> | null | undefined | '';\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    provide: CdkPortalOutlet,\n    useExisting: PortalHostDirective\n  }]\n})\nexport class PortalHostDirective extends CdkPortalOutlet {}\n\n\n@NgModule({\n  exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n  declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n})\nexport class PortalModule {}\n"]}
|
|
199
|
+
export class PortalHostDirective extends CdkPortalOutlet {
|
|
200
|
+
}
|
|
201
|
+
PortalHostDirective.decorators = [
|
|
202
|
+
{ type: Directive, args: [{
|
|
203
|
+
selector: '[cdkPortalHost], [portalHost]',
|
|
204
|
+
exportAs: 'cdkPortalHost',
|
|
205
|
+
inputs: ['portal: cdkPortalHost'],
|
|
206
|
+
providers: [{
|
|
207
|
+
provide: CdkPortalOutlet,
|
|
208
|
+
useExisting: PortalHostDirective
|
|
209
|
+
}]
|
|
210
|
+
},] }
|
|
211
|
+
];
|
|
212
|
+
export class PortalModule {
|
|
213
|
+
}
|
|
214
|
+
PortalModule.decorators = [
|
|
215
|
+
{ type: NgModule, args: [{
|
|
216
|
+
exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
|
217
|
+
declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],
|
|
218
|
+
},] }
|
|
219
|
+
];
|
|
220
|
+
//# 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/**\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    provide: CdkPortal,\n    useExisting: TemplatePortalDirective\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/**\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    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) {\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;\n  }\n\n  /** Emits when a portal is attached to the outlet. */\n  @Output() 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._attachedPortal = null;\n    this._attachedRef = 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 = portal.viewContainerRef != null ?\n        portal.viewContainerRef :\n        this._viewContainerRef;\n\n    const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;\n    const componentFactory = resolver.resolveComponentFactory(portal.component);\n    const ref = viewContainerRef.createComponent(\n        componentFactory, viewContainerRef.length,\n        portal.injector || viewContainerRef.injector);\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    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  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) {\n      throw Error('Cannot attach DOM portal without _document constructor parameter');\n    }\n\n    const element = portal.element;\n    if (!element.parentNode) {\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\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 (nativeElement.nodeType === nativeElement.ELEMENT_NODE ?\n           nativeElement : nativeElement.parentNode!) as HTMLElement;\n  }\n\n  static ngAcceptInputType_portal: Portal<any> | null | undefined | '';\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    provide: CdkPortalOutlet,\n    useExisting: PortalHostDirective\n  }]\n})\nexport class PortalHostDirective extends CdkPortalOutlet {}\n\n\n@NgModule({\n  exports: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n  declarations: [CdkPortal, CdkPortalOutlet, TemplatePortalDirective, PortalHostDirective],\n})\nexport class PortalModule {}\n"]}
|