@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
@@ -7,350 +7,344 @@
7
7
  */
8
8
  import { Directionality } from '@angular/cdk/bidi';
9
9
  import { DOCUMENT } from '@angular/common';
10
- import { ContentChild, ContentChildren, Directive, ElementRef, EventEmitter, Inject, InjectionToken, Input, NgZone, Optional, Output, QueryList, SkipSelf, ViewContainerRef, ChangeDetectorRef, isDevMode, } from '@angular/core';
10
+ import { ContentChild, ContentChildren, Directive, ElementRef, EventEmitter, Inject, Input, NgZone, Optional, Output, QueryList, SkipSelf, ViewContainerRef, ChangeDetectorRef, isDevMode, Self, } from '@angular/core';
11
11
  import { coerceBooleanProperty, coerceNumberProperty, coerceElement } from '@angular/cdk/coercion';
12
12
  import { Observable, Subject, merge } from 'rxjs';
13
13
  import { startWith, take, map, takeUntil, switchMap, tap } from 'rxjs/operators';
14
- import { CdkDragHandle } from './drag-handle';
15
- import { CdkDragPlaceholder } from './drag-placeholder';
16
- import { CdkDragPreview } from './drag-preview';
14
+ import { CDK_DRAG_HANDLE, CdkDragHandle } from './drag-handle';
15
+ import { CDK_DRAG_PLACEHOLDER, CdkDragPlaceholder } from './drag-placeholder';
16
+ import { CDK_DRAG_PREVIEW, CdkDragPreview } from './drag-preview';
17
17
  import { CDK_DRAG_PARENT } from '../drag-parent';
18
+ import { CDK_DROP_LIST } from './drop-list';
18
19
  import { DragDrop } from '../drag-drop';
19
20
  import { CDK_DRAG_CONFIG } from './config';
20
- /**
21
- * Injection token that is used to provide a CdkDropList instance to CdkDrag.
22
- * Used for avoiding circular imports.
23
- */
24
- export const CDK_DROP_LIST = new InjectionToken('CDK_DROP_LIST');
25
21
  /** Element that can be moved inside a CdkDropList container. */
