@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.
Files changed (242) hide show
  1. package/a11y/aria-describer/aria-describer.d.ts +10 -1
  2. package/a11y/focus-trap/focus-trap.d.ts +4 -2
  3. package/a11y/index.metadata.json +1 -1
  4. package/a11y/interactivity-checker/interactivity-checker.d.ts +11 -1
  5. package/a11y/key-manager/list-key-manager.d.ts +6 -0
  6. package/accordion/accordion.d.ts +7 -1
  7. package/accordion/index.d.ts +1 -0
  8. package/accordion/index.metadata.json +1 -1
  9. package/bundles/cdk-a11y.umd.js +78 -15
  10. package/bundles/cdk-a11y.umd.js.map +1 -1
  11. package/bundles/cdk-a11y.umd.min.js +11 -11
  12. package/bundles/cdk-a11y.umd.min.js.map +1 -1
  13. package/bundles/cdk-accordion.umd.js +12 -4
  14. package/bundles/cdk-accordion.umd.js.map +1 -1
  15. package/bundles/cdk-accordion.umd.min.js +2 -2
  16. package/bundles/cdk-accordion.umd.min.js.map +1 -1
  17. package/bundles/cdk-drag-drop.umd.js +717 -641
  18. package/bundles/cdk-drag-drop.umd.js.map +1 -1
  19. package/bundles/cdk-drag-drop.umd.min.js +8 -16
  20. package/bundles/cdk-drag-drop.umd.min.js.map +1 -1
  21. package/bundles/cdk-overlay.umd.js +199 -42
  22. package/bundles/cdk-overlay.umd.js.map +1 -1
  23. package/bundles/cdk-overlay.umd.min.js +11 -18
  24. package/bundles/cdk-overlay.umd.min.js.map +1 -1
  25. package/bundles/cdk-platform.umd.js +0 -1
  26. package/bundles/cdk-platform.umd.js.map +1 -1
  27. package/bundles/cdk-platform.umd.min.js +2 -2
  28. package/bundles/cdk-platform.umd.min.js.map +1 -1
  29. package/bundles/cdk-scrolling.umd.js +26 -4
  30. package/bundles/cdk-scrolling.umd.js.map +1 -1
  31. package/bundles/cdk-scrolling.umd.min.js +11 -4
  32. package/bundles/cdk-scrolling.umd.min.js.map +1 -1
  33. package/bundles/cdk-testing-protractor.umd.min.js +1 -1
  34. package/bundles/cdk-testing-protractor.umd.min.js.map +1 -1
  35. package/bundles/cdk-testing-testbed.umd.min.js +8 -8
  36. package/bundles/cdk-testing-testbed.umd.min.js.map +1 -1
  37. package/bundles/cdk-testing.umd.js +32 -0
  38. package/bundles/cdk-testing.umd.js.map +1 -1
  39. package/bundles/cdk-testing.umd.min.js +5 -5
  40. package/bundles/cdk-testing.umd.min.js.map +1 -1
  41. package/bundles/cdk-tree.umd.js +6 -2
  42. package/bundles/cdk-tree.umd.js.map +1 -1
  43. package/bundles/cdk-tree.umd.min.js +3 -3
  44. package/bundles/cdk-tree.umd.min.js.map +1 -1
  45. package/bundles/cdk.umd.js +1 -1
  46. package/bundles/cdk.umd.js.map +1 -1
  47. package/bundles/cdk.umd.min.js +1 -1
  48. package/bundles/cdk.umd.min.js.map +1 -1
  49. package/drag-drop/directives/drag-handle.d.ts +7 -1
  50. package/drag-drop/directives/drag-placeholder.d.ts +7 -1
  51. package/drag-drop/directives/drag-preview.d.ts +7 -1
  52. package/drag-drop/directives/drag.d.ts +4 -14
  53. package/drag-drop/directives/drop-list-group.d.ts +7 -1
  54. package/drag-drop/directives/drop-list.d.ts +7 -1
  55. package/drag-drop/drag-ref.d.ts +6 -0
  56. package/drag-drop/drop-list-ref.d.ts +3 -2
  57. package/drag-drop/index.d.ts +2 -2
  58. package/drag-drop/index.metadata.json +1 -1
  59. package/esm2015/a11y/a11y-module.js +15 -19
  60. package/esm2015/a11y/aria-describer/aria-describer.js +177 -167
  61. package/esm2015/a11y/focus-monitor/focus-monitor.js +337 -345
  62. package/esm2015/a11y/focus-trap/configurable-focus-trap-factory.js +30 -34
  63. package/esm2015/a11y/focus-trap/focus-trap-manager.js +36 -40
  64. package/esm2015/a11y/focus-trap/focus-trap.js +85 -82
  65. package/esm2015/a11y/high-contrast-mode/high-contrast-mode-detector.js +56 -60
  66. package/esm2015/a11y/interactivity-checker/interactivity-checker.js +113 -104
  67. package/esm2015/a11y/key-manager/list-key-manager.js +29 -4
  68. package/esm2015/a11y/live-announcer/live-announcer.js +138 -146
  69. package/esm2015/accordion/accordion-item.js +119 -123
  70. package/esm2015/accordion/accordion-module.js +9 -13
  71. package/esm2015/accordion/accordion.js +49 -46
  72. package/esm2015/accordion/index.js +2 -1
  73. package/esm2015/bidi/bidi-module.js +9 -13
  74. package/esm2015/bidi/dir.js +41 -45
  75. package/esm2015/bidi/directionality.js +27 -31
  76. package/esm2015/clipboard/clipboard-module.js +9 -13
  77. package/esm2015/clipboard/clipboard.js +36 -40
  78. package/esm2015/clipboard/copy-to-clipboard.js +71 -75
  79. package/esm2015/collections/unique-selection-dispatcher.js +33 -37
  80. package/esm2015/drag-drop/directives/drag-handle.js +42 -39
  81. package/esm2015/drag-drop/directives/drag-placeholder.js +24 -21
  82. package/esm2015/drag-drop/directives/drag-preview.js +29 -26
  83. package/esm2015/drag-drop/directives/drag.js +313 -319
  84. package/esm2015/drag-drop/directives/drop-list-group.js +32 -29
  85. package/esm2015/drag-drop/directives/drop-list.js +251 -250
  86. package/esm2015/drag-drop/drag-drop-module.js +27 -31
  87. package/esm2015/drag-drop/drag-drop-registry.js +139 -143
  88. package/esm2015/drag-drop/drag-drop.js +33 -37
  89. package/esm2015/drag-drop/drag-ref.js +59 -25
  90. package/esm2015/drag-drop/drop-list-ref.js +15 -9
  91. package/esm2015/drag-drop/index.js +3 -2
  92. package/esm2015/layout/breakpoints-observer.js +81 -85
  93. package/esm2015/layout/layout-module.js +6 -10
  94. package/esm2015/layout/media-matcher.js +28 -32
  95. package/esm2015/observers/observe-content.js +147 -163
  96. package/esm2015/overlay/dispatchers/base-overlay-dispatcher.js +51 -0
  97. package/esm2015/overlay/dispatchers/index.js +10 -0
  98. package/esm2015/overlay/dispatchers/overlay-keyboard-dispatcher.js +79 -0
  99. package/esm2015/overlay/dispatchers/overlay-outside-click-dispatcher.js +94 -0
  100. package/esm2015/overlay/fullscreen-overlay-container.js +70 -74
  101. package/esm2015/overlay/index.js +5 -4
  102. package/esm2015/overlay/overlay-config.js +5 -1
  103. package/esm2015/overlay/overlay-container.js +69 -73
  104. package/esm2015/overlay/overlay-directives.js +245 -243
  105. package/esm2015/overlay/overlay-module.js +15 -19
  106. package/esm2015/overlay/overlay-ref.js +24 -2
  107. package/esm2015/overlay/overlay-reference.js +1 -1
  108. package/esm2015/overlay/overlay.js +93 -92
  109. package/esm2015/overlay/position/connected-position.js +14 -18
  110. package/esm2015/overlay/position/overlay-position-builder.js +43 -47
  111. package/esm2015/overlay/public-api.js +2 -2
  112. package/esm2015/overlay/scroll/scroll-strategy-options.js +33 -37
  113. package/esm2015/platform/features/scrolling.js +1 -2
  114. package/esm2015/platform/platform-module.js +6 -10
  115. package/esm2015/platform/platform.js +48 -52
  116. package/esm2015/portal/portal-directives.js +181 -201
  117. package/esm2015/scrolling/fixed-size-virtual-scroll.js +57 -47
  118. package/esm2015/scrolling/public-api.js +2 -1
  119. package/esm2015/scrolling/scroll-dispatcher.js +139 -143
  120. package/esm2015/scrolling/scrollable.js +135 -139
  121. package/esm2015/scrolling/scrolling-module.js +32 -40
  122. package/esm2015/scrolling/viewport-ruler.js +105 -109
  123. package/esm2015/scrolling/virtual-for-of.js +264 -268
  124. package/esm2015/scrolling/virtual-scroll-repeater.js +8 -0
  125. package/esm2015/scrolling/virtual-scroll-viewport.js +318 -322
  126. package/esm2015/stepper/step-header.js +20 -24
  127. package/esm2015/stepper/step-label.js +13 -17
  128. package/esm2015/stepper/stepper-button.js +59 -67
  129. package/esm2015/stepper/stepper-module.js +24 -28
  130. package/esm2015/stepper/stepper.js +313 -321
  131. package/esm2015/table/cell.js +129 -157
  132. package/esm2015/table/row.js +183 -219
  133. package/esm2015/table/table-module.js +9 -13
  134. package/esm2015/table/table.js +765 -785
  135. package/esm2015/table/text-column.js +85 -89
  136. package/esm2015/testing/component-harness.js +19 -1
  137. package/esm2015/testing/harness-environment.js +7 -1
  138. package/esm2015/text-field/autofill.js +89 -97
  139. package/esm2015/text-field/autosize.js +225 -229
  140. package/esm2015/text-field/text-field-module.js +10 -14
  141. package/esm2015/tree/control/nested-tree-control.js +7 -3
  142. package/esm2015/tree/nested-node.js +79 -83
  143. package/esm2015/tree/node.js +17 -21
  144. package/esm2015/tree/outlet.js +15 -19
  145. package/esm2015/tree/padding.js +88 -92
  146. package/esm2015/tree/toggle.js +32 -36
  147. package/esm2015/tree/tree-module.js +10 -14
  148. package/esm2015/tree/tree.js +266 -274
  149. package/esm2015/version.js +1 -1
  150. package/fesm2015/a11y.js +1021 -996
  151. package/fesm2015/a11y.js.map +1 -1
  152. package/fesm2015/accordion.js +173 -175
  153. package/fesm2015/accordion.js.map +1 -1
  154. package/fesm2015/bidi.js +74 -83
  155. package/fesm2015/bidi.js.map +1 -1
  156. package/fesm2015/cdk.js +1 -1
  157. package/fesm2015/cdk.js.map +1 -1
  158. package/fesm2015/clipboard.js +113 -122
  159. package/fesm2015/clipboard.js.map +1 -1
  160. package/fesm2015/collections.js +32 -35
  161. package/fesm2015/collections.js.map +1 -1
  162. package/fesm2015/drag-drop.js +1005 -961
  163. package/fesm2015/drag-drop.js.map +1 -1
  164. package/fesm2015/layout.js +111 -120
  165. package/fesm2015/layout.js.map +1 -1
  166. package/fesm2015/observers.js +146 -158
  167. package/fesm2015/observers.js.map +1 -1
  168. package/fesm2015/overlay.js +793 -659
  169. package/fesm2015/overlay.js.map +1 -1
  170. package/fesm2015/platform.js +52 -59
  171. package/fesm2015/platform.js.map +1 -1
  172. package/fesm2015/portal.js +180 -195
  173. package/fesm2015/portal.js.map +1 -1
  174. package/fesm2015/scrolling.js +1058 -1060
  175. package/fesm2015/scrolling.js.map +1 -1
  176. package/fesm2015/stepper.js +424 -445
  177. package/fesm2015/stepper.js.map +1 -1
  178. package/fesm2015/table.js +1178 -1247
  179. package/fesm2015/table.js.map +1 -1
  180. package/fesm2015/testing.js +25 -1
  181. package/fesm2015/testing.js.map +1 -1
  182. package/fesm2015/text-field.js +318 -330
  183. package/fesm2015/text-field.js.map +1 -1
  184. package/fesm2015/tree.js +517 -537
  185. package/fesm2015/tree.js.map +1 -1
  186. package/overlay/dispatchers/base-overlay-dispatcher.d.ts +28 -0
  187. package/overlay/dispatchers/index.d.ts +9 -0
  188. package/overlay/{keyboard → dispatchers}/overlay-keyboard-dispatcher.d.ts +4 -10
  189. package/overlay/dispatchers/overlay-outside-click-dispatcher.d.ts +27 -0
  190. package/overlay/index.d.ts +4 -3
  191. package/overlay/index.metadata.json +1 -1
  192. package/overlay/overlay-config.d.ts +4 -0
  193. package/overlay/overlay-directives.d.ts +4 -0
  194. package/overlay/overlay-ref.d.ts +8 -2
  195. package/overlay/overlay-reference.d.ts +1 -0
  196. package/overlay/overlay.d.ts +4 -2
  197. package/overlay/public-api.d.ts +1 -1
  198. package/package.json +3 -3
  199. package/schematics/index.js +1 -1
  200. package/schematics/migration.json +5 -0
  201. package/schematics/ng-add/index.js +1 -1
  202. package/schematics/ng-update/data/index.js +1 -1
  203. package/schematics/ng-update/devkit-file-system.d.ts +5 -5
  204. package/schematics/ng-update/devkit-file-system.js +21 -16
  205. package/schematics/ng-update/devkit-migration-rule.js +13 -20
  206. package/schematics/ng-update/devkit-migration.d.ts +0 -2
  207. package/schematics/ng-update/devkit-migration.js +1 -1
  208. package/schematics/ng-update/find-stylesheets.d.ts +10 -0
  209. package/schematics/ng-update/find-stylesheets.js +31 -0
  210. package/schematics/ng-update/index.d.ts +2 -0
  211. package/schematics/ng-update/index.js +7 -2
  212. package/schematics/ng-update/migrations/attribute-selectors.js +3 -3
  213. package/schematics/ng-update/migrations/css-selectors.js +3 -3
  214. package/schematics/ng-update/migrations/element-selectors.js +3 -3
  215. package/schematics/ng-update/public-api.js +1 -1
  216. package/schematics/update-tool/component-resource-collector.d.ts +1 -1
  217. package/schematics/update-tool/component-resource-collector.js +18 -14
  218. package/schematics/update-tool/file-system.d.ts +19 -14
  219. package/schematics/update-tool/file-system.js +1 -1
  220. package/schematics/update-tool/index.d.ts +21 -3
  221. package/schematics/update-tool/index.js +29 -23
  222. package/schematics/update-tool/public-api.js +1 -1
  223. package/schematics/update-tool/target-version.d.ts +2 -1
  224. package/schematics/update-tool/target-version.js +5 -3
  225. package/schematics/update-tool/utils/parse-tsconfig.d.ts +2 -1
  226. package/schematics/update-tool/utils/parse-tsconfig.js +6 -10
  227. package/schematics/update-tool/utils/virtual-host.d.ts +34 -0
  228. package/schematics/update-tool/utils/virtual-host.js +62 -0
  229. package/schematics/update-tool/version-changes.js +4 -6
  230. package/schematics/utils/index.js +1 -1
  231. package/schematics/utils/project-tsconfig-paths.d.ts +2 -1
  232. package/schematics/utils/project-tsconfig-paths.js +1 -1
  233. package/scrolling/index.metadata.json +1 -1
  234. package/scrolling/public-api.d.ts +1 -0
  235. package/scrolling/virtual-for-of.d.ts +2 -1
  236. package/scrolling/virtual-scroll-repeater.d.ts +16 -0
  237. package/scrolling/virtual-scroll-viewport.d.ts +4 -4
  238. package/testing/component-harness.d.ts +12 -0
  239. package/testing/harness-environment.d.ts +1 -0
  240. package/tree/control/nested-tree-control.d.ts +7 -2
  241. package/tree/index.metadata.json +1 -1
  242. 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
