1 | /**
|
---|
2 | * @license
|
---|
3 | * Copyright Google LLC All Rights Reserved.
|
---|
4 | *
|
---|
5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
6 | * found in the LICENSE file at https://angular.io/license
|
---|
7 | */
|
---|
8 | import { coerceArray, coerceNumberProperty, coerceBooleanProperty, } from '@angular/cdk/coercion';
|
---|
9 | import { ElementRef, EventEmitter, Input, Output, Optional, Directive, ChangeDetectorRef, SkipSelf, Inject, InjectionToken, } from '@angular/core';
|
---|
10 | import { Directionality } from '@angular/cdk/bidi';
|
---|
11 | import { ScrollDispatcher } from '@angular/cdk/scrolling';
|
---|
12 | import { CDK_DROP_LIST_GROUP, CdkDropListGroup } from './drop-list-group';
|
---|
13 | import { DragDrop } from '../drag-drop';
|
---|
14 | import { CDK_DRAG_CONFIG } from './config';
|
---|
15 | import { Subject } from 'rxjs';
|
---|
16 | import { startWith, takeUntil } from 'rxjs/operators';
|
---|
17 | import { assertElementNode } from './assertions';
|
---|
18 | /** Counter used to generate unique ids for drop zones. */
|
---|
19 | let _uniqueIdCounter = 0;
|
---|
20 | /**
|
---|
21 | * Injection token that can be used to reference instances of `CdkDropList`. It serves as
|
---|
22 | * alternative token to the actual `CdkDropList` class which could cause unnecessary
|
---|
23 | * retention of the class and its directive metadata.
|
---|
24 | */
|
---|
25 | export const CDK_DROP_LIST = new InjectionToken('CdkDropList');
|
---|
26 | const ɵ0 = undefined;
|
---|
27 | /** Container that wraps a set of draggable items. */
|
---|
28 | export class CdkDropList {
|
---|
29 | constructor(
|
---|
30 | /** Element that the drop list is attached to. */
|
---|
31 | element, dragDrop, _changeDetectorRef, _scrollDispatcher, _dir, _group, config) {
|
---|
32 | this.element = element;
|
---|
33 | this._changeDetectorRef = _changeDetectorRef;
|
---|
34 | this._scrollDispatcher = _scrollDispatcher;
|
---|
35 | this._dir = _dir;
|
---|
36 | this._group = _group;
|
---|
37 | /** Emits when the list has been destroyed. */
|
---|
38 | this._destroyed = new Subject();
|
---|
39 | /**
|
---|
40 | * Other draggable containers that this container is connected to and into which the
|
---|
41 | * container's items can be transferred. Can either be references to other drop containers,
|
---|
42 | * or their unique IDs.
|
---|
43 | */
|
---|
44 | this.connectedTo = [];
|
---|
45 | /**
|
---|
46 | * Unique ID for the drop zone. Can be used as a reference
|
---|
47 | * in the `connectedTo` of another `CdkDropList`.
|
---|
48 | */
|
---|
49 | this.id = `cdk-drop-list-${_uniqueIdCounter++}`;
|
---|
50 | /**
|
---|
51 | * Function that is used to determine whether an item
|
---|
52 | * is allowed to be moved into a drop container.
|
---|
53 | */
|
---|
54 | this.enterPredicate = () => true;
|
---|
55 | /** Functions that is used to determine whether an item can be sorted into a particular index. */
|
---|
56 | this.sortPredicate = () => true;
|
---|
57 | /** Emits when the user drops an item inside the container. */
|
---|
58 | this.dropped = new EventEmitter();
|
---|
59 | /**
|
---|
60 | * Emits when the user has moved a new drag item into this container.
|
---|
61 | */
|
---|
62 | this.entered = new EventEmitter();
|
---|
63 | /**
|
---|
64 | * Emits when the user removes an item from the container
|
---|
65 | * by dragging it into another container.
|
---|
66 | */
|
---|
67 | this.exited = new EventEmitter();
|
---|
68 | /** Emits as the user is swapping items while actively dragging. */
|
---|
69 | this.sorted = new EventEmitter();
|
---|
70 | /**
|
---|
71 | * Keeps track of the items that are registered with this container. Historically we used to
|
---|
72 | * do this with a `ContentChildren` query, however queries don't handle transplanted views very
|
---|
73 | * well which means that we can't handle cases like dragging the headers of a `mat-table`
|
---|
74 | * correctly. What we do instead is to have the items register themselves with the container
|
---|
75 | * and then we sort them based on their position in the DOM.
|
---|
76 | */
|
---|
77 | this._unsortedItems = new Set();
|
---|
78 | if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
---|
79 | assertElementNode(element.nativeElement, 'cdkDropList');
|
---|
80 | }
|
---|
81 | this._dropListRef = dragDrop.createDropList(element);
|
---|
82 | this._dropListRef.data = this;
|
---|
83 | if (config) {
|
---|
84 | this._assignDefaults(config);
|
---|
85 | }
|
---|
86 | this._dropListRef.enterPredicate = (drag, drop) => {
|
---|
87 | return this.enterPredicate(drag.data, drop.data);
|
---|
88 | };
|
---|
89 | this._dropListRef.sortPredicate =
|
---|
90 | (index, drag, drop) => {
|
---|
91 | return this.sortPredicate(index, drag.data, drop.data);
|
---|
92 | };
|
---|
93 | this._setupInputSyncSubscription(this._dropListRef);
|
---|
94 | this._handleEvents(this._dropListRef);
|
---|
95 | CdkDropList._dropLists.push(this);
|
---|
96 | if (_group) {
|
---|
97 | _group._items.add(this);
|
---|
98 | }
|
---|
99 | }
|
---|
100 | /** Whether starting a dragging sequence from this container is disabled. */
|
---|
101 | get disabled() {
|
---|
102 | return this._disabled || (!!this._group && this._group.disabled);
|
---|
103 | }
|
---|
104 | set disabled(value) {
|
---|
105 | // Usually we sync the directive and ref state right before dragging starts, in order to have
|
---|
106 | // a single point of failure and to avoid having to use setters for everything. `disabled` is
|
---|
107 | // a special case, because it can prevent the `beforeStarted` event from firing, which can lock
|
---|
108 | // the user in a disabled state, so we also need to sync it as it's being set.
|
---|
109 | this._dropListRef.disabled = this._disabled = coerceBooleanProperty(value);
|
---|
110 | }
|
---|
111 | /** Registers an items with the drop list. */
|
---|
112 | addItem(item) {
|
---|
113 | this._unsortedItems.add(item);
|
---|
114 | if (this._dropListRef.isDragging()) {
|
---|
115 | this._syncItemsWithRef();
|
---|
116 | }
|
---|
117 | }
|
---|
118 | /** Removes an item from the drop list. */
|
---|
119 | removeItem(item) {
|
---|
120 | this._unsortedItems.delete(item);
|
---|
121 | if (this._dropListRef.isDragging()) {
|
---|
122 | this._syncItemsWithRef();
|
---|
123 | }
|
---|
124 | }
|
---|
125 | /** Gets the registered items in the list, sorted by their position in the DOM. */
|
---|
126 | getSortedItems() {
|
---|
127 | return Array.from(this._unsortedItems).sort((a, b) => {
|
---|
128 | const documentPosition = a._dragRef.getVisibleElement().compareDocumentPosition(b._dragRef.getVisibleElement());
|
---|
129 | // `compareDocumentPosition` returns a bitmask so we have to use a bitwise operator.
|
---|
130 | // https://developer.mozilla.org/en-US/docs/Web/API/Node/compareDocumentPosition
|
---|
131 | // tslint:disable-next-line:no-bitwise
|
---|
132 | return documentPosition & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1;
|
---|
133 | });
|
---|
134 | }
|
---|
135 | ngOnDestroy() {
|
---|
136 | const index = CdkDropList._dropLists.indexOf(this);
|
---|
137 | if (index > -1) {
|
---|
138 | CdkDropList._dropLists.splice(index, 1);
|
---|
139 | }
|
---|
140 | if (this._group) {
|
---|
141 | this._group._items.delete(this);
|
---|
142 | }
|
---|
143 | this._unsortedItems.clear();
|
---|
144 | this._dropListRef.dispose();
|
---|
145 | this._destroyed.next();
|
---|
146 | this._destroyed.complete();
|
---|
147 | }
|
---|
148 | /** Syncs the inputs of the CdkDropList with the options of the underlying DropListRef. */
|
---|
149 | _setupInputSyncSubscription(ref) {
|
---|
150 | if (this._dir) {
|
---|
151 | this._dir.change
|
---|
152 | .pipe(startWith(this._dir.value), takeUntil(this._destroyed))
|
---|
153 | .subscribe(value => ref.withDirection(value));
|
---|
154 | }
|
---|
155 | ref.beforeStarted.subscribe(() => {
|
---|
156 | const siblings = coerceArray(this.connectedTo).map(drop => {
|
---|
157 | if (typeof drop === 'string') {
|
---|
158 | const correspondingDropList = CdkDropList._dropLists.find(list => list.id === drop);
|
---|
159 | if (!correspondingDropList && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
---|
160 | console.warn(`CdkDropList could not find connected drop list with id "${drop}"`);
|
---|
161 | }
|
---|
162 | return correspondingDropList;
|
---|
163 | }
|
---|
164 | return drop;
|
---|
165 | });
|
---|
166 | if (this._group) {
|
---|
167 | this._group._items.forEach(drop => {
|
---|
168 | if (siblings.indexOf(drop) === -1) {
|
---|
169 | siblings.push(drop);
|
---|
170 | }
|
---|
171 | });
|
---|
172 | }
|
---|
173 | // Note that we resolve the scrollable parents here so that we delay the resolution
|
---|
174 | // as long as possible, ensuring that the element is in its final place in the DOM.
|
---|
175 | if (!this._scrollableParentsResolved) {
|
---|
176 | const scrollableParents = this._scrollDispatcher
|
---|
177 | .getAncestorScrollContainers(this.element)
|
---|
178 | .map(scrollable => scrollable.getElementRef().nativeElement);
|
---|
179 | this._dropListRef.withScrollableParents(scrollableParents);
|
---|
180 | // Only do this once since it involves traversing the DOM and the parents
|
---|
181 | // shouldn't be able to change without the drop list being destroyed.
|
---|
182 | this._scrollableParentsResolved = true;
|
---|
183 | }
|
---|
184 | ref.disabled = this.disabled;
|
---|
185 | ref.lockAxis = this.lockAxis;
|
---|
186 | ref.sortingDisabled = coerceBooleanProperty(this.sortingDisabled);
|
---|
187 | ref.autoScrollDisabled = coerceBooleanProperty(this.autoScrollDisabled);
|
---|
188 | ref.autoScrollStep = coerceNumberProperty(this.autoScrollStep, 2);
|
---|
189 | ref
|
---|
190 | .connectedTo(siblings.filter(drop => drop && drop !== this).map(list => list._dropListRef))
|
---|
191 | .withOrientation(this.orientation);
|
---|
192 | });
|
---|
193 | }
|
---|
194 | /** Handles events from the underlying DropListRef. */
|
---|
195 | _handleEvents(ref) {
|
---|
196 | ref.beforeStarted.subscribe(() => {
|
---|
197 | this._syncItemsWithRef();
|
---|
198 | this._changeDetectorRef.markForCheck();
|
---|
199 | });
|
---|
200 | ref.entered.subscribe(event => {
|
---|
201 | this.entered.emit({
|
---|
202 | container: this,
|
---|
203 | item: event.item.data,
|
---|
204 | currentIndex: event.currentIndex
|
---|
205 | });
|
---|
206 | });
|
---|
207 | ref.exited.subscribe(event => {
|
---|
208 | this.exited.emit({
|
---|
209 | container: this,
|
---|
210 | item: event.item.data
|
---|
211 | });
|
---|
212 | this._changeDetectorRef.markForCheck();
|
---|
213 | });
|
---|
214 | ref.sorted.subscribe(event => {
|
---|
215 | this.sorted.emit({
|
---|
216 | previousIndex: event.previousIndex,
|
---|
217 | currentIndex: event.currentIndex,
|
---|
218 | container: this,
|
---|
219 | item: event.item.data
|
---|
220 | });
|
---|
221 | });
|
---|
222 | ref.dropped.subscribe(event => {
|
---|
223 | this.dropped.emit({
|
---|
224 | previousIndex: event.previousIndex,
|
---|
225 | currentIndex: event.currentIndex,
|
---|
226 | previousContainer: event.previousContainer.data,
|
---|
227 | container: event.container.data,
|
---|
228 | item: event.item.data,
|
---|
229 | isPointerOverContainer: event.isPointerOverContainer,
|
---|
230 | distance: event.distance,
|
---|
231 | dropPoint: event.dropPoint
|
---|
232 | });
|
---|
233 | // Mark for check since all of these events run outside of change
|
---|
234 | // detection and we're not guaranteed for something else to have triggered it.
|
---|
235 | this._changeDetectorRef.markForCheck();
|
---|
236 | });
|
---|
237 | }
|
---|
238 | /** Assigns the default input values based on a provided config object. */
|
---|
239 | _assignDefaults(config) {
|
---|
240 | const { lockAxis, draggingDisabled, sortingDisabled, listAutoScrollDisabled, listOrientation } = config;
|
---|
241 | this.disabled = draggingDisabled == null ? false : draggingDisabled;
|
---|
242 | this.sortingDisabled = sortingDisabled == null ? false : sortingDisabled;
|
---|
243 | this.autoScrollDisabled = listAutoScrollDisabled == null ? false : listAutoScrollDisabled;
|
---|
244 | this.orientation = listOrientation || 'vertical';
|
---|
245 | if (lockAxis) {
|
---|
246 | this.lockAxis = lockAxis;
|
---|
247 | }
|
---|
248 | }
|
---|
249 | /** Syncs up the registered drag items with underlying drop list ref. */
|
---|
250 | _syncItemsWithRef() {
|
---|
251 | this._dropListRef.withItems(this.getSortedItems().map(item => item._dragRef));
|
---|
252 | }
|
---|
253 | }
|
---|
254 | /** Keeps track of the drop lists that are currently on the page. */
|
---|
255 | CdkDropList._dropLists = [];
|
---|
256 | CdkDropList.decorators = [
|
---|
257 | { type: Directive, args: [{
|
---|
258 | selector: '[cdkDropList], cdk-drop-list',
|
---|
259 | exportAs: 'cdkDropList',
|
---|
260 | providers: [
|
---|
261 | // Prevent child drop lists from picking up the same group as their parent.
|
---|
262 | { provide: CDK_DROP_LIST_GROUP, useValue: ɵ0 },
|
---|
263 | { provide: CDK_DROP_LIST, useExisting: CdkDropList },
|
---|
264 | ],
|
---|
265 | host: {
|
---|
266 | 'class': 'cdk-drop-list',
|
---|
267 | '[attr.id]': 'id',
|
---|
268 | '[class.cdk-drop-list-disabled]': 'disabled',
|
---|
269 | '[class.cdk-drop-list-dragging]': '_dropListRef.isDragging()',
|
---|
270 | '[class.cdk-drop-list-receiving]': '_dropListRef.isReceiving()',
|
---|
271 | }
|
---|
272 | },] }
|
---|
273 | ];
|
---|
274 | CdkDropList.ctorParameters = () => [
|
---|
275 | { type: ElementRef },
|
---|
276 | { type: DragDrop },
|
---|
277 | { type: ChangeDetectorRef },
|
---|
278 | { type: ScrollDispatcher },
|
---|
279 | { type: Directionality, decorators: [{ type: Optional }] },
|
---|
280 | { type: CdkDropListGroup, decorators: [{ type: Optional }, { type: Inject, args: [CDK_DROP_LIST_GROUP,] }, { type: SkipSelf }] },
|
---|
281 | { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CDK_DRAG_CONFIG,] }] }
|
---|
282 | ];
|
---|
283 | CdkDropList.propDecorators = {
|
---|
284 | connectedTo: [{ type: Input, args: ['cdkDropListConnectedTo',] }],
|
---|
285 | data: [{ type: Input, args: ['cdkDropListData',] }],
|
---|
286 | orientation: [{ type: Input, args: ['cdkDropListOrientation',] }],
|
---|
287 | id: [{ type: Input }],
|
---|
288 | lockAxis: [{ type: Input, args: ['cdkDropListLockAxis',] }],
|
---|
289 | disabled: [{ type: Input, args: ['cdkDropListDisabled',] }],
|
---|
290 | sortingDisabled: [{ type: Input, args: ['cdkDropListSortingDisabled',] }],
|
---|
291 | enterPredicate: [{ type: Input, args: ['cdkDropListEnterPredicate',] }],
|
---|
292 | sortPredicate: [{ type: Input, args: ['cdkDropListSortPredicate',] }],
|
---|
293 | autoScrollDisabled: [{ type: Input, args: ['cdkDropListAutoScrollDisabled',] }],
|
---|
294 | autoScrollStep: [{ type: Input, args: ['cdkDropListAutoScrollStep',] }],
|
---|
295 | dropped: [{ type: Output, args: ['cdkDropListDropped',] }],
|
---|
296 | entered: [{ type: Output, args: ['cdkDropListEntered',] }],
|
---|
297 | exited: [{ type: Output, args: ['cdkDropListExited',] }],
|
---|
298 | sorted: [{ type: Output, args: ['cdkDropListSorted',] }]
|
---|
299 | };
|
---|
300 | export { ɵ0 };
|
---|
301 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-list.js","sourceRoot":"","sources":["../../../../../../../src/cdk/drag-drop/directives/drop-list.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  BooleanInput,\n  coerceArray,\n  coerceNumberProperty,\n  coerceBooleanProperty,\n  NumberInput,\n} from '@angular/cdk/coercion';\nimport {\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  Optional,\n  Directive,\n  ChangeDetectorRef,\n  SkipSelf,\n  Inject,\n  InjectionToken,\n} from '@angular/core';\nimport {Directionality} from '@angular/cdk/bidi';\nimport {ScrollDispatcher} from '@angular/cdk/scrolling';\nimport {CdkDrag} from './drag';\nimport {CdkDragDrop, CdkDragEnter, CdkDragExit, CdkDragSortEvent} from '../drag-events';\nimport {CDK_DROP_LIST_GROUP, CdkDropListGroup} from './drop-list-group';\nimport {DropListRef} from '../drop-list-ref';\nimport {DragRef} from '../drag-ref';\nimport {DragDrop} from '../drag-drop';\nimport {DropListOrientation, DragAxis, DragDropConfig, CDK_DRAG_CONFIG} from './config';\nimport {Subject} from 'rxjs';\nimport {startWith, takeUntil} from 'rxjs/operators';\nimport {assertElementNode} from './assertions';\n\n/** Counter used to generate unique ids for drop zones. */\nlet _uniqueIdCounter = 0;\n\n/**\n * Internal compile-time-only representation of a `CdkDropList`.\n * Used to avoid circular import issues between the `CdkDropList` and the `CdkDrag`.\n * @docs-private\n */\nexport interface CdkDropListInternal extends CdkDropList {}\n\n/**\n * Injection token that can be used to reference instances of `CdkDropList`. It serves as\n * alternative token to the actual `CdkDropList` class which could cause unnecessary\n * retention of the class and its directive metadata.\n */\nexport const CDK_DROP_LIST = new InjectionToken<CdkDropList>('CdkDropList');\n\n/** Container that wraps a set of draggable items. */\n@Directive({\n  selector: '[cdkDropList], cdk-drop-list',\n  exportAs: 'cdkDropList',\n  providers: [\n    // Prevent child drop lists from picking up the same group as their parent.\n    {provide: CDK_DROP_LIST_GROUP, useValue: undefined},\n    {provide: CDK_DROP_LIST, useExisting: CdkDropList},\n  ],\n  host: {\n    'class': 'cdk-drop-list',\n    '[attr.id]': 'id',\n    '[class.cdk-drop-list-disabled]': 'disabled',\n    '[class.cdk-drop-list-dragging]': '_dropListRef.isDragging()',\n    '[class.cdk-drop-list-receiving]': '_dropListRef.isReceiving()',\n  }\n})\nexport class CdkDropList<T = any> implements OnDestroy {\n  /** Emits when the list has been destroyed. */\n  private readonly _destroyed = new Subject<void>();\n\n  /** Whether the element's scrollable parents have been resolved. */\n  private _scrollableParentsResolved: boolean;\n\n  /** Keeps track of the drop lists that are currently on the page. */\n  private static _dropLists: CdkDropList[] = [];\n\n  /** Reference to the underlying drop list instance. */\n  _dropListRef: DropListRef<CdkDropList<T>>;\n\n  /**\n   * Other draggable containers that this container is connected to and into which the\n   * container's items can be transferred. Can either be references to other drop containers,\n   * or their unique IDs.\n   */\n  @Input('cdkDropListConnectedTo')\n  connectedTo: (CdkDropList | string)[] | CdkDropList | string = [];\n\n  /** Arbitrary data to attach to this container. */\n  @Input('cdkDropListData') data: T;\n\n  /** Direction in which the list is oriented. */\n  @Input('cdkDropListOrientation') orientation: DropListOrientation;\n\n  /**\n   * Unique ID for the drop zone. Can be used as a reference\n   * in the `connectedTo` of another `CdkDropList`.\n   */\n  @Input() id: string = `cdk-drop-list-${_uniqueIdCounter++}`;\n\n  /** Locks the position of the draggable elements inside the container along the specified axis. */\n  @Input('cdkDropListLockAxis') lockAxis: DragAxis;\n\n  /** Whether starting a dragging sequence from this container is disabled. */\n  @Input('cdkDropListDisabled')\n  get disabled(): boolean {\n    return this._disabled || (!!this._group && this._group.disabled);\n  }\n  set disabled(value: boolean) {\n    // Usually we sync the directive and ref state right before dragging starts, in order to have\n    // a single point of failure and to avoid having to use setters for everything. `disabled` is\n    // a special case, because it can prevent the `beforeStarted` event from firing, which can lock\n    // the user in a disabled state, so we also need to sync it as it's being set.\n    this._dropListRef.disabled = this._disabled = coerceBooleanProperty(value);\n  }\n  private _disabled: boolean;\n\n  /** Whether sorting within this drop list is disabled. */\n  @Input('cdkDropListSortingDisabled')\n  sortingDisabled: boolean;\n\n  /**\n   * Function that is used to determine whether an item\n   * is allowed to be moved into a drop container.\n   */\n  @Input('cdkDropListEnterPredicate')\n  enterPredicate: (drag: CdkDrag, drop: CdkDropList) => boolean = () => true\n\n  /** Functions that is used to determine whether an item can be sorted into a particular index. */\n  @Input('cdkDropListSortPredicate')\n  sortPredicate: (index: number, drag: CdkDrag, drop: CdkDropList) => boolean = () => true\n\n  /** Whether to auto-scroll the view when the user moves their pointer close to the edges. */\n  @Input('cdkDropListAutoScrollDisabled')\n  autoScrollDisabled: boolean;\n\n  /** Number of pixels to scroll for each frame when auto-scrolling an element. */\n  @Input('cdkDropListAutoScrollStep')\n  autoScrollStep: number;\n\n  /** Emits when the user drops an item inside the container. */\n  @Output('cdkDropListDropped')\n  readonly dropped: EventEmitter<CdkDragDrop<T, any>> = new EventEmitter<CdkDragDrop<T, any>>();\n\n  /**\n   * Emits when the user has moved a new drag item into this container.\n   */\n  @Output('cdkDropListEntered')\n  readonly entered: EventEmitter<CdkDragEnter<T>> = new EventEmitter<CdkDragEnter<T>>();\n\n  /**\n   * Emits when the user removes an item from the container\n   * by dragging it into another container.\n   */\n  @Output('cdkDropListExited')\n  readonly exited: EventEmitter<CdkDragExit<T>> = new EventEmitter<CdkDragExit<T>>();\n\n  /** Emits as the user is swapping items while actively dragging. */\n  @Output('cdkDropListSorted')\n  readonly sorted: EventEmitter<CdkDragSortEvent<T>> = new EventEmitter<CdkDragSortEvent<T>>();\n\n  /**\n   * Keeps track of the items that are registered with this container. Historically we used to\n   * do this with a `ContentChildren` query, however queries don't handle transplanted views very\n   * well which means that we can't handle cases like dragging the headers of a `mat-table`\n   * correctly. What we do instead is to have the items register themselves with the container\n   * and then we sort them based on their position in the DOM.\n   */\n  private _unsortedItems = new Set<CdkDrag>();\n\n  constructor(\n      /** Element that the drop list is attached to. */\n      public element: ElementRef<HTMLElement>, dragDrop: DragDrop,\n      private _changeDetectorRef: ChangeDetectorRef,\n      private _scrollDispatcher: ScrollDispatcher,\n      @Optional() private _dir?: Directionality,\n      @Optional() @Inject(CDK_DROP_LIST_GROUP) @SkipSelf()\n      private _group?: CdkDropListGroup<CdkDropList>,\n      @Optional() @Inject(CDK_DRAG_CONFIG) config?: DragDropConfig) {\n\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      assertElementNode(element.nativeElement, 'cdkDropList');\n    }\n\n    this._dropListRef = dragDrop.createDropList(element);\n    this._dropListRef.data = this;\n\n    if (config) {\n      this._assignDefaults(config);\n    }\n\n    this._dropListRef.enterPredicate = (drag: DragRef<CdkDrag>, drop: DropListRef<CdkDropList>) => {\n      return this.enterPredicate(drag.data, drop.data);\n    };\n\n    this._dropListRef.sortPredicate =\n      (index: number, drag: DragRef<CdkDrag>, drop: DropListRef<CdkDropList>) => {\n        return this.sortPredicate(index, drag.data, drop.data);\n      };\n\n    this._setupInputSyncSubscription(this._dropListRef);\n    this._handleEvents(this._dropListRef);\n    CdkDropList._dropLists.push(this);\n\n    if (_group) {\n      _group._items.add(this);\n    }\n  }\n\n  /** Registers an items with the drop list. */\n  addItem(item: CdkDrag): void {\n    this._unsortedItems.add(item);\n\n    if (this._dropListRef.isDragging()) {\n      this._syncItemsWithRef();\n    }\n  }\n\n  /** Removes an item from the drop list. */\n  removeItem(item: CdkDrag): void {\n    this._unsortedItems.delete(item);\n\n    if (this._dropListRef.isDragging()) {\n      this._syncItemsWithRef();\n    }\n  }\n\n  /** Gets the registered items in the list, sorted by their position in the DOM. */\n  getSortedItems(): CdkDrag[] {\n    return Array.from(this._unsortedItems).sort((a: CdkDrag, b: CdkDrag) => {\n      const documentPosition =\n          a._dragRef.getVisibleElement().compareDocumentPosition(b._dragRef.getVisibleElement());\n\n      // `compareDocumentPosition` returns a bitmask so we have to use a bitwise operator.\n      // https://developer.mozilla.org/en-US/docs/Web/API/Node/compareDocumentPosition\n      // tslint:disable-next-line:no-bitwise\n      return documentPosition & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1;\n    });\n  }\n\n  ngOnDestroy() {\n    const index = CdkDropList._dropLists.indexOf(this);\n\n    if (index > -1) {\n      CdkDropList._dropLists.splice(index, 1);\n    }\n\n    if (this._group) {\n      this._group._items.delete(this);\n    }\n\n    this._unsortedItems.clear();\n    this._dropListRef.dispose();\n    this._destroyed.next();\n    this._destroyed.complete();\n  }\n\n  /** Syncs the inputs of the CdkDropList with the options of the underlying DropListRef. */\n  private _setupInputSyncSubscription(ref: DropListRef<CdkDropList>) {\n    if (this._dir) {\n      this._dir.change\n        .pipe(startWith(this._dir.value), takeUntil(this._destroyed))\n        .subscribe(value => ref.withDirection(value));\n    }\n\n    ref.beforeStarted.subscribe(() => {\n      const siblings = coerceArray(this.connectedTo).map(drop => {\n        if (typeof drop === 'string') {\n          const correspondingDropList = CdkDropList._dropLists.find(list => list.id === drop);\n\n          if (!correspondingDropList && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n            console.warn(`CdkDropList could not find connected drop list with id \"${drop}\"`);\n          }\n\n          return correspondingDropList!;\n        }\n\n        return drop;\n      });\n\n      if (this._group) {\n        this._group._items.forEach(drop => {\n          if (siblings.indexOf(drop) === -1) {\n            siblings.push(drop);\n          }\n        });\n      }\n\n      // Note that we resolve the scrollable parents here so that we delay the resolution\n      // as long as possible, ensuring that the element is in its final place in the DOM.\n      if (!this._scrollableParentsResolved) {\n        const scrollableParents = this._scrollDispatcher\n          .getAncestorScrollContainers(this.element)\n          .map(scrollable => scrollable.getElementRef().nativeElement);\n        this._dropListRef.withScrollableParents(scrollableParents);\n\n        // Only do this once since it involves traversing the DOM and the parents\n        // shouldn't be able to change without the drop list being destroyed.\n        this._scrollableParentsResolved = true;\n      }\n\n      ref.disabled = this.disabled;\n      ref.lockAxis = this.lockAxis;\n      ref.sortingDisabled = coerceBooleanProperty(this.sortingDisabled);\n      ref.autoScrollDisabled = coerceBooleanProperty(this.autoScrollDisabled);\n      ref.autoScrollStep = coerceNumberProperty(this.autoScrollStep, 2);\n      ref\n        .connectedTo(siblings.filter(drop => drop && drop !== this).map(list => list._dropListRef))\n        .withOrientation(this.orientation);\n    });\n  }\n\n  /** Handles events from the underlying DropListRef. */\n  private _handleEvents(ref: DropListRef<CdkDropList>) {\n    ref.beforeStarted.subscribe(() => {\n      this._syncItemsWithRef();\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.entered.subscribe(event => {\n      this.entered.emit({\n        container: this,\n        item: event.item.data,\n        currentIndex: event.currentIndex\n      });\n    });\n\n    ref.exited.subscribe(event => {\n      this.exited.emit({\n        container: this,\n        item: event.item.data\n      });\n      this._changeDetectorRef.markForCheck();\n    });\n\n    ref.sorted.subscribe(event => {\n      this.sorted.emit({\n        previousIndex: event.previousIndex,\n        currentIndex: event.currentIndex,\n        container: this,\n        item: event.item.data\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        item: event.item.data,\n        isPointerOverContainer: event.isPointerOverContainer,\n        distance: event.distance,\n        dropPoint: event.dropPoint\n      });\n\n      // Mark for check since all of these events run outside of change\n      // detection and we're not guaranteed for something else to have triggered it.\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n\n  /** Assigns the default input values based on a provided config object. */\n  private _assignDefaults(config: DragDropConfig) {\n    const {\n      lockAxis, draggingDisabled, sortingDisabled, listAutoScrollDisabled, listOrientation\n    } = config;\n\n    this.disabled = draggingDisabled == null ? false : draggingDisabled;\n    this.sortingDisabled = sortingDisabled == null ? false : sortingDisabled;\n    this.autoScrollDisabled = listAutoScrollDisabled == null ? false : listAutoScrollDisabled;\n    this.orientation = listOrientation || 'vertical';\n\n    if (lockAxis) {\n      this.lockAxis = lockAxis;\n    }\n  }\n\n  /** Syncs up the registered drag items with underlying drop list ref. */\n  private _syncItemsWithRef() {\n    this._dropListRef.withItems(this.getSortedItems().map(item => item._dragRef));\n  }\n\n  static ngAcceptInputType_disabled: BooleanInput;\n  static ngAcceptInputType_sortingDisabled: BooleanInput;\n  static ngAcceptInputType_autoScrollDisabled: BooleanInput;\n  static ngAcceptInputType_autoScrollStep: NumberInput;\n}\n"]} |
---|