26
- let CdkDrag = /** @class */ (() => {
27
- class CdkDrag {
28
- constructor(
29
- /** Element that the draggable is attached to. */
30
- element,
31
- /** Droppable container that the draggable is a part of. */
32
- dropContainer, _document, _ngZone, _viewContainerRef, config, _dir, dragDrop, _changeDetectorRef) {
33
- this.element = element;
34
- this.dropContainer = dropContainer;
35
- this._document = _document;
36
- this._ngZone = _ngZone;
37
- this._viewContainerRef = _viewContainerRef;
38
- this._dir = _dir;
39
- this._changeDetectorRef = _changeDetectorRef;
40
- this._destroyed = new Subject();
41
- /** Emits when the user starts dragging the item. */
42
- this.started = new EventEmitter();
43
- /** Emits when the user has released a drag item, before any animations have started. */
44
- this.released = new EventEmitter();
45
- /** Emits when the user stops dragging an item in the container. */
46
- this.ended = new EventEmitter();
47
- /** Emits when the user has moved the item into a new container. */
48
- this.entered = new EventEmitter();
49
- /** Emits when the user removes the item its container by dragging it into another container. */
50
- this.exited = new EventEmitter();
51
- /** Emits when the user drops the item inside a container. */
52
- this.dropped = new EventEmitter();
53
- /**
54
- * Emits as the user is dragging the item. Use with caution,
55
- * because this event will fire for every pixel that the user has dragged.
56
- */
57
- this.moved = new Observable((observer) => {
58
- const subscription = this._dragRef.moved.pipe(map(movedEvent => ({
59
- source: this,
60
- pointerPosition: movedEvent.pointerPosition,
61
- event: movedEvent.event,
62
- delta: movedEvent.delta,
63
- distance: movedEvent.distance
64
- }))).subscribe(observer);
65
- return () => {
66
- subscription.unsubscribe();
67
- };
68
- });
69
- this._dragRef = dragDrop.createDrag(element, {
70
- dragStartThreshold: config && config.dragStartThreshold != null ?
71
- config.dragStartThreshold : 5,
72
- pointerDirectionChangeThreshold: config && config.pointerDirectionChangeThreshold != null ?
73
- config.pointerDirectionChangeThreshold : 5,
74
- zIndex: config === null || config === void 0 ? void 0 : config.zIndex
75
- });
76
- this._dragRef.data = this;
77
- if (config) {
78
- this._assignDefaults(config);
79
- }
80
- // Note that usually the container is assigned when the drop list is picks up the item, but in
81
- // some cases (mainly transplanted views with OnPush, see #18341) we may end up in a situation
82
- // where there are no items on the first change detection pass, but the items get picked up as
83
- // soon as the user triggers another pass by dragging. This is a problem, because the item would
84
- // have to switch from standalone mode to drag mode in the middle of the dragging sequence which
85
- // is too late since the two modes save different kinds of information. We work around it by
86
- // assigning the drop container both from here and the list.
87
- if (dropContainer) {
88
- this._dragRef._withDropContainer(dropContainer._dropListRef);
89
- dropContainer.addItem(this);
90
- }
91
- this._syncInputs(this._dragRef);
92
- this._handleEvents(this._dragRef);
93
- }
94
- /** Whether starting to drag this element is disabled. */
95
- get disabled() {
96
- return this._disabled || (this.dropContainer && this.dropContainer.disabled);
97
- }
98
- set disabled(value) {
99
- this._disabled = coerceBooleanProperty(value);
100
- this._dragRef.disabled = this._disabled;
101
- }
22
+ export class CdkDrag {
23
+ constructor(
24
+ /** Element that the draggable is attached to. */
25
+ element,
26
+ /** Droppable container that the draggable is a part of. */
27
+ dropContainer, _document, _ngZone, _viewContainerRef, config, _dir, dragDrop, _changeDetectorRef, _selfHandle) {
28
+ this.element = element;
29
+ this.dropContainer = dropContainer;
30
+ this._document = _document;
31
+ this._ngZone = _ngZone;
32
+ this._viewContainerRef = _viewContainerRef;
33
+ this._dir = _dir;
34
+ this._changeDetectorRef = _changeDetectorRef;
35
+ this._selfHandle = _selfHandle;
36
+ this._destroyed = new Subject();
37
+ /** Emits when the user starts dragging the item. */
38
+ this.started = new EventEmitter();
39
+ /** Emits when the user has released a drag item, before any animations have started. */
40
+ this.released = new EventEmitter();
41
+ /** Emits when the user stops dragging an item in the container. */
42
+ this.ended = new EventEmitter();
43
+ /** Emits when the user has moved the item into a new container. */
44
+ this.entered = new EventEmitter();
45
+ /** Emits when the user removes the item its container by dragging it into another container. */
46
+ this.exited = new EventEmitter();
47
+ /** Emits when the user drops the item inside a container. */
48
+ this.dropped = new EventEmitter();
102
49
  /**
103
- * Returns the element that is being used as a placeholder
104
- * while the current element is being dragged.
105
- * @deprecated No longer being used to be removed.
106
- * @breaking-change 11.0.0
50
+ * Emits as the user is dragging the item. Use with caution,
51
+ * because this event will fire for every pixel that the user has dragged.
107
52
  */
108
- getPlaceholderElement() {
109
- return this._dragRef.getPlaceholderElement();
53
+ this.moved = new Observable((observer) => {
54
+ const subscription = this._dragRef.moved.pipe(map(movedEvent => ({
55
+ source: this,
56
+ pointerPosition: movedEvent.pointerPosition,
57
+ event: movedEvent.event,
58
+ delta: movedEvent.delta,
59
+ distance: movedEvent.distance
60
+ }))).subscribe(observer);
61
+ return () => {
62
+ subscription.unsubscribe();
63
+ };
64
+ });
65
+ this._dragRef = dragDrop.createDrag(element, {
66
+ dragStartThreshold: config && config.dragStartThreshold != null ?
67
+ config.dragStartThreshold : 5,
68
+ pointerDirectionChangeThreshold: config && config.pointerDirectionChangeThreshold != null ?
69
+ config.pointerDirectionChangeThreshold : 5,
70
+ zIndex: config === null || config === void 0 ? void 0 : config.zIndex
71
+ });
72
+ this._dragRef.data = this;
73
+ if (config) {
74
+ this._assignDefaults(config);
110
75
  }
111
- /**
112
- * Returns the root draggable element.
113
- * @deprecated No longer being used to be removed.
114
- * @breaking-change 11.0.0
115
- */
116
- getRootElement() {
117
- return this._dragRef.getRootElement();
76
+ // Note that usually the container is assigned when the drop list is picks up the item, but in
77
+ // some cases (mainly transplanted views with OnPush, see #18341) we may end up in a situation
78
+ // where there are no items on the first change detection pass, but the items get picked up as
79
+ // soon as the user triggers another pass by dragging. This is a problem, because the item would
80
+ // have to switch from standalone mode to drag mode in the middle of the dragging sequence which
81
+ // is too late since the two modes save different kinds of information. We work around it by
82
+ // assigning the drop container both from here and the list.
83
+ if (dropContainer) {
84
+ this._dragRef._withDropContainer(dropContainer._dropListRef);
85
+ dropContainer.addItem(this);
118
86
  }
119
- /** Resets a standalone drag item to its initial position. */
120
- reset() {
121
- this._dragRef.reset();
122
- }
123
- /**
124
- * Gets the pixel coordinates of the draggable outside of a drop container.
125
- */
126
- getFreeDragPosition() {
127
- return this._dragRef.getFreeDragPosition();
128
- }
129
- ngAfterViewInit() {
130
- // We need to wait for the zone to stabilize, in order for the reference
131
- // element to be in the proper place in the DOM. This is mostly relevant
132
- // for draggable elements inside portals since they get stamped out in
133
- // their original DOM position and then they get transferred to the portal.
134
- this._ngZone.onStable.asObservable()
135
- .pipe(take(1), takeUntil(this._destroyed))
136
- .subscribe(() => {
137
- this._updateRootElement();
138
- // Listen for any newly-added handles.
139
- this._handles.changes.pipe(startWith(this._handles),
140
- // Sync the new handles with the DragRef.
141
- tap((handles) => {
142
- const childHandleElements = handles
143
- .filter(handle => handle._parentDrag === this)
144
- .map(handle => handle.element);
145
- this._dragRef.withHandles(childHandleElements);
146
- }),
147
- // Listen if the state of any of the handles changes.
148
- switchMap((handles) => {
149
- return merge(...handles.map(item => {
150
- return item._stateChanges.pipe(startWith(item));
151
- }));
152
- }), takeUntil(this._destroyed)).subscribe(handleInstance => {
153
- // Enabled/disable the handle that changed in the DragRef.
154
- const dragRef = this._dragRef;
155
- const handle = handleInstance.element.nativeElement;
156
- handleInstance.disabled ? dragRef.disableHandle(handle) : dragRef.enableHandle(handle);
157
- });
158
- if (this.freeDragPosition) {
159
- this._dragRef.setFreeDragPosition(this.freeDragPosition);
87
+ this._syncInputs(this._dragRef);
88
+ this._handleEvents(this._dragRef);
89
+ }
90
+ /** Whether starting to drag this element is disabled. */
91
+ get disabled() {
92
+ return this._disabled || (this.dropContainer && this.dropContainer.disabled);
93
+ }
94
+ set disabled(value) {
95
+ this._disabled = coerceBooleanProperty(value);
96
+ this._dragRef.disabled = this._disabled;
97
+ }
98
+ /**
99
+ * Returns the element that is being used as a placeholder
100
+ * while the current element is being dragged.
101
+ */
102
+ getPlaceholderElement() {
103
+ return this._dragRef.getPlaceholderElement();
104
+ }
105
+ /** Returns the root draggable element. */
106
+ getRootElement() {
107
+ return this._dragRef.getRootElement();
108
+ }
109
+ /** Resets a standalone drag item to its initial position. */
110
+ reset() {
111
+ this._dragRef.reset();
112
+ }
113
+ /**
114
+ * Gets the pixel coordinates of the draggable outside of a drop container.
115
+ */
116
+ getFreeDragPosition() {
117
+ return this._dragRef.getFreeDragPosition();
118
+ }
119
+ ngAfterViewInit() {
120
+ // We need to wait for the zone to stabilize, in order for the reference
121
+ // element to be in the proper place in the DOM. This is mostly relevant
122
+ // for draggable elements inside portals since they get stamped out in
123
+ // their original DOM position and then they get transferred to the portal.
124
+ this._ngZone.onStable.asObservable()
125
+ .pipe(take(1), takeUntil(this._destroyed))
126
+ .subscribe(() => {
127
+ this._updateRootElement();
128
+ // Listen for any newly-added handles.
129
+ this._handles.changes.pipe(startWith(this._handles),
130
+ // Sync the new handles with the DragRef.
131
+ tap((handles) => {
132
+ const childHandleElements = handles
133
+ .filter(handle => handle._parentDrag === this)
134
+ .map(handle => handle.element);
135
+ // Usually handles are only allowed to be a descendant of the drag element, but if
136
+ // the consumer defined a different drag root, we should allow the drag element
137
+ // itself to be a handle too.
138
+ if (this._selfHandle && this.rootElementSelector) {
139
+ childHandleElements.push(this.element);
160
140
  }
141
+ this._dragRef.withHandles(childHandleElements);
142
+ }),
143
+ // Listen if the state of any of the handles changes.
144
+ switchMap((handles) => {
145
+ return merge(...handles.map(item => {
146
+ return item._stateChanges.pipe(startWith(item));
147
+ }));
148
+ }), takeUntil(this._destroyed)).subscribe(handleInstance => {
149
+ // Enabled/disable the handle that changed in the DragRef.
150
+ const dragRef = this._dragRef;
151
+ const handle = handleInstance.element.nativeElement;
152
+ handleInstance.disabled ? dragRef.disableHandle(handle) : dragRef.enableHandle(handle);
161
153
  });
162
- }
163
- ngOnChanges(changes) {
164
- const rootSelectorChange = changes['rootElementSelector'];
165
- const positionChange = changes['freeDragPosition'];
166
- // We don't have to react to the first change since it's being
167
- // handled in `ngAfterViewInit` where it needs to be deferred.
168
- if (rootSelectorChange && !rootSelectorChange.firstChange) {
169
- this._updateRootElement();
170
- }
171
- // Skip the first change since it's being handled in `ngAfterViewInit`.
172
- if (positionChange && !positionChange.firstChange && this.freeDragPosition) {
154
+ if (this.freeDragPosition) {
173
155
  this._dragRef.setFreeDragPosition(this.freeDragPosition);
174
156
  }
157
+ });
158
+ }
159
+ ngOnChanges(changes) {
160
+ const rootSelectorChange = changes['rootElementSelector'];
161
+ const positionChange = changes['freeDragPosition'];
162
+ // We don't have to react to the first change since it's being
163
+ // handled in `ngAfterViewInit` where it needs to be deferred.
164
+ if (rootSelectorChange && !rootSelectorChange.firstChange) {
165
+ this._updateRootElement();
175
166
  }
176
- ngOnDestroy() {
177
- if (this.dropContainer) {
178
- this.dropContainer.removeItem(this);
179
- }
180
- this._destroyed.next();
181
- this._destroyed.complete();
182
- this._dragRef.dispose();
167
+ // Skip the first change since it's being handled in `ngAfterViewInit`.
168
+ if (positionChange && !positionChange.firstChange && this.freeDragPosition) {
169
+ this._dragRef.setFreeDragPosition(this.freeDragPosition);
183
170
  }
184
- /** Syncs the root element with the `DragRef`. */
185
- _updateRootElement() {
186
- const element = this.element.nativeElement;
187
- const rootElement = this.rootElementSelector ?
188
- getClosestMatchingAncestor(element, this.rootElementSelector) : element;
189
- if (rootElement && rootElement.nodeType !== this._document.ELEMENT_NODE) {
190
- throw Error(`cdkDrag must be attached to an element node. ` +
191
- `Currently attached to "${rootElement.nodeName}".`);
192
- }
193
- this._dragRef.withRootElement(rootElement || element);
171
+ }
172
+ ngOnDestroy() {
173
+ if (this.dropContainer) {
174
+ this.dropContainer.removeItem(this);
194
175
  }
195
- /** Gets the boundary element, based on the `boundaryElement` value. */
196
- _getBoundaryElement() {
197
- const boundary = this.boundaryElement;
198
- if (!boundary) {
199
- return null;
200
- }
201
- if (typeof boundary === 'string') {
202
- return getClosestMatchingAncestor(this.element.nativeElement, boundary);
203
- }
204
- const element = coerceElement(boundary);
205
- if (isDevMode() && !element.contains(this.element.nativeElement)) {
206
- throw Error('Draggable element is not inside of the node passed into cdkDragBoundary.');
207
- }
208
- return element;
176
+ this._destroyed.next();
177
+ this._destroyed.complete();
178
+ this._dragRef.dispose();
179
+ }
180
+ /** Syncs the root element with the `DragRef`. */
181
+ _updateRootElement() {
182
+ const element = this.element.nativeElement;
183
+ const rootElement = this.rootElementSelector ?
184
+ getClosestMatchingAncestor(element, this.rootElementSelector) : element;
185
+ if (rootElement && rootElement.nodeType !== this._document.ELEMENT_NODE) {
186
+ throw Error(`cdkDrag must be attached to an element node. ` +
187
+ `Currently attached to "${rootElement.nodeName}".`);
209
188
  }
210
- /** Syncs the inputs of the CdkDrag with the options of the underlying DragRef. */
211
- _syncInputs(ref) {
212
- ref.beforeStarted.subscribe(() => {
213
- if (!ref.isDragging()) {
214
- const dir = this._dir;
215
- const dragStartDelay = this.dragStartDelay;
216
- const placeholder = this._placeholderTemplate ? {
217
- template: this._placeholderTemplate.templateRef,
218
- context: this._placeholderTemplate.data,
219
- viewContainer: this._viewContainerRef
220
- } : null;
221
- const preview = this._previewTemplate ? {
222
- template: this._previewTemplate.templateRef,
223
- context: this._previewTemplate.data,
224
- matchSize: this._previewTemplate.matchSize,
225
- viewContainer: this._viewContainerRef
226
- } : null;
227
- ref.disabled = this.disabled;
228
- ref.lockAxis = this.lockAxis;
229
- ref.dragStartDelay = (typeof dragStartDelay === 'object' && dragStartDelay) ?
230
- dragStartDelay : coerceNumberProperty(dragStartDelay);
231
- ref.constrainPosition = this.constrainPosition;
232
- ref.previewClass = this.previewClass;
233
- ref
234
- .withBoundaryElement(this._getBoundaryElement())
235
- .withPlaceholderTemplate(placeholder)
236
- .withPreviewTemplate(preview);
237
- if (dir) {
238
- ref.withDirection(dir.value);
239
- }
240
- }
241
- });
189
+ this._dragRef.withRootElement(rootElement || element);
190
+ }
191
+ /** Gets the boundary element, based on the `boundaryElement` value. */
192
+ _getBoundaryElement() {
193
+ const boundary = this.boundaryElement;
194
+ if (!boundary) {
195
+ return null;
242
196
  }
243
- /** Handles the events from the underlying `DragRef`. */
244
- _handleEvents(ref) {
245
- ref.started.subscribe(() => {
246
- this.started.emit({ source: this });
247
- // Since all of these events run outside of change detection,
248
- // we need to ensure that everything is marked correctly.
249
- this._changeDetectorRef.markForCheck();
250
- });
251
- ref.released.subscribe(() => {
252
- this.released.emit({ source: this });
253
- });
254
- ref.ended.subscribe(event => {
255
- this.ended.emit({ source: this, distance: event.distance });
256
- // Since all of these events run outside of change detection,
257
- // we need to ensure that everything is marked correctly.
258
- this._changeDetectorRef.markForCheck();
259
- });
260
- ref.entered.subscribe(event => {
261
- this.entered.emit({
262
- container: event.container.data,
263
- item: this,
264
- currentIndex: event.currentIndex
265
- });
197
+ if (typeof boundary === 'string') {
198
+ return getClosestMatchingAncestor(this.element.nativeElement, boundary);
199
+ }
200
+ const element = coerceElement(boundary);
201
+ if (isDevMode() && !element.contains(this.element.nativeElement)) {
202
+ throw Error('Draggable element is not inside of the node passed into cdkDragBoundary.');
203
+ }
204
+ return element;
205
+ }
206
+ /** Syncs the inputs of the CdkDrag with the options of the underlying DragRef. */
207
+ _syncInputs(ref) {
208
+ ref.beforeStarted.subscribe(() => {
209
+ if (!ref.isDragging()) {
210
+ const dir = this._dir;
211
+ const dragStartDelay = this.dragStartDelay;
212
+ const placeholder = this._placeholderTemplate ? {
213
+ template: this._placeholderTemplate.templateRef,
214
+ context: this._placeholderTemplate.data,
215
+ viewContainer: this._viewContainerRef
216
+ } : null;
217
+ const preview = this._previewTemplate ? {
218
+ template: this._previewTemplate.templateRef,
219
+ context: this._previewTemplate.data,
220
+ matchSize: this._previewTemplate.matchSize,
221
+ viewContainer: this._viewContainerRef
222
+ } : null;
223
+ ref.disabled = this.disabled;
224
+ ref.lockAxis = this.lockAxis;
225
+ ref.dragStartDelay = (typeof dragStartDelay === 'object' && dragStartDelay) ?
226
+ dragStartDelay : coerceNumberProperty(dragStartDelay);
227
+ ref.constrainPosition = this.constrainPosition;
228
+ ref.previewClass = this.previewClass;
229
+ ref
230
+ .withBoundaryElement(this._getBoundaryElement())
231
+ .withPlaceholderTemplate(placeholder)
232
+ .withPreviewTemplate(preview);
233
+ if (dir) {
234
+ ref.withDirection(dir.value);
235
+ }
236
+ }
237
+ });
238
+ }
239
+ /** Handles the events from the underlying `DragRef`. */
240
+ _handleEvents(ref) {
241
+ ref.started.subscribe(() => {
242
+ this.started.emit({ source: this });
243
+ // Since all of these events run outside of change detection,
244
+ // we need to ensure that everything is marked correctly.
245
+ this._changeDetectorRef.markForCheck();
246
+ });
247
+ ref.released.subscribe(() => {
248
+ this.released.emit({ source: this });
249
+ });
250
+ ref.ended.subscribe(event => {
251
+ this.ended.emit({ source: this, distance: event.distance });
252
+ // Since all of these events run outside of change detection,
253
+ // we need to ensure that everything is marked correctly.
254
+ this._changeDetectorRef.markForCheck();
255
+ });
256
+ ref.entered.subscribe(event => {
257
+ this.entered.emit({
258
+ container: event.container.data,
259
+ item: this,
260
+ currentIndex: event.currentIndex
266
261
  });
267
- ref.exited.subscribe(event => {
268
- this.exited.emit({
269
- container: event.container.data,
270
- item: this
271
- });
262
+ });
263
+ ref.exited.subscribe(event => {
264
+ this.exited.emit({
265
+ container: event.container.data,
266
+ item: this
272
267
  });
273
- ref.dropped.subscribe(event => {
274
- this.dropped.emit({
275
- previousIndex: event.previousIndex,
276
- currentIndex: event.currentIndex,
277
- previousContainer: event.previousContainer.data,
278
- container: event.container.data,
279
- isPointerOverContainer: event.isPointerOverContainer,
280
- item: this,
281
- distance: event.distance
282
- });
268
+ });
269
+ ref.dropped.subscribe(event => {
270
+ this.dropped.emit({
271
+ previousIndex: event.previousIndex,
272
+ currentIndex: event.currentIndex,
273
+ previousContainer: event.previousContainer.data,
274
+ container: event.container.data,
275
+ isPointerOverContainer: event.isPointerOverContainer,
276
+ item: this,
277
+ distance: event.distance
283
278
  });
279
+ });
280
+ }
281
+ /** Assigns the default input values based on a provided config object. */
282
+ _assignDefaults(config) {
283
+ const { lockAxis, dragStartDelay, constrainPosition, previewClass, boundaryElement, draggingDisabled, rootElementSelector } = config;
284
+ this.disabled = draggingDisabled == null ? false : draggingDisabled;
285
+ this.dragStartDelay = dragStartDelay || 0;
286
+ if (lockAxis) {
287
+ this.lockAxis = lockAxis;
284
288
  }
285
- /** Assigns the default input values based on a provided config object. */
286
- _assignDefaults(config) {
287
- const { lockAxis, dragStartDelay, constrainPosition, previewClass, boundaryElement, draggingDisabled, rootElementSelector } = config;
288
- this.disabled = draggingDisabled == null ? false : draggingDisabled;
289
- this.dragStartDelay = dragStartDelay || 0;
290
- if (lockAxis) {
291
- this.lockAxis = lockAxis;
292
- }
293
- if (constrainPosition) {
294
- this.constrainPosition = constrainPosition;
295
- }
296
- if (previewClass) {
297
- this.previewClass = previewClass;
298
- }
299
- if (boundaryElement) {
300
- this.boundaryElement = boundaryElement;
301
- }
302
- if (rootElementSelector) {
303
- this.rootElementSelector = rootElementSelector;
304
- }
289
+ if (constrainPosition) {
290
+ this.constrainPosition = constrainPosition;
291
+ }
292
+ if (previewClass) {
293
+ this.previewClass = previewClass;
294
+ }
295
+ if (boundaryElement) {
296
+ this.boundaryElement = boundaryElement;
297
+ }
298
+ if (rootElementSelector) {
299
+ this.rootElementSelector = rootElementSelector;
305
300
  }
306
301
  }
307
- CdkDrag.decorators = [
308
- { type: Directive, args: [{
309
- selector: '[cdkDrag]',
310
- exportAs: 'cdkDrag',
311
- host: {
312
- 'class': 'cdk-drag',
313
- '[class.cdk-drag-disabled]': 'disabled',
314
- '[class.cdk-drag-dragging]': '_dragRef.isDragging()',
315
- },
316
- providers: [{ provide: CDK_DRAG_PARENT, useExisting: CdkDrag }]
317
- },] }
318
- ];
319
- CdkDrag.ctorParameters = () => [
320
- { type: ElementRef },
321
- { type: undefined, decorators: [{ type: Inject, args: [CDK_DROP_LIST,] }, { type: Optional }, { type: SkipSelf }] },
322
- { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
323
- { type: NgZone },
324
- { type: ViewContainerRef },
325
- { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CDK_DRAG_CONFIG,] }] },
326
- { type: Directionality, decorators: [{ type: Optional }] },
327
- { type: DragDrop },
328
- { type: ChangeDetectorRef }
329
- ];
330
- CdkDrag.propDecorators = {
331
- _handles: [{ type: ContentChildren, args: [CdkDragHandle, { descendants: true },] }],
332
- _previewTemplate: [{ type: ContentChild, args: [CdkDragPreview,] }],
333
- _placeholderTemplate: [{ type: ContentChild, args: [CdkDragPlaceholder,] }],
334
- data: [{ type: Input, args: ['cdkDragData',] }],
335
- lockAxis: [{ type: Input, args: ['cdkDragLockAxis',] }],
336
- rootElementSelector: [{ type: Input, args: ['cdkDragRootElement',] }],
337
- boundaryElement: [{ type: Input, args: ['cdkDragBoundary',] }],
338
- dragStartDelay: [{ type: Input, args: ['cdkDragStartDelay',] }],
339
- freeDragPosition: [{ type: Input, args: ['cdkDragFreeDragPosition',] }],
340
- disabled: [{ type: Input, args: ['cdkDragDisabled',] }],
341
- constrainPosition: [{ type: Input, args: ['cdkDragConstrainPosition',] }],
342
- previewClass: [{ type: Input, args: ['cdkDragPreviewClass',] }],
343
- started: [{ type: Output, args: ['cdkDragStarted',] }],
344
- released: [{ type: Output, args: ['cdkDragReleased',] }],
345
- ended: [{ type: Output, args: ['cdkDragEnded',] }],
346
- entered: [{ type: Output, args: ['cdkDragEntered',] }],
347
- exited: [{ type: Output, args: ['cdkDragExited',] }],
348
- dropped: [{ type: Output, args: ['cdkDragDropped',] }],
349
- moved: [{ type: Output, args: ['cdkDragMoved',] }]
350
- };
351
- return CdkDrag;
352
- })();
353
- export { CdkDrag };
302
+ }
303
+ CdkDrag.decorators = [
304
+ { type: Directive, args: [{
305
+ selector: '[cdkDrag]',
306
+ exportAs: 'cdkDrag',
307
+ host: {
308
+ 'class': 'cdk-drag',
309
+ '[class.cdk-drag-disabled]': 'disabled',
310
+ '[class.cdk-drag-dragging]': '_dragRef.isDragging()',
311
+ },
312
+ providers: [{ provide: CDK_DRAG_PARENT, useExisting: CdkDrag }]
313
+ },] }
314
+ ];
315
+ CdkDrag.ctorParameters = () => [
316
+ { type: ElementRef },
317
+ { type: undefined, decorators: [{ type: Inject, args: [CDK_DROP_LIST,] }, { type: Optional }, { type: SkipSelf }] },
318
+ { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
319
+ { type: NgZone },
320
+ { type: ViewContainerRef },
321
+ { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CDK_DRAG_CONFIG,] }] },
322
+ { type: Directionality, decorators: [{ type: Optional }] },
323
+ { type: DragDrop },
324
+ { type: ChangeDetectorRef },
325
+ { type: CdkDragHandle, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [CDK_DRAG_HANDLE,] }] }
326
+ ];
327
+ CdkDrag.propDecorators = {
328
+ _handles: [{ type: ContentChildren, args: [CDK_DRAG_HANDLE, { descendants: true },] }],
329
+ _previewTemplate: [{ type: ContentChild, args: [CDK_DRAG_PREVIEW,] }],
330
+ _placeholderTemplate: [{ type: ContentChild, args: [CDK_DRAG_PLACEHOLDER,] }],
331
+ data: [{ type: Input, args: ['cdkDragData',] }],
332
+ lockAxis: [{ type: Input, args: ['cdkDragLockAxis',] }],
333
+ rootElementSelector: [{ type: Input, args: ['cdkDragRootElement',] }],
334
+ boundaryElement: [{ type: Input, args: ['cdkDragBoundary',] }],
335
+ dragStartDelay: [{ type: Input, args: ['cdkDragStartDelay',] }],
336
+ freeDragPosition: [{ type: Input, args: ['cdkDragFreeDragPosition',] }],
337
+ disabled: [{ type: Input, args: ['cdkDragDisabled',] }],
338
+ constrainPosition: [{ type: Input, args: ['cdkDragConstrainPosition',] }],
339
+ previewClass: [{ type: Input, args: ['cdkDragPreviewClass',] }],
340
+ started: [{ type: Output, args: ['cdkDragStarted',] }],
341
+ released: [{ type: Output, args: ['cdkDragReleased',] }],
342
+ ended: [{ type: Output, args: ['cdkDragEnded',] }],
343
+ entered: [{ type: Output, args: ['cdkDragEntered',] }],
344
+ exited: [{ type: Output, args: ['cdkDragExited',] }],
345
+ dropped: [{ type: Output, args: ['cdkDragDropped',] }],
346
+ moved: [{ type: Output, args: ['cdkDragMoved',] }]
347
+ };
354
348
  /** Gets the closest ancestor of an element that matches a selector. */
355
349
  function getClosestMatchingAncestor(element, selector) {
356
350
  let currentElement = element.parentElement;
@@ -364,4 +358,4 @@ function getClosestMatchingAncestor(element, selector) {
364
358
  }
365
359
  return null;
366
360
  }
367
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag.js","sourceRoot":"","sources":["../../../../../../../src/cdk/drag-drop/directives/drag.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 {Directionality} from '@angular/cdk/bidi';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  AfterViewInit,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  SkipSelf,\n  ViewContainerRef,\n  OnChanges,\n  SimpleChanges,\n  ChangeDetectorRef,\n  isDevMode,\n} from '@angular/core';\nimport {\n  coerceBooleanProperty,\n  coerceNumberProperty,\n  coerceElement,\n  BooleanInput\n} from '@angular/cdk/coercion';\nimport {Observable, Observer, Subject, merge} from 'rxjs';\nimport {startWith, take, map, takeUntil, switchMap, tap} from 'rxjs/operators';\nimport {\n  CdkDragDrop,\n  CdkDragEnd,\n  CdkDragEnter,\n  CdkDragExit,\n  CdkDragMove,\n  CdkDragStart,\n  CdkDragRelease,\n} from '../drag-events';\nimport {CdkDragHandle} from './drag-handle';\nimport {CdkDragPlaceholder} from './drag-placeholder';\nimport {CdkDragPreview} from './drag-preview';\nimport {CDK_DRAG_PARENT} from '../drag-parent';\nimport {DragRef, Point} from '../drag-ref';\nimport {CdkDropListInternal as CdkDropList} from './drop-list';\nimport {DragDrop} from '../drag-drop';\nimport {CDK_DRAG_CONFIG, DragDropConfig, DragStartDelay, DragAxis} from './config';\n\n/**\n * Injection token that is used to provide a CdkDropList instance to CdkDrag.\n * Used for avoiding circular imports.\n */\nexport const CDK_DROP_LIST = new InjectionToken<CdkDropList>('CDK_DROP_LIST');\n\n/** Element that can be moved inside a CdkDropList container. */\n@Directive({\n  selector: '[cdkDrag]',\n  exportAs: 'cdkDrag',\n  host: {\n    'class': 'cdk-drag',\n    '[class.cdk-drag-disabled]': 'disabled',\n    '[class.cdk-drag-dragging]': '_dragRef.isDragging()',\n  },\n  providers: [{provide: CDK_DRAG_PARENT, useExisting: CdkDrag}]\n})\nexport class CdkDrag<T = any> implements AfterViewInit, OnChanges, OnDestroy {\n  private _destroyed = new Subject<void>();\n\n  /** Reference to the underlying drag instance. */\n  _dragRef: DragRef<CdkDrag<T>>;\n\n  /** Elements that can be used to drag the draggable item. */\n  @ContentChildren(CdkDragHandle, {descendants: true}) _handles: QueryList<CdkDragHandle>;\n\n  /** Element that will be used as a template to create the draggable item's preview. */\n  @ContentChild(CdkDragPreview) _previewTemplate: CdkDragPreview;\n\n  /** Template for placeholder element rendered to show where a draggable would be dropped. */\n  @ContentChild(CdkDragPlaceholder) _placeholderTemplate: CdkDragPlaceholder;\n\n  /** Arbitrary data to attach to this drag instance. */\n  @Input('cdkDragData') data: T;\n\n  /** Locks the position of the dragged element along the specified axis. */\n  @Input('cdkDragLockAxis') lockAxis: DragAxis;\n\n  /**\n   * Selector that will be used to determine the root draggable element, starting from\n   * the `cdkDrag` element and going up the DOM. Passing an alternate root element is useful\n   * when trying to enable dragging on an element that you might not have access to.\n   */\n  @Input('cdkDragRootElement') rootElementSelector: string;\n\n  /**\n   * Node or selector that will be used to determine the element to which the draggable's\n   * position will be constrained. If a string is passed in, it'll be used as a selector that\n   * will be matched starting from the element's parent and going up the DOM until a match\n   * has been found.\n   */\n  @Input('cdkDragBoundary') boundaryElement: string | ElementRef<HTMLElement> | HTMLElement;\n\n  /**\n   * Amount of milliseconds to wait after the user has put their\n   * pointer down before starting to drag the element.\n   */\n  @Input('cdkDragStartDelay') dragStartDelay: DragStartDelay;\n\n  /**\n   * Sets the position of a `CdkDrag` that is outside of a drop container.\n   * Can be used to restore the element's position for a returning user.\n   */\n  @Input('cdkDragFreeDragPosition') freeDragPosition: {x: number, y: number};\n\n  /** Whether starting to drag this element is disabled. */\n  @Input('cdkDragDisabled')\n  get disabled(): boolean {\n    return this._disabled || (this.dropContainer && this.dropContainer.disabled);\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n    this._dragRef.disabled = this._disabled;\n  }\n  private _disabled: boolean;\n\n  /**\n   * Function that can be used to customize the logic of how the position of the drag item\n   * is limited while it's being dragged. Gets called with a point containing the current position\n   * of the user's pointer on the page and should return a point describing where the item should\n   * be rendered.\n   */\n  @Input('cdkDragConstrainPosition') constrainPosition?: (point: Point, dragRef: DragRef) => Point;\n\n  /** Class to be added to the preview element. */\n  @Input('cdkDragPreviewClass') previewClass: string | string[];\n\n  /** Emits when the user starts dragging the item. */\n  @Output('cdkDragStarted') started: EventEmitter<CdkDragStart> = new EventEmitter<CdkDragStart>();\n\n  /** Emits when the user has released a drag item, before any animations have started. */\n  @Output('cdkDragReleased') released: EventEmitter<CdkDragRelease> =\n      new EventEmitter<CdkDragRelease>();\n\n  /** Emits when the user stops dragging an item in the container. */\n  @Output('cdkDragEnded') ended: EventEmitter<CdkDragEnd> = new EventEmitter<CdkDragEnd>();\n\n  /** Emits when the user has moved the item into a new container. */\n  @Output('cdkDragEntered') entered: EventEmitter<CdkDragEnter<any>> =\n      new EventEmitter<CdkDragEnter<any>>();\n\n  /** Emits when the user removes the item its container by dragging it into another container. */\n  @Output('cdkDragExited') exited: EventEmitter<CdkDragExit<any>> =\n      new EventEmitter<CdkDragExit<any>>();\n\n  /** Emits when the user drops the item inside a container. */\n  @Output('cdkDragDropped') dropped: EventEmitter<CdkDragDrop<any>> =\n      new EventEmitter<CdkDragDrop<any>>();\n\n  /**\n   * Emits as the user is dragging the item. Use with caution,\n   * because this event will fire for every pixel that the user has dragged.\n   */\n  @Output('cdkDragMoved') moved: Observable<CdkDragMove<T>> =\n      new Observable((observer: Observer<CdkDragMove<T>>) => {\n        const subscription = this._dragRef.moved.pipe(map(movedEvent => ({\n          source: this,\n          pointerPosition: movedEvent.pointerPosition,\n          event: movedEvent.event,\n          delta: movedEvent.delta,\n          distance: movedEvent.distance\n        }))).subscribe(observer);\n\n        return () => {\n          subscription.unsubscribe();\n        };\n      });\n\n  constructor(\n      /** Element that the draggable is attached to. */\n      public element: ElementRef<HTMLElement>,\n      /** Droppable container that the draggable is a part of. */\n      @Inject(CDK_DROP_LIST) @Optional() @SkipSelf() public dropContainer: CdkDropList,\n      @Inject(DOCUMENT) private _document: any, private _ngZone: NgZone,\n      private _viewContainerRef: ViewContainerRef,\n      @Optional() @Inject(CDK_DRAG_CONFIG) config: DragDropConfig,\n      @Optional() private _dir: Directionality, dragDrop: DragDrop,\n      private _changeDetectorRef: ChangeDetectorRef) {\n    this._dragRef = dragDrop.createDrag(element, {\n      dragStartThreshold: config && config.dragStartThreshold != null ?\n          config.dragStartThreshold : 5,\n      pointerDirectionChangeThreshold: config && config.pointerDirectionChangeThreshold != null ?\n          config.pointerDirectionChangeThreshold : 5,\n      zIndex: config?.zIndex\n    });\n    this._dragRef.data = this;\n\n    if (config) {\n      this._assignDefaults(config);\n    }\n\n    // Note that usually the container is assigned when the drop list is picks up the item, but in\n    // some cases (mainly transplanted views with OnPush, see #18341) we may end up in a situation\n    // where there are no items on the first change detection pass, but the items get picked up as\n    // soon as the user triggers another pass by dragging. This is a problem, because the item would\n    // have to switch from standalone mode to drag mode in the middle of the dragging sequence which\n    // is too late since the two modes save different kinds of information. We work around it by\n    // assigning the drop container both from here and the list.\n    if (dropContainer) {\n      this._dragRef._withDropContainer(dropContainer._dropListRef);\n      dropContainer.addItem(this);\n    }\n\n    this._syncInputs(this._dragRef);\n    this._handleEvents(this._dragRef);\n  }\n\n  /**\n   * Returns the element that is being used as a placeholder\n   * while the current element is being dragged.\n   * @deprecated No longer being used to be removed.\n   * @breaking-change 11.0.0\n   */\n  getPlaceholderElement(): HTMLElement {\n    return this._dragRef.getPlaceholderElement();\n  }\n\n  /**\n   * Returns the root draggable element.\n   * @deprecated No longer being used to be removed.\n   * @breaking-change 11.0.0\n   */\n  getRootElement(): HTMLElement {\n    return this._dragRef.getRootElement();\n  }\n\n  /** Resets a standalone drag item to its initial position. */\n  reset(): void {\n    this._dragRef.reset();\n  }\n\n  /**\n   * Gets the pixel coordinates of the draggable outside of a drop container.\n   */\n  getFreeDragPosition(): {readonly x: number, readonly y: number} {\n    return this._dragRef.getFreeDragPosition();\n  }\n\n  ngAfterViewInit() {\n    // We need to wait for the zone to stabilize, in order for the reference\n    // element to be in the proper place in the DOM. This is mostly relevant\n    // for draggable elements inside portals since they get stamped out in\n    // their original DOM position and then they get transferred to the portal.\n    this._ngZone.onStable.asObservable()\n      .pipe(take(1), takeUntil(this._destroyed))\n      .subscribe(() => {\n        this._updateRootElement();\n\n        // Listen for any newly-added handles.\n        this._handles.changes.pipe(\n          startWith(this._handles),\n          // Sync the new handles with the DragRef.\n          tap((handles: QueryList<CdkDragHandle>) => {\n            const childHandleElements = handles\n              .filter(handle => handle._parentDrag === this)\n              .map(handle => handle.element);\n            this._dragRef.withHandles(childHandleElements);\n          }),\n          // Listen if the state of any of the handles changes.\n          switchMap((handles: QueryList<CdkDragHandle>) => {\n            return merge(...handles.map(item => {\n              return item._stateChanges.pipe(startWith(item));\n            })) as Observable<CdkDragHandle>;\n          }),\n          takeUntil(this._destroyed)\n        ).subscribe(handleInstance => {\n          // Enabled/disable the handle that changed in the DragRef.\n          const dragRef = this._dragRef;\n          const handle = handleInstance.element.nativeElement;\n          handleInstance.disabled ? dragRef.disableHandle(handle) : dragRef.enableHandle(handle);\n        });\n\n        if (this.freeDragPosition) {\n          this._dragRef.setFreeDragPosition(this.freeDragPosition);\n        }\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const rootSelectorChange = changes['rootElementSelector'];\n    const positionChange = changes['freeDragPosition'];\n\n    // We don't have to react to the first change since it's being\n    // handled in `ngAfterViewInit` where it needs to be deferred.\n    if (rootSelectorChange && !rootSelectorChange.firstChange) {\n      this._updateRootElement();\n    }\n\n    // Skip the first change since it's being handled in `ngAfterViewInit`.\n    if (positionChange && !positionChange.firstChange && this.freeDragPosition) {\n      this._dragRef.setFreeDragPosition(this.freeDragPosition);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.dropContainer) {\n      this.dropContainer.removeItem(this);\n    }\n\n    this._destroyed.next();\n    this._destroyed.complete();\n    this._dragRef.dispose();\n  }\n\n  /** Syncs the root element with the `DragRef`. */\n  private _updateRootElement() {\n    const element = this.element.nativeElement;\n    const rootElement = this.rootElementSelector ?\n        getClosestMatchingAncestor(element, this.rootElementSelector) : element;\n\n    if (rootElement && rootElement.nodeType !== this._document.ELEMENT_NODE) {\n      throw Error(`cdkDrag must be attached to an element node. ` +\n                  `Currently attached to \"${rootElement.nodeName}\".`);\n    }\n\n    this._dragRef.withRootElement(rootElement || element);\n  }\n\n  /** Gets the boundary element, based on the `boundaryElement` value. */\n  private _getBoundaryElement() {\n    const boundary = this.boundaryElement;\n\n    if (!boundary) {\n      return null;\n    }\n\n    if (typeof boundary === 'string') {\n      return getClosestMatchingAncestor(this.element.nativeElement, boundary);\n    }\n\n    const element = coerceElement(boundary);\n\n    if (isDevMode() && !element.contains(this.element.nativeElement)) {\n      throw Error('Draggable element is not inside of the node passed into cdkDragBoundary.');\n    }\n\n    return element;\n  }\n\n  /** Syncs the inputs of the CdkDrag with the options of the underlying DragRef. */\n  private _syncInputs(ref: DragRef<CdkDrag<T>>) {\n    ref.beforeStarted.subscribe(() => {\n      if (!ref.isDragging()) {\n        const dir = this._dir;\n        const dragStartDelay = this.dragStartDelay;\n        const placeholder = this._placeholderTemplate ? {\n          template: this._placeholderTemplate.templateRef,\n          context: this._placeholderTemplate.data,\n          viewContainer: this._viewContainerRef\n        } : null;\n        const preview = this._previewTemplate ? {\n          template: this._previewTemplate.templateRef,\n          context: this._previewTemplate.data,\n          matchSize: this._previewTemplate.matchSize,\n          viewContainer: this._viewContainerRef\n        } : null;\n\n        ref.disabled = this.disabled;\n        ref.lockAxis = this.lockAxis;\n        ref.dragStartDelay = (typeof dragStartDelay === 'object' && dragStartDelay) ?\n            dragStartDelay : coerceNumberProperty(dragStartDelay);\n        ref.constrainPosition = this.constrainPosition;\n        ref.previewClass = this.previewClass;\n        ref\n          .withBoundaryElement(this._getBoundaryElement())\n          .withPlaceholderTemplate(placeholder)\n          .withPreviewTemplate(preview);\n\n        if (dir) {\n          ref.withDirection(dir.value);\n        }\n      }\n    });\n  }\n\n  /** Handles the events from the underlying `DragRef`. */\n  private _handleEvents(ref: DragRef<CdkDrag<T>>) {\n    ref.started.subscribe(() => {\n      this.started.emit({source: this});\n\n      // Since all of these events run outside of change detection,\n      // we need to ensure that everything is marked correctly.\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.released.subscribe(() => {\n      this.released.emit({source: this});\n    });\n\n    ref.ended.subscribe(event => {\n      this.ended.emit({source: this, distance: event.distance});\n\n      // Since all of these events run outside of change detection,\n      // we need to ensure that everything is marked correctly.\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.entered.subscribe(event => {\n      this.entered.emit({\n        container: event.container.data,\n        item: this,\n        currentIndex: event.currentIndex\n      });\n    });\n\n    ref.exited.subscribe(event => {\n      this.exited.emit({\n        container: event.container.data,\n        item: this\n      });\n    });\n\n    ref.dropped.subscribe(event => {\n      this.dropped.emit({\n        previousIndex: event.previousIndex,\n        currentIndex: event.currentIndex,\n        previousContainer: event.previousContainer.data,\n        container: event.container.data,\n        isPointerOverContainer: event.isPointerOverContainer,\n        item: this,\n        distance: event.distance\n      });\n    });\n  }\n\n  /** Assigns the default input values based on a provided config object. */\n  private _assignDefaults(config: DragDropConfig) {\n    const {\n      lockAxis, dragStartDelay, constrainPosition, previewClass,\n      boundaryElement, draggingDisabled, rootElementSelector\n    } = config;\n\n    this.disabled = draggingDisabled == null ? false : draggingDisabled;\n    this.dragStartDelay = dragStartDelay || 0;\n\n    if (lockAxis) {\n      this.lockAxis = lockAxis;\n    }\n\n    if (constrainPosition) {\n      this.constrainPosition = constrainPosition;\n    }\n\n    if (previewClass) {\n      this.previewClass = previewClass;\n    }\n\n    if (boundaryElement) {\n      this.boundaryElement = boundaryElement;\n    }\n\n    if (rootElementSelector) {\n      this.rootElementSelector = rootElementSelector;\n    }\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n\n/** Gets the closest ancestor of an element that matches a selector. */\nfunction getClosestMatchingAncestor(element: HTMLElement, selector: string) {\n  let currentElement = element.parentElement as HTMLElement | null;\n\n  while (currentElement) {\n    // IE doesn't support `matches` so we have to fall back to `msMatchesSelector`.\n    if (currentElement.matches ? currentElement.matches(selector) :\n        (currentElement as any).msMatchesSelector(selector)) {\n      return currentElement;\n    }\n\n    currentElement = currentElement.parentElement;\n  }\n\n  return null;\n}\n\n"]}
361
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag.js","sourceRoot":"","sources":["../../../../../../../src/cdk/drag-drop/directives/drag.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,cAAc,EAAC,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAEL,YAAY,EACZ,eAAe,EACf,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,EAEN,QAAQ,EACR,MAAM,EACN,SAAS,EACT,QAAQ,EACR,gBAAgB,EAGhB,iBAAiB,EACjB,SAAS,EACT,IAAI,GACL,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,aAAa,EAEd,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAC,UAAU,EAAY,OAAO,EAAE,KAAK,EAAC,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAC,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAU/E,OAAO,EAAC,eAAe,EAAE,aAAa,EAAC,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAC,oBAAoB,EAAE,kBAAkB,EAAC,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAC,gBAAgB,EAAE,cAAc,EAAC,MAAM,gBAAgB,CAAC;AAChE,OAAO,EAAC,eAAe,EAAC,MAAM,gBAAgB,CAAC;AAE/C,OAAO,EAAC,aAAa,EAAqC,MAAM,aAAa,CAAC;AAC9E,OAAO,EAAC,QAAQ,EAAC,MAAM,cAAc,CAAC;AACtC,OAAO,EAAC,eAAe,EAA2C,MAAM,UAAU,CAAC;AAEnF,gEAAgE;AAWhE,MAAM,OAAO,OAAO;IAkHlB;IACI,iDAAiD;IAC1C,OAAgC;IACvC,2DAA2D;IACL,aAA0B,EACtD,SAAc,EAAU,OAAe,EACzD,iBAAmC,EACN,MAAsB,EACvC,IAAoB,EAAE,QAAkB,EACpD,kBAAqC,EACQ,WAA2B;QARzE,YAAO,GAAP,OAAO,CAAyB;QAEe,kBAAa,GAAb,aAAa,CAAa;QACtD,cAAS,GAAT,SAAS,CAAK;QAAU,YAAO,GAAP,OAAO,CAAQ;QACzD,sBAAiB,GAAjB,iBAAiB,CAAkB;QAEvB,SAAI,GAAJ,IAAI,CAAgB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAmB;QACQ,gBAAW,GAAX,WAAW,CAAgB;QA3H5E,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAwEzC,oDAAoD;QAC1B,YAAO,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAEjG,wFAAwF;QAC7D,aAAQ,GAC/B,IAAI,YAAY,EAAkB,CAAC;QAEvC,mEAAmE;QAC3C,UAAK,GAA6B,IAAI,YAAY,EAAc,CAAC;QAEzF,mEAAmE;QACzC,YAAO,GAC7B,IAAI,YAAY,EAAqB,CAAC;QAE1C,gGAAgG;QACvE,WAAM,GAC3B,IAAI,YAAY,EAAoB,CAAC;QAEzC,6DAA6D;QACnC,YAAO,GAC7B,IAAI,YAAY,EAAoB,CAAC;QAEzC;;;WAGG;QACqB,UAAK,GACzB,IAAI,UAAU,CAAC,CAAC,QAAkC,EAAE,EAAE;YACpD,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;gBAC/D,MAAM,EAAE,IAAI;gBACZ,eAAe,EAAE,UAAU,CAAC,eAAe;gBAC3C,KAAK,EAAE,UAAU,CAAC,KAAK;gBACvB,KAAK,EAAE,UAAU,CAAC,KAAK;gBACvB,QAAQ,EAAE,UAAU,CAAC,QAAQ;aAC9B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAEzB,OAAO,GAAG,EAAE;gBACV,YAAY,CAAC,WAAW,EAAE,CAAC;YAC7B,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAaL,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,UAAU,CAAC,OAAO,EAAE;YAC3C,kBAAkB,EAAE,MAAM,IAAI,MAAM,CAAC,kBAAkB,IAAI,IAAI,CAAC,CAAC;gBAC7D,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;YACjC,+BAA+B,EAAE,MAAM,IAAI,MAAM,CAAC,+BAA+B,IAAI,IAAI,CAAC,CAAC;gBACvF,MAAM,CAAC,+BAA+B,CAAC,CAAC,CAAC,CAAC;YAC9C,MAAM,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM;SACvB,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QAE1B,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;SAC9B;QAED,8FAA8F;QAC9F,8FAA8F;QAC9F,8FAA8F;QAC9F,gGAAgG;QAChG,gGAAgG;QAChG,4FAA4F;QAC5F,4DAA4D;QAC5D,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;YAC7D,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAC7B;QAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IArGD,yDAAyD;IACzD,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IAC/E,CAAC;IACD,IAAI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;IAC1C,CAAC;IA+FD;;;OAGG;IACH,qBAAqB;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,qBAAqB,EAAE,CAAC;IAC/C,CAAC;IAED,0CAA0C;IAC1C,cAAc;QACZ,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC;IACxC,CAAC;IAED,6DAA6D;IAC7D,KAAK;QACH,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACH,mBAAmB;QACjB,OAAO,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC;IAC7C,CAAC;IAED,eAAe;QACb,wEAAwE;QACxE,wEAAwE;QACxE,sEAAsE;QACtE,2EAA2E;QAC3E,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,EAAE;aACjC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAE1B,sCAAsC;YACtC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CACxB,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC;YACxB,yCAAyC;YACzC,GAAG,CAAC,CAAC,OAAiC,EAAE,EAAE;gBACxC,MAAM,mBAAmB,GAAG,OAAO;qBAChC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,WAAW,KAAK,IAAI,CAAC;qBAC7C,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAEjC,kFAAkF;gBAClF,+EAA+E;gBAC/E,6BAA6B;gBAC7B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,mBAAmB,EAAE;oBAChD,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;iBACxC;gBAED,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC;YACjD,CAAC,CAAC;YACF,qDAAqD;YACrD,SAAS,CAAC,CAAC,OAAiC,EAAE,EAAE;gBAC9C,OAAO,KAAK,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;oBACjC,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;gBAClD,CAAC,CAAC,CAA8B,CAAC;YACnC,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE;gBAC3B,0DAA0D;gBAC1D,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAC9B,MAAM,MAAM,GAAG,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC;gBACpD,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YACzF,CAAC,CAAC,CAAC;YAEH,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACzB,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aAC1D;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,kBAAkB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAAC;QAC1D,MAAM,cAAc,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;QAEnD,8DAA8D;QAC9D,8DAA8D;QAC9D,IAAI,kBAAkB,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE;YACzD,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;QAED,uEAAuE;QACvE,IAAI,cAAc,IAAI,CAAC,cAAc,CAAC,WAAW,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC1E,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC1D;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;SACrC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IAED,iDAAiD;IACzC,kBAAkB;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QAC3C,MAAM,WAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAC1C,0BAA0B,CAAC,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAE5E,IAAI,WAAW,IAAI,WAAW,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE;YACvE,MAAM,KAAK,CAAC,+CAA+C;gBAC/C,0BAA0B,WAAW,CAAC,QAAQ,IAAI,CAAC,CAAC;SACjE;QAED,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,WAAW,IAAI,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,uEAAuE;IAC/D,mBAAmB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC;QAEtC,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,IAAI,CAAC;SACb;QAED,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;YAChC,OAAO,0BAA0B,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;SACzE;QAED,MAAM,OAAO,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE;YAChE,MAAM,KAAK,CAAC,0EAA0E,CAAC,CAAC;SACzF;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,kFAAkF;IAC1E,WAAW,CAAC,GAAwB;QAC1C,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/B,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,EAAE;gBACrB,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC;gBACtB,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;gBAC3C,MAAM,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;oBAC9C,QAAQ,EAAE,IAAI,CAAC,oBAAoB,CAAC,WAAW;oBAC/C,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,IAAI;oBACvC,aAAa,EAAE,IAAI,CAAC,iBAAiB;iBACtC,CAAC,CAAC,CAAC,IAAI,CAAC;gBACT,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;oBACtC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW;oBAC3C,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI;oBACnC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,SAAS;oBAC1C,aAAa,EAAE,IAAI,CAAC,iBAAiB;iBACtC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAET,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAC7B,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;gBAC7B,GAAG,CAAC,cAAc,GAAG,CAAC,OAAO,cAAc,KAAK,QAAQ,IAAI,cAAc,CAAC,CAAC,CAAC;oBACzE,cAAc,CAAC,CAAC,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;gBAC1D,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;gBAC/C,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;gBACrC,GAAG;qBACA,mBAAmB,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;qBAC/C,uBAAuB,CAAC,WAAW,CAAC;qBACpC,mBAAmB,CAAC,OAAO,CAAC,CAAC;gBAEhC,IAAI,GAAG,EAAE;oBACP,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;iBAC9B;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,wDAAwD;IAChD,aAAa,CAAC,GAAwB;QAC5C,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC;YAElC,6DAA6D;YAC7D,yDAAyD;YACzD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC1B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAC,CAAC,CAAC;YAE1D,6DAA6D;YAC7D,yDAAyD;YACzD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAChB,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI;gBAC/B,IAAI,EAAE,IAAI;gBACV,YAAY,EAAE,KAAK,CAAC,YAAY;aACjC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;gBACf,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI;gBAC/B,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC5B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;gBAChB,aAAa,EAAE,KAAK,CAAC,aAAa;gBAClC,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,iBAAiB,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI;gBAC/C,SAAS,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI;gBAC/B,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;gBACpD,IAAI,EAAE,IAAI;gBACV,QAAQ,EAAE,KAAK,CAAC,QAAQ;aACzB,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0EAA0E;IAClE,eAAe,CAAC,MAAsB;QAC5C,MAAM,EACJ,QAAQ,EAAE,cAAc,EAAE,iBAAiB,EAAE,YAAY,EACzD,eAAe,EAAE,gBAAgB,EAAE,mBAAmB,EACvD,GAAG,MAAM,CAAC;QAEX,IAAI,CAAC,QAAQ,GAAG,gBAAgB,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,gBAAgB,CAAC;QACpE,IAAI,CAAC,cAAc,GAAG,cAAc,IAAI,CAAC,CAAC;QAE1C,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC1B;QAED,IAAI,iBAAiB,EAAE;YACrB,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;SAC5C;QAED,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;SAClC;QAED,IAAI,eAAe,EAAE;YACnB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;SACxC;QAED,IAAI,mBAAmB,EAAE;YACvB,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;SAChD;IACH,CAAC;;;YA7ZF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;gBACrB,QAAQ,EAAE,SAAS;gBACnB,IAAI,EAAE;oBACJ,OAAO,EAAE,UAAU;oBACnB,2BAA2B,EAAE,UAAU;oBACvC,2BAA2B,EAAE,uBAAuB;iBACrD;gBACD,SAAS,EAAE,CAAC,EAAC,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,OAAO,EAAC,CAAC;aAC9D;;;YArDC,UAAU;4CA4KL,MAAM,SAAC,aAAa,cAAG,QAAQ,YAAI,QAAQ;4CAC3C,MAAM,SAAC,QAAQ;YAzKpB,MAAM;YAMN,gBAAgB;4CAqKX,QAAQ,YAAI,MAAM,SAAC,eAAe;YAtLjC,cAAc,uBAuLf,QAAQ;YAxIP,QAAQ;YA3Bd,iBAAiB;YAqBM,aAAa,uBAgJ/B,QAAQ,YAAI,IAAI,YAAI,MAAM,SAAC,eAAe;;;uBApH9C,eAAe,SAAC,eAAsB,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;+BAI3D,YAAY,SAAC,gBAAuB;mCAIpC,YAAY,SAAC,oBAA2B;mBAGxC,KAAK,SAAC,aAAa;uBAGnB,KAAK,SAAC,iBAAiB;kCAOvB,KAAK,SAAC,oBAAoB;8BAQ1B,KAAK,SAAC,iBAAiB;6BAMvB,KAAK,SAAC,mBAAmB;+BAMzB,KAAK,SAAC,yBAAyB;uBAG/B,KAAK,SAAC,iBAAiB;gCAgBvB,KAAK,SAAC,0BAA0B;2BAGhC,KAAK,SAAC,qBAAqB;sBAG3B,MAAM,SAAC,gBAAgB;uBAGvB,MAAM,SAAC,iBAAiB;oBAIxB,MAAM,SAAC,cAAc;sBAGrB,MAAM,SAAC,gBAAgB;qBAIvB,MAAM,SAAC,eAAe;sBAItB,MAAM,SAAC,gBAAgB;oBAOvB,MAAM,SAAC,cAAc;;AAqTxB,uEAAuE;AACvE,SAAS,0BAA0B,CAAC,OAAoB,EAAE,QAAgB;IACxE,IAAI,cAAc,GAAG,OAAO,CAAC,aAAmC,CAAC;IAEjE,OAAO,cAAc,EAAE;QACrB,+EAA+E;QAC/E,IAAI,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC1D,cAAsB,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE;YACvD,OAAO,cAAc,CAAC;SACvB;QAED,cAAc,GAAG,cAAc,CAAC,aAAa,CAAC;KAC/C;IAED,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directionality} from '@angular/cdk/bidi';\nimport {DOCUMENT} from '@angular/common';\nimport {\n  AfterViewInit,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  SkipSelf,\n  ViewContainerRef,\n  OnChanges,\n  SimpleChanges,\n  ChangeDetectorRef,\n  isDevMode,\n  Self,\n} from '@angular/core';\nimport {\n  coerceBooleanProperty,\n  coerceNumberProperty,\n  coerceElement,\n  BooleanInput\n} from '@angular/cdk/coercion';\nimport {Observable, Observer, Subject, merge} from 'rxjs';\nimport {startWith, take, map, takeUntil, switchMap, tap} from 'rxjs/operators';\nimport {\n  CdkDragDrop,\n  CdkDragEnd,\n  CdkDragEnter,\n  CdkDragExit,\n  CdkDragMove,\n  CdkDragStart,\n  CdkDragRelease,\n} from '../drag-events';\nimport {CDK_DRAG_HANDLE, CdkDragHandle} from './drag-handle';\nimport {CDK_DRAG_PLACEHOLDER, CdkDragPlaceholder} from './drag-placeholder';\nimport {CDK_DRAG_PREVIEW, CdkDragPreview} from './drag-preview';\nimport {CDK_DRAG_PARENT} from '../drag-parent';\nimport {DragRef, Point} from '../drag-ref';\nimport {CDK_DROP_LIST, CdkDropListInternal as CdkDropList} from './drop-list';\nimport {DragDrop} from '../drag-drop';\nimport {CDK_DRAG_CONFIG, DragDropConfig, DragStartDelay, DragAxis} from './config';\n\n/** Element that can be moved inside a CdkDropList container. */\n@Directive({\n  selector: '[cdkDrag]',\n  exportAs: 'cdkDrag',\n  host: {\n    'class': 'cdk-drag',\n    '[class.cdk-drag-disabled]': 'disabled',\n    '[class.cdk-drag-dragging]': '_dragRef.isDragging()',\n  },\n  providers: [{provide: CDK_DRAG_PARENT, useExisting: CdkDrag}]\n})\nexport class CdkDrag<T = any> implements AfterViewInit, OnChanges, OnDestroy {\n  private _destroyed = new Subject<void>();\n\n  /** Reference to the underlying drag instance. */\n  _dragRef: DragRef<CdkDrag<T>>;\n\n  // TODO: Remove cast once https://github.com/angular/angular/pull/37506 is available.\n  /** Elements that can be used to drag the draggable item. */\n  @ContentChildren(CDK_DRAG_HANDLE as any, {descendants: true}) _handles: QueryList<CdkDragHandle>;\n\n  // TODO: Remove cast once https://github.com/angular/angular/pull/37506 is available.\n  /** Element that will be used as a template to create the draggable item's preview. */\n  @ContentChild(CDK_DRAG_PREVIEW as any) _previewTemplate: CdkDragPreview;\n\n  // TODO: Remove cast once https://github.com/angular/angular/pull/37506 is available.\n  /** Template for placeholder element rendered to show where a draggable would be dropped. */\n  @ContentChild(CDK_DRAG_PLACEHOLDER as any) _placeholderTemplate: CdkDragPlaceholder;\n\n  /** Arbitrary data to attach to this drag instance. */\n  @Input('cdkDragData') data: T;\n\n  /** Locks the position of the dragged element along the specified axis. */\n  @Input('cdkDragLockAxis') lockAxis: DragAxis;\n\n  /**\n   * Selector that will be used to determine the root draggable element, starting from\n   * the `cdkDrag` element and going up the DOM. Passing an alternate root element is useful\n   * when trying to enable dragging on an element that you might not have access to.\n   */\n  @Input('cdkDragRootElement') rootElementSelector: string;\n\n  /**\n   * Node or selector that will be used to determine the element to which the draggable's\n   * position will be constrained. If a string is passed in, it'll be used as a selector that\n   * will be matched starting from the element's parent and going up the DOM until a match\n   * has been found.\n   */\n  @Input('cdkDragBoundary') boundaryElement: string | ElementRef<HTMLElement> | HTMLElement;\n\n  /**\n   * Amount of milliseconds to wait after the user has put their\n   * pointer down before starting to drag the element.\n   */\n  @Input('cdkDragStartDelay') dragStartDelay: DragStartDelay;\n\n  /**\n   * Sets the position of a `CdkDrag` that is outside of a drop container.\n   * Can be used to restore the element's position for a returning user.\n   */\n  @Input('cdkDragFreeDragPosition') freeDragPosition: {x: number, y: number};\n\n  /** Whether starting to drag this element is disabled. */\n  @Input('cdkDragDisabled')\n  get disabled(): boolean {\n    return this._disabled || (this.dropContainer && this.dropContainer.disabled);\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n    this._dragRef.disabled = this._disabled;\n  }\n  private _disabled: boolean;\n\n  /**\n   * Function that can be used to customize the logic of how the position of the drag item\n   * is limited while it's being dragged. Gets called with a point containing the current position\n   * of the user's pointer on the page and should return a point describing where the item should\n   * be rendered.\n   */\n  @Input('cdkDragConstrainPosition') constrainPosition?: (point: Point, dragRef: DragRef) => Point;\n\n  /** Class to be added to the preview element. */\n  @Input('cdkDragPreviewClass') previewClass: string | string[];\n\n  /** Emits when the user starts dragging the item. */\n  @Output('cdkDragStarted') started: EventEmitter<CdkDragStart> = new EventEmitter<CdkDragStart>();\n\n  /** Emits when the user has released a drag item, before any animations have started. */\n  @Output('cdkDragReleased') released: EventEmitter<CdkDragRelease> =\n      new EventEmitter<CdkDragRelease>();\n\n  /** Emits when the user stops dragging an item in the container. */\n  @Output('cdkDragEnded') ended: EventEmitter<CdkDragEnd> = new EventEmitter<CdkDragEnd>();\n\n  /** Emits when the user has moved the item into a new container. */\n  @Output('cdkDragEntered') entered: EventEmitter<CdkDragEnter<any>> =\n      new EventEmitter<CdkDragEnter<any>>();\n\n  /** Emits when the user removes the item its container by dragging it into another container. */\n  @Output('cdkDragExited') exited: EventEmitter<CdkDragExit<any>> =\n      new EventEmitter<CdkDragExit<any>>();\n\n  /** Emits when the user drops the item inside a container. */\n  @Output('cdkDragDropped') dropped: EventEmitter<CdkDragDrop<any>> =\n      new EventEmitter<CdkDragDrop<any>>();\n\n  /**\n   * Emits as the user is dragging the item. Use with caution,\n   * because this event will fire for every pixel that the user has dragged.\n   */\n  @Output('cdkDragMoved') moved: Observable<CdkDragMove<T>> =\n      new Observable((observer: Observer<CdkDragMove<T>>) => {\n        const subscription = this._dragRef.moved.pipe(map(movedEvent => ({\n          source: this,\n          pointerPosition: movedEvent.pointerPosition,\n          event: movedEvent.event,\n          delta: movedEvent.delta,\n          distance: movedEvent.distance\n        }))).subscribe(observer);\n\n        return () => {\n          subscription.unsubscribe();\n        };\n      });\n\n  constructor(\n      /** Element that the draggable is attached to. */\n      public element: ElementRef<HTMLElement>,\n      /** Droppable container that the draggable is a part of. */\n      @Inject(CDK_DROP_LIST) @Optional() @SkipSelf() public dropContainer: CdkDropList,\n      @Inject(DOCUMENT) private _document: any, private _ngZone: NgZone,\n      private _viewContainerRef: ViewContainerRef,\n      @Optional() @Inject(CDK_DRAG_CONFIG) config: DragDropConfig,\n      @Optional() private _dir: Directionality, dragDrop: DragDrop,\n      private _changeDetectorRef: ChangeDetectorRef,\n      @Optional() @Self() @Inject(CDK_DRAG_HANDLE) private _selfHandle?: CdkDragHandle) {\n    this._dragRef = dragDrop.createDrag(element, {\n      dragStartThreshold: config && config.dragStartThreshold != null ?\n          config.dragStartThreshold : 5,\n      pointerDirectionChangeThreshold: config && config.pointerDirectionChangeThreshold != null ?\n          config.pointerDirectionChangeThreshold : 5,\n      zIndex: config?.zIndex\n    });\n    this._dragRef.data = this;\n\n    if (config) {\n      this._assignDefaults(config);\n    }\n\n    // Note that usually the container is assigned when the drop list is picks up the item, but in\n    // some cases (mainly transplanted views with OnPush, see #18341) we may end up in a situation\n    // where there are no items on the first change detection pass, but the items get picked up as\n    // soon as the user triggers another pass by dragging. This is a problem, because the item would\n    // have to switch from standalone mode to drag mode in the middle of the dragging sequence which\n    // is too late since the two modes save different kinds of information. We work around it by\n    // assigning the drop container both from here and the list.\n    if (dropContainer) {\n      this._dragRef._withDropContainer(dropContainer._dropListRef);\n      dropContainer.addItem(this);\n    }\n\n    this._syncInputs(this._dragRef);\n    this._handleEvents(this._dragRef);\n  }\n\n  /**\n   * Returns the element that is being used as a placeholder\n   * while the current element is being dragged.\n   */\n  getPlaceholderElement(): HTMLElement {\n    return this._dragRef.getPlaceholderElement();\n  }\n\n  /** Returns the root draggable element. */\n  getRootElement(): HTMLElement {\n    return this._dragRef.getRootElement();\n  }\n\n  /** Resets a standalone drag item to its initial position. */\n  reset(): void {\n    this._dragRef.reset();\n  }\n\n  /**\n   * Gets the pixel coordinates of the draggable outside of a drop container.\n   */\n  getFreeDragPosition(): {readonly x: number, readonly y: number} {\n    return this._dragRef.getFreeDragPosition();\n  }\n\n  ngAfterViewInit() {\n    // We need to wait for the zone to stabilize, in order for the reference\n    // element to be in the proper place in the DOM. This is mostly relevant\n    // for draggable elements inside portals since they get stamped out in\n    // their original DOM position and then they get transferred to the portal.\n    this._ngZone.onStable.asObservable()\n      .pipe(take(1), takeUntil(this._destroyed))\n      .subscribe(() => {\n        this._updateRootElement();\n\n        // Listen for any newly-added handles.\n        this._handles.changes.pipe(\n          startWith(this._handles),\n          // Sync the new handles with the DragRef.\n          tap((handles: QueryList<CdkDragHandle>) => {\n            const childHandleElements = handles\n              .filter(handle => handle._parentDrag === this)\n              .map(handle => handle.element);\n\n            // Usually handles are only allowed to be a descendant of the drag element, but if\n            // the consumer defined a different drag root, we should allow the drag element\n            // itself to be a handle too.\n            if (this._selfHandle && this.rootElementSelector) {\n              childHandleElements.push(this.element);\n            }\n\n            this._dragRef.withHandles(childHandleElements);\n          }),\n          // Listen if the state of any of the handles changes.\n          switchMap((handles: QueryList<CdkDragHandle>) => {\n            return merge(...handles.map(item => {\n              return item._stateChanges.pipe(startWith(item));\n            })) as Observable<CdkDragHandle>;\n          }),\n          takeUntil(this._destroyed)\n        ).subscribe(handleInstance => {\n          // Enabled/disable the handle that changed in the DragRef.\n          const dragRef = this._dragRef;\n          const handle = handleInstance.element.nativeElement;\n          handleInstance.disabled ? dragRef.disableHandle(handle) : dragRef.enableHandle(handle);\n        });\n\n        if (this.freeDragPosition) {\n          this._dragRef.setFreeDragPosition(this.freeDragPosition);\n        }\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const rootSelectorChange = changes['rootElementSelector'];\n    const positionChange = changes['freeDragPosition'];\n\n    // We don't have to react to the first change since it's being\n    // handled in `ngAfterViewInit` where it needs to be deferred.\n    if (rootSelectorChange && !rootSelectorChange.firstChange) {\n      this._updateRootElement();\n    }\n\n    // Skip the first change since it's being handled in `ngAfterViewInit`.\n    if (positionChange && !positionChange.firstChange && this.freeDragPosition) {\n      this._dragRef.setFreeDragPosition(this.freeDragPosition);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.dropContainer) {\n      this.dropContainer.removeItem(this);\n    }\n\n    this._destroyed.next();\n    this._destroyed.complete();\n    this._dragRef.dispose();\n  }\n\n  /** Syncs the root element with the `DragRef`. */\n  private _updateRootElement() {\n    const element = this.element.nativeElement;\n    const rootElement = this.rootElementSelector ?\n        getClosestMatchingAncestor(element, this.rootElementSelector) : element;\n\n    if (rootElement && rootElement.nodeType !== this._document.ELEMENT_NODE) {\n      throw Error(`cdkDrag must be attached to an element node. ` +\n                  `Currently attached to \"${rootElement.nodeName}\".`);\n    }\n\n    this._dragRef.withRootElement(rootElement || element);\n  }\n\n  /** Gets the boundary element, based on the `boundaryElement` value. */\n  private _getBoundaryElement() {\n    const boundary = this.boundaryElement;\n\n    if (!boundary) {\n      return null;\n    }\n\n    if (typeof boundary === 'string') {\n      return getClosestMatchingAncestor(this.element.nativeElement, boundary);\n    }\n\n    const element = coerceElement(boundary);\n\n    if (isDevMode() && !element.contains(this.element.nativeElement)) {\n      throw Error('Draggable element is not inside of the node passed into cdkDragBoundary.');\n    }\n\n    return element;\n  }\n\n  /** Syncs the inputs of the CdkDrag with the options of the underlying DragRef. */\n  private _syncInputs(ref: DragRef<CdkDrag<T>>) {\n    ref.beforeStarted.subscribe(() => {\n      if (!ref.isDragging()) {\n        const dir = this._dir;\n        const dragStartDelay = this.dragStartDelay;\n        const placeholder = this._placeholderTemplate ? {\n          template: this._placeholderTemplate.templateRef,\n          context: this._placeholderTemplate.data,\n          viewContainer: this._viewContainerRef\n        } : null;\n        const preview = this._previewTemplate ? {\n          template: this._previewTemplate.templateRef,\n          context: this._previewTemplate.data,\n          matchSize: this._previewTemplate.matchSize,\n          viewContainer: this._viewContainerRef\n        } : null;\n\n        ref.disabled = this.disabled;\n        ref.lockAxis = this.lockAxis;\n        ref.dragStartDelay = (typeof dragStartDelay === 'object' && dragStartDelay) ?\n            dragStartDelay : coerceNumberProperty(dragStartDelay);\n        ref.constrainPosition = this.constrainPosition;\n        ref.previewClass = this.previewClass;\n        ref\n          .withBoundaryElement(this._getBoundaryElement())\n          .withPlaceholderTemplate(placeholder)\n          .withPreviewTemplate(preview);\n\n        if (dir) {\n          ref.withDirection(dir.value);\n        }\n      }\n    });\n  }\n\n  /** Handles the events from the underlying `DragRef`. */\n  private _handleEvents(ref: DragRef<CdkDrag<T>>) {\n    ref.started.subscribe(() => {\n      this.started.emit({source: this});\n\n      // Since all of these events run outside of change detection,\n      // we need to ensure that everything is marked correctly.\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.released.subscribe(() => {\n      this.released.emit({source: this});\n    });\n\n    ref.ended.subscribe(event => {\n      this.ended.emit({source: this, distance: event.distance});\n\n      // Since all of these events run outside of change detection,\n      // we need to ensure that everything is marked correctly.\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.entered.subscribe(event => {\n      this.entered.emit({\n        container: event.container.data,\n        item: this,\n        currentIndex: event.currentIndex\n      });\n    });\n\n    ref.exited.subscribe(event => {\n      this.exited.emit({\n        container: event.container.data,\n        item: this\n      });\n    });\n\n    ref.dropped.subscribe(event => {\n      this.dropped.emit({\n        previousIndex: event.previousIndex,\n        currentIndex: event.currentIndex,\n        previousContainer: event.previousContainer.data,\n        container: event.container.data,\n        isPointerOverContainer: event.isPointerOverContainer,\n        item: this,\n        distance: event.distance\n      });\n    });\n  }\n\n  /** Assigns the default input values based on a provided config object. */\n  private _assignDefaults(config: DragDropConfig) {\n    const {\n      lockAxis, dragStartDelay, constrainPosition, previewClass,\n      boundaryElement, draggingDisabled, rootElementSelector\n    } = config;\n\n    this.disabled = draggingDisabled == null ? false : draggingDisabled;\n    this.dragStartDelay = dragStartDelay || 0;\n\n    if (lockAxis) {\n      this.lockAxis = lockAxis;\n    }\n\n    if (constrainPosition) {\n      this.constrainPosition = constrainPosition;\n    }\n\n    if (previewClass) {\n      this.previewClass = previewClass;\n    }\n\n    if (boundaryElement) {\n      this.boundaryElement = boundaryElement;\n    }\n\n    if (rootElementSelector) {\n      this.rootElementSelector = rootElementSelector;\n    }\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n}\n\n/** Gets the closest ancestor of an element that matches a selector. */\nfunction getClosestMatchingAncestor(element: HTMLElement, selector: string) {\n  let currentElement = element.parentElement as HTMLElement | null;\n\n  while (currentElement) {\n    // IE doesn't support `matches` so we have to fall back to `msMatchesSelector`.\n    if (currentElement.matches ? currentElement.matches(selector) :\n        (currentElement as any).msMatchesSelector(selector)) {\n      return currentElement;\n    }\n\n    currentElement = currentElement.parentElement;\n  }\n\n  return null;\n}\n\n"]}