@limble/limble-tree 0.12.4 → 0.13.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 (45) hide show
  1. package/README.md +149 -149
  2. package/{esm2015/lib/classes/Branch.js → esm2020/lib/classes/Branch.mjs} +1 -1
  3. package/{esm2015/lib/classes/DropZone.js → esm2020/lib/classes/DropZone.mjs} +1 -1
  4. package/{esm2015/lib/classes/DropZoneLocation.js → esm2020/lib/classes/DropZoneLocation.mjs} +1 -1
  5. package/{esm2015/lib/custom-event-bindings/dragleave-no-change-detect.directive.js → esm2020/lib/custom-event-bindings/dragleave-no-change-detect.directive.mjs} +0 -0
  6. package/{esm2015/lib/custom-event-bindings/dragover-no-change-detect.directive.js → esm2020/lib/custom-event-bindings/dragover-no-change-detect.directive.mjs} +1 -1
  7. package/esm2020/lib/drop-zone/drop-zone.component.mjs +75 -0
  8. package/esm2020/lib/limble-tree-branch/limble-tree-branch.component.mjs +110 -0
  9. package/esm2020/lib/limble-tree-node/limble-tree-node.component.mjs +467 -0
  10. package/{esm2015/lib/limble-tree-placeholder/limble-tree-placeholder.component.js → esm2020/lib/limble-tree-placeholder/limble-tree-placeholder.component.mjs} +3 -8
  11. package/esm2020/lib/limble-tree-root/drop-zone.service.mjs +376 -0
  12. package/esm2020/lib/limble-tree-root/limble-tree-root.component.mjs +172 -0
  13. package/{esm2015/lib/limble-tree-root/tree-construction-status.service.js → esm2020/lib/limble-tree-root/tree-construction-status.service.mjs} +1 -1
  14. package/esm2020/lib/limble-tree-root/tree.service.mjs +297 -0
  15. package/{esm2015/lib/limble-tree.module.js → esm2020/lib/limble-tree.module.mjs} +5 -5
  16. package/{esm2015/lib/singletons/component-creator.service.js → esm2020/lib/singletons/component-creator.service.mjs} +1 -1
  17. package/esm2020/lib/singletons/drag-state.service.mjs +63 -0
  18. package/esm2020/lib/singletons/global-events.service.mjs +136 -0
  19. package/{esm2015/lib/util.js → esm2020/lib/util.mjs} +1 -1
  20. package/{esm2015/limble-limble-tree.js → esm2020/limble-limble-tree.mjs} +0 -0
  21. package/{esm2015/public-api.js → esm2020/public-api.mjs} +1 -1
  22. package/fesm2015/limble-limble-tree.mjs +2256 -0
  23. package/fesm2015/limble-limble-tree.mjs.map +1 -0
  24. package/{fesm2015/limble-limble-tree.js → fesm2020/limble-limble-tree.mjs} +89 -136
  25. package/fesm2020/limble-limble-tree.mjs.map +1 -0
  26. package/{limble-limble-tree.d.ts → index.d.ts} +0 -0
  27. package/lib/custom-event-bindings/dragleave-no-change-detect.directive.d.ts +1 -1
  28. package/lib/custom-event-bindings/dragover-no-change-detect.directive.d.ts +1 -1
  29. package/lib/drop-zone/drop-zone.component.d.ts +1 -1
  30. package/lib/limble-tree-branch/limble-tree-branch.component.d.ts +1 -1
  31. package/lib/limble-tree-node/limble-tree-node.component.d.ts +1 -1
  32. package/lib/limble-tree-placeholder/limble-tree-placeholder.component.d.ts +1 -1
  33. package/lib/limble-tree-root/limble-tree-root.component.d.ts +1 -1
  34. package/package.json +22 -9
  35. package/bundles/limble-limble-tree.umd.js +0 -2910
  36. package/bundles/limble-limble-tree.umd.js.map +0 -1
  37. package/esm2015/lib/drop-zone/drop-zone.component.js +0 -81
  38. package/esm2015/lib/limble-tree-branch/limble-tree-branch.component.js +0 -116
  39. package/esm2015/lib/limble-tree-node/limble-tree-node.component.js +0 -484
  40. package/esm2015/lib/limble-tree-root/drop-zone.service.js +0 -377
  41. package/esm2015/lib/limble-tree-root/limble-tree-root.component.js +0 -178
  42. package/esm2015/lib/limble-tree-root/tree.service.js +0 -301
  43. package/esm2015/lib/singletons/drag-state.service.js +0 -64
  44. package/esm2015/lib/singletons/global-events.service.js +0 -137
  45. package/fesm2015/limble-limble-tree.js.map +0 -1
