@colijnit/sharedcomponents 1.0.57 → 1.0.58

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 (157) hide show
  1. package/bundles/colijnit-sharedcomponents.umd.js +3555 -6
  2. package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
  3. package/colijnit-sharedcomponents.d.ts +17 -0
  4. package/colijnit-sharedcomponents.metadata.json +1 -1
  5. package/esm2015/colijnit-sharedcomponents.js +18 -1
  6. package/esm2015/lib/businessobject/build-images-and-documentation-result.js +2 -0
  7. package/esm2015/lib/businessobject/co-document-right.bo.js +3 -0
  8. package/esm2015/lib/businessobject/drag-drop-container-element.js +2 -0
  9. package/esm2015/lib/businessobject/drag-drop-container.js +7 -0
  10. package/esm2015/lib/components/activity-list/activity-list.component.js +130 -0
  11. package/esm2015/lib/components/activity-list/activity-list.module.js +24 -0
  12. package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.component.js +47 -0
  13. package/esm2015/lib/components/app-file-dropzone/app-file-dropzone.module.js +20 -0
  14. package/esm2015/lib/components/file-upload/file-upload.component.js +189 -0
  15. package/esm2015/lib/components/file-upload/file-upload.module.js +25 -0
  16. package/esm2015/lib/components/file-upload-popup/file-upload-popup.component.js +397 -0
  17. package/esm2015/lib/components/file-upload-popup/file-upload-popup.module.js +30 -0
  18. package/esm2015/lib/components/files-upload/components/base-file-upload.component.js +469 -0
  19. package/esm2015/lib/components/files-upload/components/drag-drop-container.component.js +115 -0
  20. package/esm2015/lib/components/files-upload/files-upload.component.js +131 -0
  21. package/esm2015/lib/components/files-upload/files-upload.module.js +47 -0
  22. package/esm2015/lib/components/image-display/image-display.component.js +36 -0
  23. package/esm2015/lib/components/image-display/image-display.module.js +23 -0
  24. package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.component.js +89 -0
  25. package/esm2015/lib/components/multi-property-toggler/multiple-property-toggler.module.js +21 -0
  26. package/esm2015/lib/components/tile-renderer/tile-render.component.js +80 -0
  27. package/esm2015/lib/components/tile-renderer/tile-render.module.js +26 -0
  28. package/esm2015/lib/decorator/input-boolean.decorator.js +34 -0
  29. package/esm2015/lib/enum/document-email-report.enum.js +18 -0
  30. package/esm2015/lib/enum/domain-multiple-name.enum.js +13 -0
  31. package/esm2015/lib/enum/file-type.js +14 -0
  32. package/esm2015/lib/enum/files-upload-config-objects.js +3 -0
  33. package/esm2015/lib/enum/icon.enum.js +7 -1
  34. package/esm2015/lib/enum/internal-param.enum.js +38 -0
  35. package/esm2015/lib/enum/read-write-access-config-names.enum.js +2 -0
  36. package/esm2015/lib/enum/table-name.enum.js +86 -0
  37. package/esm2015/lib/enum/tag-category.enum.js +22 -0
  38. package/esm2015/lib/enum/tags-component-config-names.js +2 -0
  39. package/esm2015/lib/enum/tile-size-type.js +7 -0
  40. package/esm2015/lib/event/co-drag-event.js +2 -0
  41. package/esm2015/lib/event/co-drop-event.js +2 -0
  42. package/esm2015/lib/interface/key-value-pair.js +2 -0
  43. package/esm2015/lib/interface/operation-callback-simple-function.js +4 -0
  44. package/esm2015/lib/model/icon-svg.js +7 -1
  45. package/esm2015/lib/model/tag-tree-item.bo.js +16 -0
  46. package/esm2015/lib/model/tree-object.js +15 -0
  47. package/esm2015/lib/pipe/file-type-image.pipe.js +51 -0
  48. package/esm2015/lib/pipe/master-pipes.js +4 -2
  49. package/esm2015/lib/service/drag-drop.service.js +365 -0
  50. package/esm2015/lib/service/shared-connector.service.js +10 -1
  51. package/esm2015/lib/service/shared.service.js +2 -2
  52. package/esm2015/lib/utils/array-utils.js +202 -0
  53. package/esm2015/lib/utils/check-precision-and-scale-result.js +2 -0
  54. package/esm2015/lib/utils/check-within-stepped-bounds-result.js +2 -0
  55. package/esm2015/lib/utils/co-document-shared-field-logic.js +50 -0
  56. package/esm2015/lib/utils/enum-utils.js +128 -0
  57. package/esm2015/lib/utils/is-nill.function.js +5 -0
  58. package/esm2015/lib/utils/number-utils.js +390 -0
  59. package/esm2015/lib/utils/object-utils.js +278 -0
  60. package/esm2015/lib/utils/ref-code-utils.js +49 -0
  61. package/esm2015/lib/utils/string-utils.js +30 -1
  62. package/esm2015/public-api.js +5 -1
  63. package/fesm2015/colijnit-sharedcomponents.js +3528 -6
  64. package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
  65. package/lib/businessobject/build-images-and-documentation-result.d.ts +5 -0
  66. package/lib/businessobject/co-document-right.bo.d.ts +6 -0
  67. package/lib/businessobject/drag-drop-container-element.d.ts +6 -0
  68. package/lib/businessobject/drag-drop-container.d.ts +6 -0
  69. package/lib/components/access/read-write-access.scss +25 -0
  70. package/lib/components/access/style/_layout.scss +23 -0
  71. package/lib/components/access/style/_material-definition.scss +12 -0
  72. package/lib/components/access/style/_theme.scss +4 -0
  73. package/lib/components/access/style/material.scss +4 -0
  74. package/lib/components/activity-list/activity-list.component.d.ts +33 -0
  75. package/lib/components/activity-list/activity-list.module.d.ts +2 -0
  76. package/lib/components/activity-list/style/_layout.scss +68 -0
  77. package/lib/components/activity-list/style/_material-definition.scss +0 -0
  78. package/lib/components/activity-list/style/_theme.scss +4 -0
  79. package/lib/components/activity-list/style/material.scss +4 -0
  80. package/lib/components/app-file-dropzone/app-file-dropzone.component.d.ts +14 -0
  81. package/lib/components/app-file-dropzone/app-file-dropzone.module.d.ts +2 -0
  82. package/lib/components/app-file-dropzone/style/_layout.scss +61 -0
  83. package/lib/components/app-file-dropzone/style/_material-definition.scss +0 -0
  84. package/lib/components/app-file-dropzone/style/_theme.scss +4 -0
  85. package/lib/components/app-file-dropzone/style/material.scss +4 -0
  86. package/lib/components/file-upload/file-upload.component.d.ts +42 -0
  87. package/lib/components/file-upload/file-upload.module.d.ts +2 -0
  88. package/lib/components/file-upload/style/_layout.scss +59 -0
  89. package/lib/components/file-upload/style/_material-definition.scss +2 -0
  90. package/lib/components/file-upload/style/_theme.scss +4 -0
  91. package/lib/components/file-upload/style/material.scss +4 -0
  92. package/lib/components/file-upload-popup/file-upload-popup.component.d.ts +75 -0
  93. package/lib/components/file-upload-popup/file-upload-popup.module.d.ts +2 -0
  94. package/lib/components/file-upload-popup/style/_layout.scss +48 -0
  95. package/lib/components/file-upload-popup/style/_material-definition.scss +2 -0
  96. package/lib/components/file-upload-popup/style/_theme.scss +5 -0
  97. package/lib/components/file-upload-popup/style/material.scss +4 -0
  98. package/lib/components/files-upload/components/base-file-upload.component.d.ts +98 -0
  99. package/lib/components/files-upload/components/drag-drop-container.component.d.ts +34 -0
  100. package/lib/components/files-upload/files-upload.component.d.ts +32 -0
  101. package/lib/components/files-upload/files-upload.module.d.ts +2 -0
  102. package/lib/components/files-upload/style/_layout.scss +49 -0
  103. package/lib/components/files-upload/style/_material-definition.scss +0 -0
  104. package/lib/components/files-upload/style/_theme.scss +5 -0
  105. package/lib/components/files-upload/style/material.scss +4 -0
  106. package/lib/components/image-display/image-display.component.d.ts +14 -0
  107. package/lib/components/image-display/image-display.module.d.ts +2 -0
  108. package/lib/components/image-display/style/_layout.scss +56 -0
  109. package/lib/components/image-display/style/_material-definition.scss +4 -0
  110. package/lib/components/image-display/style/_theme.scss +6 -0
  111. package/lib/components/image-display/style/material.scss +3 -0
  112. package/lib/components/multi-property-toggler/multiple-property-toggler.component.d.ts +27 -0
  113. package/lib/components/multi-property-toggler/multiple-property-toggler.module.d.ts +2 -0
  114. package/lib/components/multi-property-toggler/style/_layout.scss +24 -0
  115. package/lib/components/multi-property-toggler/style/_material-definition.scss +0 -0
  116. package/lib/components/multi-property-toggler/style/_theme.scss +4 -0
  117. package/lib/components/multi-property-toggler/style/material.scss +4 -0
  118. package/lib/components/tile-renderer/style/_layout.scss +90 -0
  119. package/lib/components/tile-renderer/style/_material-definition.scss +0 -0
  120. package/lib/components/tile-renderer/style/_theme.scss +4 -0
  121. package/lib/components/tile-renderer/style/material.scss +4 -0
  122. package/lib/components/tile-renderer/tile-render.component.d.ts +31 -0
  123. package/lib/components/tile-renderer/tile-render.module.d.ts +2 -0
  124. package/lib/decorator/input-boolean.decorator.d.ts +8 -0
  125. package/lib/enum/document-email-report.enum.d.ts +15 -0
  126. package/lib/enum/domain-multiple-name.enum.d.ts +10 -0
  127. package/lib/enum/file-type.d.ts +7 -0
  128. package/lib/enum/files-upload-config-objects.d.ts +22 -0
  129. package/lib/enum/icon.enum.d.ts +6 -0
  130. package/lib/enum/internal-param.enum.d.ts +34 -0
  131. package/lib/enum/read-write-access-config-names.enum.d.ts +4 -0
  132. package/lib/enum/table-name.enum.d.ts +84 -0
  133. package/lib/enum/tag-category.enum.d.ts +19 -0
  134. package/lib/enum/tags-component-config-names.d.ts +4 -0
  135. package/lib/enum/tile-size-type.d.ts +4 -0
  136. package/lib/event/co-drag-event.d.ts +5 -0
  137. package/lib/event/co-drop-event.d.ts +8 -0
  138. package/lib/interface/key-value-pair.d.ts +4 -0
  139. package/lib/interface/operation-callback-simple-function.d.ts +4 -0
  140. package/lib/model/tag-tree-item.bo.d.ts +18 -0
  141. package/lib/model/tree-object.d.ts +8 -0
  142. package/lib/pipe/file-type-image.pipe.d.ts +12 -0
  143. package/lib/service/drag-drop.service.d.ts +86 -0
  144. package/lib/service/shared-connector.service.d.ts +2 -0
  145. package/lib/style/_variables.scss +1 -1
  146. package/lib/utils/array-utils.d.ts +63 -0
  147. package/lib/utils/check-precision-and-scale-result.d.ts +4 -0
  148. package/lib/utils/check-within-stepped-bounds-result.d.ts +8 -0
  149. package/lib/utils/co-document-shared-field-logic.d.ts +7 -0
  150. package/lib/utils/enum-utils.d.ts +31 -0
  151. package/lib/utils/is-nill.function.d.ts +1 -0
  152. package/lib/utils/number-utils.d.ts +125 -0
  153. package/lib/utils/object-utils.d.ts +40 -0
  154. package/lib/utils/ref-code-utils.d.ts +10 -0
  155. package/lib/utils/string-utils.d.ts +16 -0
  156. package/package.json +1 -1
  157. package/public-api.d.ts +4 -0
