@libs-ui/components-drag-drop 0.2.127 → 0.2.129

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.
@@ -1,14 +1,14 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
2
  import { Directive, ElementRef, effect, inject, input, output, signal } from "@angular/core";
3
- import { checkMouseOverInContainer, checkViewInScreen, get, getViewport } from "@libs-ui/utils";
4
- import { fromEvent, mergeMap, startWith, takeUntil, tap, throttleTime } from "rxjs";
3
+ import { checkMouseOverInContainer, checkViewInScreen, get, getDragEventByElement, getViewport } from "@libs-ui/utils";
4
+ import { fromEvent, takeUntil, tap, throttleTime } from "rxjs";
5
5
  import { LibsUiDragItemInContainerVirtualScrollDirective } from "./drag-item-in-container-virtual-scroll.directive";
6
6
  import * as i0 from "@angular/core";
7
7
  export class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScrollDirective {
8
- /* PROPERTY */
8
+ // #region PROPERTY
9
9
  isDragOver = signal(false);
10
10
  isDragging = signal(false);
11
- /* INPUT */
11
+ // #region INPUT
12
12
  //setup 3 field phía dưới nếu đang sử dụng item trong virtual-scroll
13
13
  fieldId = input('');
14
14
  item = input(undefined);
@@ -24,13 +24,13 @@ export class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScr
24
24
  elementContainer = input();
25
25
  zIndex = input(1300, { transform: value => value ?? 1300 });
26
26
  disable = input();
27
- /* OUTPUT */
27
+ // #region OUTPUT
28
28
  outDragStart = output();
29
29
  outDragOver = output();
30
30
  outDragLeave = output();
31
31
  outDragEnd = output();
32
32
  outDropped = output();
33
- /* INJECT */
33
+ // #region INJECT
34
34
  elementRef = inject(ElementRef);
35
35
  constructor() {
36
36
  super();
@@ -122,49 +122,51 @@ export class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScr
122
122
  }
123
123
  contextMenu = true;
124
124
  }), takeUntil(this.onDestroy)).subscribe();
125
- const documentMouseUp = fromEvent(document, 'mouseup')
126
- .pipe(tap((eventMouseup) => {
127
- this.updateMouseEventsWhenMoveOverIframe('auto');
128
- this.dragDropService.resetItemClick();
129
- stopEventMouse(eventMouseup);
130
- if (this.disable() || element.getAttribute('disableDragContainer') || contextMenu || !this.isDragging()) {
131
- contextMenu = false;
132
- return;
133
- }
134
- contextMenu = false;
135
- this.isDragging.set(false);
136
- element.removeAttribute(this.dragDropService.TargetItemDragFlag);
137
- if (this.itemInContainerVirtualScroll()) {
138
- return;
139
- }
140
- const mousePosition = { clientX: eventMouseup.clientX, clientY: eventMouseup.clientY };
141
- if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {
142
- const result = this.getClientPosition(element, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());
143
- mousePosition.clientX = result.clientX;
144
- mousePosition.clientY = result.clientY;
145
- }
146
- const dragEndEvent = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };
147
- this.dragDropService.ItemDragInfo = undefined;
148
- this.dragDropService.OnDragEnd.next(dragEndEvent);
149
- this.outDragEnd.emit(dragEndEvent);
150
- document.body.classList.remove('!select-none');
151
- nodeClone.classList.remove('libs-ui-drag-drop-item-dragging');
152
- styleTag.remove();
153
- updatePositionElementRootAndRemoveNodeClone();
154
- }), takeUntil(this.onDestroy));
155
- const elementMouseDown = fromEvent(element, 'mousedown').pipe(tap(eventMousedown => {
156
- this.dragDropService.ItemClick = element;
157
- contextMenu = false;
158
- this.updateMouseEventsWhenMoveOverIframe('none');
159
- if ((this.disable() || element.getAttribute('disableDragContainer') || !this.isDragging() || this.itemInContainerVirtualScroll()) && !this.onlyMouseDownStopEvent()) {
160
- return;
161
- }
162
- stopEventMouse(eventMousedown);
163
- }), takeUntil(this.onDestroy));
164
- const documentMouseMove = fromEvent(document, 'mousemove').pipe(tap((eventMousemove) => stopEventMouse(eventMousemove)), takeUntil((documentMouseUp)), takeUntil(this.onDestroy));
165
- const drag = elementMouseDown.pipe(mergeMap((mouseEvent) => documentMouseMove.pipe(startWith((mouseEvent)))));
166
125
  let ignoreMousedown = false;
