405 lines
63 KiB
JavaScript
405 lines
63 KiB
JavaScript
import { DirTypes } from './gridsterConfig.interface';
|
|
import { GridsterPush } from './gridsterPush.service';
|
|
import { cancelScroll, scroll } from './gridsterScroll.service';
|
|
import { GridsterSwap } from './gridsterSwap.service';
|
|
import { GridsterUtils } from './gridsterUtils.service';
|
|
const GRIDSTER_ITEM_RESIZABLE_HANDLER_CLASS = 'gridster-item-resizable-handler';
|
|
var Direction;
|
|
(function (Direction) {
|
|
Direction["UP"] = "UP";
|
|
Direction["DOWN"] = "DOWN";
|
|
Direction["LEFT"] = "LEFT";
|
|
Direction["RIGHT"] = "RIGHT";
|
|
})(Direction || (Direction = {}));
|
|
export class GridsterDraggable {
|
|
constructor(gridsterItem, gridster, zone) {
|
|
this.zone = zone;
|
|
this.collision = false;
|
|
this.dragMove = (e) => {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
GridsterUtils.checkTouchEvent(e);
|
|
// get the directions of the mouse event
|
|
let directions = this.getDirections(e);
|
|
if (this.gridster.options.enableBoundaryControl) {
|
|
// prevent moving up at the top of gridster
|
|
if (directions.includes(Direction.UP) &&
|
|
this.gridsterItem.el.getBoundingClientRect().top <
|
|
this.gridster.el.getBoundingClientRect().top +
|
|
(this.outerMarginTop ?? this.margin)) {
|
|
directions = directions.filter(direction => direction != Direction.UP);
|
|
e = new MouseEvent(e.type, {
|
|
clientX: e.clientX,
|
|
clientY: this.lastMouse.clientY
|
|
});
|
|
}
|
|
// prevent moving left at the leftmost column of gridster
|
|
if (directions.includes(Direction.LEFT) &&
|
|
this.gridsterItem.el.getBoundingClientRect().left <
|
|
this.gridster.el.getBoundingClientRect().left +
|
|
(this.outerMarginLeft ?? this.margin)) {
|
|
directions = directions.filter(direction => direction != Direction.LEFT);
|
|
e = new MouseEvent(e.type, {
|
|
clientX: this.lastMouse.clientX,
|
|
clientY: e.clientY
|
|
});
|
|
}
|
|
// prevent moving right at the rightmost column of gridster
|
|
if (directions.includes(Direction.RIGHT) &&
|
|
this.gridsterItem.el.getBoundingClientRect().right >
|
|
this.gridster.el.getBoundingClientRect().right -
|
|
(this.outerMarginRight ?? this.margin)) {
|
|
directions = directions.filter(direction => direction != Direction.RIGHT);
|
|
e = new MouseEvent(e.type, {
|
|
clientX: this.lastMouse.clientX,
|
|
clientY: e.clientY
|
|
});
|
|
}
|
|
// prevent moving down at the bottom of gridster
|
|
if (directions.includes(Direction.DOWN) &&
|
|
this.gridsterItem.el.getBoundingClientRect().bottom >
|
|
this.gridster.el.getBoundingClientRect().bottom -
|
|
(this.outerMarginBottom ?? this.margin)) {
|
|
directions = directions.filter(direction => direction != Direction.DOWN);
|
|
e = new MouseEvent(e.type, {
|
|
clientX: e.clientX,
|
|
clientY: this.lastMouse.clientY
|
|
});
|
|
}
|
|
}
|
|
// do not change item location when there is no direction to go
|
|
if (directions.length) {
|
|
this.offsetLeft =
|
|
this.gridster.el.scrollLeft - this.gridster.el.offsetLeft;
|
|
this.offsetTop = this.gridster.el.scrollTop - this.gridster.el.offsetTop;
|
|
scroll(this.gridster, this.left, this.top, this.width, this.height, e, this.lastMouse, this.calculateItemPositionFromMousePosition);
|
|
this.calculateItemPositionFromMousePosition(e);
|
|
}
|
|
};
|
|
this.calculateItemPositionFromMousePosition = (e) => {
|
|
if (this.gridster.options.scale) {
|
|
this.calculateItemPositionWithScale(e, this.gridster.options.scale);
|
|
}
|
|
else {
|
|
this.calculateItemPositionWithoutScale(e);
|
|
}
|
|
this.calculateItemPosition();
|
|
this.lastMouse.clientX = e.clientX;
|
|
this.lastMouse.clientY = e.clientY;
|
|
this.zone.run(() => {
|
|
this.gridster.updateGrid();
|
|
});
|
|
};
|
|
this.dragStop = (e) => {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
cancelScroll();
|
|
this.cancelOnBlur();
|
|
this.mousemove();
|
|
this.mouseup();
|
|
this.mouseleave();
|
|
this.touchmove();
|
|
this.touchend();
|
|
this.touchcancel();
|
|
this.gridsterItem.renderer.removeClass(this.gridsterItem.el, 'gridster-item-moving');
|
|
this.gridster.dragInProgress = false;
|
|
this.gridster.updateGrid();
|
|
this.path = [];
|
|
if (this.gridster.options.draggable &&
|
|
this.gridster.options.draggable.stop) {
|
|
Promise.resolve(this.gridster.options.draggable.stop(this.gridsterItem.item, this.gridsterItem, e)).then(this.makeDrag, this.cancelDrag);
|
|
}
|
|
else {
|
|
this.makeDrag();
|
|
}
|
|
setTimeout(() => {
|
|
if (this.gridster) {
|
|
this.gridster.movingItem = null;
|
|
this.gridster.previewStyle(true);
|
|
}
|
|
});
|
|
};
|
|
this.cancelDrag = () => {
|
|
this.gridsterItem.$item.x = this.gridsterItem.item.x || 0;
|
|
this.gridsterItem.$item.y = this.gridsterItem.item.y || 0;
|
|
this.gridsterItem.setSize();
|
|
if (this.push) {
|
|
this.push.restoreItems();
|
|
}
|
|
if (this.swap) {
|
|
this.swap.restoreSwapItem();
|
|
}
|
|
if (this.push) {
|
|
this.push.destroy();
|
|
this.push = null;
|
|
}
|
|
if (this.swap) {
|
|
this.swap.destroy();
|
|
this.swap = null;
|
|
}
|
|
};
|
|
this.makeDrag = () => {
|
|
if (this.gridster.$options.draggable.dropOverItems &&
|
|
this.gridster.options.draggable &&
|
|
this.gridster.options.draggable.dropOverItemsCallback &&
|
|
this.collision &&
|
|
this.collision !== true &&
|
|
this.collision.$item) {
|
|
this.gridster.options.draggable.dropOverItemsCallback(this.gridsterItem.item, this.collision.item, this.gridster);
|
|
}
|
|
this.collision = false;
|
|
this.gridsterItem.setSize();
|
|
this.gridsterItem.checkItemChanges(this.gridsterItem.$item, this.gridsterItem.item);
|
|
if (this.push) {
|
|
this.push.setPushedItems();
|
|
}
|
|
if (this.swap) {
|
|
this.swap.setSwapItem();
|
|
}
|
|
if (this.push) {
|
|
this.push.destroy();
|
|
this.push = null;
|
|
}
|
|
if (this.swap) {
|
|
this.swap.destroy();
|
|
this.swap = null;
|
|
}
|
|
};
|
|
this.dragStartDelay = (e) => {
|
|
const target = e.target;
|
|
if (target.classList.contains(GRIDSTER_ITEM_RESIZABLE_HANDLER_CLASS)) {
|
|
return;
|
|
}
|
|
if (GridsterUtils.checkContentClassForEvent(this.gridster, e)) {
|
|
return;
|
|
}
|
|
GridsterUtils.checkTouchEvent(e);
|
|
if (!this.gridster.$options.draggable.delayStart) {
|
|
this.dragStart(e);
|
|
return;
|
|
}
|
|
const timeout = setTimeout(() => {
|
|
this.dragStart(e);
|
|
cancelDrag();
|
|
}, this.gridster.$options.draggable.delayStart);
|
|
const cancelMouse = this.gridsterItem.renderer.listen('document', 'mouseup', cancelDrag);
|
|
const cancelMouseLeave = this.gridsterItem.renderer.listen('document', 'mouseleave', cancelDrag);
|
|
const cancelOnBlur = this.gridsterItem.renderer.listen('window', 'blur', cancelDrag);
|
|
const cancelTouchMove = this.gridsterItem.renderer.listen('document', 'touchmove', cancelMove);
|
|
const cancelTouchEnd = this.gridsterItem.renderer.listen('document', 'touchend', cancelDrag);
|
|
const cancelTouchCancel = this.gridsterItem.renderer.listen('document', 'touchcancel', cancelDrag);
|
|
function cancelMove(eventMove) {
|
|
GridsterUtils.checkTouchEvent(eventMove);
|
|
if (Math.abs(eventMove.clientX - e.clientX) > 9 ||
|
|
Math.abs(eventMove.clientY - e.clientY) > 9) {
|
|
cancelDrag();
|
|
}
|
|
}
|
|
function cancelDrag() {
|
|
clearTimeout(timeout);
|
|
cancelOnBlur();
|
|
cancelMouse();
|
|
cancelMouseLeave();
|
|
cancelTouchMove();
|
|
cancelTouchEnd();
|
|
cancelTouchCancel();
|
|
}
|
|
};
|
|
this.gridsterItem = gridsterItem;
|
|
this.gridster = gridster;
|
|
this.lastMouse = {
|
|
clientX: 0,
|
|
clientY: 0
|
|
};
|
|
this.path = [];
|
|
}
|
|
destroy() {
|
|
if (this.gridster.previewStyle) {
|
|
this.gridster.previewStyle(true);
|
|
}
|
|
this.gridsterItem = this.gridster = this.collision = null;
|
|
if (this.mousedown) {
|
|
this.mousedown();
|
|
this.touchstart();
|
|
}
|
|
}
|
|
dragStart(e) {
|
|
if (e.which && e.which !== 1) {
|
|
return;
|
|
}
|
|
if (this.gridster.options.draggable &&
|
|
this.gridster.options.draggable.start) {
|
|
this.gridster.options.draggable.start(this.gridsterItem.item, this.gridsterItem, e);
|
|
}
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
this.zone.runOutsideAngular(() => {
|
|
this.mousemove = this.gridsterItem.renderer.listen('document', 'mousemove', this.dragMove);
|
|
this.touchmove = this.gridster.renderer.listen(this.gridster.el, 'touchmove', this.dragMove);
|
|
});
|
|
this.mouseup = this.gridsterItem.renderer.listen('document', 'mouseup', this.dragStop);
|
|
this.mouseleave = this.gridsterItem.renderer.listen('document', 'mouseleave', this.dragStop);
|
|
this.cancelOnBlur = this.gridsterItem.renderer.listen('window', 'blur', this.dragStop);
|
|
this.touchend = this.gridsterItem.renderer.listen('document', 'touchend', this.dragStop);
|
|
this.touchcancel = this.gridsterItem.renderer.listen('document', 'touchcancel', this.dragStop);
|
|
this.gridsterItem.renderer.addClass(this.gridsterItem.el, 'gridster-item-moving');
|
|
this.margin = this.gridster.$options.margin;
|
|
this.outerMarginTop = this.gridster.$options.outerMarginTop;
|
|
this.outerMarginRight = this.gridster.$options.outerMarginRight;
|
|
this.outerMarginBottom = this.gridster.$options.outerMarginBottom;
|
|
this.outerMarginLeft = this.gridster.$options.outerMarginLeft;
|
|
this.offsetLeft = this.gridster.el.scrollLeft - this.gridster.el.offsetLeft;
|
|
this.offsetTop = this.gridster.el.scrollTop - this.gridster.el.offsetTop;
|
|
this.left = this.gridsterItem.left - this.margin;
|
|
this.top = this.gridsterItem.top - this.margin;
|
|
this.originalClientX = e.clientX;
|
|
this.originalClientY = e.clientY;
|
|
this.width = this.gridsterItem.width;
|
|
this.height = this.gridsterItem.height;
|
|
if (this.gridster.$options.dirType === DirTypes.RTL) {
|
|
this.diffLeft =
|
|
e.clientX - this.gridster.el.scrollWidth + this.gridsterItem.left;
|
|
}
|
|
else {
|
|
this.diffLeft = e.clientX + this.offsetLeft - this.margin - this.left;
|
|
}
|
|
this.diffTop = e.clientY + this.offsetTop - this.margin - this.top;
|
|
this.gridster.movingItem = this.gridsterItem.$item;
|
|
this.gridster.previewStyle(true);
|
|
this.push = new GridsterPush(this.gridsterItem);
|
|
this.swap = new GridsterSwap(this.gridsterItem);
|
|
this.gridster.dragInProgress = true;
|
|
this.gridster.updateGrid();
|
|
this.path.push({
|
|
x: this.gridsterItem.item.x || 0,
|
|
y: this.gridsterItem.item.y || 0
|
|
});
|
|
}
|
|
calculateItemPositionWithScale(e, scale) {
|
|
if (this.gridster.$options.dirType === DirTypes.RTL) {
|
|
this.left =
|
|
this.gridster.el.scrollWidth -
|
|
this.originalClientX +
|
|
(e.clientX - this.originalClientX) / scale +
|
|
this.diffLeft;
|
|
}
|
|
else {
|
|
this.left =
|
|
this.originalClientX +
|
|
(e.clientX - this.originalClientX) / scale +
|
|
this.offsetLeft -
|
|
this.diffLeft;
|
|
}
|
|
this.top =
|
|
this.originalClientY +
|
|
(e.clientY - this.originalClientY) / scale +
|
|
this.offsetTop -
|
|
this.diffTop;
|
|
}
|
|
calculateItemPositionWithoutScale(e) {
|
|
if (this.gridster.$options.dirType === DirTypes.RTL) {
|
|
this.left = this.gridster.el.scrollWidth - e.clientX + this.diffLeft;
|
|
}
|
|
else {
|
|
this.left = e.clientX + this.offsetLeft - this.diffLeft;
|
|
}
|
|
this.top = e.clientY + this.offsetTop - this.diffTop;
|
|
}
|
|
calculateItemPosition() {
|
|
this.gridster.movingItem = this.gridsterItem.$item;
|
|
this.positionX = this.gridster.pixelsToPositionX(this.left, Math.round);
|
|
this.positionY = this.gridster.pixelsToPositionY(this.top, Math.round);
|
|
this.positionXBackup = this.gridsterItem.$item.x;
|
|
this.positionYBackup = this.gridsterItem.$item.y;
|
|
this.gridsterItem.$item.x = this.positionX;
|
|
if (this.gridster.checkGridCollision(this.gridsterItem.$item)) {
|
|
this.gridsterItem.$item.x = this.positionXBackup;
|
|
}
|
|
this.gridsterItem.$item.y = this.positionY;
|
|
if (this.gridster.checkGridCollision(this.gridsterItem.$item)) {
|
|
this.gridsterItem.$item.y = this.positionYBackup;
|
|
}
|
|
this.gridster.gridRenderer.setCellPosition(this.gridsterItem.renderer, this.gridsterItem.el, this.left, this.top);
|
|
if (this.positionXBackup !== this.gridsterItem.$item.x ||
|
|
this.positionYBackup !== this.gridsterItem.$item.y) {
|
|
const lastPosition = this.path[this.path.length - 1];
|
|
let direction = '';
|
|
if (lastPosition.x < this.gridsterItem.$item.x) {
|
|
direction = this.push.fromWest;
|
|
}
|
|
else if (lastPosition.x > this.gridsterItem.$item.x) {
|
|
direction = this.push.fromEast;
|
|
}
|
|
else if (lastPosition.y < this.gridsterItem.$item.y) {
|
|
direction = this.push.fromNorth;
|
|
}
|
|
else if (lastPosition.y > this.gridsterItem.$item.y) {
|
|
direction = this.push.fromSouth;
|
|
}
|
|
this.push.pushItems(direction, this.gridster.$options.disablePushOnDrag);
|
|
this.swap.swapItems();
|
|
this.collision = this.gridster.checkCollision(this.gridsterItem.$item);
|
|
if (this.collision) {
|
|
this.gridsterItem.$item.x = this.positionXBackup;
|
|
this.gridsterItem.$item.y = this.positionYBackup;
|
|
if (this.gridster.$options.draggable.dropOverItems &&
|
|
this.collision !== true &&
|
|
this.collision.$item) {
|
|
this.gridster.movingItem = null;
|
|
}
|
|
}
|
|
else {
|
|
this.path.push({
|
|
x: this.gridsterItem.$item.x,
|
|
y: this.gridsterItem.$item.y
|
|
});
|
|
}
|
|
this.push.checkPushBack();
|
|
}
|
|
else {
|
|
// reset the collision when you drag and drop on an adjacent cell that is not empty
|
|
// and go back to the cell you were in from the beginning,
|
|
// this is to prevent `dropOverItemsCallback'
|
|
this.collision = false;
|
|
}
|
|
this.gridster.previewStyle(true);
|
|
}
|
|
toggle() {
|
|
const enableDrag = this.gridsterItem.canBeDragged();
|
|
if (!this.enabled && enableDrag) {
|
|
this.enabled = !this.enabled;
|
|
this.mousedown = this.gridsterItem.renderer.listen(this.gridsterItem.el, 'mousedown', this.dragStartDelay);
|
|
this.touchstart = this.gridsterItem.renderer.listen(this.gridsterItem.el, 'touchstart', this.dragStartDelay);
|
|
}
|
|
else if (this.enabled && !enableDrag) {
|
|
this.enabled = !this.enabled;
|
|
this.mousedown();
|
|
this.touchstart();
|
|
}
|
|
}
|
|
/**
|
|
* Returns the list of directions for given mouse event
|
|
* @param e Mouse event
|
|
* */
|
|
getDirections(e) {
|
|
const directions = [];
|
|
if (this.lastMouse.clientX === 0 && this.lastMouse.clientY === 0) {
|
|
this.lastMouse.clientY = e.clientY;
|
|
this.lastMouse.clientX = e.clientX;
|
|
}
|
|
if (this.lastMouse.clientY > e.clientY) {
|
|
directions.push(Direction.UP);
|
|
}
|
|
if (this.lastMouse.clientY < e.clientY) {
|
|
directions.push(Direction.DOWN);
|
|
}
|
|
if (this.lastMouse.clientX < e.clientX) {
|
|
directions.push(Direction.RIGHT);
|
|
}
|
|
if (this.lastMouse.clientX > e.clientX) {
|
|
directions.push(Direction.LEFT);
|
|
}
|
|
return directions;
|
|
}
|
|
}
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridsterDraggable.service.js","sourceRoot":"","sources":["../../../../projects/angular-gridster2/src/lib/gridsterDraggable.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgZone } from '@angular/core';\nimport { GridsterComponentInterface } from './gridster.interface';\nimport { DirTypes } from './gridsterConfig.interface';\nimport { GridsterItemComponentInterface } from './gridsterItem.interface';\nimport { GridsterPush } from './gridsterPush.service';\nimport { cancelScroll, scroll } from './gridsterScroll.service';\n\nimport { GridsterSwap } from './gridsterSwap.service';\nimport { GridsterUtils } from './gridsterUtils.service';\n\nconst GRIDSTER_ITEM_RESIZABLE_HANDLER_CLASS = 'gridster-item-resizable-handler';\n\nenum Direction {\n  UP = 'UP',\n  DOWN = 'DOWN',\n  LEFT = 'LEFT',\n  RIGHT = 'RIGHT'\n}\n\nexport class GridsterDraggable {\n  gridsterItem: GridsterItemComponentInterface;\n  gridster: GridsterComponentInterface;\n  lastMouse: {\n    clientX: number;\n    clientY: number;\n  };\n  offsetLeft: number;\n  offsetTop: number;\n  margin: number;\n  outerMarginTop: number | null;\n  outerMarginRight: number | null;\n  outerMarginBottom: number | null;\n  outerMarginLeft: number | null;\n  diffTop: number;\n  diffLeft: number;\n  originalClientX: number;\n  originalClientY: number;\n  top: number;\n  left: number;\n  height: number;\n  width: number;\n  positionX: number;\n  positionY: number;\n  positionXBackup: number;\n  positionYBackup: number;\n  enabled: boolean;\n  mousemove: () => void;\n  mouseup: () => void;\n  mouseleave: () => void;\n  cancelOnBlur: () => void;\n  touchmove: () => void;\n  touchend: () => void;\n  touchcancel: () => void;\n  mousedown: () => void;\n  touchstart: () => void;\n  push: GridsterPush;\n  swap: GridsterSwap;\n  path: Array<{ x: number; y: number }>;\n  collision: GridsterItemComponentInterface | boolean = false;\n\n  constructor(\n    gridsterItem: GridsterItemComponentInterface,\n    gridster: GridsterComponentInterface,\n    private zone: NgZone\n  ) {\n    this.gridsterItem = gridsterItem;\n    this.gridster = gridster;\n    this.lastMouse = {\n      clientX: 0,\n      clientY: 0\n    };\n    this.path = [];\n  }\n\n  destroy(): void {\n    if (this.gridster.previewStyle) {\n      this.gridster.previewStyle(true);\n    }\n    this.gridsterItem = this.gridster = this.collision = null!;\n    if (this.mousedown) {\n      this.mousedown();\n      this.touchstart();\n    }\n  }\n\n  dragStart(e: MouseEvent): void {\n    if (e.which && e.which !== 1) {\n      return;\n    }\n\n    if (\n      this.gridster.options.draggable &&\n      this.gridster.options.draggable.start\n    ) {\n      this.gridster.options.draggable.start(\n        this.gridsterItem.item,\n        this.gridsterItem,\n        e\n      );\n    }\n\n    e.stopPropagation();\n    e.preventDefault();\n\n    this.zone.runOutsideAngular(() => {\n      this.mousemove = this.gridsterItem.renderer.listen(\n        'document',\n        'mousemove',\n        this.dragMove\n      );\n      this.touchmove = this.gridster.renderer.listen(\n        this.gridster.el,\n        'touchmove',\n        this.dragMove\n      );\n    });\n    this.mouseup = this.gridsterItem.renderer.listen(\n      'document',\n      'mouseup',\n      this.dragStop\n    );\n    this.mouseleave = this.gridsterItem.renderer.listen(\n      'document',\n      'mouseleave',\n      this.dragStop\n    );\n    this.cancelOnBlur = this.gridsterItem.renderer.listen(\n      'window',\n      'blur',\n      this.dragStop\n    );\n    this.touchend = this.gridsterItem.renderer.listen(\n      'document',\n      'touchend',\n      this.dragStop\n    );\n    this.touchcancel = this.gridsterItem.renderer.listen(\n      'document',\n      'touchcancel',\n      this.dragStop\n    );\n    this.gridsterItem.renderer.addClass(\n      this.gridsterItem.el,\n      'gridster-item-moving'\n    );\n    this.margin = this.gridster.$options.margin;\n    this.outerMarginTop = this.gridster.$options.outerMarginTop;\n    this.outerMarginRight = this.gridster.$options.outerMarginRight;\n    this.outerMarginBottom = this.gridster.$options.outerMarginBottom;\n    this.outerMarginLeft = this.gridster.$options.outerMarginLeft;\n    this.offsetLeft = this.gridster.el.scrollLeft - this.gridster.el.offsetLeft;\n    this.offsetTop = this.gridster.el.scrollTop - this.gridster.el.offsetTop;\n    this.left = this.gridsterItem.left - this.margin;\n    this.top = this.gridsterItem.top - this.margin;\n    this.originalClientX = e.clientX;\n    this.originalClientY = e.clientY;\n    this.width = this.gridsterItem.width;\n    this.height = this.gridsterItem.height;\n    if (this.gridster.$options.dirType === DirTypes.RTL) {\n      this.diffLeft =\n        e.clientX - this.gridster.el.scrollWidth + this.gridsterItem.left;\n    } else {\n      this.diffLeft = e.clientX + this.offsetLeft - this.margin - this.left;\n    }\n    this.diffTop = e.clientY + this.offsetTop - this.margin - this.top;\n    this.gridster.movingItem = this.gridsterItem.$item;\n    this.gridster.previewStyle(true);\n    this.push = new GridsterPush(this.gridsterItem);\n    this.swap = new GridsterSwap(this.gridsterItem);\n    this.gridster.dragInProgress = true;\n    this.gridster.updateGrid();\n    this.path.push({\n      x: this.gridsterItem.item.x || 0,\n      y: this.gridsterItem.item.y || 0\n    });\n  }\n\n  dragMove = (e: MouseEvent): void => {\n    e.stopPropagation();\n    e.preventDefault();\n    GridsterUtils.checkTouchEvent(e);\n\n    // get the directions of the mouse event\n    let directions = this.getDirections(e);\n\n    if (this.gridster.options.enableBoundaryControl) {\n      // prevent moving up at the top of gridster\n      if (\n        directions.includes(Direction.UP) &&\n        this.gridsterItem.el.getBoundingClientRect().top <\n          this.gridster.el.getBoundingClientRect().top +\n            (this.outerMarginTop ?? this.margin)\n      ) {\n        directions = directions.filter(direction => direction != Direction.UP);\n        e = new MouseEvent(e.type, {\n          clientX: e.clientX,\n          clientY: this.lastMouse.clientY\n        });\n      }\n      // prevent moving left at the leftmost column of gridster\n      if (\n        directions.includes(Direction.LEFT) &&\n        this.gridsterItem.el.getBoundingClientRect().left <\n          this.gridster.el.getBoundingClientRect().left +\n            (this.outerMarginLeft ?? this.margin)\n      ) {\n        directions = directions.filter(\n          direction => direction != Direction.LEFT\n        );\n        e = new MouseEvent(e.type, {\n          clientX: this.lastMouse.clientX,\n          clientY: e.clientY\n        });\n      }\n      // prevent moving right at the rightmost column of gridster\n      if (\n        directions.includes(Direction.RIGHT) &&\n        this.gridsterItem.el.getBoundingClientRect().right >\n          this.gridster.el.getBoundingClientRect().right -\n            (this.outerMarginRight ?? this.margin)\n      ) {\n        directions = directions.filter(\n          direction => direction != Direction.RIGHT\n        );\n        e = new MouseEvent(e.type, {\n          clientX: this.lastMouse.clientX,\n          clientY: e.clientY\n        });\n      }\n      // prevent moving down at the bottom of gridster\n      if (\n        directions.includes(Direction.DOWN) &&\n        this.gridsterItem.el.getBoundingClientRect().bottom >\n          this.gridster.el.getBoundingClientRect().bottom - \n            (this.outerMarginBottom ?? this.margin)\n      ) {\n        directions = directions.filter(\n          direction => direction != Direction.DOWN\n        );\n        e = new MouseEvent(e.type, {\n          clientX: e.clientX,\n          clientY: this.lastMouse.clientY\n        });\n      }\n    }\n\n    // do not change item location when there is no direction to go\n    if (directions.length) {\n      this.offsetLeft =\n        this.gridster.el.scrollLeft - this.gridster.el.offsetLeft;\n      this.offsetTop = this.gridster.el.scrollTop - this.gridster.el.offsetTop;\n      scroll(\n        this.gridster,\n        this.left,\n        this.top,\n        this.width,\n        this.height,\n        e,\n        this.lastMouse,\n        this.calculateItemPositionFromMousePosition\n      );\n\n      this.calculateItemPositionFromMousePosition(e);\n    }\n  };\n\n  calculateItemPositionFromMousePosition = (e: MouseEvent): void => {\n    if (this.gridster.options.scale) {\n      this.calculateItemPositionWithScale(e, this.gridster.options.scale);\n    } else {\n      this.calculateItemPositionWithoutScale(e);\n    }\n    this.calculateItemPosition();\n    this.lastMouse.clientX = e.clientX;\n    this.lastMouse.clientY = e.clientY;\n    this.zone.run(() => {\n      this.gridster.updateGrid();\n    });\n  };\n\n  calculateItemPositionWithScale(e: MouseEvent, scale: number): void {\n    if (this.gridster.$options.dirType === DirTypes.RTL) {\n      this.left =\n        this.gridster.el.scrollWidth -\n        this.originalClientX +\n        (e.clientX - this.originalClientX) / scale +\n        this.diffLeft;\n    } else {\n      this.left =\n        this.originalClientX +\n        (e.clientX - this.originalClientX) / scale +\n        this.offsetLeft -\n        this.diffLeft;\n    }\n    this.top =\n      this.originalClientY +\n      (e.clientY - this.originalClientY) / scale +\n      this.offsetTop -\n      this.diffTop;\n  }\n\n  calculateItemPositionWithoutScale(e: MouseEvent): void {\n    if (this.gridster.$options.dirType === DirTypes.RTL) {\n      this.left = this.gridster.el.scrollWidth - e.clientX + this.diffLeft;\n    } else {\n      this.left = e.clientX + this.offsetLeft - this.diffLeft;\n    }\n\n    this.top = e.clientY + this.offsetTop - this.diffTop;\n  }\n\n  dragStop = (e: MouseEvent): void => {\n    e.stopPropagation();\n    e.preventDefault();\n\n    cancelScroll();\n    this.cancelOnBlur();\n    this.mousemove();\n    this.mouseup();\n    this.mouseleave();\n    this.touchmove();\n    this.touchend();\n    this.touchcancel();\n    this.gridsterItem.renderer.removeClass(\n      this.gridsterItem.el,\n      'gridster-item-moving'\n    );\n    this.gridster.dragInProgress = false;\n    this.gridster.updateGrid();\n    this.path = [];\n    if (\n      this.gridster.options.draggable &&\n      this.gridster.options.draggable.stop\n    ) {\n      Promise.resolve(\n        this.gridster.options.draggable.stop(\n          this.gridsterItem.item,\n          this.gridsterItem,\n          e\n        )\n      ).then(this.makeDrag, this.cancelDrag);\n    } else {\n      this.makeDrag();\n    }\n    setTimeout(() => {\n      if (this.gridster) {\n        this.gridster.movingItem = null;\n        this.gridster.previewStyle(true);\n      }\n    });\n  };\n\n  cancelDrag = (): void => {\n    this.gridsterItem.$item.x = this.gridsterItem.item.x || 0;\n    this.gridsterItem.$item.y = this.gridsterItem.item.y || 0;\n    this.gridsterItem.setSize();\n    if (this.push) {\n      this.push.restoreItems();\n    }\n    if (this.swap) {\n      this.swap.restoreSwapItem();\n    }\n    if (this.push) {\n      this.push.destroy();\n      this.push = null!;\n    }\n    if (this.swap) {\n      this.swap.destroy();\n      this.swap = null!;\n    }\n  };\n\n  makeDrag = (): void => {\n    if (\n      this.gridster.$options.draggable.dropOverItems &&\n      this.gridster.options.draggable &&\n      this.gridster.options.draggable.dropOverItemsCallback &&\n      this.collision &&\n      this.collision !== true &&\n      this.collision.$item\n    ) {\n      this.gridster.options.draggable.dropOverItemsCallback(\n        this.gridsterItem.item,\n        this.collision.item,\n        this.gridster\n      );\n    }\n    this.collision = false;\n    this.gridsterItem.setSize();\n    this.gridsterItem.checkItemChanges(\n      this.gridsterItem.$item,\n      this.gridsterItem.item\n    );\n    if (this.push) {\n      this.push.setPushedItems();\n    }\n    if (this.swap) {\n      this.swap.setSwapItem();\n    }\n    if (this.push) {\n      this.push.destroy();\n      this.push = null!;\n    }\n    if (this.swap) {\n      this.swap.destroy();\n      this.swap = null!;\n    }\n  };\n\n  calculateItemPosition(): void {\n    this.gridster.movingItem = this.gridsterItem.$item;\n    this.positionX = this.gridster.pixelsToPositionX(this.left, Math.round);\n    this.positionY = this.gridster.pixelsToPositionY(this.top, Math.round);\n    this.positionXBackup = this.gridsterItem.$item.x;\n    this.positionYBackup = this.gridsterItem.$item.y;\n    this.gridsterItem.$item.x = this.positionX;\n    if (this.gridster.checkGridCollision(this.gridsterItem.$item)) {\n      this.gridsterItem.$item.x = this.positionXBackup;\n    }\n    this.gridsterItem.$item.y = this.positionY;\n    if (this.gridster.checkGridCollision(this.gridsterItem.$item)) {\n      this.gridsterItem.$item.y = this.positionYBackup;\n    }\n    this.gridster.gridRenderer.setCellPosition(\n      this.gridsterItem.renderer,\n      this.gridsterItem.el,\n      this.left,\n      this.top\n    );\n\n    if (\n      this.positionXBackup !== this.gridsterItem.$item.x ||\n      this.positionYBackup !== this.gridsterItem.$item.y\n    ) {\n      const lastPosition = this.path[this.path.length - 1];\n      let direction = '';\n      if (lastPosition.x < this.gridsterItem.$item.x) {\n        direction = this.push.fromWest;\n      } else if (lastPosition.x > this.gridsterItem.$item.x) {\n        direction = this.push.fromEast;\n      } else if (lastPosition.y < this.gridsterItem.$item.y) {\n        direction = this.push.fromNorth;\n      } else if (lastPosition.y > this.gridsterItem.$item.y) {\n        direction = this.push.fromSouth;\n      }\n      this.push.pushItems(direction, this.gridster.$options.disablePushOnDrag);\n      this.swap.swapItems();\n      this.collision = this.gridster.checkCollision(this.gridsterItem.$item);\n      if (this.collision) {\n        this.gridsterItem.$item.x = this.positionXBackup;\n        this.gridsterItem.$item.y = this.positionYBackup;\n        if (\n          this.gridster.$options.draggable.dropOverItems &&\n          this.collision !== true &&\n          this.collision.$item\n        ) {\n          this.gridster.movingItem = null;\n        }\n      } else {\n        this.path.push({\n          x: this.gridsterItem.$item.x,\n          y: this.gridsterItem.$item.y\n        });\n      }\n      this.push.checkPushBack();\n    } else {\n      // reset the collision when you drag and drop on an adjacent cell that is not empty\n      // and go back to the cell you were in from the beginning,\n      // this is to prevent `dropOverItemsCallback'\n      this.collision = false;\n    }\n    this.gridster.previewStyle(true);\n  }\n\n  toggle(): void {\n    const enableDrag = this.gridsterItem.canBeDragged();\n    if (!this.enabled && enableDrag) {\n      this.enabled = !this.enabled;\n      this.mousedown = this.gridsterItem.renderer.listen(\n        this.gridsterItem.el,\n        'mousedown',\n        this.dragStartDelay\n      );\n      this.touchstart = this.gridsterItem.renderer.listen(\n        this.gridsterItem.el,\n        'touchstart',\n        this.dragStartDelay\n      );\n    } else if (this.enabled && !enableDrag) {\n      this.enabled = !this.enabled;\n      this.mousedown();\n      this.touchstart();\n    }\n  }\n\n  dragStartDelay = (e: MouseEvent): void => {\n    const target = e.target as HTMLElement;\n    if (target.classList.contains(GRIDSTER_ITEM_RESIZABLE_HANDLER_CLASS)) {\n      return;\n    }\n    if (GridsterUtils.checkContentClassForEvent(this.gridster, e)) {\n      return;\n    }\n    GridsterUtils.checkTouchEvent(e);\n    if (!this.gridster.$options.draggable.delayStart) {\n      this.dragStart(e);\n      return;\n    }\n    const timeout = setTimeout(() => {\n      this.dragStart(e);\n      cancelDrag();\n    }, this.gridster.$options.draggable.delayStart);\n    const cancelMouse = this.gridsterItem.renderer.listen(\n      'document',\n      'mouseup',\n      cancelDrag\n    );\n    const cancelMouseLeave = this.gridsterItem.renderer.listen(\n      'document',\n      'mouseleave',\n      cancelDrag\n    );\n    const cancelOnBlur = this.gridsterItem.renderer.listen(\n      'window',\n      'blur',\n      cancelDrag\n    );\n    const cancelTouchMove = this.gridsterItem.renderer.listen(\n      'document',\n      'touchmove',\n      cancelMove\n    );\n    const cancelTouchEnd = this.gridsterItem.renderer.listen(\n      'document',\n      'touchend',\n      cancelDrag\n    );\n    const cancelTouchCancel = this.gridsterItem.renderer.listen(\n      'document',\n      'touchcancel',\n      cancelDrag\n    );\n\n    function cancelMove(eventMove: MouseEvent): void {\n      GridsterUtils.checkTouchEvent(eventMove);\n      if (\n        Math.abs(eventMove.clientX - e.clientX) > 9 ||\n        Math.abs(eventMove.clientY - e.clientY) > 9\n      ) {\n        cancelDrag();\n      }\n    }\n\n    function cancelDrag(): void {\n      clearTimeout(timeout);\n      cancelOnBlur();\n      cancelMouse();\n      cancelMouseLeave();\n      cancelTouchMove();\n      cancelTouchEnd();\n      cancelTouchCancel();\n    }\n  };\n\n  /**\n   * Returns the list of directions for given mouse event\n   * @param e Mouse event\n   * */\n  private getDirections(e: MouseEvent) {\n    const directions: string[] = [];\n    if (this.lastMouse.clientX === 0 && this.lastMouse.clientY === 0) {\n      this.lastMouse.clientY = e.clientY;\n      this.lastMouse.clientX = e.clientX;\n    }\n    if (this.lastMouse.clientY > e.clientY) {\n      directions.push(Direction.UP);\n    }\n    if (this.lastMouse.clientY < e.clientY) {\n      directions.push(Direction.DOWN);\n    }\n    if (this.lastMouse.clientX < e.clientX) {\n      directions.push(Direction.RIGHT);\n    }\n    if (this.lastMouse.clientX > e.clientX) {\n      directions.push(Direction.LEFT);\n    }\n    return directions;\n  }\n}\n"]}
|