@@ -1,484 +0,0 @@
1
- import { Component, ElementRef, Input, ViewChild, ViewContainerRef } from "@angular/core";
2
- import { arraysAreEqual, isDraggingAllowed, isNestingAllowed, suddenTreeExit } from "../util";
3
- import { filter, first, skip, skipUntil } from "rxjs/operators";
4
- import { DropZone } from "../classes/DropZone";
5
- import { fromEvent, merge } from "rxjs";
6
- import { LimbleTreeBranchComponent } from "../limble-tree-branch/limble-tree-branch.component";
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../singletons/component-creator.service";
9
- import * as i2 from "../singletons/drag-state.service";
10
- import * as i3 from "../limble-tree-root/drop-zone.service";
11
- import * as i4 from "../limble-tree-root/tree.service";
12
- import * as i5 from "../singletons/global-events.service";
13
- import * as i6 from "../limble-tree-root/tree-construction-status.service";
14
- const _c0 = ["nodeHost"];
15
- const _c1 = ["draggableDiv"];
16
- const _c2 = ["nodeHostContainer"];
17
- const _c3 = ["innerBranch"];
18
- function LimbleTreeNodeComponent_drop_zone_0_Template(rf, ctx) { if (rf & 1) {
19
- i0.ɵɵelement(0, "drop-zone", 7);
20
- } if (rf & 2) {
21
- const ctx_r0 = i0.ɵɵnextContext();
22
- i0.ɵɵproperty("dropZone", ctx_r0.dropZoneAbove);
23
- } }
24
- function LimbleTreeNodeComponent_ng_template_5_Template(rf, ctx) { }
25
- function LimbleTreeNodeComponent_limble_tree_branch_7_Template(rf, ctx) { if (rf & 1) {
26
- i0.ɵɵelement(0, "limble-tree-branch", 8, 9);
27
- } if (rf & 2) {
28
- const ctx_r5 = i0.ɵɵnextContext();
29
- i0.ɵɵproperty("branch", ctx_r5.branch);
30
- } }
31
- function LimbleTreeNodeComponent_drop_zone_8_Template(rf, ctx) { if (rf & 1) {
32
- i0.ɵɵelement(0, "drop-zone", 7);
33
- } if (rf & 2) {
34
- const ctx_r6 = i0.ɵɵnextContext();
35
- i0.ɵɵproperty("dropZone", ctx_r6.dropZoneBelow);
36
- } }
37
- export class LimbleTreeNodeComponent {
38
- constructor(componentCreatorService, changeDetectorRef, dragStateService, dropZoneService, treeService, globalEventsService, ngZone, treeConstructionStatus) {
39
- this.componentCreatorService = componentCreatorService;
40
- this.changeDetectorRef = changeDetectorRef;
41
- this.dragStateService = dragStateService;
42
- this.dropZoneService = dropZoneService;
43
- this.treeService = treeService;
44
- this.globalEventsService = globalEventsService;
45
- this.ngZone = ngZone;
46
- this.treeConstructionStatus = treeConstructionStatus;
47
- this.treeConstructionStatus.constructing();
48
- if (this.treeService.treeOptions !== undefined &&
49
- this.treeService.treeOptions.listMode !== true) {
50
- this.renderInnerBranch = true;
51
- }
52
- else {
53
- this.renderInnerBranch = false;
54
- }
55
- this.renderDropZoneBelow = false;
56
- this.renderDropZoneAbove = false;
57
- this.treeChangeSubscription = this.treeService.changes$
58
- .pipe(
59
- //The first one is the initial tree render, which we can ignore
60
- skip(1))
61
- .subscribe(() => {
62
- this.treeChangeHandler();
63
- });
64
- }
65
- treeChangeHandler() {
66
- if (this.branch !== undefined &&
67
- this.currentBranchCoordinates !== undefined &&
68
- !arraysAreEqual(this.branch.getCoordinates(), this.currentBranchCoordinates)) {
69
- this.updateDropZones();
70
- }
71
- }
72
- ngOnInit() {
73
- var _a, _b, _c;
74
- if (((_a = this.treeService.treeOptions) === null || _a === void 0 ? void 0 : _a.allowDragging) === false) {
75
- return;
76
- }
77
- const parent = (_b = this.branch) === null || _b === void 0 ? void 0 : _b.getParent();
78
- if ((parent === null || parent === void 0 ? void 0 : parent.data) !== null) {
79
- const parentData = parent === null || parent === void 0 ? void 0 : parent.data;
80
- if (!isNestingAllowed(this.treeService.treeOptions, parentData)) {
81
- this.renderInnerBranch = false;
82
- return;
83
- }
84
- }
85
- this.registerDropZones();
86
- this.currentBranchCoordinates = (_c = this.branch) === null || _c === void 0 ? void 0 : _c.getCoordinates();
87
- this.ngZone.runOutsideAngular(() => {
88
- if (this.dropZoneAbove === undefined ||
89
- this.dropZoneBelow === undefined) {
90
- throw new Error("Zones not registered");
91
- }
92
- merge(this.dropZoneAbove.getCommChannel(), this.dropZoneBelow.getCommChannel())
93
- .pipe(filter((message) => message === "checkRendered"))
94
- .subscribe(() => {
95
- if (this.dropZoneAbove === undefined ||
96
- this.dropZoneBelow === undefined ||
97
- this.branch === undefined) {
98
- throw new Error("Zones not registered");
99
- }
100
- this.renderDropZoneAbove = this.dropZoneAbove.isRendered();
101
- this.renderDropZoneBelow = this.dropZoneBelow.isRendered();
102
- });
103
- });
104
- }
105
- ngAfterViewInit() {
106
- this.renderNode();
107
- this.setDropZoneHosts();
108
- this.checkForHandle();
109
- this.treeConstructionStatus.doneConstructing();
110
- this.changeDetectorRef.detectChanges();
111
- }
112
- ngOnDestroy() {
113
- this.treeChangeSubscription.unsubscribe();
114
- if (this.dropZoneAbove !== undefined) {
115
- this.dropZoneService.removeDropZone(this.dropZoneAbove);
116
- }
117
- if (this.dropZoneBelow !== undefined) {
118
- this.dropZoneService.removeDropZone(this.dropZoneBelow);
119
- }
120
- this.treeService.cleanupSignal$.next(true);
121
- }
122
- dragstartHandler(event) {
123
- var _a;
124
- event.stopPropagation();
125
- if (event.dataTransfer === null ||
126
- this.branch === undefined ||
127
- this.parentHost === undefined) {
128
- throw new Error("failed to run dragstartHandler");
129
- }
130
- const draggedElement = event.target;
131
- if (((_a = draggedElement.parentElement) === null || _a === void 0 ? void 0 : _a.tagName) !== "LIMBLE-TREE-NODE") {
132
- //Don't drag stuff that isn't part of the tree
133
- event.preventDefault();
134
- return;
135
- }
136
- event.dataTransfer.effectAllowed = "move";
137
- this.dragStateService.dragging(this.branch, this.parentHost);
138
- const treeElement = draggedElement.closest("limble-tree-root");
139
- if (treeElement === null) {
140
- throw new Error("could not get root of tree");
141
- }
142
- this.ngZone.runOutsideAngular(() => {
143
- //We have to use a setTimeout due to a bug in chrome: https://stackoverflow.com/a/20733870/8796651
144
- setTimeout(() => {
145
- var _a, _b;
146
- draggedElement.classList.add("dragging");
147
- if (((_a = this.treeService.treeData) === null || _a === void 0 ? void 0 : _a.length) === 1 &&
148
- ((_b = this.branch) === null || _b === void 0 ? void 0 : _b.getCoordinates().length) === 1) {
149
- //We are dragging the only element in the tree, so we have to use the placeholder system
150
- this.treeService.placeholder$.next(true);
151
- }
152
- });
153
- //We use this weird subscription/timeout combo in order to avoid a strange bug where the dragleave event
154
- //does not fire if the user drags out of the tree too quickly. This issue would make the drop zone
155
- //remain in the UI, potentially causing drop zones to appear in multiple trees at a time. This subscription
156
- //waits for the dragover event on the tree to fire before rendering any drop zones. If the dragover
157
- //event does not fire within a half second, we know the mouse left the tree too quickly, and we won't
158
- //render the drop zone at all.
159
- const dragSubscription = fromEvent(treeElement, "dragover")
160
- .pipe(first())
161
- .subscribe((dragoverEvent) => {
162
- dragoverEvent.stopPropagation();
163
- if (this.branch === undefined) {
164
- throw new Error("Could not show surrounding drop zones");
165
- }
166
- const parent = this.branch.getParent();
167
- let parentData;
168
- let parentNestingAllowed = true;
169
- if ((parent === null || parent === void 0 ? void 0 : parent.data) !== null) {
170
- parentData = parent === null || parent === void 0 ? void 0 : parent.data;
171
- parentNestingAllowed = isNestingAllowed(this.treeService.treeOptions, parentData);
172
- }
173
- if (this.dropZoneAbove !== undefined && parentNestingAllowed) {
174
- this.dropZoneService.showDropZoneFamily(this.dropZoneAbove, {
175
- joinFamilies: true
176
- });
177
- }
178
- });
179
- setTimeout(() => {
180
- if (!dragSubscription.closed) {
181
- dragSubscription.unsubscribe();
182
- }
183
- }, 500);
184
- });
185
- }
186
- dragendHandler(event) {
187
- var _a, _b;
188
- event === null || event === void 0 ? void 0 : event.stopPropagation();
189
- if (this.draggableDiv === undefined) {
190
- throw new Error("could not get draggable div");
191
- }
192
- this.draggableDiv.nativeElement.classList.remove("dragging");
193
- if (this.dragStateService.getState() === "captured") {
194
- if (this.treeService.captured === false) {
195
- //Dropped in a different tree. Remove the one in this tree
196
- if (this.branch === undefined) {
197
- throw new Error("could not get branch in dragendHandler");
198
- }
199
- this.treeService.cleanupSignal$.next(true);
200
- this.treeService.captured = false;
201
- }
202
- this.dragStateService.release();
203
- }
204
- else {
205
- //Wasn't dropped into a valid tree, so reset for next drag and
206
- //don't do anything else.
207
- this.dragStateService.release();
208
- this.dropZoneService.clearVisibleZones();
209
- this.dropZoneService.restoreFamilies();
210
- if (((_a = this.treeService.treeData) === null || _a === void 0 ? void 0 : _a.length) === 1 &&
211
- ((_b = this.branch) === null || _b === void 0 ? void 0 : _b.getCoordinates().length) === 1) {
212
- //We were dragging the only element in the tree, so we have to
213
- //remove the placeholder that we added in the dragstart
214
- this.treeService.placeholder$.next(false);
215
- }
216
- }
217
- }
218
- dragoverHandler(event) {
219
- var _a, _b, _c;
220
- if (this.globalEventsService.scrolling === true) {
221
- return;
222
- }
223
- if (this.branch === undefined) {
224
- throw new Error("Can't get current branch during dragover event");
225
- }
226
- const data = this.dragStateService.getData();
227
- if (data === undefined) {
228
- //They might be dragging something that isn't a node. Just ignore it.
229
- return;
230
- }
231
- const sourceBranch = data.branch;
232
- //If trying to drop on self, return.
233
- if (sourceBranch === this.branch ||
234
- this.branch.getAncestors().includes(sourceBranch)) {
235
- return;
236
- }
237
- const target = event.currentTarget.closest(".node-host-container");
238
- if (!(target instanceof HTMLElement)) {
239
- throw new Error("Failed to find node host container while dragging");
240
- }
241
- let topLine;
242
- let bottomLine;
243
- if (((_a = this.innerBranch) === null || _a === void 0 ? void 0 : _a.renderDropZoneInside) === false) {
244
- topLine = target.offsetHeight / 2 - 6;
245
- bottomLine = topLine;
246
- }
247
- else {
248
- topLine = target.offsetHeight / 3 - 3; //an imaginary line 1/3 of the way down from the top of the element;
249
- bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;
250
- }
251
- const parent = this.branch.getParent();
252
- let parentData;
253
- let parentNestingAllowed = true;
254
- if ((parent === null || parent === void 0 ? void 0 : parent.data) !== null) {
255
- parentData = parent === null || parent === void 0 ? void 0 : parent.data;
256
- parentNestingAllowed = isNestingAllowed(this.treeService.treeOptions, parentData);
257
- }
258
- /** The y-coordinates of the mouse in relation to the node it is hovering over */
259
- const offsetY = event.clientY - target.getBoundingClientRect().top;
260
- const activeDropZone = this.dropZoneService.getActiveDropZone();
261
- if (offsetY < topLine &&
262
- this.dropZoneAbove !== undefined &&
263
- parentNestingAllowed &&
264
- (activeDropZone === null ||
265
- !DropZone.dropZoneLocationsAreEqual(activeDropZone, this.dropZoneAbove))) {
266
- const index = this.branch.getIndex();
267
- if (index === undefined || index === null) {
268
- throw new Error("can't get branch index");
269
- }
270
- this.dropZoneService.showDropZoneFamily(this.dropZoneAbove, {
271
- activateLowestInsteadOfFounder: true
272
- });
273
- if (suddenTreeExit(event)) {
274
- this.dropZoneService.clearVisibleZones();
275
- }
276
- }
277
- else if (offsetY < bottomLine &&
278
- offsetY > topLine &&
279
- ((_b = this.innerBranch) === null || _b === void 0 ? void 0 : _b.renderDropZoneInside) === true &&
280
- ((_c = this.innerBranch) === null || _c === void 0 ? void 0 : _c.dropZoneInside) !== undefined &&
281
- (activeDropZone === null ||
282
- !DropZone.dropZoneLocationsAreEqual(activeDropZone, this.innerBranch.dropZoneInside))) {
283
- this.dropZoneService.showDropZoneFamily(this.innerBranch.dropZoneInside);
284
- if (suddenTreeExit(event)) {
285
- this.dropZoneService.clearVisibleZones();
286
- }
287
- }
288
- else if (offsetY >= bottomLine &&
289
- this.dropZoneBelow !== undefined &&
290
- parentNestingAllowed &&
291
- (activeDropZone === null ||
292
- !DropZone.dropZoneLocationsAreEqual(activeDropZone, this.dropZoneBelow)) &&
293
- this.branch.getChildren().length === 0) {
294
- const index = this.branch.getIndex();
295
- if (index === undefined || index === null) {
296
- throw new Error("can't get branch index");
297
- }
298
- this.dropZoneService.showDropZoneFamily(this.dropZoneBelow);
299
- if (suddenTreeExit(event)) {
300
- this.dropZoneService.clearVisibleZones();
301
- }
302
- }
303
- }
304
- renderNode() {
305
- var _a;
306
- if (this.nodeHost === undefined || this.branch === undefined) {
307
- throw new Error("Failed to render tree node");
308
- }
309
- let component = this.branch.data.component;
310
- if (component === undefined) {
311
- component = (_a = this.treeService.treeOptions) === null || _a === void 0 ? void 0 : _a.defaultComponent;
312
- }
313
- if (component === undefined) {
314
- throw new Error("limbleTree requires a component to render");
315
- }
316
- const componentRef = this.componentCreatorService.appendComponent(component.class, this.nodeHost);
317
- componentRef.instance.nodeData = this.branch.data;
318
- for (const binding in component.bindings) {
319
- componentRef.instance[binding] = component.bindings[binding];
320
- }
321
- }
322
- registerDropZones() {
323
- this.addDropZoneAbove();
324
- this.addDropZoneBelow();
325
- }
326
- addDropZoneAbove() {
327
- var _a;
328
- if (this.branch === undefined) {
329
- throw new Error("failed to register drop zone above");
330
- }
331
- const parent = this.branch.getParent();
332
- const currentCoordinates = this.branch.getCoordinates();
333
- const index = currentCoordinates[currentCoordinates.length - 1];
334
- this.dropZoneAbove = new DropZone([...((_a = parent === null || parent === void 0 ? void 0 : parent.getCoordinates()) !== null && _a !== void 0 ? _a : [])], index);
335
- this.dropZoneService.addDropZone(this.dropZoneAbove);
336
- }
337
- addDropZoneBelow() {
338
- var _a;
339
- if (this.branch === undefined) {
340
- throw new Error("failed to register drop zone below");
341
- }
342
- const parent = this.branch.getParent();
343
- const currentCoordinates = this.branch.getCoordinates();
344
- const index = currentCoordinates[currentCoordinates.length - 1];
345
- this.dropZoneBelow = new DropZone([...((_a = parent === null || parent === void 0 ? void 0 : parent.getCoordinates()) !== null && _a !== void 0 ? _a : [])], index + 1);
346
- this.dropZoneService.addDropZone(this.dropZoneBelow);
347
- }
348
- updateDropZones() {
349
- var _a;
350
- this.currentBranchCoordinates = (_a = this.branch) === null || _a === void 0 ? void 0 : _a.getCoordinates();
351
- this.updateDropZoneAbove();
352
- this.updateDropZoneBelow();
353
- this.updateDropZoneInside();
354
- this.setDropZoneHosts();
355
- }
356
- updateDropZoneAbove() {
357
- var _a;
358
- if (this.branch === undefined || this.dropZoneAbove === undefined) {
359
- throw new Error("failed to update drop zone above");
360
- }
361
- const parent = this.branch.getParent();
362
- const currentCoordinates = this.branch.getCoordinates();
363
- const index = currentCoordinates[currentCoordinates.length - 1];
364
- const location = this.dropZoneAbove.getLocation();
365
- location.setParentCoordinates([...((_a = parent === null || parent === void 0 ? void 0 : parent.getCoordinates()) !== null && _a !== void 0 ? _a : [])]);
366
- location.setInsertIndex(index);
367
- }
368
- updateDropZoneBelow() {
369
- var _a;
370
- if (this.branch === undefined || this.dropZoneBelow === undefined) {
371
- throw new Error("failed to update drop zone below");
372
- }
373
- const parent = this.branch.getParent();
374
- const currentCoordinates = this.branch.getCoordinates();
375
- const index = currentCoordinates[currentCoordinates.length - 1];
376
- const location = this.dropZoneBelow.getLocation();
377
- location.setParentCoordinates([...((_a = parent === null || parent === void 0 ? void 0 : parent.getCoordinates()) !== null && _a !== void 0 ? _a : [])]);
378
- location.setInsertIndex(index + 1);
379
- }
380
- updateDropZoneInside() {
381
- var _a;
382
- if (((_a = this.innerBranch) === null || _a === void 0 ? void 0 : _a.dropZoneInside) === undefined) {
383
- return;
384
- }
385
- if (this.branch === undefined) {
386
- throw new Error("failed to update drop zone inside");
387
- }
388
- const location = this.innerBranch.dropZoneInside.getLocation();
389
- location.setParentCoordinates([...this.branch.getCoordinates()]);
390
- }
391
- setDropZoneHosts() {
392
- if (this.dropZoneAbove === undefined ||
393
- this.dropZoneBelow === undefined) {
394
- return;
395
- }
396
- this.dropZoneAbove.setHost(this.parentHost);
397
- this.dropZoneBelow.setHost(this.parentHost);
398
- }
399
- checkForHandle() {
400
- var _a;
401
- if (this.nodeHostContainer === undefined ||
402
- this.draggableDiv === undefined) {
403
- return;
404
- }
405
- const nodeHostContainerElement = this.nodeHostContainer.nativeElement;
406
- const handle = nodeHostContainerElement.querySelector(".limble-tree-handle");
407
- const draggableDivElement = this.draggableDiv.nativeElement;
408
- if (!isDraggingAllowed(this.treeService.treeOptions, (_a = this.branch) === null || _a === void 0 ? void 0 : _a.data)) {
409
- draggableDivElement.setAttribute("draggable", "false");
410
- }
411
- else if (handle === null) {
412
- draggableDivElement.setAttribute("draggable", "true");
413
- }
414
- else {
415
- handle.addEventListener("mousedown", () => {
416
- draggableDivElement.setAttribute("draggable", "true");
417
- //For some reason mouseup doesn't fire after a drag, so we use this observable sequence instead.
418
- const dragging = this.dragStateService.state$.pipe(filter((state) => state === "dragging"), first());
419
- this.dragStateService.state$
420
- .pipe(skipUntil(dragging), filter((state) => state === "idle"), first())
421
- .subscribe(() => {
422
- draggableDivElement.setAttribute("draggable", "false");
423
- });
424
- });
425
- }
426
- }
427
- }
428
- LimbleTreeNodeComponent.ɵfac = function LimbleTreeNodeComponent_Factory(t) { return new (t || LimbleTreeNodeComponent)(i0.ɵɵdirectiveInject(i1.ComponentCreatorService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i2.DragStateService), i0.ɵɵdirectiveInject(i3.DropZoneService), i0.ɵɵdirectiveInject(i4.TreeService), i0.ɵɵdirectiveInject(i5.GlobalEventsService), i0.ɵɵdirectiveInject(i0.NgZone), i0.ɵɵdirectiveInject(i6.TreeConstructionStatus)); };
429
- LimbleTreeNodeComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: LimbleTreeNodeComponent, selectors: [["limble-tree-node"]], viewQuery: function LimbleTreeNodeComponent_Query(rf, ctx) { if (rf & 1) {
430
- i0.ɵɵviewQuery(_c0, 5, ViewContainerRef);
431
- i0.ɵɵviewQuery(_c1, 5, ElementRef);
432
- i0.ɵɵviewQuery(_c2, 5, ElementRef);
433
- i0.ɵɵviewQuery(_c3, 5, LimbleTreeBranchComponent);
434
- } if (rf & 2) {
435
- let _t;
436
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.nodeHost = _t.first);
437
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.draggableDiv = _t.first);
438
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.nodeHostContainer = _t.first);
439
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.innerBranch = _t.first);
440
- } }, inputs: { branch: "branch", parentHost: "parentHost" }, decls: 9, vars: 4, consts: [[3, "dropZone", 4, "ngIf"], [1, "limble-parent-container", 3, "dragstart", "dragend"], ["draggableDiv", ""], [1, "node-host-container", 3, "dragoverEventThrottle", "dragoverNoChangeDetect"], ["nodeHostContainer", ""], ["nodeHost", ""], [3, "branch", 4, "ngIf"], [3, "dropZone"], [3, "branch"], ["innerBranch", ""]], template: function LimbleTreeNodeComponent_Template(rf, ctx) { if (rf & 1) {
441
- i0.ɵɵtemplate(0, LimbleTreeNodeComponent_drop_zone_0_Template, 1, 1, "drop-zone", 0);
442
- i0.ɵɵelementStart(1, "div", 1, 2);
443
- i0.ɵɵlistener("dragstart", function LimbleTreeNodeComponent_Template_div_dragstart_1_listener($event) { return ctx.dragstartHandler($event); })("dragend", function LimbleTreeNodeComponent_Template_div_dragend_1_listener($event) { return ctx.dragendHandler($event); });
444
- i0.ɵɵelementStart(3, "div", 3, 4);
445
- i0.ɵɵlistener("dragoverNoChangeDetect", function LimbleTreeNodeComponent_Template_div_dragoverNoChangeDetect_3_listener($event) { return ctx.dragoverHandler($event); });
446
- i0.ɵɵtemplate(5, LimbleTreeNodeComponent_ng_template_5_Template, 0, 0, "ng-template", null, 5, i0.ɵɵtemplateRefExtractor);
447
- i0.ɵɵelementEnd();
448
- i0.ɵɵtemplate(7, LimbleTreeNodeComponent_limble_tree_branch_7_Template, 2, 1, "limble-tree-branch", 6);
449
- i0.ɵɵelementEnd();
450
- i0.ɵɵtemplate(8, LimbleTreeNodeComponent_drop_zone_8_Template, 1, 1, "drop-zone", 0);
451
- } if (rf & 2) {
452
- i0.ɵɵproperty("ngIf", ctx.renderDropZoneAbove === true);
453
- i0.ɵɵadvance(3);
454
- i0.ɵɵproperty("dragoverEventThrottle", 10);
455
- i0.ɵɵadvance(4);
456
- i0.ɵɵproperty("ngIf", ctx.branch !== undefined && ctx.renderInnerBranch === true);
457
- i0.ɵɵadvance(1);
458
- i0.ɵɵproperty("ngIf", ctx.renderDropZoneBelow === true);
459
- } }, styles: [".dragging[_ngcontent-%COMP%]{position:absolute;transition:transform .01s;transform:translate(-9999px)}"] });
460
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(LimbleTreeNodeComponent, [{
461
- type: Component,
462
- args: [{
463
- selector: "limble-tree-node",
464
- templateUrl: "./limble-tree-node.component.html",
465
- styleUrls: ["./limble-tree-node.component.scss"]
466
- }]
467
- }], function () { return [{ type: i1.ComponentCreatorService }, { type: i0.ChangeDetectorRef }, { type: i2.DragStateService }, { type: i3.DropZoneService }, { type: i4.TreeService }, { type: i5.GlobalEventsService }, { type: i0.NgZone }, { type: i6.TreeConstructionStatus }]; }, { branch: [{
468
- type: Input
469
- }], nodeHost: [{
470
- type: ViewChild,
471
- args: ["nodeHost", { read: ViewContainerRef }]
472
- }], draggableDiv: [{
473
- type: ViewChild,
474
- args: ["draggableDiv", { read: ElementRef }]
475
- }], nodeHostContainer: [{
476
- type: ViewChild,
477
- args: ["nodeHostContainer", { read: ElementRef }]
478
- }], parentHost: [{
479
- type: Input
480
- }], innerBranch: [{
481
- type: ViewChild,
482
- args: ["innerBranch", { read: LimbleTreeBranchComponent }]
483
- }] }); })();
484
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"limble-tree-node.component.js","sourceRoot":"","sources":["../../../../../projects/limble-tree/src/lib/limble-tree-node/limble-tree-node.component.ts","../../../../../projects/limble-tree/src/lib/limble-tree-node/limble-tree-node.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n   AfterViewInit,\r\n   ChangeDetectorRef,\r\n   Component,\r\n   ElementRef,\r\n   Input,\r\n   NgZone,\r\n   OnDestroy,\r\n   OnInit,\r\n   ViewChild,\r\n   ViewContainerRef\r\n} from \"@angular/core\";\r\nimport { ComponentCreatorService } from \"../singletons/component-creator.service\";\r\nimport { DropZoneService } from \"../limble-tree-root/drop-zone.service\";\r\nimport { DragStateService } from \"../singletons/drag-state.service\";\r\nimport { LimbleTreeNode, TreeService } from \"../limble-tree-root/tree.service\";\r\nimport { Branch, BranchCoordinates } from \"../classes/Branch\";\r\nimport {\r\n   arraysAreEqual,\r\n   isDraggingAllowed,\r\n   isNestingAllowed,\r\n   suddenTreeExit\r\n} from \"../util\";\r\nimport { filter, first, skip, skipUntil } from \"rxjs/operators\";\r\nimport { GlobalEventsService } from \"../singletons/global-events.service\";\r\nimport { DropZone } from \"../classes/DropZone\";\r\nimport { fromEvent, merge, Subscription } from \"rxjs\";\r\nimport { LimbleTreeBranchComponent } from \"../limble-tree-branch/limble-tree-branch.component\";\r\nimport { TreeConstructionStatus } from \"../limble-tree-root/tree-construction-status.service\";\r\n\r\n@Component({\r\n   selector: \"limble-tree-node\",\r\n   templateUrl: \"./limble-tree-node.component.html\",\r\n   styleUrls: [\"./limble-tree-node.component.scss\"]\r\n})\r\nexport class LimbleTreeNodeComponent\r\n   implements OnInit, AfterViewInit, OnDestroy\r\n{\r\n   @Input() branch: Branch<any> | undefined;\r\n   @ViewChild(\"nodeHost\", { read: ViewContainerRef }) private nodeHost:\r\n      | ViewContainerRef\r\n      | undefined;\r\n   public dropZoneAbove: DropZone | undefined;\r\n   public renderDropZoneAbove: boolean;\r\n   public dropZoneBelow: DropZone | undefined;\r\n   public renderDropZoneBelow: boolean;\r\n   public renderInnerBranch: Boolean;\r\n   @ViewChild(\"draggableDiv\", { read: ElementRef }) private draggableDiv:\r\n      | ElementRef<HTMLElement>\r\n      | undefined;\r\n   @ViewChild(\"nodeHostContainer\", { read: ElementRef })\r\n   private nodeHostContainer: ElementRef<HTMLElement> | undefined;\r\n   private currentBranchCoordinates: BranchCoordinates | undefined;\r\n   private readonly treeChangeSubscription: Subscription;\r\n   @Input() parentHost: ViewContainerRef | undefined;\r\n   @ViewChild(\"innerBranch\", { read: LimbleTreeBranchComponent })\r\n   private innerBranch: LimbleTreeBranchComponent | undefined;\r\n\r\n   constructor(\r\n      private readonly componentCreatorService: ComponentCreatorService,\r\n      private readonly changeDetectorRef: ChangeDetectorRef,\r\n      private readonly dragStateService: DragStateService,\r\n      private readonly dropZoneService: DropZoneService,\r\n      private readonly treeService: TreeService,\r\n      private readonly globalEventsService: GlobalEventsService,\r\n      private readonly ngZone: NgZone,\r\n      private readonly treeConstructionStatus: TreeConstructionStatus\r\n   ) {\r\n      this.treeConstructionStatus.constructing();\r\n      if (\r\n         this.treeService.treeOptions !== undefined &&\r\n         this.treeService.treeOptions.listMode !== true\r\n      ) {\r\n         this.renderInnerBranch = true;\r\n      } else {\r\n         this.renderInnerBranch = false;\r\n      }\r\n      this.renderDropZoneBelow = false;\r\n      this.renderDropZoneAbove = false;\r\n      this.treeChangeSubscription = this.treeService.changes$\r\n         .pipe(\r\n            //The first one is the initial tree render, which we can ignore\r\n            skip(1)\r\n         )\r\n         .subscribe(() => {\r\n            this.treeChangeHandler();\r\n         });\r\n   }\r\n\r\n   private treeChangeHandler() {\r\n      if (\r\n         this.branch !== undefined &&\r\n         this.currentBranchCoordinates !== undefined &&\r\n         !arraysAreEqual(\r\n            this.branch.getCoordinates(),\r\n            this.currentBranchCoordinates\r\n         )\r\n      ) {\r\n         this.updateDropZones();\r\n      }\r\n   }\r\n\r\n   ngOnInit() {\r\n      if (this.treeService.treeOptions?.allowDragging === false) {\r\n         return;\r\n      }\r\n      const parent = this.branch?.getParent();\r\n      if (parent?.data !== null) {\r\n         const parentData = parent?.data as LimbleTreeNode;\r\n         if (!isNestingAllowed(this.treeService.treeOptions, parentData)) {\r\n            this.renderInnerBranch = false;\r\n            return;\r\n         }\r\n      }\r\n      this.registerDropZones();\r\n      this.currentBranchCoordinates = this.branch?.getCoordinates();\r\n      this.ngZone.runOutsideAngular(() => {\r\n         if (\r\n            this.dropZoneAbove === undefined ||\r\n            this.dropZoneBelow === undefined\r\n         ) {\r\n            throw new Error(\"Zones not registered\");\r\n         }\r\n         merge(\r\n            this.dropZoneAbove.getCommChannel(),\r\n            this.dropZoneBelow.getCommChannel()\r\n         )\r\n            .pipe(filter((message) => message === \"checkRendered\"))\r\n            .subscribe(() => {\r\n               if (\r\n                  this.dropZoneAbove === undefined ||\r\n                  this.dropZoneBelow === undefined ||\r\n                  this.branch === undefined\r\n               ) {\r\n                  throw new Error(\"Zones not registered\");\r\n               }\r\n               this.renderDropZoneAbove = this.dropZoneAbove.isRendered();\r\n               this.renderDropZoneBelow = this.dropZoneBelow.isRendered();\r\n            });\r\n      });\r\n   }\r\n\r\n   ngAfterViewInit() {\r\n      this.renderNode();\r\n      this.setDropZoneHosts();\r\n      this.checkForHandle();\r\n      this.treeConstructionStatus.doneConstructing();\r\n      this.changeDetectorRef.detectChanges();\r\n   }\r\n\r\n   ngOnDestroy() {\r\n      this.treeChangeSubscription.unsubscribe();\r\n      if (this.dropZoneAbove !== undefined) {\r\n         this.dropZoneService.removeDropZone(this.dropZoneAbove);\r\n      }\r\n      if (this.dropZoneBelow !== undefined) {\r\n         this.dropZoneService.removeDropZone(this.dropZoneBelow);\r\n      }\r\n      this.treeService.cleanupSignal$.next(true);\r\n   }\r\n\r\n   public dragstartHandler(event: DragEvent): void {\r\n      event.stopPropagation();\r\n      if (\r\n         event.dataTransfer === null ||\r\n         this.branch === undefined ||\r\n         this.parentHost === undefined\r\n      ) {\r\n         throw new Error(\"failed to run dragstartHandler\");\r\n      }\r\n      const draggedElement = event.target as HTMLElement;\r\n      if (draggedElement.parentElement?.tagName !== \"LIMBLE-TREE-NODE\") {\r\n         //Don't drag stuff that isn't part of the tree\r\n         event.preventDefault();\r\n         return;\r\n      }\r\n      event.dataTransfer.effectAllowed = \"move\";\r\n      this.dragStateService.dragging(this.branch, this.parentHost);\r\n      const treeElement = draggedElement.closest(\"limble-tree-root\");\r\n      if (treeElement === null) {\r\n         throw new Error(\"could not get root of tree\");\r\n      }\r\n      this.ngZone.runOutsideAngular(() => {\r\n         //We have to use a setTimeout due to a bug in chrome: https://stackoverflow.com/a/20733870/8796651\r\n         setTimeout(() => {\r\n            draggedElement.classList.add(\"dragging\");\r\n            if (\r\n               this.treeService.treeData?.length === 1 &&\r\n               this.branch?.getCoordinates().length === 1\r\n            ) {\r\n               //We are dragging the only element in the tree, so we have to use the placeholder system\r\n               this.treeService.placeholder$.next(true);\r\n            }\r\n         });\r\n         //We use this weird subscription/timeout combo in order to avoid a strange bug where the dragleave event\r\n         //does not fire if the user drags out of the tree too quickly. This issue would make the drop zone\r\n         //remain in the UI, potentially causing drop zones to appear in multiple trees at a time. This subscription\r\n         //waits for the dragover event on the tree to fire before rendering any drop zones. If the dragover\r\n         //event does not fire within a half second, we know the mouse left the tree too quickly, and we won't\r\n         //render the drop zone at all.\r\n         const dragSubscription = fromEvent(treeElement, \"dragover\")\r\n            .pipe(first())\r\n            .subscribe((dragoverEvent) => {\r\n               dragoverEvent.stopPropagation();\r\n               if (this.branch === undefined) {\r\n                  throw new Error(\"Could not show surrounding drop zones\");\r\n               }\r\n               const parent = this.branch.getParent();\r\n               let parentData: LimbleTreeNode;\r\n               let parentNestingAllowed = true;\r\n               if (parent?.data !== null) {\r\n                  parentData = parent?.data as LimbleTreeNode;\r\n                  parentNestingAllowed = isNestingAllowed(\r\n                     this.treeService.treeOptions,\r\n                     parentData\r\n                  );\r\n               }\r\n               if (this.dropZoneAbove !== undefined && parentNestingAllowed) {\r\n                  this.dropZoneService.showDropZoneFamily(this.dropZoneAbove, {\r\n                     joinFamilies: true\r\n                  });\r\n               }\r\n            });\r\n         setTimeout(() => {\r\n            if (!dragSubscription.closed) {\r\n               dragSubscription.unsubscribe();\r\n            }\r\n         }, 500);\r\n      });\r\n   }\r\n\r\n   public dragendHandler(event?: DragEvent): void {\r\n      event?.stopPropagation();\r\n      if (this.draggableDiv === undefined) {\r\n         throw new Error(\"could not get draggable div\");\r\n      }\r\n      this.draggableDiv.nativeElement.classList.remove(\"dragging\");\r\n      if (this.dragStateService.getState() === \"captured\") {\r\n         if (this.treeService.captured === false) {\r\n            //Dropped in a different tree. Remove the one in this tree\r\n            if (this.branch === undefined) {\r\n               throw new Error(\"could not get branch in dragendHandler\");\r\n            }\r\n            this.treeService.cleanupSignal$.next(true);\r\n            this.treeService.captured = false;\r\n         }\r\n         this.dragStateService.release();\r\n      } else {\r\n         //Wasn't dropped into a valid tree, so reset for next drag and\r\n         //don't do anything else.\r\n         this.dragStateService.release();\r\n         this.dropZoneService.clearVisibleZones();\r\n         this.dropZoneService.restoreFamilies();\r\n         if (\r\n            this.treeService.treeData?.length === 1 &&\r\n            this.branch?.getCoordinates().length === 1\r\n         ) {\r\n            //We were dragging the only element in the tree, so we have to\r\n            //remove the placeholder that we added in the dragstart\r\n            this.treeService.placeholder$.next(false);\r\n         }\r\n      }\r\n   }\r\n\r\n   public dragoverHandler(event: DragEvent) {\r\n      if (this.globalEventsService.scrolling === true) {\r\n         return;\r\n      }\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"Can't get current branch during dragover event\");\r\n      }\r\n      const data = this.dragStateService.getData();\r\n      if (data === undefined) {\r\n         //They might be dragging something that isn't a node. Just ignore it.\r\n         return;\r\n      }\r\n      const sourceBranch = data.branch;\r\n      //If trying to drop on self, return.\r\n      if (\r\n         sourceBranch === this.branch ||\r\n         this.branch.getAncestors().includes(sourceBranch)\r\n      ) {\r\n         return;\r\n      }\r\n      const target = (event.currentTarget as HTMLElement).closest(\r\n         \".node-host-container\"\r\n      );\r\n      if (!(target instanceof HTMLElement)) {\r\n         throw new Error(\"Failed to find node host container while dragging\");\r\n      }\r\n      let topLine: number;\r\n      let bottomLine: number;\r\n      if (this.innerBranch?.renderDropZoneInside === false) {\r\n         topLine = target.offsetHeight / 2 - 6;\r\n         bottomLine = topLine;\r\n      } else {\r\n         topLine = target.offsetHeight / 3 - 3; //an imaginary line 1/3 of the way down from the top of the element;\r\n         bottomLine = topLine * 2; //an imaginary line 1/3 of the way up from the bottom of the element;\r\n      }\r\n      const parent = this.branch.getParent();\r\n      let parentData: LimbleTreeNode;\r\n      let parentNestingAllowed = true;\r\n      if (parent?.data !== null) {\r\n         parentData = parent?.data as LimbleTreeNode;\r\n         parentNestingAllowed = isNestingAllowed(\r\n            this.treeService.treeOptions,\r\n            parentData\r\n         );\r\n      }\r\n      /** The y-coordinates of the mouse in relation to the node it is hovering over */\r\n      const offsetY = event.clientY - target.getBoundingClientRect().top;\r\n      const activeDropZone = this.dropZoneService.getActiveDropZone();\r\n      if (\r\n         offsetY < topLine &&\r\n         this.dropZoneAbove !== undefined &&\r\n         parentNestingAllowed &&\r\n         (activeDropZone === null ||\r\n            !DropZone.dropZoneLocationsAreEqual(\r\n               activeDropZone,\r\n               this.dropZoneAbove\r\n            ))\r\n      ) {\r\n         const index = this.branch.getIndex();\r\n         if (index === undefined || index === null) {\r\n            throw new Error(\"can't get branch index\");\r\n         }\r\n         this.dropZoneService.showDropZoneFamily(this.dropZoneAbove, {\r\n            activateLowestInsteadOfFounder: true\r\n         });\r\n         if (suddenTreeExit(event)) {\r\n            this.dropZoneService.clearVisibleZones();\r\n         }\r\n      } else if (\r\n         offsetY < bottomLine &&\r\n         offsetY > topLine &&\r\n         this.innerBranch?.renderDropZoneInside === true &&\r\n         this.innerBranch?.dropZoneInside !== undefined &&\r\n         (activeDropZone === null ||\r\n            !DropZone.dropZoneLocationsAreEqual(\r\n               activeDropZone,\r\n               this.innerBranch.dropZoneInside\r\n            ))\r\n      ) {\r\n         this.dropZoneService.showDropZoneFamily(\r\n            this.innerBranch.dropZoneInside\r\n         );\r\n         if (suddenTreeExit(event)) {\r\n            this.dropZoneService.clearVisibleZones();\r\n         }\r\n      } else if (\r\n         offsetY >= bottomLine &&\r\n         this.dropZoneBelow !== undefined &&\r\n         parentNestingAllowed &&\r\n         (activeDropZone === null ||\r\n            !DropZone.dropZoneLocationsAreEqual(\r\n               activeDropZone,\r\n               this.dropZoneBelow\r\n            )) &&\r\n         this.branch.getChildren().length === 0\r\n      ) {\r\n         const index = this.branch.getIndex();\r\n         if (index === undefined || index === null) {\r\n            throw new Error(\"can't get branch index\");\r\n         }\r\n         this.dropZoneService.showDropZoneFamily(this.dropZoneBelow);\r\n         if (suddenTreeExit(event)) {\r\n            this.dropZoneService.clearVisibleZones();\r\n         }\r\n      }\r\n   }\r\n\r\n   private renderNode() {\r\n      if (this.nodeHost === undefined || this.branch === undefined) {\r\n         throw new Error(\"Failed to render tree node\");\r\n      }\r\n      let component = this.branch.data.component;\r\n      if (component === undefined) {\r\n         component = this.treeService.treeOptions?.defaultComponent;\r\n      }\r\n      if (component === undefined) {\r\n         throw new Error(\"limbleTree requires a component to render\");\r\n      }\r\n      const componentRef = this.componentCreatorService.appendComponent<any>(\r\n         component.class,\r\n         this.nodeHost\r\n      );\r\n      componentRef.instance.nodeData = this.branch.data;\r\n      for (const binding in component.bindings) {\r\n         componentRef.instance[binding] = component.bindings[binding];\r\n      }\r\n   }\r\n\r\n   private registerDropZones(): void {\r\n      this.addDropZoneAbove();\r\n      this.addDropZoneBelow();\r\n   }\r\n\r\n   private addDropZoneAbove(): void {\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"failed to register drop zone above\");\r\n      }\r\n      const parent = this.branch.getParent();\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const index = currentCoordinates[currentCoordinates.length - 1];\r\n      this.dropZoneAbove = new DropZone(\r\n         [...(parent?.getCoordinates() ?? [])],\r\n         index\r\n      );\r\n      this.dropZoneService.addDropZone(this.dropZoneAbove);\r\n   }\r\n\r\n   private addDropZoneBelow(): void {\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"failed to register drop zone below\");\r\n      }\r\n      const parent = this.branch.getParent();\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const index = currentCoordinates[currentCoordinates.length - 1];\r\n      this.dropZoneBelow = new DropZone(\r\n         [...(parent?.getCoordinates() ?? [])],\r\n         index + 1\r\n      );\r\n      this.dropZoneService.addDropZone(this.dropZoneBelow);\r\n   }\r\n\r\n   private updateDropZones(): void {\r\n      this.currentBranchCoordinates = this.branch?.getCoordinates();\r\n      this.updateDropZoneAbove();\r\n      this.updateDropZoneBelow();\r\n      this.updateDropZoneInside();\r\n      this.setDropZoneHosts();\r\n   }\r\n\r\n   private updateDropZoneAbove(): void {\r\n      if (this.branch === undefined || this.dropZoneAbove === undefined) {\r\n         throw new Error(\"failed to update drop zone above\");\r\n      }\r\n      const parent = this.branch.getParent();\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const index = currentCoordinates[currentCoordinates.length - 1];\r\n      const location = this.dropZoneAbove.getLocation();\r\n      location.setParentCoordinates([...(parent?.getCoordinates() ?? [])]);\r\n      location.setInsertIndex(index);\r\n   }\r\n\r\n   private updateDropZoneBelow(): void {\r\n      if (this.branch === undefined || this.dropZoneBelow === undefined) {\r\n         throw new Error(\"failed to update drop zone below\");\r\n      }\r\n      const parent = this.branch.getParent();\r\n      const currentCoordinates = this.branch.getCoordinates();\r\n      const index = currentCoordinates[currentCoordinates.length - 1];\r\n      const location = this.dropZoneBelow.getLocation();\r\n      location.setParentCoordinates([...(parent?.getCoordinates() ?? [])]);\r\n      location.setInsertIndex(index + 1);\r\n   }\r\n\r\n   private updateDropZoneInside(): void {\r\n      if (this.innerBranch?.dropZoneInside === undefined) {\r\n         return;\r\n      }\r\n      if (this.branch === undefined) {\r\n         throw new Error(\"failed to update drop zone inside\");\r\n      }\r\n      const location = this.innerBranch.dropZoneInside.getLocation();\r\n      location.setParentCoordinates([...this.branch.getCoordinates()]);\r\n   }\r\n\r\n   private setDropZoneHosts() {\r\n      if (\r\n         this.dropZoneAbove === undefined ||\r\n         this.dropZoneBelow === undefined\r\n      ) {\r\n         return;\r\n      }\r\n      this.dropZoneAbove.setHost(this.parentHost);\r\n      this.dropZoneBelow.setHost(this.parentHost);\r\n   }\r\n\r\n   private checkForHandle(): void {\r\n      if (\r\n         this.nodeHostContainer === undefined ||\r\n         this.draggableDiv === undefined\r\n      ) {\r\n         return;\r\n      }\r\n      const nodeHostContainerElement = this.nodeHostContainer.nativeElement;\r\n      const handle = nodeHostContainerElement.querySelector(\r\n         \".limble-tree-handle\"\r\n      );\r\n      const draggableDivElement = this.draggableDiv.nativeElement;\r\n      if (!isDraggingAllowed(this.treeService.treeOptions, this.branch?.data)) {\r\n         draggableDivElement.setAttribute(\"draggable\", \"false\");\r\n      } else if (handle === null) {\r\n         draggableDivElement.setAttribute(\"draggable\", \"true\");\r\n      } else {\r\n         handle.addEventListener(\"mousedown\", () => {\r\n            draggableDivElement.setAttribute(\"draggable\", \"true\");\r\n            //For some reason mouseup doesn't fire after a drag, so we use this observable sequence instead.\r\n            const dragging = this.dragStateService.state$.pipe(\r\n               filter((state) => state === \"dragging\"),\r\n               first()\r\n            );\r\n            this.dragStateService.state$\r\n               .pipe(\r\n                  skipUntil(dragging),\r\n                  filter((state) => state === \"idle\"),\r\n                  first()\r\n               )\r\n               .subscribe(() => {\r\n                  draggableDivElement.setAttribute(\"draggable\", \"false\");\r\n               });\r\n         });\r\n      }\r\n   }\r\n}\r\n","<drop-zone\r\n   *ngIf=\"renderDropZoneAbove === true\"\r\n   [dropZone]=\"dropZoneAbove\"\r\n></drop-zone>\r\n<div\r\n   (dragstart)=\"dragstartHandler($event)\"\r\n   (dragend)=\"dragendHandler($event)\"\r\n   class=\"limble-parent-container\"\r\n   #draggableDiv\r\n>\r\n   <div\r\n      class=\"node-host-container\"\r\n      (dragoverNoChangeDetect)=\"dragoverHandler($event)\"\r\n      [dragoverEventThrottle]=\"10\"\r\n      #nodeHostContainer\r\n   >\r\n      <ng-template #nodeHost></ng-template>\r\n   </div>\r\n   <limble-tree-branch\r\n      *ngIf=\"branch !== undefined && renderInnerBranch === true\"\r\n      [branch]=\"branch\"\r\n      #innerBranch\r\n   ></limble-tree-branch>\r\n</div>\r\n<drop-zone\r\n   *ngIf=\"renderDropZoneBelow === true\"\r\n   [dropZone]=\"dropZoneBelow\"\r\n></drop-zone>\r\n"]}