167
- drag.pipe(tap((dragMouseEvent) => {
126
+ getDragEventByElement({
127
+ elementMouseDown: element,
128
+ functionMouseDown: (event) => {
129
+ this.dragDropService.ItemClick = element;
130
+ contextMenu = false;
131
+ this.updateMouseEventsWhenMoveOverIframe('none');
132
+ if ((this.disable() || element.getAttribute('disableDragContainer') || !this.isDragging() || this.itemInContainerVirtualScroll()) && !this.onlyMouseDownStopEvent()) {
133
+ return;
134
+ }
135
+ stopEventMouse(event);
136
+ },
137
+ functionMouseMove: (event) => {
138
+ stopEventMouse(event);
139
+ },
140
+ functionMouseUp: (event) => {
141
+ this.updateMouseEventsWhenMoveOverIframe('auto');
142
+ this.dragDropService.resetItemClick();
143
+ stopEventMouse(event);
144
+ if (this.disable() || element.getAttribute('disableDragContainer') || contextMenu || !this.isDragging()) {
145
+ contextMenu = false;
146
+ return;
147
+ }
148
+ contextMenu = false;
149
+ this.isDragging.set(false);
150
+ element.removeAttribute(this.dragDropService.TargetItemDragFlag);
151
+ if (this.itemInContainerVirtualScroll()) {
152
+ return;
153
+ }
154
+ const mousePosition = { clientX: event.clientX, clientY: event.clientY };
155
+ if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {
156
+ const result = this.getClientPosition(element, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());
157
+ mousePosition.clientX = result.clientX;
158
+ mousePosition.clientY = result.clientY;
159
+ }
160
+ const dragEndEvent = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };
161
+ this.dragDropService.ItemDragInfo = undefined;
162
+ this.dragDropService.OnDragEnd.next(dragEndEvent);
163
+ this.outDragEnd.emit(dragEndEvent);
164
+ nodeClone.classList.remove('libs-ui-drag-drop-item-dragging');
165
+ styleTag.remove();
166
+ updatePositionElementRootAndRemoveNodeClone();
167
+ },
168
+ onDestroy: this.onDestroy
169
+ }).pipe(tap((dragMouseEvent) => {
168
170
  const rectElement = element.getBoundingClientRect();
169
171
  const viewport = getViewport();
170
172
  if (this.disable() || element.getAttribute('disableDragContainer') || !dragMouseEvent.clientX || (!ignoreMousedown && dragMouseEvent.type === 'mousedown' && rectElement.height + rectElement.top >= viewport.height)) {
@@ -177,7 +179,7 @@ export class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScr
177
179
  if (distanceStartElementAndMouseTop === -1) {
178
180
  distanceStartElementAndMouseTop = clientY - rectElement.top;
179
181
  }
180
- }), takeUntil(this.onDestroy)).subscribe(dragMouseEvent => {
182
+ })).subscribe(dragMouseEvent => {
181
183
  if (this.dragDropService.ItemClick.filter(item => item !== element).some(item => element.contains(item))) {
182
184
  return;
183
185
  }
@@ -206,7 +208,6 @@ export class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScr
206
208
  nodeClone.style.height = `${rectElement.height}px`;
207
209
  nodeClone.style.left = `${-999}px`;
208
210
  nodeClone.style.top = `${-999}px`;
209
- document.body.classList.add('!select-none');
210
211
  document.body.append(nodeClone);
211
212
  if (this.dragRootElement()) {
212
213
  element.classList.add('opacity-0');
@@ -260,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
260
261
  standalone: true
261
262
  }]
262
263
  }], ctorParameters: () => [] });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-item.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/drag-drop/src/drag-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AfterViewInit, Directive, ElementRef, OnDestroy, effect, inject, input, output, signal } from \"@angular/core\";\nimport { IBoundingClientRect } from \"@libs-ui/interfaces-types\";\nimport { checkMouseOverInContainer, checkViewInScreen, get, getViewport } from \"@libs-ui/utils\";\nimport { Observable, fromEvent, mergeMap, startWith, takeUntil, tap, throttleTime } from \"rxjs\";\nimport { LibsUiDragItemInContainerVirtualScrollDirective } from \"./drag-item-in-container-virtual-scroll.directive\";\nimport { IDragEnd, IDragLeave, IDragOver, IDragStart, IDrop } from \"./interfaces/event.interface\";\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: \"[LibsUiDragItemDirective]\",\n  standalone: true\n})\nexport class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScrollDirective implements AfterViewInit, OnDestroy {\n  /* PROPERTY */\n  private isDragOver = signal<boolean>(false);\n  private isDragging = signal<boolean>(false);\n\n  /* INPUT */\n  //setup 3 field phía dưới nếu đang sử dụng item trong virtual-scroll \n  readonly fieldId = input<string>('');\n  readonly item = input<any>(undefined);\n  readonly itemInContainerVirtualScroll = input<boolean>();\n  //----------------------------------\n  readonly throttleTimeHandlerDraggingEvent = input<number, number | undefined>(0, { transform: value => value || 0 });\n  readonly ignoreStopEvent = input<boolean>();\n  readonly onlyMouseDownStopEvent = input<boolean>();\n  readonly dragRootElement = input<boolean>();\n  readonly groupName = input<string, string | undefined>('groupDragAndDropDefault', { transform: value => value ?? 'groupDragAndDropDefault' });\n  readonly dragBoundary = input<boolean>();\n  readonly dragBoundaryAcceptMouseLeaveContainer = input<boolean>();\n  readonly elementContainer = input<HTMLElement>();\n  readonly zIndex = input<number, number | undefined>(1300, { transform: value => value ?? 1300 });\n  readonly disable = input<boolean>();\n\n  /* OUTPUT */\n  readonly outDragStart = output<IDragStart>();\n  readonly outDragOver = output<IDragOver>();\n  readonly outDragLeave = output<IDragLeave>();\n  readonly outDragEnd = output<IDragEnd>();\n  readonly outDropped = output<IDrop>();\n\n  /* INJECT */\n  private elementRef = inject(ElementRef);\n\n  constructor() {\n    super();\n    effect(() => {\n      if (!this.elementRef?.nativeElement) {\n        return;\n      }\n      const element = this.elementRef.nativeElement as HTMLElement;\n\n      element.classList.remove(`${this.dragDropService.ClassItemDefine}-disable`);\n      if (this.disable() && !element.classList.contains(`${this.dragDropService.ClassItemDefine}-disable`)) {\n        element.classList.add(`${this.dragDropService.ClassItemDefine}-disable`);\n      }\n    });\n  }\n\n  override ngAfterViewInit() {\n    const element = this.elementRef.nativeElement as HTMLElement;\n    if (this.fieldId()) {\n      element.setAttribute('field_id', this.fieldId());\n      if (this.item()) {\n        element.setAttribute('item_id', get(this.item(), this.fieldId()));\n      }\n    }\n    element.setAttribute('groupName', this.groupName());\n    element.classList.add(this.dragDropService.ClassItemDefine);\n    this.dragDropService.OnDragging.pipe(throttleTime(this.throttleTimeHandlerDraggingEvent()), takeUntil(this.onDestroy)).subscribe((eventDragging) => {\n      if (this.disable() || element.getAttribute('disableDragContainer') || (this.fieldId() && this.item() && eventDragging.elementDrag.getAttribute('item_id') === get(this.item(), this.fieldId()))) {\n        return;\n      }\n      const containerById = this.dragDropService.Container().get(element.getAttribute('groupID') || '');\n\n      if (containerById) {\n        if (eventDragging.elementKeepContainer || !this.dragDropService.checkElementOverAcceptElementDrag(containerById.element.getAttribute('groupName'), eventDragging.elementDrag.getAttribute('groupName'), eventDragging.elementDrag.getAttribute('dropToGroupName'))) {\n          return;\n        }\n      }\n      if (checkMouseOverInContainer(eventDragging.mousePosition, element) && element !== eventDragging.elementDrag && containerById && checkViewInScreen(containerById.element, element, containerById.elementScroll)) {\n        if (this.isDragOver()) {\n          return;\n        }\n        const eventDragOver = { ...eventDragging, elementDragOver: element };\n\n        this.dragDropService.OnDragOver.next(eventDragOver);\n        this.outDragOver.emit(eventDragOver);\n        this.isDragOver.set(true);\n\n        return;\n      }\n\n      if (this.isDragOver()) {\n        const eventDragLeave = { ...eventDragging, elementDragLeave: element };\n        this.isDragOver.set(false);\n        this.dragDropService.OnDragLeave.next(eventDragLeave);\n        this.outDragLeave.emit(eventDragLeave);\n      }\n    });\n\n    this.dragDropService.OnDropContainer.pipe(takeUntil(this.onDestroy)).subscribe((eventDrop) => {\n      if (eventDrop.elementDrop !== element) {\n        return;\n      }\n      const dropEvent = { elementDrag: eventDrop.elementDrag, elementDrop: element, itemDragInfo: eventDrop.itemDragInfo };\n\n      this.outDropped.emit(dropEvent);\n    });\n    const styleTag = document.createElement(\"style\");\n\n    styleTag.textContent = `.libs-ui-drag-drop-item-dragging{cursor:move}`;\n    let nodeClone = element;\n    let distanceStartElementAndMouseLeft = -1;\n    let distanceStartElementAndMouseTop = -1;\n    let contextMenu = false;\n    const stopEventMouse = (mouseEvent: MouseEvent) => {\n      if (!this.ignoreStopEvent()) {\n        mouseEvent.preventDefault();\n        mouseEvent.stopPropagation();\n      }\n    };\n    const updatePositionElementRootAndRemoveNodeClone = () => {\n      if (this.dragRootElement()) {\n        const containerById = this.dragDropService.Container().get(element.getAttribute('groupID') || '');\n\n        const containerItem = this.elementContainer() || containerById?.elementScroll || containerById?.element || document.body;\n        const rectContainer = containerItem.getBoundingClientRect();\n        const rectNodeClone = nodeClone.getBoundingClientRect();\n        const numberSub = Number((getComputedStyle(containerItem).border.match(/\\d+px/gi) || ['0'])[0].replace(/\\D+/ig, '')).valueOf();\n\n        element.style.left = (rectNodeClone.left - rectContainer.left - numberSub) + 'px';\n        element.style.top = (rectNodeClone.top - rectContainer.top - numberSub) + 'px';\n        element.classList.remove('opacity-0');\n      }\n      distanceStartElementAndMouseLeft = -1;\n      distanceStartElementAndMouseTop = -1;\n      nodeClone.remove();\n    };\n\n    fromEvent(document, 'contextmenu').pipe(\n      tap(() => {\n        if (this.isDragging()) {\n          updatePositionElementRootAndRemoveNodeClone();\n        }\n        contextMenu = true;\n\n      }),\n      takeUntil(this.onDestroy)\n    ).subscribe();\n\n    const documentMouseUp = fromEvent<MouseEvent>(document, 'mouseup')\n      .pipe(\n        tap((eventMouseup) => {\n          this.updateMouseEventsWhenMoveOverIframe('auto');\n          this.dragDropService.resetItemClick();\n          stopEventMouse(eventMouseup);\n          if (this.disable() || element.getAttribute('disableDragContainer') || contextMenu || !this.isDragging()) {\n            contextMenu = false;\n\n            return;\n          }\n          contextMenu = false;\n          this.isDragging.set(false);\n          element.removeAttribute(this.dragDropService.TargetItemDragFlag);\n          if (this.itemInContainerVirtualScroll()) {\n            return;\n          }\n          const mousePosition = { clientX: eventMouseup.clientX, clientY: eventMouseup.clientY };\n\n          if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {\n            const result = this.getClientPosition(element, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());\n\n            mousePosition.clientX = result.clientX;\n            mousePosition.clientY = result.clientY;\n          }\n          const dragEndEvent = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n          this.dragDropService.ItemDragInfo = undefined;\n          this.dragDropService.OnDragEnd.next(dragEndEvent);\n          this.outDragEnd.emit(dragEndEvent);\n\n          document.body.classList.remove('!select-none');\n          nodeClone.classList.remove('libs-ui-drag-drop-item-dragging');\n          styleTag.remove();\n\n          updatePositionElementRootAndRemoveNodeClone();\n        }),\n        takeUntil(this.onDestroy)\n      );\n\n    const elementMouseDown = fromEvent<MouseEvent>(element, 'mousedown').pipe(\n      tap(eventMousedown => {\n        this.dragDropService.ItemClick = element;\n        contextMenu = false;\n        this.updateMouseEventsWhenMoveOverIframe('none');\n        if ((this.disable() || element.getAttribute('disableDragContainer') || !this.isDragging() || this.itemInContainerVirtualScroll()) && !this.onlyMouseDownStopEvent()) {\n          return;\n        }\n        stopEventMouse(eventMousedown);\n      }),\n      takeUntil(this.onDestroy)\n    );\n    const documentMouseMove = fromEvent<MouseEvent>(document, 'mousemove').pipe(tap((eventMousemove) => stopEventMouse(eventMousemove)), takeUntil((documentMouseUp)), takeUntil(this.onDestroy));\n    const drag = elementMouseDown.pipe(mergeMap((mouseEvent: MouseEvent) => documentMouseMove.pipe(startWith((mouseEvent))))) as Observable<MouseEvent>;\n    let ignoreMousedown = false;\n\n    drag.pipe(tap((dragMouseEvent: MouseEvent) => {\n      const rectElement = element.getBoundingClientRect();\n      const viewport = getViewport() as IBoundingClientRect;\n\n      if (this.disable() || element.getAttribute('disableDragContainer') || !dragMouseEvent.clientX || (!ignoreMousedown && dragMouseEvent.type === 'mousedown' && rectElement.height + rectElement.top >= viewport.height)) {\n\n        return;\n      }\n      const { clientX, clientY } = dragMouseEvent;\n\n      if (distanceStartElementAndMouseLeft === -1) {\n        distanceStartElementAndMouseLeft = clientX - rectElement.left;\n      }\n\n      if (distanceStartElementAndMouseTop === -1) {\n        distanceStartElementAndMouseTop = clientY - rectElement.top;\n      }\n    }), takeUntil(this.onDestroy)).subscribe(dragMouseEvent => {\n      if (this.dragDropService.ItemClick.filter(item => item !== element).some(item => element.contains(item))) {\n        return;\n      }\n      if (this.disable() || element.getAttribute('disableDragContainer') || !dragMouseEvent.clientX || dragMouseEvent.type === 'mousedown' || contextMenu || (this.itemInContainerVirtualScroll() && this.isDragging())) {\n        return;\n      }\n      ignoreMousedown = true;\n      const { clientX, clientY } = dragMouseEvent;\n      const mousePosition = { clientX, clientY };\n      const rectElement = element.getBoundingClientRect();\n\n      if (!this.isDragging()) {\n        this.isDragging.set(true);\n        const eventDragStart = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n        element.setAttribute(this.dragDropService.TargetItemDragFlag, 'true');\n        this.dragDropService.OnDragStart.next(eventDragStart);\n        eventDragStart.itemDragInfo = this.dragDropService.ItemDragInfo;\n        this.outDragStart.emit(eventDragStart);\n\n        nodeClone = element.cloneNode(true) as HTMLElement;\n        nodeClone.style.zIndex = `${this.zIndex()}`;\n        nodeClone.classList.add('!fixed');\n        nodeClone.classList.remove('libs-ui-drag-drop-item-origin-placeholder');\n        nodeClone.classList.remove('libs-ui-drag-drop-item-placeholder');\n        nodeClone.appendChild(styleTag);\n        nodeClone.classList.add('libs-ui-drag-drop-item-dragging');\n        nodeClone.style.width = `${rectElement.width}px`;\n        nodeClone.style.height = `${rectElement.height}px`;\n        nodeClone.style.left = `${-999}px`;\n        nodeClone.style.top = `${-999}px`;\n        document.body.classList.add('!select-none');\n        document.body.append(nodeClone);\n        if (this.dragRootElement()) {\n          element.classList.add('opacity-0');\n        }\n\n        if (this.itemInContainerVirtualScroll()) {\n          this.dragDropService.OnDragItemInContainerVirtualScroll.next({\n            itemDragInfo: this.dragDropService.ItemDragInfo,\n            elementDrag: nodeClone,\n            distanceStartElementAndMouseTop,\n            distanceStartElementAndMouseLeft,\n            elementContainer: this.elementContainer(),\n            dragBoundary: this.dragBoundary(),\n            dragBoundaryAcceptMouseLeaveContainer: this.dragBoundaryAcceptMouseLeaveContainer(),\n            ignoreStopEvent: this.ignoreStopEvent()\n          });\n\n          return;\n        }\n      }\n      const result = this.getClientPosition(nodeClone, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());\n\n      const elementKeepContainer = result.elementKeepContainer;\n      const left = result.clientX - distanceStartElementAndMouseLeft;\n      const top = result.clientY - distanceStartElementAndMouseTop;\n\n      if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {\n        if (clientX < result.viewport.left) {\n          mousePosition.clientX = result.viewport.left;\n        }\n        if (clientX > result.viewport.width) {\n          mousePosition.clientX = result.viewport.width;\n        }\n        if (clientY < result.viewport.top) {\n          mousePosition.clientY = result.viewport.top;\n        }\n        if (clientY > result.viewport.height) {\n          mousePosition.clientY = result.viewport.height;\n        }\n      }\n      nodeClone.style.left = `${left}px`;\n      nodeClone.style.top = `${top}px`;\n\n      const eventDragging = { mousePosition, elementDrag: nodeClone, elementKeepContainer, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n      this.dragDropService.OnDragging.next(eventDragging);\n    });\n  }\n}"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-item.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/drag-drop/src/drag-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AfterViewInit, Directive, ElementRef, OnDestroy, effect, inject, input, output, signal } from \"@angular/core\";\nimport { IBoundingClientRect } from \"@libs-ui/interfaces-types\";\nimport { checkMouseOverInContainer, checkViewInScreen, get, getDragEventByElement, getViewport } from \"@libs-ui/utils\";\nimport { fromEvent, takeUntil, tap, throttleTime } from \"rxjs\";\nimport { LibsUiDragItemInContainerVirtualScrollDirective } from \"./drag-item-in-container-virtual-scroll.directive\";\nimport { IDragEnd, IDragLeave, IDragOver, IDragStart, IDrop } from \"./interfaces/event.interface\";\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: \"[LibsUiDragItemDirective]\",\n  standalone: true\n})\nexport class LibsUiDragItemDirective extends LibsUiDragItemInContainerVirtualScrollDirective implements AfterViewInit, OnDestroy {\n  // #region PROPERTY\n  private isDragOver = signal<boolean>(false);\n  private isDragging = signal<boolean>(false);\n\n  // #region INPUT\n  //setup 3 field phía dưới nếu đang sử dụng item trong virtual-scroll \n  readonly fieldId = input<string>('');\n  readonly item = input<any>(undefined);\n  readonly itemInContainerVirtualScroll = input<boolean>();\n  //----------------------------------\n  readonly throttleTimeHandlerDraggingEvent = input<number, number | undefined>(0, { transform: value => value || 0 });\n  readonly ignoreStopEvent = input<boolean>();\n  readonly onlyMouseDownStopEvent = input<boolean>();\n  readonly dragRootElement = input<boolean>();\n  readonly groupName = input<string, string | undefined>('groupDragAndDropDefault', { transform: value => value ?? 'groupDragAndDropDefault' });\n  readonly dragBoundary = input<boolean>();\n  readonly dragBoundaryAcceptMouseLeaveContainer = input<boolean>();\n  readonly elementContainer = input<HTMLElement>();\n  readonly zIndex = input<number, number | undefined>(1300, { transform: value => value ?? 1300 });\n  readonly disable = input<boolean>();\n\n  // #region OUTPUT\n  readonly outDragStart = output<IDragStart>();\n  readonly outDragOver = output<IDragOver>();\n  readonly outDragLeave = output<IDragLeave>();\n  readonly outDragEnd = output<IDragEnd>();\n  readonly outDropped = output<IDrop>();\n\n  // #region INJECT\n  private elementRef = inject(ElementRef);\n\n  constructor() {\n    super();\n    effect(() => {\n      if (!this.elementRef?.nativeElement) {\n        return;\n      }\n      const element = this.elementRef.nativeElement as HTMLElement;\n\n      element.classList.remove(`${this.dragDropService.ClassItemDefine}-disable`);\n      if (this.disable() && !element.classList.contains(`${this.dragDropService.ClassItemDefine}-disable`)) {\n        element.classList.add(`${this.dragDropService.ClassItemDefine}-disable`);\n      }\n    });\n  }\n\n  override ngAfterViewInit() {\n    const element = this.elementRef.nativeElement as HTMLElement;\n    if (this.fieldId()) {\n      element.setAttribute('field_id', this.fieldId());\n      if (this.item()) {\n        element.setAttribute('item_id', get(this.item(), this.fieldId()));\n      }\n    }\n    element.setAttribute('groupName', this.groupName());\n    element.classList.add(this.dragDropService.ClassItemDefine);\n    this.dragDropService.OnDragging.pipe(throttleTime(this.throttleTimeHandlerDraggingEvent()), takeUntil(this.onDestroy)).subscribe((eventDragging) => {\n      if (this.disable() || element.getAttribute('disableDragContainer') || (this.fieldId() && this.item() && eventDragging.elementDrag.getAttribute('item_id') === get(this.item(), this.fieldId()))) {\n        return;\n      }\n      const containerById = this.dragDropService.Container().get(element.getAttribute('groupID') || '');\n\n      if (containerById) {\n        if (eventDragging.elementKeepContainer || !this.dragDropService.checkElementOverAcceptElementDrag(containerById.element.getAttribute('groupName'), eventDragging.elementDrag.getAttribute('groupName'), eventDragging.elementDrag.getAttribute('dropToGroupName'))) {\n          return;\n        }\n      }\n      if (checkMouseOverInContainer(eventDragging.mousePosition, element) && element !== eventDragging.elementDrag && containerById && checkViewInScreen(containerById.element, element, containerById.elementScroll)) {\n        if (this.isDragOver()) {\n          return;\n        }\n        const eventDragOver = { ...eventDragging, elementDragOver: element };\n\n        this.dragDropService.OnDragOver.next(eventDragOver);\n        this.outDragOver.emit(eventDragOver);\n        this.isDragOver.set(true);\n\n        return;\n      }\n\n      if (this.isDragOver()) {\n        const eventDragLeave = { ...eventDragging, elementDragLeave: element };\n        this.isDragOver.set(false);\n        this.dragDropService.OnDragLeave.next(eventDragLeave);\n        this.outDragLeave.emit(eventDragLeave);\n      }\n    });\n\n    this.dragDropService.OnDropContainer.pipe(takeUntil(this.onDestroy)).subscribe((eventDrop) => {\n      if (eventDrop.elementDrop !== element) {\n        return;\n      }\n      const dropEvent = { elementDrag: eventDrop.elementDrag, elementDrop: element, itemDragInfo: eventDrop.itemDragInfo };\n\n      this.outDropped.emit(dropEvent);\n    });\n    const styleTag = document.createElement(\"style\");\n\n    styleTag.textContent = `.libs-ui-drag-drop-item-dragging{cursor:move}`;\n    let nodeClone = element;\n    let distanceStartElementAndMouseLeft = -1;\n    let distanceStartElementAndMouseTop = -1;\n    let contextMenu = false;\n    const stopEventMouse = (mouseEvent: MouseEvent) => {\n      if (!this.ignoreStopEvent()) {\n        mouseEvent.preventDefault();\n        mouseEvent.stopPropagation();\n      }\n    };\n    const updatePositionElementRootAndRemoveNodeClone = () => {\n      if (this.dragRootElement()) {\n        const containerById = this.dragDropService.Container().get(element.getAttribute('groupID') || '');\n\n        const containerItem = this.elementContainer() || containerById?.elementScroll || containerById?.element || document.body;\n        const rectContainer = containerItem.getBoundingClientRect();\n        const rectNodeClone = nodeClone.getBoundingClientRect();\n        const numberSub = Number((getComputedStyle(containerItem).border.match(/\\d+px/gi) || ['0'])[0].replace(/\\D+/ig, '')).valueOf();\n\n        element.style.left = (rectNodeClone.left - rectContainer.left - numberSub) + 'px';\n        element.style.top = (rectNodeClone.top - rectContainer.top - numberSub) + 'px';\n        element.classList.remove('opacity-0');\n      }\n      distanceStartElementAndMouseLeft = -1;\n      distanceStartElementAndMouseTop = -1;\n      nodeClone.remove();\n    };\n\n    fromEvent(document, 'contextmenu').pipe(\n      tap(() => {\n        if (this.isDragging()) {\n          updatePositionElementRootAndRemoveNodeClone();\n        }\n        contextMenu = true;\n\n      }),\n      takeUntil(this.onDestroy)\n    ).subscribe();\n\n    let ignoreMousedown = false;\n\n    getDragEventByElement({\n      elementMouseDown: element,\n      functionMouseDown: (event: MouseEvent) => {\n        this.dragDropService.ItemClick = element;\n        contextMenu = false;\n        this.updateMouseEventsWhenMoveOverIframe('none');\n        if ((this.disable() || element.getAttribute('disableDragContainer') || !this.isDragging() || this.itemInContainerVirtualScroll()) && !this.onlyMouseDownStopEvent()) {\n          return;\n        }\n        stopEventMouse(event);\n      },\n      functionMouseMove:(event: MouseEvent) =>{\n        stopEventMouse(event);\n      },\n      functionMouseUp:(event: MouseEvent) =>{\n        this.updateMouseEventsWhenMoveOverIframe('auto');\n          this.dragDropService.resetItemClick();\n          stopEventMouse(event);\n          if (this.disable() || element.getAttribute('disableDragContainer') || contextMenu || !this.isDragging()) {\n            contextMenu = false;\n\n            return;\n          }\n          contextMenu = false;\n          this.isDragging.set(false);\n          element.removeAttribute(this.dragDropService.TargetItemDragFlag);\n          if (this.itemInContainerVirtualScroll()) {\n            return;\n          }\n          const mousePosition = { clientX: event.clientX, clientY: event.clientY };\n\n          if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {\n            const result = this.getClientPosition(element, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());\n\n            mousePosition.clientX = result.clientX;\n            mousePosition.clientY = result.clientY;\n          }\n          const dragEndEvent = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n          this.dragDropService.ItemDragInfo = undefined;\n          this.dragDropService.OnDragEnd.next(dragEndEvent);\n          this.outDragEnd.emit(dragEndEvent);\n\n          nodeClone.classList.remove('libs-ui-drag-drop-item-dragging');\n          styleTag.remove();\n\n          updatePositionElementRootAndRemoveNodeClone();\n      },\n      onDestroy: this.onDestroy\n    }).pipe(tap((dragMouseEvent: MouseEvent) => {\n      const rectElement = element.getBoundingClientRect();\n      const viewport = getViewport() as IBoundingClientRect;\n\n      if (this.disable() || element.getAttribute('disableDragContainer') || !dragMouseEvent.clientX || (!ignoreMousedown && dragMouseEvent.type === 'mousedown' && rectElement.height + rectElement.top >= viewport.height)) {\n\n        return;\n      }\n      const { clientX, clientY } = dragMouseEvent;\n\n      if (distanceStartElementAndMouseLeft === -1) {\n        distanceStartElementAndMouseLeft = clientX - rectElement.left;\n      }\n\n      if (distanceStartElementAndMouseTop === -1) {\n        distanceStartElementAndMouseTop = clientY - rectElement.top;\n      }\n    })).subscribe(dragMouseEvent => {\n      if (this.dragDropService.ItemClick.filter(item => item !== element).some(item => element.contains(item))) {\n        return;\n      }\n      if (this.disable() || element.getAttribute('disableDragContainer') || !dragMouseEvent.clientX || dragMouseEvent.type === 'mousedown' || contextMenu || (this.itemInContainerVirtualScroll() && this.isDragging())) {\n        return;\n      }\n      ignoreMousedown = true;\n      const { clientX, clientY } = dragMouseEvent;\n      const mousePosition = { clientX, clientY };\n      const rectElement = element.getBoundingClientRect();\n\n      if (!this.isDragging()) {\n        this.isDragging.set(true);\n        const eventDragStart = { mousePosition, elementDrag: element, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n        element.setAttribute(this.dragDropService.TargetItemDragFlag, 'true');\n        this.dragDropService.OnDragStart.next(eventDragStart);\n        eventDragStart.itemDragInfo = this.dragDropService.ItemDragInfo;\n        this.outDragStart.emit(eventDragStart);\n\n        nodeClone = element.cloneNode(true) as HTMLElement;\n        nodeClone.style.zIndex = `${this.zIndex()}`;\n        nodeClone.classList.add('!fixed');\n        nodeClone.classList.remove('libs-ui-drag-drop-item-origin-placeholder');\n        nodeClone.classList.remove('libs-ui-drag-drop-item-placeholder');\n        nodeClone.appendChild(styleTag);\n        nodeClone.classList.add('libs-ui-drag-drop-item-dragging');\n        nodeClone.style.width = `${rectElement.width}px`;\n        nodeClone.style.height = `${rectElement.height}px`;\n        nodeClone.style.left = `${-999}px`;\n        nodeClone.style.top = `${-999}px`;\n        document.body.append(nodeClone);\n        if (this.dragRootElement()) {\n          element.classList.add('opacity-0');\n        }\n\n        if (this.itemInContainerVirtualScroll()) {\n          this.dragDropService.OnDragItemInContainerVirtualScroll.next({\n            itemDragInfo: this.dragDropService.ItemDragInfo,\n            elementDrag: nodeClone,\n            distanceStartElementAndMouseTop,\n            distanceStartElementAndMouseLeft,\n            elementContainer: this.elementContainer(),\n            dragBoundary: this.dragBoundary(),\n            dragBoundaryAcceptMouseLeaveContainer: this.dragBoundaryAcceptMouseLeaveContainer(),\n            ignoreStopEvent: this.ignoreStopEvent()\n          });\n\n          return;\n        }\n      }\n      const result = this.getClientPosition(nodeClone, mousePosition, distanceStartElementAndMouseLeft, distanceStartElementAndMouseTop, this.dragBoundary(), this.elementContainer());\n\n      const elementKeepContainer = result.elementKeepContainer;\n      const left = result.clientX - distanceStartElementAndMouseLeft;\n      const top = result.clientY - distanceStartElementAndMouseTop;\n\n      if (this.dragBoundary() && this.dragBoundaryAcceptMouseLeaveContainer()) {\n        if (clientX < result.viewport.left) {\n          mousePosition.clientX = result.viewport.left;\n        }\n        if (clientX > result.viewport.width) {\n          mousePosition.clientX = result.viewport.width;\n        }\n        if (clientY < result.viewport.top) {\n          mousePosition.clientY = result.viewport.top;\n        }\n        if (clientY > result.viewport.height) {\n          mousePosition.clientY = result.viewport.height;\n        }\n      }\n      nodeClone.style.left = `${left}px`;\n      nodeClone.style.top = `${top}px`;\n\n      const eventDragging = { mousePosition, elementDrag: nodeClone, elementKeepContainer, itemDragInfo: this.dragDropService.ItemDragInfo };\n\n      this.dragDropService.OnDragging.next(eventDragging);\n    });\n  }\n}"]}