@@ -0,0 +1,365 @@
1
+ import { Injectable } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import { ArrayUtils } from "../utils/array-utils";
4
+ import { CoOrientation } from "@colijnit/corecomponents_v12";
5
+ import * as i0 from "@angular/core";
6
+ /**
7
+ * Handles drag and drop elements
8
+ */
9
+ export class DragDropService {
10
+ constructor() {
11
+ this.drag = new Subject();
12
+ this.drop = new Subject();
13
+ // Container(s) holding the elements to be dragged.
14
+ this._containers = [];
15
+ this._disabledContainers = [];
16
+ // Drag handle(s) that contains the classes of the handles.
17
+ this._dragHandles = [];
18
+ this._isdragging = false;
19
+ this._clickCounter = 0;
20
+ this._ghostLeft = 0;
21
+ this._ghostTop = 0;
22
+ this._mouseDown = false;
23
+ this._currentMousePosition = { x: 0, y: 0 };
24
+ this._currentMouseOffset = { x: 0, y: 0 };
25
+ // Handles the mouse down event. Saves the current mouse position.
26
+ this._handleMouseDown = (event) => {
27
+ this._currentMousePosition.x = event.screenX;
28
+ this._currentMousePosition.y = event.screenY;
29
+ if (event.buttons !== 1 || event.metaKey || event.ctrlKey) {
30
+ return;
31
+ }
32
+ const element = event.target ? event.target : event.srcElement;
33
+ const dragElement = this._getValidDragDropElement(element, true);
34
+ if (!dragElement) {
35
+ return;
36
+ }
37
+ if (this._disabledContainers.indexOf(dragElement.container) !== -1) {
38
+ return;
39
+ }
40
+ this._dragElement = dragElement;
41
+ this._dragInContainer = dragElement.container.element;
42
+ const offset = this._getOffset();
43
+ this._currentMouseOffset.x = event.clientX - offset.left;
44
+ this._currentMouseOffset.y = event.clientY - offset.top;
45
+ this._mouseDown = true;
46
+ this._handleEventListener(document, "mousemove", this._handleMouseMove);
47
+ this._clickCounter++;
48
+ };
49
+ this._handleMouseUp = (event) => {
50
+ this._mouseDown = false;
51
+ this._handleEventListener(document, "mousemove", this._handleMouseMove, false);
52
+ this._clickCounter--;
53
+ if (this._isdragging) {
54
+ this._endDrag();
55
+ }
56
+ };
57
+ this._handleMouseMove = (event) => {
58
+ // nothing to drag?
59
+ if (!this._dragElement) {
60
+ return;
61
+ }
62
+ // only drag when mouse down and there actually is movement
63
+ if (!this._mouseDown || (this._currentMousePosition.x === event.screenX && this._currentMousePosition.y === event.screenY)) {
64
+ return;
65
+ }
66
+ this._isdragging = true;
67
+ this._startDrag();
68
+ this._drag(event);
69
+ this._currentMousePosition.x = event.screenX;
70
+ this._currentMousePosition.y = event.screenY;
71
+ };
72
+ }
73
+ set renderer(value) {
74
+ this._renderer = value;
75
+ this._setEvents();
76
+ }
77
+ set ghostLeft(value) {
78
+ this._ghostLeft = value;
79
+ this._positionGhostImage();
80
+ }
81
+ set ghostTop(value) {
82
+ this._ghostTop = value;
83
+ this._positionGhostImage();
84
+ }
85
+ ngOnDestroy() {
86
+ this._removeListeners();
87
+ }
88
+ addContainer(container) {
89
+ const direction = (getComputedStyle(container.element).flexDirection === "row" && getComputedStyle(container.element).display === "flex")
90
+ ? CoOrientation.Horizontal
91
+ : CoOrientation.Vertical;
92
+ container.direction = direction;
93
+ this._containers.push(container);
94
+ }
95
+ addDragHandle(handle) {
96
+ this._dragHandles.push(handle);
97
+ }
98
+ removeContainer(container) {
99
+ ArrayUtils.RemoveElement(container, this._containers);
100
+ ArrayUtils.RemoveElement(container, this._disabledContainers);
101
+ if (!this._containers || this._containers.length === 0) {
102
+ this._removeListeners();
103
+ }
104
+ }
105
+ removeDragHandle(handle) {
106
+ ArrayUtils.RemoveElement(handle, this._dragHandles);
107
+ }
108
+ enableContainer(container) {
109
+ ArrayUtils.RemoveElement(container, this._disabledContainers);
110
+ }
111
+ disableContainer(container) {
112
+ this._disabledContainers.push(container);
113
+ }
114
+ _removeListeners() {
115
+ this._handleEventListener(document, "mouseup", this._handleMouseUp, false);
116
+ this._handleEventListener(document, "mousemove", this._handleMouseMove, false);
117
+ }
118
+ _setEvents() {
119
+ this._handleEventListener(document, "mousedown", this._handleMouseDown); //TODO: mousedown only within given containers
120
+ this._handleEventListener(document, "mouseup", this._handleMouseUp);
121
+ }
122
+ _setElementClass(element, elementClass) {
123
+ if (!this._renderer) {
124
+ return;
125
+ }
126
+ this._renderer.addClass(element, elementClass);
127
+ }
128
+ _handleEventListener(element, event, handler, add = true) {
129
+ if (add) {
130
+ element.removeEventListener(event, handler);
131
+ element.addEventListener(event, handler);
132
+ }
133
+ else {
134
+ element.removeEventListener(event, handler);
135
+ }
136
+ }
137
+ // Returns the container that holds given element.
138
+ _getContainerOfElement(element) {
139
+ for (let i = 0, len1 = this._containers.length; i < len1; i++) {
140
+ const container = this._containers[i];
141
+ for (let ii = 0, len2 = container.element.children.length; ii < len2; ii++) {
142
+ if (container.element.children[ii] === element) {
143
+ return container;
144
+ }
145
+ }
146
+ }
147
+ }
148
+ /**
149
+ * Checks if given element is a child of container(s)
150
+ * @param element
151
+ * @returns {number} index of element
152
+ */
153
+ _getElementOfContainer(element) {
154
+ for (let i = 0, len1 = this._containers.length; i < len1; i++) {
155
+ const container = this._containers[i];
156
+ for (let ii = 0, len2 = container.element.children.length; ii < len2; ii++) {
157
+ if (container.element.children[ii] === element) {
158
+ return { container: container, element: element, elementIdx: ii };
159
+ }
160
+ }
161
+ }
162
+ return { container: undefined, element: undefined, elementIdx: -1 };
163
+ }
164
+ /**
165
+ * Returns next sibling of container that contains given element.
166
+ * @param element
167
+ * @returns {any} null if there are no siblings left
168
+ */
169
+ _getNextElementInContainer(element) {
170
+ const container = this._getContainerOfElement(element);
171
+ for (let i = 0, len = container.element.children.length; i < len; i++) {
172
+ if (container.element.children[i] === element) {
173
+ return i < (len - 1) ? { container: container, element: container.element.children[i + 1], elementIdx: i } : null;
174
+ }
175
+ }
176
+ }
177
+ _getDragHandleClicked(element) {
178
+ if (this._dragHandles && this._dragHandles.length > 0) { // check if handle clicked
179
+ while (element) {
180
+ for (let i = 0, len = this._dragHandles.length; i < len; i++) {
181
+ if (element.classList && element.classList.length > 0 && !!this._dragHandles[i]) {
182
+ if (element.classList.contains(this._dragHandles[i])) {
183
+ return true;
184
+ }
185
+ }
186
+ }
187
+ element = element.parentNode === document ? null : element.parentNode;
188
+ }
189
+ return false;
190
+ }
191
+ else {
192
+ return true;
193
+ }
194
+ }
195
+ // Returns element when it's a valid drop target, false otherwise.
196
+ _getValidDragDropElement(element, checkHandle = false) {
197
+ if (checkHandle) {
198
+ const validHandleClicked = this._getDragHandleClicked(element);
199
+ if (!validHandleClicked) {
200
+ return undefined;
201
+ }
202
+ }
203
+ while (element) {
204
+ const elementOfContainer = this._getElementOfContainer(element);
205
+ if (elementOfContainer.elementIdx > -1) {
206
+ return elementOfContainer;
207
+ }
208
+ element = element.parentNode === document ? null : element.parentNode;
209
+ }
210
+ return undefined;
211
+ }
212
+ _getNextSibling(element) {
213
+ return this._getNextElementInContainer(element);
214
+ }
215
+ // Returns the current index of element within its container.
216
+ _indexOf(element) {
217
+ const elementOfContainer = this._getElementOfContainer(element.hasOwnProperty("element") ? element.element : element);
218
+ return elementOfContainer ? elementOfContainer.elementIdx : -1;
219
+ }
220
+ // Creates a ghost image/element of the element being dragged.
221
+ _createGhostImage() {
222
+ if (this._ghostDragImage) {
223
+ return;
224
+ }
225
+ // create ghost drag image
226
+ const offsetRect = this._getOffset();
227
+ this._ghostDragImage = this._dragElement.element.cloneNode(true);
228
+ this._ghostDragImage.style.width = offsetRect.width + "px";
229
+ this._ghostDragImage.style.height = offsetRect.height + "px";
230
+ this.ghostLeft = offsetRect.left;
231
+ this.ghostTop = offsetRect.top;
232
+ this._setElementClass(this._ghostDragImage, "ghost-image");
233
+ this._setElementClass(document.activeElement, "no-select");
234
+ document.body.appendChild(this._ghostDragImage);
235
+ }
236
+ _destroyGhostImage() {
237
+ if (this._ghostDragImage) {
238
+ this._renderer.removeClass(document.activeElement, "no-select");
239
+ document.body.removeChild(this._ghostDragImage);
240
+ this._ghostDragImage = undefined;
241
+ }
242
+ }
243
+ // Positions the ghost image at the given coordinates.
244
+ _positionGhostImage() {
245
+ if (!this._ghostDragImage) {
246
+ return;
247
+ }
248
+ this._ghostDragImage.style.left = this._ghostLeft + "px";
249
+ this._ghostDragImage.style.top = this._ghostTop + "px";
250
+ }
251
+ _getScroll(scrollProp, offsetProp) {
252
+ if (document.activeElement.clientHeight) {
253
+ return document.activeElement[scrollProp];
254
+ }
255
+ return document.body[scrollProp];
256
+ }
257
+ _getOffset() {
258
+ const rect = this._dragElement.element.getBoundingClientRect();
259
+ const scrollLeft = 0;
260
+ const scrollTop = 0;
261
+ return {
262
+ bottom: rect.bottom,
263
+ height: rect.height,
264
+ left: rect.left + scrollLeft,
265
+ right: rect.right,
266
+ top: rect.top + scrollTop,
267
+ width: rect.width
268
+ };
269
+ }
270
+ _determineDroptarget(element, x, y) {
271
+ const dropElement = this._getValidDragDropElement(element);
272
+ if (dropElement) {
273
+ if (dropElement.element !== this._dragElement.element) {
274
+ this._dropTargetElement = dropElement;
275
+ return;
276
+ }
277
+ }
278
+ this._dropTargetElement = null;
279
+ }
280
+ /**
281
+ * Briefly hides the ghost image to be able to determine which element is under mouse.
282
+ * @param x
283
+ * @param y
284
+ * @returns {Element} Top level element
285
+ */
286
+ _getHoveredElement(x, y) {
287
+ this._setElementClass(this._ghostDragImage, "ghost-image-hide");
288
+ const elm = document.elementFromPoint(x, y);
289
+ this._renderer.removeClass(this._ghostDragImage, "ghost-image-hide");
290
+ return elm;
291
+ }
292
+ _animateVisibility(element, transitionTime = 0.2, start = "0", end = "1") {
293
+ if (!element) {
294
+ return;
295
+ }
296
+ const transitionStyle = "opacity " + transitionTime + "s ease-in-out";
297
+ const transition = element.style.transition;
298
+ element.style.transition = transition + (transition ? "," : "") + transitionStyle;
299
+ element.style.opacity = start;
300
+ element.style.opacity = end;
301
+ return new Promise((resolve) => {
302
+ setTimeout(() => {
303
+ resolve();
304
+ }, transitionTime * 1000);
305
+ });
306
+ }
307
+ _animateMove(parent, dragElement, dropTargetElement, down) {
308
+ if (down) { // insert element before
309
+ parent.insertBefore(dragElement.element, dropTargetElement.element);
310
+ }
311
+ else { // insert after
312
+ parent.insertBefore(dragElement.element, dropTargetElement.element.nextSibling);
313
+ }
314
+ }
315
+ _startDrag() {
316
+ this._createGhostImage();
317
+ this._setElementClass(this._dragElement.element, "is-dragged");
318
+ }
319
+ _drag(event) {
320
+ this.ghostLeft = this._ghostLeft + (event.screenX - this._currentMousePosition.x);
321
+ this.ghostTop = this._ghostTop + (event.screenY - this._currentMousePosition.y);
322
+ const x = event.clientX;
323
+ const y = event.clientY;
324
+ const hoveredElement = this._getHoveredElement(x, y);
325
+ this._determineDroptarget(hoveredElement, x, y);
326
+ if (this._dropTargetElement) {
327
+ const down = (this._dropTargetElement.container.direction === CoOrientation.Vertical && event.screenY > this._currentMousePosition.y) ||
328
+ (this._dropTargetElement.container.direction === CoOrientation.Horizontal && event.screenX > this._currentMousePosition.x);
329
+ this._animateMove(this._dropTargetElement.container.element, this._dragElement, this._dropTargetElement, down);
330
+ this.drag.next({
331
+ element: this._dragElement,
332
+ elementIndex: this._dragElement.elementIdx,
333
+ source: this._dropTargetElement.container.element
334
+ });
335
+ this._lastDropTarget = this._dropTargetElement;
336
+ }
337
+ }
338
+ // element is dropped
339
+ _endDrag() {
340
+ this._renderer.removeClass(this._dragElement.element, "is-dragged");
341
+ this._destroyGhostImage();
342
+ this.drop.next({
343
+ element: this._dragElement.element,
344
+ elementIndex: this._dragElement.elementIdx,
345
+ target: this._lastDropTarget ? this._lastDropTarget.element : null,
346
+ targetIndex: this._lastDropTarget ? this._lastDropTarget.elementIdx : -1,
347
+ container: this._lastDropTarget ? this._lastDropTarget.container : null
348
+ });
349
+ this._resetDrag();
350
+ }
351
+ _resetDrag() {
352
+ this._dragElement = null;
353
+ this._dragInContainer = null;
354
+ this._lastDropTarget = null;
355
+ this._isdragging = false;
356
+ }
357
+ }
358
+ DragDropService.ɵprov = i0.ɵɵdefineInjectable({ factory: function DragDropService_Factory() { return new DragDropService(); }, token: DragDropService, providedIn: "root" });
359
+ DragDropService.decorators = [
360
+ { type: Injectable, args: [{
361
+ providedIn: "root"
362
+ },] }
363
+ ];
364
+ DragDropService.ctorParameters = () => [];
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-drop.service.js","sourceRoot":"","sources":["../../../../../projects/sharedcomponents/src/lib/service/drag-drop.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,UAAU,EAAuB,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAI7B,OAAO,EAAC,UAAU,EAAC,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAC,aAAa,EAAC,MAAM,8BAA8B,CAAC;;AAG3D;;GAEG;AAIH,MAAM,OAAO,eAAe;IAmDxB;QA1CO,SAAI,GAAyB,IAAI,OAAO,EAAe,CAAC;QACxD,SAAI,GAAyB,IAAI,OAAO,EAAe,CAAC;QAG/D,mDAAmD;QAC3C,gBAAW,GAAwB,EAAE,CAAC;QAEtC,wBAAmB,GAAwB,EAAE,CAAC;QAItD,2DAA2D;QACnD,iBAAY,GAAU,EAAE,CAAC;QACzB,gBAAW,GAAY,KAAK,CAAC;QAS7B,kBAAa,GAAW,CAAC,CAAC;QAY1B,eAAU,GAAW,CAAC,CAAC;QACvB,cAAS,GAAW,CAAC,CAAC;QAEtB,eAAU,GAAY,KAAK,CAAC;QAE5B,0BAAqB,GAAQ,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,CAAC;QAC1C,wBAAmB,GAAQ,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,CAAC;QAoQhD,kEAAkE;QAC1D,qBAAgB,GAAa,CAAC,KAAiB,EAAQ,EAAE;YAC7D,IAAI,CAAC,qBAAqB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;YAC7C,IAAI,CAAC,qBAAqB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;YAC7C,IAAI,KAAK,CAAC,OAAO,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE;gBACvD,OAAO;aACV;YACD,MAAM,OAAO,GAAQ,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC;YACpE,MAAM,WAAW,GAA6B,IAAI,CAAC,wBAAwB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;YAC3F,IAAI,CAAC,WAAW,EAAE;gBACd,OAAO;aACV;YACD,IAAI,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE;gBAChE,OAAO;aACV;YACD,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YAChC,IAAI,CAAC,gBAAgB,GAAG,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC;YACtD,MAAM,MAAM,GAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;YACtC,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC;YACxD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACxE,IAAI,CAAC,aAAa,EAAE,CAAC;QACzB,CAAC,CAAA;QAEO,mBAAc,GAAa,CAAC,KAAiB,EAAQ,EAAE;YAC3D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;YAC/E,IAAI,CAAC,aAAa,EAAE,CAAC;YAErB,IAAI,IAAI,CAAC,WAAW,EAAE;gBAClB,IAAI,CAAC,QAAQ,EAAE,CAAC;aACnB;QACL,CAAC,CAAA;QAEO,qBAAgB,GAAa,CAAC,KAAiB,EAAQ,EAAE;YAC7D,mBAAmB;YACnB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBACpB,OAAO;aACV;YACD,2DAA2D;YAC3D,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,KAAK,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,qBAAqB,CAAC,CAAC,KAAK,KAAK,CAAC,OAAO,CAAC,EAAE;gBACxH,OAAO;aACV;YACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAClB,IAAI,CAAC,qBAAqB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;YAC7C,IAAI,CAAC,qBAAqB,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC;QACjD,CAAC,CAAA;IAlTD,CAAC;IAnDD,IAAW,QAAQ,CAAC,KAAgB;QAChC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IA6BD,IAAY,SAAS,CAAC,KAAa;QAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,IAAY,QAAQ,CAAC,KAAa;QAC9B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAaD,WAAW;QACP,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAEM,YAAY,CAAC,SAA4B;QAC5C,MAAM,SAAS,GACX,CAAC,gBAAgB,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,aAAa,KAAK,KAAK,IAAI,gBAAgB,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC;YACnH,CAAC,CAAC,aAAa,CAAC,UAAU;YAC1B,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC;QACjC,SAAS,CAAC,SAAS,GAAG,SAAS,CAAC;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;IAEM,aAAa,CAAC,MAAW;QAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAEM,eAAe,CAAC,SAA4B;QAC/C,UAAU,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QACtD,UAAU,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC9D,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;YACpD,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAEM,gBAAgB,CAAC,MAAW;QAC/B,UAAU,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACxD,CAAC;IAEM,eAAe,CAAC,SAA4B;QAC/C,UAAU,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAClE,CAAC;IAEM,gBAAgB,CAAC,SAA4B;QAChD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAC3E,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IACnF,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,8CAA8C;QACvH,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IACxE,CAAC;IAEO,gBAAgB,CAAC,OAAY,EAAE,YAAoB;QACvD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,OAAO;SACV;QACD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IACnD,CAAC;IAEO,oBAAoB,CAAC,OAAY,EAAE,KAAa,EAAE,OAAY,EAAE,MAAe,IAAI;QACvF,IAAI,GAAG,EAAE;YACL,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAC5C,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;SAC5C;aAAM;YACH,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;SAC/C;IACL,CAAC;IAED,kDAAkD;IAC1C,sBAAsB,CAAC,OAAoB;QAC/C,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,IAAI,GAAW,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC3E,MAAM,SAAS,GAAsB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACzD,KAAK,IAAI,EAAE,GAAW,CAAC,EAAE,IAAI,GAAW,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,EAAE;gBACxF,IAAI,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,OAAO,EAAE;oBAC5C,OAAO,SAAS,CAAC;iBACpB;aACJ;SACJ;IACL,CAAC;IAED;;;;OAIG;IACK,sBAAsB,CAAC,OAAY;QACvC,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,IAAI,GAAW,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC3E,MAAM,SAAS,GAAsB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACzD,KAAK,IAAI,EAAE,GAAW,CAAC,EAAE,IAAI,GAAW,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,EAAE,EAAE,EAAE;gBACxF,IAAI,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,OAAO,EAAE;oBAC5C,OAAO,EAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAC,CAAC;iBACnE;aACJ;SACJ;QACD,OAAO,EAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC,EAAC,CAAC;IACtE,CAAC;IAED;;;;OAIG;IACK,0BAA0B,CAAC,OAAoB;QACnD,MAAM,SAAS,GAAsB,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;QAC1E,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,GAAG,GAAW,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YACnF,IAAI,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE;gBAC3C,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAe,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,EAAC,CAAC,CAAC,CAAC,IAAI,CAAC;aAChI;SACJ;IACL,CAAC;IAEO,qBAAqB,CAAC,OAAY;QACtC,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,EAAE,0BAA0B;YAC/E,OAAO,OAAO,EAAE;gBACZ,KAAK,IAAI,CAAC,GAAW,CAAC,EAAE,GAAG,GAAW,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;oBAC1E,IAAI,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE;wBAC7E,IAAI,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE;4BAClD,OAAO,IAAI,CAAC;yBACf;qBACJ;iBACJ;gBACD,OAAO,GAAG,OAAO,CAAC,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;aACzE;YACD,OAAO,KAAK,CAAC;SAChB;aAAM;YACH,OAAO,IAAI,CAAC;SACf;IACL,CAAC;IAED,kEAAkE;IAC1D,wBAAwB,CAAC,OAAY,EAAE,cAAuB,KAAK;QACvE,IAAI,WAAW,EAAE;YACb,MAAM,kBAAkB,GAAY,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;YACxE,IAAI,CAAC,kBAAkB,EAAE;gBACrB,OAAO,SAAS,CAAC;aACpB;SACJ;QACD,OAAO,OAAO,EAAE;YACZ,MAAM,kBAAkB,GAA6B,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;YAC1F,IAAI,kBAAkB,CAAC,UAAU,GAAG,CAAC,CAAC,EAAE;gBACpC,OAAO,kBAAkB,CAAC;aAC7B;YACD,OAAO,GAAG,OAAO,CAAC,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;SACzE;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;IAEO,eAAe,CAAC,OAAoB;QACxC,OAAO,IAAI,CAAC,0BAA0B,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,6DAA6D;IACrD,QAAQ,CAAC,OAAY;QACzB,MAAM,kBAAkB,GAA6B,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAChJ,OAAO,kBAAkB,CAAC,CAAC,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,8DAA8D;IACtD,iBAAiB;QACrB,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,OAAO;SACV;QACD,0BAA0B;QAC1B,MAAM,UAAU,GAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC;QAC3D,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC;QAC7D,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAG,CAAC;QAC/B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC;QAC3D,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;QAC3D,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACpD,CAAC;IAEO,kBAAkB;QACtB,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;YAChE,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAChD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;SACpC;IACL,CAAC;IAED,sDAAsD;IAC9C,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,OAAO;SACV;QACD,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzD,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAC3D,CAAC;IAEO,UAAU,CAAC,UAAkB,EAAE,UAAkB;QACrD,IAAI,QAAQ,CAAC,aAAa,CAAC,YAAY,EAAE;YACrC,OAAO,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SAC7C;QACD,OAAO,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;IAEO,UAAU;QACd,MAAM,IAAI,GAAe,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;QAC3E,MAAM,UAAU,GAAW,CAAC,CAAC;QAC7B,MAAM,SAAS,GAAW,CAAC,CAAC;QAC5B,OAAO;YACH,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,UAAU;YAC5B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,GAAG,EAAE,IAAI,CAAC,GAAG,GAAG,SAAS;YACzB,KAAK,EAAE,IAAI,CAAC,KAAK;SACpB,CAAC;IACN,CAAC;IAEO,oBAAoB,CAAC,OAAY,EAAE,CAAS,EAAE,CAAS;QAC3D,MAAM,WAAW,GAA6B,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC,CAAC;QACrF,IAAI,WAAW,EAAE;YACb,IAAI,WAAW,CAAC,OAAO,KAAK,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE;gBACnD,IAAI,CAAC,kBAAkB,GAAG,WAAW,CAAC;gBACtC,OAAO;aACV;SACJ;QACD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACK,kBAAkB,CAAC,CAAS,EAAE,CAAS;QAC3C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,eAAe,EAAE,kBAAkB,CAAC,CAAC;QAChE,MAAM,GAAG,GAAQ,QAAQ,CAAC,gBAAgB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,EAAE,kBAAkB,CAAC,CAAC;QACrE,OAAO,GAAG,CAAC;IACf,CAAC;IAEO,kBAAkB,CAAC,OAAY,EAAE,iBAAyB,GAAG,EAAE,QAAgB,GAAG,EAAE,MAAc,GAAG;QACzG,IAAI,CAAC,OAAO,EAAE;YACV,OAAO;SACV;QACD,MAAM,eAAe,GAAW,UAAU,GAAG,cAAc,GAAG,eAAe,CAAC;QAC9E,MAAM,UAAU,GAAW,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC;QACpD,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,UAAU,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC;QAClF,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;QAC9B,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;QAC5B,OAAO,IAAI,OAAO,CAAO,CAAC,OAAiB,EAAE,EAAE;YAC3C,UAAU,CAAC,GAAG,EAAE;gBACZ,OAAO,EAAE,CAAC;YACd,CAAC,EAAE,cAAc,GAAG,IAAI,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,YAAY,CAAC,MAAmB,EAAE,WAAqC,EAAE,iBAA2C,EAAE,IAAa;QACvI,IAAI,IAAI,EAAE,EAAE,wBAAwB;YAChC,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACvE;aAAM,EAAE,eAAe;YACpB,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;SACnF;IACL,CAAC;IAqDO,UAAU;QACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;IACnE,CAAC;IAEO,KAAK,CAAC,KAAiB;QAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAClF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;QAEhF,MAAM,CAAC,GAAW,KAAK,CAAC,OAAO,CAAC;QAChC,MAAM,CAAC,GAAW,KAAK,CAAC,OAAO,CAAC;QAChC,MAAM,cAAc,GAAQ,IAAI,CAAC,kBAAkB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1D,IAAI,CAAC,oBAAoB,CAAC,cAAc,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAChD,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,MAAM,IAAI,GACN,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,SAAS,KAAK,aAAa,CAAC,QAAQ,IAAI,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC;gBACxH,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,SAAS,KAAK,aAAa,CAAC,UAAU,IAAI,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;YAC/H,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC;YAC/G,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;gBACX,OAAO,EAAE,IAAI,CAAC,YAAY;gBAC1B,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,UAAU;gBAC1C,MAAM,EAAE,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,OAAO;aACpD,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC;SAClD;IACL,CAAC;IAED,qBAAqB;IACb,QAAQ;QACZ,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACpE,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;YACX,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO;YAClC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,UAAU;YAC1C,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;YAClE,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;YACxE,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI;SAC1E,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC7B,CAAC;;;;YAzZJ,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB","sourcesContent":["import {Directive, Injectable, OnDestroy, Renderer2} from \"@angular/core\";\r\nimport {Subject} from \"rxjs\";\r\nimport {CoDropEvent} from \"../event/co-drop-event\";\r\nimport {CoDragEvent} from \"../event/co-drag-event\";\r\nimport {DragDropContainer} from \"../businessobject/drag-drop-container\";\r\nimport {ArrayUtils} from \"../utils/array-utils\";\r\nimport {CoOrientation} from \"@colijnit/corecomponents_v12\";\r\nimport {DragDropContainerElement} from \"../businessobject/drag-drop-container-element\";\r\n\r\n/**\r\n * Handles drag and drop elements\r\n */\r\n@Injectable({\r\n  providedIn: \"root\"\r\n})\r\nexport class DragDropService implements OnDestroy {\r\n    public set renderer(value: Renderer2) {\r\n        this._renderer = value;\r\n        this._setEvents();\r\n    }\r\n\r\n    // ToDo: use drag and drop Subjects instead and track origin and target components\r\n    public dragData: any;\r\n\r\n    public drag: Subject<CoDragEvent> = new Subject<CoDragEvent>();\r\n    public drop: Subject<CoDropEvent> = new Subject<CoDropEvent>();\r\n\r\n    private _renderer: Renderer2;\r\n    // Container(s) holding the elements to be dragged.\r\n    private _containers: DragDropContainer[] = [];\r\n\r\n    private _disabledContainers: DragDropContainer[] = [];\r\n\r\n    private _dropTargetElement: DragDropContainerElement;\r\n\r\n    // Drag handle(s) that contains the classes of the handles.\r\n    private _dragHandles: any[] = [];\r\n    private _isdragging: boolean = false;\r\n    private _dragElement: DragDropContainerElement;\r\n    private _dragInContainer: any;\r\n    private _lastDropTarget: DragDropContainerElement;\r\n    /**\r\n     * Ghost image of the element being dragged\r\n     */\r\n    private _ghostDragImage: any;\r\n\r\n    private _clickCounter: number = 0;\r\n\r\n    private set ghostLeft(value: number) {\r\n        this._ghostLeft = value;\r\n        this._positionGhostImage();\r\n    }\r\n\r\n    private set ghostTop(value: number) {\r\n        this._ghostTop = value;\r\n        this._positionGhostImage();\r\n    }\r\n\r\n    private _ghostLeft: number = 0;\r\n    private _ghostTop: number = 0;\r\n\r\n    private _mouseDown: boolean = false;\r\n\r\n    private _currentMousePosition: any = {x: 0, y: 0};\r\n    private _currentMouseOffset: any = {x: 0, y: 0};\r\n\r\n    constructor() {\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this._removeListeners();\r\n    }\r\n\r\n    public addContainer(container: DragDropContainer): void {\r\n        const direction: CoOrientation =\r\n            (getComputedStyle(container.element).flexDirection === \"row\" && getComputedStyle(container.element).display === \"flex\")\r\n                ? CoOrientation.Horizontal\r\n                : CoOrientation.Vertical;\r\n        container.direction = direction;\r\n        this._containers.push(container);\r\n    }\r\n\r\n    public addDragHandle(handle: any): void {\r\n        this._dragHandles.push(handle);\r\n    }\r\n\r\n    public removeContainer(container: DragDropContainer): void {\r\n        ArrayUtils.RemoveElement(container, this._containers);\r\n        ArrayUtils.RemoveElement(container, this._disabledContainers);\r\n        if (!this._containers || this._containers.length === 0) {\r\n            this._removeListeners();\r\n        }\r\n    }\r\n\r\n    public removeDragHandle(handle: any): void {\r\n        ArrayUtils.RemoveElement(handle, this._dragHandles);\r\n    }\r\n\r\n    public enableContainer(container: DragDropContainer): void {\r\n        ArrayUtils.RemoveElement(container, this._disabledContainers);\r\n    }\r\n\r\n    public disableContainer(container: DragDropContainer): void {\r\n        this._disabledContainers.push(container);\r\n    }\r\n\r\n    private _removeListeners(): void {\r\n        this._handleEventListener(document, \"mouseup\", this._handleMouseUp, false);\r\n        this._handleEventListener(document, \"mousemove\", this._handleMouseMove, false);\r\n    }\r\n\r\n    private _setEvents(): void {\r\n        this._handleEventListener(document, \"mousedown\", this._handleMouseDown); //TODO: mousedown only within given containers\r\n        this._handleEventListener(document, \"mouseup\", this._handleMouseUp);\r\n    }\r\n\r\n    private _setElementClass(element: any, elementClass: string): void {\r\n        if (!this._renderer) {\r\n            return;\r\n        }\r\n        this._renderer.addClass(element, elementClass);\r\n    }\r\n\r\n    private _handleEventListener(element: any, event: string, handler: any, add: boolean = true): void {\r\n        if (add) {\r\n            element.removeEventListener(event, handler);\r\n            element.addEventListener(event, handler);\r\n        } else {\r\n            element.removeEventListener(event, handler);\r\n        }\r\n    }\r\n\r\n    // Returns the container that holds given element.\r\n    private _getContainerOfElement(element: HTMLElement): DragDropContainer {\r\n        for (let i: number = 0, len1: number = this._containers.length; i < len1; i++) {\r\n            const container: DragDropContainer = this._containers[i];\r\n            for (let ii: number = 0, len2: number = container.element.children.length; ii < len2; ii++) {\r\n                if (container.element.children[ii] === element) {\r\n                    return container;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Checks if given element is a child of container(s)\r\n     * @param element\r\n     * @returns {number} index of element\r\n     */\r\n    private _getElementOfContainer(element: any): DragDropContainerElement {\r\n        for (let i: number = 0, len1: number = this._containers.length; i < len1; i++) {\r\n            const container: DragDropContainer = this._containers[i];\r\n            for (let ii: number = 0, len2: number = container.element.children.length; ii < len2; ii++) {\r\n                if (container.element.children[ii] === element) {\r\n                    return {container: container, element: element, elementIdx: ii};\r\n                }\r\n            }\r\n        }\r\n        return {container: undefined, element: undefined, elementIdx: -1};\r\n    }\r\n\r\n    /**\r\n     * Returns next sibling of container that contains given element.\r\n     * @param element\r\n     * @returns {any} null if there are no siblings left\r\n     */\r\n    private _getNextElementInContainer(element: HTMLElement): DragDropContainerElement {\r\n        const container: DragDropContainer = this._getContainerOfElement(element);\r\n        for (let i: number = 0, len: number = container.element.children.length; i < len; i++) {\r\n            if (container.element.children[i] === element) {\r\n                return i < (len - 1) ? {container: container, element: <HTMLElement>container.element.children[i + 1], elementIdx: i} : null;\r\n            }\r\n        }\r\n    }\r\n\r\n    private _getDragHandleClicked(element: any): boolean {\r\n        if (this._dragHandles && this._dragHandles.length > 0) { // check if handle clicked\r\n            while (element) {\r\n                for (let i: number = 0, len: number = this._dragHandles.length; i < len; i++) {\r\n                    if (element.classList && element.classList.length > 0 && !!this._dragHandles[i]) {\r\n                        if (element.classList.contains(this._dragHandles[i])) {\r\n                            return true;\r\n                        }\r\n                    }\r\n                }\r\n                element = element.parentNode === document ? null : element.parentNode;\r\n            }\r\n            return false;\r\n        } else {\r\n            return true;\r\n        }\r\n    }\r\n\r\n    // Returns element when it's a valid drop target, false otherwise.\r\n    private _getValidDragDropElement(element: any, checkHandle: boolean = false): DragDropContainerElement {\r\n        if (checkHandle) {\r\n            const validHandleClicked: boolean = this._getDragHandleClicked(element);\r\n            if (!validHandleClicked) {\r\n                return undefined;\r\n            }\r\n        }\r\n        while (element) {\r\n            const elementOfContainer: DragDropContainerElement = this._getElementOfContainer(element);\r\n            if (elementOfContainer.elementIdx > -1) {\r\n                return elementOfContainer;\r\n            }\r\n            element = element.parentNode === document ? null : element.parentNode;\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    private _getNextSibling(element: HTMLElement): DragDropContainerElement {\r\n        return this._getNextElementInContainer(element);\r\n    }\r\n\r\n    // Returns the current index of element within its container.\r\n    private _indexOf(element: any): number {\r\n        const elementOfContainer: DragDropContainerElement = this._getElementOfContainer(element.hasOwnProperty(\"element\") ? element.element : element);\r\n        return elementOfContainer ? elementOfContainer.elementIdx : -1;\r\n    }\r\n\r\n    // Creates a ghost image/element of the element being dragged.\r\n    private _createGhostImage(): void {\r\n        if (this._ghostDragImage) {\r\n            return;\r\n        }\r\n        // create ghost drag image\r\n        const offsetRect: any = this._getOffset();\r\n        this._ghostDragImage = this._dragElement.element.cloneNode(true);\r\n        this._ghostDragImage.style.width = offsetRect.width + \"px\";\r\n        this._ghostDragImage.style.height = offsetRect.height + \"px\";\r\n        this.ghostLeft = offsetRect.left;\r\n        this.ghostTop = offsetRect.top;\r\n        this._setElementClass(this._ghostDragImage, \"ghost-image\");\r\n        this._setElementClass(document.activeElement, \"no-select\");\r\n        document.body.appendChild(this._ghostDragImage);\r\n    }\r\n\r\n    private _destroyGhostImage(): void {\r\n        if (this._ghostDragImage) {\r\n            this._renderer.removeClass(document.activeElement, \"no-select\");\r\n            document.body.removeChild(this._ghostDragImage);\r\n            this._ghostDragImage = undefined;\r\n        }\r\n    }\r\n\r\n    // Positions the ghost image at the given coordinates.\r\n    private _positionGhostImage(): void {\r\n        if (!this._ghostDragImage) {\r\n            return;\r\n        }\r\n        this._ghostDragImage.style.left = this._ghostLeft + \"px\";\r\n        this._ghostDragImage.style.top = this._ghostTop + \"px\";\r\n    }\r\n\r\n    private _getScroll(scrollProp: string, offsetProp: string): any {\r\n        if (document.activeElement.clientHeight) {\r\n            return document.activeElement[scrollProp];\r\n        }\r\n        return document.body[scrollProp];\r\n    }\r\n\r\n    private _getOffset(): ClientRect {\r\n        const rect: ClientRect = this._dragElement.element.getBoundingClientRect();\r\n        const scrollLeft: number = 0;\r\n        const scrollTop: number = 0;\r\n        return {\r\n            bottom: rect.bottom,\r\n            height: rect.height,\r\n            left: rect.left + scrollLeft,\r\n            right: rect.right,\r\n            top: rect.top + scrollTop,\r\n            width: rect.width\r\n        };\r\n    }\r\n\r\n    private _determineDroptarget(element: any, x: number, y: number): void {\r\n        const dropElement: DragDropContainerElement = this._getValidDragDropElement(element);\r\n        if (dropElement) {\r\n            if (dropElement.element !== this._dragElement.element) {\r\n                this._dropTargetElement = dropElement;\r\n                return;\r\n            }\r\n        }\r\n        this._dropTargetElement = null;\r\n    }\r\n\r\n    /**\r\n     * Briefly hides the ghost image to be able to determine which element is under mouse.\r\n     * @param x\r\n     * @param y\r\n     * @returns {Element} Top level element\r\n     */\r\n    private _getHoveredElement(x: number, y: number): any {\r\n        this._setElementClass(this._ghostDragImage, \"ghost-image-hide\");\r\n        const elm: any = document.elementFromPoint(x, y);\r\n        this._renderer.removeClass(this._ghostDragImage, \"ghost-image-hide\");\r\n        return elm;\r\n    }\r\n\r\n    private _animateVisibility(element: any, transitionTime: number = 0.2, start: string = \"0\", end: string = \"1\"): Promise<void> {\r\n        if (!element) {\r\n            return;\r\n        }\r\n        const transitionStyle: string = \"opacity \" + transitionTime + \"s ease-in-out\";\r\n        const transition: string = element.style.transition;\r\n        element.style.transition = transition + (transition ? \",\" : \"\") + transitionStyle;\r\n        element.style.opacity = start;\r\n        element.style.opacity = end;\r\n        return new Promise<void>((resolve: Function) => {\r\n            setTimeout(() => {\r\n                resolve();\r\n            }, transitionTime * 1000);\r\n        });\r\n    }\r\n\r\n    private _animateMove(parent: HTMLElement, dragElement: DragDropContainerElement, dropTargetElement: DragDropContainerElement, down: boolean): void {\r\n        if (down) { // insert element before\r\n            parent.insertBefore(dragElement.element, dropTargetElement.element);\r\n        } else { // insert after\r\n            parent.insertBefore(dragElement.element, dropTargetElement.element.nextSibling);\r\n        }\r\n    }\r\n\r\n    // Handles the mouse down event. Saves the current mouse position.\r\n    private _handleMouseDown: Function = (event: MouseEvent): void => {\r\n        this._currentMousePosition.x = event.screenX;\r\n        this._currentMousePosition.y = event.screenY;\r\n        if (event.buttons !== 1 || event.metaKey || event.ctrlKey) {\r\n            return;\r\n        }\r\n        const element: any = event.target ? event.target : event.srcElement;\r\n        const dragElement: DragDropContainerElement = this._getValidDragDropElement(element, true);\r\n        if (!dragElement) {\r\n            return;\r\n        }\r\n        if (this._disabledContainers.indexOf(dragElement.container) !== -1) {\r\n            return;\r\n        }\r\n        this._dragElement = dragElement;\r\n        this._dragInContainer = dragElement.container.element;\r\n        const offset: any = this._getOffset();\r\n        this._currentMouseOffset.x = event.clientX - offset.left;\r\n        this._currentMouseOffset.y = event.clientY - offset.top;\r\n        this._mouseDown = true;\r\n        this._handleEventListener(document, \"mousemove\", this._handleMouseMove);\r\n        this._clickCounter++;\r\n    }\r\n\r\n    private _handleMouseUp: Function = (event: MouseEvent): void => {\r\n        this._mouseDown = false;\r\n        this._handleEventListener(document, \"mousemove\", this._handleMouseMove, false);\r\n        this._clickCounter--;\r\n\r\n        if (this._isdragging) {\r\n            this._endDrag();\r\n        }\r\n    }\r\n\r\n    private _handleMouseMove: Function = (event: MouseEvent): void => {\r\n        // nothing to drag?\r\n        if (!this._dragElement) {\r\n            return;\r\n        }\r\n        // only drag when mouse down and there actually is movement\r\n        if (!this._mouseDown || (this._currentMousePosition.x === event.screenX && this._currentMousePosition.y === event.screenY)) {\r\n            return;\r\n        }\r\n        this._isdragging = true;\r\n        this._startDrag();\r\n        this._drag(event);\r\n        this._currentMousePosition.x = event.screenX;\r\n        this._currentMousePosition.y = event.screenY;\r\n    }\r\n\r\n    private _startDrag(): void {\r\n        this._createGhostImage();\r\n        this._setElementClass(this._dragElement.element, \"is-dragged\");\r\n    }\r\n\r\n    private _drag(event: MouseEvent): void {\r\n        this.ghostLeft = this._ghostLeft + (event.screenX - this._currentMousePosition.x);\r\n        this.ghostTop = this._ghostTop + (event.screenY - this._currentMousePosition.y);\r\n\r\n        const x: number = event.clientX;\r\n        const y: number = event.clientY;\r\n        const hoveredElement: any = this._getHoveredElement(x, y);\r\n        this._determineDroptarget(hoveredElement, x, y);\r\n        if (this._dropTargetElement) {\r\n            const down: boolean =\r\n                (this._dropTargetElement.container.direction === CoOrientation.Vertical && event.screenY > this._currentMousePosition.y) ||\r\n                (this._dropTargetElement.container.direction === CoOrientation.Horizontal && event.screenX > this._currentMousePosition.x);\r\n            this._animateMove(this._dropTargetElement.container.element, this._dragElement, this._dropTargetElement, down);\r\n            this.drag.next({\r\n                element: this._dragElement,\r\n                elementIndex: this._dragElement.elementIdx,\r\n                source: this._dropTargetElement.container.element\r\n            });\r\n            this._lastDropTarget = this._dropTargetElement;\r\n        }\r\n    }\r\n\r\n    // element is dropped\r\n    private _endDrag(): void {\r\n        this._renderer.removeClass(this._dragElement.element, \"is-dragged\");\r\n        this._destroyGhostImage();\r\n        this.drop.next({\r\n            element: this._dragElement.element,\r\n            elementIndex: this._dragElement.elementIdx,\r\n            target: this._lastDropTarget ? this._lastDropTarget.element : null,\r\n            targetIndex: this._lastDropTarget ? this._lastDropTarget.elementIdx : -1, // items are already shifted so subtract 1 from target index\r\n            container: this._lastDropTarget ? this._lastDropTarget.container : null\r\n        });\r\n        this._resetDrag();\r\n    }\r\n\r\n    private _resetDrag(): void {\r\n        this._dragElement = null;\r\n        this._dragInContainer = null;\r\n        this._lastDropTarget = null;\r\n        this._isdragging = false;\r\n    }\r\n}\r\n"]}