- let CdkPortal = /** @class */ (() => {
16
- class CdkPortal extends TemplatePortal {
17
- constructor(templateRef, viewContainerRef) {
18
- super(templateRef, viewContainerRef);
19
- }
15
+ export class CdkPortal extends TemplatePortal {
16
+ constructor(templateRef, viewContainerRef) {
17
+ super(templateRef, viewContainerRef);
20
18
  }
21
- CdkPortal.decorators = [
22
- { type: Directive, args: [{
23
- selector: '[cdkPortal]',
24
- exportAs: 'cdkPortal',
25
- },] }
26
- ];
27
- CdkPortal.ctorParameters = () => [
28
- { type: TemplateRef },
29
- { type: ViewContainerRef }
30
- ];
31
- return CdkPortal;
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
- let TemplatePortalDirective = /** @class */ (() => {
39
- class TemplatePortalDirective extends CdkPortal {
40
- }
41
- TemplatePortalDirective.decorators = [
42
- { type: Directive, args: [{
43
- selector: '[cdk-portal], [portal]',
44
- exportAs: 'cdkPortal',
45
- providers: [{
46
- provide: CdkPortal,
47
- useExisting: TemplatePortalDirective
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
- let CdkPortalOutlet = /** @class */ (() => {
62
- class CdkPortalOutlet extends BasePortalOutlet {
63
- constructor(_componentFactoryResolver, _viewContainerRef,
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
- * @deprecated `_document` parameter to be made required.
66
- * @breaking-change 9.0.0
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
- _document) {
69
- super();
70
- this._componentFactoryResolver = _componentFactoryResolver;
71
- this._viewContainerRef = _viewContainerRef;
72
- /** Whether the portal component is initialized. */
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
- if (portal) {
122
- super.attach(portal);
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
- this._attachedPortal = portal;
125
- }
126
- /** Component or view reference that is attached to the portal. */
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
- // If the portal specifies an origin, use that as the logical location of the component
147
- // in the application tree. Otherwise use the location of this PortalOutlet.
148
- const viewContainerRef = portal.viewContainerRef != null ?
149
- portal.viewContainerRef :
150
- this._viewContainerRef;
151
- const resolver = portal.componentFactoryResolver || this._componentFactoryResolver;
152
- const componentFactory = resolver.resolveComponentFactory(portal.component);
153
- const ref = viewContainerRef.createComponent(componentFactory, viewContainerRef.length, portal.injector || viewContainerRef.injector);
154
- // If we're using a view container that's different from the injected one (e.g. when the portal
155
- // specifies its own) we need to move the component into the outlet, otherwise it'll be rendered
156
- // inside of the alternate view container.
157
- if (viewContainerRef !== this._viewContainerRef) {
158
- this._getRootNode().appendChild(ref.hostView.rootNodes[0]);
159
- }
160
- super.setDisposeFn(() => ref.destroy());
161
- this._attachedPortal = portal;
162
- this._attachedRef = ref;
163
- this.attached.emit(ref);
164
- return ref;
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
- * Attach the given TemplatePortal to this PortalHost as an embedded View.
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
- /** Gets the root node of the portal outlet. */
181
- _getRootNode() {
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
- CdkPortalOutlet.decorators = [
190
- { type: Directive, args: [{
191
- selector: '[cdkPortalOutlet]',
192
- exportAs: 'cdkPortalOutlet',
193
- inputs: ['portal: cdkPortalOutlet']
194
- },] }
195
- ];
196
- CdkPortalOutlet.ctorParameters = () => [
197
- { type: ComponentFactoryResolver },
198
- { type: ViewContainerRef },
199
- { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
200
- ];
201
- CdkPortalOutlet.propDecorators = {
202
- attached: [{ type: Output }]
203
- };
204
- return CdkPortalOutlet;
205
- })();
206
- export { CdkPortalOutlet };
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
- let PortalHostDirective = /** @class */ (() => {
212
- class PortalHostDirective extends CdkPortalOutlet {
213
- }
214
- PortalHostDirective.decorators = [
215
- { type: Directive, args: [{
216
- selector: '[cdkPortalHost], [portalHost]',
217
- exportAs: 'cdkPortalHost',
218
- inputs: ['portal: cdkPortalHost'],
219
- providers: [{
220
- provide: CdkPortalOutlet,
221
- useExisting: PortalHostDirective
222
- }]
223
- },] }
224
- ];
225
- return PortalHostDirective;
226
- })();
227
- export { PortalHostDirective };
228
- let PortalModule = /** @class */ (() => {
229
- class PortalModule {
230
- }
231
- PortalModule.decorators = [
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"]}