@@ -4,18 +4,18 @@ import { Subject, takeUntil } from "rxjs";
4
4
  import { MoLibsSharedDragDropService } from "./drag-drop.service";
5
5
  import * as i0 from "@angular/core";
6
6
  export class LibsUiComponentsDragScrollDirective {
7
- /* PROPERTY */
7
+ // #region PROPERTY
8
8
  stopScroll = signal(false);
9
9
  virtualScrollPageInfo = signal(undefined);
10
10
  intervalScrollToElement = signal(undefined);
11
11
  onDestroy = new Subject();
12
- /* INPUT */
12
+ // #region INPUT
13
13
  ignoreAutoScroll = input();
14
14
  widthZoneDetect = input(16, { transform: value => value ?? 16 });
15
15
  movementLength = input(6, { transform: value => value ?? 6 });
16
16
  rootElementScroll = input();
17
17
  virtualScrollerComponent = input();
18
- /* INJECT */
18
+ // #region INJECT
19
19
  elementRef = inject(ElementRef);
20
20
  dragDropService = inject(MoLibsSharedDragDropService);
21
21
  ngAfterViewInit() {
@@ -135,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
135
135
  standalone: true
136
136
  }]
137
137
  }] });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-scroll.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/drag-drop/src/drag-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, OnDestroy, inject, input, signal } from \"@angular/core\";\nimport { IPageInfo, VirtualScrollerComponent } from \"@iharbeck/ngx-virtual-scroller\";\nimport { IBoundingClientRect } from \"@libs-ui/interfaces-types\";\nimport { checkMouseOverInContainer, cloneIBoundingClientRect, get } from \"@libs-ui/utils\";\nimport { Subject, takeUntil } from \"rxjs\";\nimport { MoLibsSharedDragDropService } from \"./drag-drop.service\";\nimport { IDragging } from \"./interfaces/event.interface\";\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: \"[LibsUiComponentsDragScrollDirective]\",\n  standalone: true\n})\nexport class LibsUiComponentsDragScrollDirective implements AfterViewInit, OnDestroy {\n  /* PROPERTY */\n  private stopScroll = signal<boolean>(false);\n  private virtualScrollPageInfo = signal<IPageInfo | undefined>(undefined);\n  protected intervalScrollToElement = signal<number | undefined>(undefined);\n  protected onDestroy = new Subject<void>();\n\n  /* INPUT */\n  readonly ignoreAutoScroll = input<boolean>();\n  readonly widthZoneDetect = input<number, number | undefined>(16, { transform: value => value ?? 16 });\n  readonly movementLength = input<number, number | undefined>(6, { transform: value => value ?? 6 });\n  readonly rootElementScroll = input<HTMLElement>();\n  readonly virtualScrollerComponent = input<VirtualScrollerComponent>();\n\n  /* INJECT */\n  protected elementRef = inject(ElementRef);\n  protected dragDropService = inject(MoLibsSharedDragDropService);\n\n  ngAfterViewInit(): void {\n    this.dragDropService.OnDragging.pipe(takeUntil(this.onDestroy)).subscribe((eventDragging) => this.checkAndScrollElementToPosition(eventDragging, this.ignoreAutoScroll()));\n    this.dragDropService.OnDragEnd.pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      clearInterval(this.intervalScrollToElement());\n      if (this.virtualScrollPageInfo()) {\n        const firstElement = get(this.virtualScrollerComponent(), 'element')?.nativeElement.firstElementChild;\n        const isHorizontal = get(this.virtualScrollerComponent(), '_horizontal');\n        if (isHorizontal) {\n          firstElement.style.transform = `scaleX(${this.virtualScrollPageInfo()?.scrollEndPosition})`;\n        }\n        if (!isHorizontal) {\n          firstElement.style.transform = `scaleY(${this.virtualScrollPageInfo()?.scrollEndPosition})`;\n        }\n        this.virtualScrollPageInfo.set(undefined);\n      }\n      this.stopScroll.set(false);\n    });\n    this.dragDropService.OnDragStart.pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      if (this.virtualScrollerComponent) {\n        this.virtualScrollerComponent()?.scrollToIndex(0);\n      }\n    });\n    if (!this.virtualScrollerComponent) {\n      return;\n    }\n    this.virtualScrollerComponent()?.vsChange.pipe(takeUntil(this.onDestroy)).subscribe(pageInfo => {\n      const items = get(this.virtualScrollerComponent, '_items');\n\n      if (items && items.length === pageInfo.endIndex) {\n        this.virtualScrollPageInfo.set(pageInfo);\n        const elementSetScroll = this.rootElementScroll() || this.elementRef.nativeElement;\n        const isHorizontal = get(this.virtualScrollerComponent, '_horizontal');\n\n        if (isHorizontal && pageInfo.scrollEndPosition < elementSetScroll.offsetWidth + elementSetScroll.scrollLeft + 3) {\n          this.stopScroll.set(true);\n          clearInterval(this.intervalScrollToElement());\n\n          return;\n        }\n\n        if (!isHorizontal && pageInfo.scrollEndPosition < elementSetScroll.offsetHeight + elementSetScroll.scrollTop + 3) {\n          this.stopScroll.set(true);\n          clearInterval(this.intervalScrollToElement());\n\n          return;\n        }\n      }\n      this.stopScroll.set(false);\n    });\n  }\n\n  /* FUNCTIONS */\n  protected checkAndScrollElementToPosition(eventDragging: IDragging, ignoreAutoScroll?: boolean) {\n    let elementSetScroll = this.rootElementScroll() || this.elementRef.nativeElement;\n\n    if (ignoreAutoScroll || !checkMouseOverInContainer(eventDragging.mousePosition, elementSetScroll)) {\n      return;\n    }\n    const rectElement = cloneIBoundingClientRect(this.elementRef.nativeElement.getBoundingClientRect());\n\n    if (this.rootElementScroll()) {\n      const rectElementScroll = this.rootElementScroll()?.getBoundingClientRect() as IBoundingClientRect;\n\n      rectElement.left = rectElementScroll.left;\n      rectElement.top = rectElementScroll.top;\n    }\n\n    const { width, height, top, left } = rectElement;\n    const { clientX, clientY } = eventDragging.mousePosition;\n    const limitLeft = left + elementSetScroll.offsetWidth;\n    const limitTop = top + elementSetScroll.offsetHeight;\n\n    clearInterval(this.intervalScrollToElement());\n    if ((clientX < left || clientX > left + width) && (clientY < top || clientY > top + height)) {\n      return;\n    }\n\n    this.intervalScrollToElement.set(setInterval(() => {\n      elementSetScroll = (this.rootElementScroll() || this.elementRef.nativeElement);\n      let directionTop = 0;\n      let directionLeft = 0;\n\n      if (top <= clientY && clientY <= top + this.widthZoneDetect()) {\n        elementSetScroll.scrollTop -= this.movementLength();\n        directionTop = -1;\n      }\n\n      if (limitTop - this.widthZoneDetect() <= clientY && clientY <= limitTop) {\n        if (this.stopScroll()) {\n          return;\n        }\n        elementSetScroll.scrollTop += this.movementLength();\n        directionTop = 1;\n      }\n\n      if ((limitLeft - this.widthZoneDetect() <= clientX) && (clientX <= limitLeft)) {\n        if (this.stopScroll()) {\n          return;\n        }\n        elementSetScroll.scrollLeft += this.movementLength();\n        directionLeft = +1;\n\n      }\n      if (left <= clientX && clientX <= left + this.widthZoneDetect()) {\n        elementSetScroll.scrollLeft -= this.movementLength();\n        directionLeft = -1;\n      }\n\n      if (elementSetScroll.scrollLeft && (elementSetScroll.scrollLeft + elementSetScroll.offsetWidth >= elementSetScroll.scrollWidth)) {\n        elementSetScroll.scrollLeft -= elementSetScroll.scrollLeft + elementSetScroll.offsetWidth - elementSetScroll.scrollWidth;\n      }\n\n      if (elementSetScroll.scrollTop && (elementSetScroll.scrollTop + elementSetScroll.offsetHeight >= elementSetScroll.scrollHeight)) {\n        elementSetScroll.scrollTop -= elementSetScroll.scrollTop + elementSetScroll.offsetHeight - elementSetScroll.scrollHeight;\n      }\n\n      if ((directionTop < 0 && !elementSetScroll.scrollTop) || (!elementSetScroll.scrollLeft && directionLeft < 0) || (directionTop && elementSetScroll.scrollHeight <= elementSetScroll.scrollTop + elementSetScroll.offsetHeight + 3) || (directionLeft && elementSetScroll.scrollWidth <= elementSetScroll.scrollLeft + elementSetScroll.offsetWidth + 3)) {\n        return clearInterval(this.intervalScrollToElement());\n      }\n    }, 10));\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-scroll.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/drag-drop/src/drag-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, OnDestroy, inject, input, signal } from \"@angular/core\";\nimport { IPageInfo, VirtualScrollerComponent } from \"@iharbeck/ngx-virtual-scroller\";\nimport { IBoundingClientRect } from \"@libs-ui/interfaces-types\";\nimport { checkMouseOverInContainer, cloneIBoundingClientRect, get } from \"@libs-ui/utils\";\nimport { Subject, takeUntil } from \"rxjs\";\nimport { MoLibsSharedDragDropService } from \"./drag-drop.service\";\nimport { IDragging } from \"./interfaces/event.interface\";\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: \"[LibsUiComponentsDragScrollDirective]\",\n  standalone: true\n})\nexport class LibsUiComponentsDragScrollDirective implements AfterViewInit, OnDestroy {\n  // #region PROPERTY\n  private stopScroll = signal<boolean>(false);\n  private virtualScrollPageInfo = signal<IPageInfo | undefined>(undefined);\n  protected intervalScrollToElement = signal<number | undefined>(undefined);\n  protected onDestroy = new Subject<void>();\n\n  // #region INPUT\n  readonly ignoreAutoScroll = input<boolean>();\n  readonly widthZoneDetect = input<number, number | undefined>(16, { transform: value => value ?? 16 });\n  readonly movementLength = input<number, number | undefined>(6, { transform: value => value ?? 6 });\n  readonly rootElementScroll = input<HTMLElement>();\n  readonly virtualScrollerComponent = input<VirtualScrollerComponent>();\n\n  // #region INJECT\n  protected elementRef = inject(ElementRef);\n  protected dragDropService = inject(MoLibsSharedDragDropService);\n\n  ngAfterViewInit(): void {\n    this.dragDropService.OnDragging.pipe(takeUntil(this.onDestroy)).subscribe((eventDragging) => this.checkAndScrollElementToPosition(eventDragging, this.ignoreAutoScroll()));\n    this.dragDropService.OnDragEnd.pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      clearInterval(this.intervalScrollToElement());\n      if (this.virtualScrollPageInfo()) {\n        const firstElement = get(this.virtualScrollerComponent(), 'element')?.nativeElement.firstElementChild;\n        const isHorizontal = get(this.virtualScrollerComponent(), '_horizontal');\n        if (isHorizontal) {\n          firstElement.style.transform = `scaleX(${this.virtualScrollPageInfo()?.scrollEndPosition})`;\n        }\n        if (!isHorizontal) {\n          firstElement.style.transform = `scaleY(${this.virtualScrollPageInfo()?.scrollEndPosition})`;\n        }\n        this.virtualScrollPageInfo.set(undefined);\n      }\n      this.stopScroll.set(false);\n    });\n    this.dragDropService.OnDragStart.pipe(takeUntil(this.onDestroy)).subscribe(() => {\n      if (this.virtualScrollerComponent) {\n        this.virtualScrollerComponent()?.scrollToIndex(0);\n      }\n    });\n    if (!this.virtualScrollerComponent) {\n      return;\n    }\n    this.virtualScrollerComponent()?.vsChange.pipe(takeUntil(this.onDestroy)).subscribe(pageInfo => {\n      const items = get(this.virtualScrollerComponent, '_items');\n\n      if (items && items.length === pageInfo.endIndex) {\n        this.virtualScrollPageInfo.set(pageInfo);\n        const elementSetScroll = this.rootElementScroll() || this.elementRef.nativeElement;\n        const isHorizontal = get(this.virtualScrollerComponent, '_horizontal');\n\n        if (isHorizontal && pageInfo.scrollEndPosition < elementSetScroll.offsetWidth + elementSetScroll.scrollLeft + 3) {\n          this.stopScroll.set(true);\n          clearInterval(this.intervalScrollToElement());\n\n          return;\n        }\n\n        if (!isHorizontal && pageInfo.scrollEndPosition < elementSetScroll.offsetHeight + elementSetScroll.scrollTop + 3) {\n          this.stopScroll.set(true);\n          clearInterval(this.intervalScrollToElement());\n\n          return;\n        }\n      }\n      this.stopScroll.set(false);\n    });\n  }\n\n  /* FUNCTIONS */\n  protected checkAndScrollElementToPosition(eventDragging: IDragging, ignoreAutoScroll?: boolean) {\n    let elementSetScroll = this.rootElementScroll() || this.elementRef.nativeElement;\n\n    if (ignoreAutoScroll || !checkMouseOverInContainer(eventDragging.mousePosition, elementSetScroll)) {\n      return;\n    }\n    const rectElement = cloneIBoundingClientRect(this.elementRef.nativeElement.getBoundingClientRect());\n\n    if (this.rootElementScroll()) {\n      const rectElementScroll = this.rootElementScroll()?.getBoundingClientRect() as IBoundingClientRect;\n\n      rectElement.left = rectElementScroll.left;\n      rectElement.top = rectElementScroll.top;\n    }\n\n    const { width, height, top, left } = rectElement;\n    const { clientX, clientY } = eventDragging.mousePosition;\n    const limitLeft = left + elementSetScroll.offsetWidth;\n    const limitTop = top + elementSetScroll.offsetHeight;\n\n    clearInterval(this.intervalScrollToElement());\n    if ((clientX < left || clientX > left + width) && (clientY < top || clientY > top + height)) {\n      return;\n    }\n\n    this.intervalScrollToElement.set(setInterval(() => {\n      elementSetScroll = (this.rootElementScroll() || this.elementRef.nativeElement);\n      let directionTop = 0;\n      let directionLeft = 0;\n\n      if (top <= clientY && clientY <= top + this.widthZoneDetect()) {\n        elementSetScroll.scrollTop -= this.movementLength();\n        directionTop = -1;\n      }\n\n      if (limitTop - this.widthZoneDetect() <= clientY && clientY <= limitTop) {\n        if (this.stopScroll()) {\n          return;\n        }\n        elementSetScroll.scrollTop += this.movementLength();\n        directionTop = 1;\n      }\n\n      if ((limitLeft - this.widthZoneDetect() <= clientX) && (clientX <= limitLeft)) {\n        if (this.stopScroll()) {\n          return;\n        }\n        elementSetScroll.scrollLeft += this.movementLength();\n        directionLeft = +1;\n\n      }\n      if (left <= clientX && clientX <= left + this.widthZoneDetect()) {\n        elementSetScroll.scrollLeft -= this.movementLength();\n        directionLeft = -1;\n      }\n\n      if (elementSetScroll.scrollLeft && (elementSetScroll.scrollLeft + elementSetScroll.offsetWidth >= elementSetScroll.scrollWidth)) {\n        elementSetScroll.scrollLeft -= elementSetScroll.scrollLeft + elementSetScroll.offsetWidth - elementSetScroll.scrollWidth;\n      }\n\n      if (elementSetScroll.scrollTop && (elementSetScroll.scrollTop + elementSetScroll.offsetHeight >= elementSetScroll.scrollHeight)) {\n        elementSetScroll.scrollTop -= elementSetScroll.scrollTop + elementSetScroll.offsetHeight - elementSetScroll.scrollHeight;\n      }\n\n      if ((directionTop < 0 && !elementSetScroll.scrollTop) || (!elementSetScroll.scrollLeft && directionLeft < 0) || (directionTop && elementSetScroll.scrollHeight <= elementSetScroll.scrollTop + elementSetScroll.offsetHeight + 3) || (directionLeft && elementSetScroll.scrollWidth <= elementSetScroll.scrollLeft + elementSetScroll.offsetWidth + 3)) {\n        return clearInterval(this.intervalScrollToElement());\n      }\n    }, 10));\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n"]}