You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

557 lines
56 KiB
JavaScript

/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { FlowchartConstants } from './ngx-flowchart.models';
/** @type {?} */
var nodeDropScope = {
dropElement: null
};
var FcNodeDraggingService = /** @class */ (function () {
function FcNodeDraggingService(modelService, applyFunction, automaticResize, dragAnimation) {
this.nodeDraggingScope = {
shadowDragStarted: false,
dropElement: null,
draggedNodes: [],
shadowElements: []
};
this.dragOffsets = [];
this.draggedElements = [];
this.destinationHtmlElements = [];
this.oldDisplayStyles = [];
this.modelService = modelService;
this.automaticResize = automaticResize;
this.dragAnimation = dragAnimation;
this.applyFunction = applyFunction;
}
/**
* @private
* @param {?} coordinate
* @param {?} max
* @return {?}
*/
FcNodeDraggingService.prototype.getCoordinate = /**
* @private
* @param {?} coordinate
* @param {?} max
* @return {?}
*/
function (coordinate, max) {
coordinate = Math.max(coordinate, 0);
coordinate = Math.min(coordinate, max);
return coordinate;
};
/**
* @private
* @param {?} x
* @return {?}
*/
FcNodeDraggingService.prototype.getXCoordinate = /**
* @private
* @param {?} x
* @return {?}
*/
function (x) {
return this.getCoordinate(x, this.modelService.canvasHtmlElement.offsetWidth);
};
/**
* @private
* @param {?} y
* @return {?}
*/
FcNodeDraggingService.prototype.getYCoordinate = /**
* @private
* @param {?} y
* @return {?}
*/
function (y) {
return this.getCoordinate(y, this.modelService.canvasHtmlElement.offsetHeight);
};
/**
* @private
* @param {?} draggedNode
* @param {?} nodeElement
* @return {?}
*/
FcNodeDraggingService.prototype.resizeCanvas = /**
* @private
* @param {?} draggedNode
* @param {?} nodeElement
* @return {?}
*/
function (draggedNode, nodeElement) {
if (this.automaticResize && !this.modelService.isDropSource()) {
/** @type {?} */
var canvasElement = this.modelService.canvasHtmlElement;
if (canvasElement.offsetWidth < draggedNode.x + nodeElement.offsetWidth + FlowchartConstants.canvasResizeThreshold) {
canvasElement.style.width = canvasElement.offsetWidth + FlowchartConstants.canvasResizeStep + 'px';
}
if (canvasElement.offsetHeight < draggedNode.y + nodeElement.offsetHeight + FlowchartConstants.canvasResizeThreshold) {
canvasElement.style.height = canvasElement.offsetHeight + FlowchartConstants.canvasResizeStep + 'px';
}
}
};
/**
* @param {?} node
* @return {?}
*/
FcNodeDraggingService.prototype.isDraggingNode = /**
* @param {?} node
* @return {?}
*/
function (node) {
return this.nodeDraggingScope.draggedNodes.includes(node);
};
/**
* @param {?} event
* @param {?} node
* @return {?}
*/
FcNodeDraggingService.prototype.dragstart = /**
* @param {?} event
* @param {?} node
* @return {?}
*/
function (event, node) {
var e_1, _a, e_2, _b;
if (node.readonly) {
return;
}
this.dragOffsets.length = 0;
this.draggedElements.length = 0;
this.nodeDraggingScope.draggedNodes.length = 0;
this.nodeDraggingScope.shadowElements.length = 0;
this.destinationHtmlElements.length = 0;
this.oldDisplayStyles.length = 0;
/** @type {?} */
var elements = [];
/** @type {?} */
var nodes = [];
if (this.modelService.nodes.isSelected(node)) {
/** @type {?} */
var selectedNodes = this.modelService.nodes.getSelectedNodes();
try {
for (var selectedNodes_1 = tslib_1.__values(selectedNodes), selectedNodes_1_1 = selectedNodes_1.next(); !selectedNodes_1_1.done; selectedNodes_1_1 = selectedNodes_1.next()) {
var selectedNode = selectedNodes_1_1.value;
/** @type {?} */
var element = $(this.modelService.nodes.getHtmlElement(selectedNode.id));
elements.push(element);
nodes.push(selectedNode);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (selectedNodes_1_1 && !selectedNodes_1_1.done && (_a = selectedNodes_1.return)) _a.call(selectedNodes_1);
}
finally { if (e_1) throw e_1.error; }
}
}
else {
elements.push($((/** @type {?} */ (event.target))));
nodes.push(node);
}
/** @type {?} */
var offsetsX = [];
/** @type {?} */
var offsetsY = [];
try {
for (var elements_1 = tslib_1.__values(elements), elements_1_1 = elements_1.next(); !elements_1_1.done; elements_1_1 = elements_1.next()) {
var element = elements_1_1.value;
offsetsX.push(parseInt(element.css('left'), 10) - event.clientX);
offsetsY.push(parseInt(element.css('top'), 10) - event.clientY);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (elements_1_1 && !elements_1_1.done && (_b = elements_1.return)) _b.call(elements_1);
}
finally { if (e_2) throw e_2.error; }
}
/** @type {?} */
var originalEvent = ((/** @type {?} */ (event))).originalEvent || event;
if (this.modelService.isDropSource()) {
if (nodeDropScope.dropElement) {
nodeDropScope.dropElement.parentNode.removeChild(nodeDropScope.dropElement);
nodeDropScope.dropElement = null;
}
nodeDropScope.dropElement = (/** @type {?} */ (elements[0][0].cloneNode(true)));
/** @type {?} */
var offset = $(this.modelService.canvasHtmlElement).offset();
nodeDropScope.dropElement.offsetInfo = {
offsetX: Math.round(offsetsX[0] + offset.left),
offsetY: Math.round(offsetsY[0] + offset.top)
};
nodeDropScope.dropElement.style.position = 'absolute';
nodeDropScope.dropElement.style.pointerEvents = 'none';
nodeDropScope.dropElement.style.zIndex = '9999';
document.body.appendChild(nodeDropScope.dropElement);
/** @type {?} */
var dropNodeInfo = {
node: node,
dropTargetId: this.modelService.dropTargetId,
offsetX: Math.round(offsetsX[0] + offset.left),
offsetY: Math.round(offsetsY[0] + offset.top)
};
originalEvent.dataTransfer.setData('text', JSON.stringify(dropNodeInfo));
if (originalEvent.dataTransfer.setDragImage) {
originalEvent.dataTransfer.setDragImage(this.modelService.getDragImage(), 0, 0);
}
else {
/** @type {?} */
var target_1 = (/** @type {?} */ (event.target));
/** @type {?} */
var cloneNode_1 = target_1.cloneNode(true);
target_1.parentNode.insertBefore(cloneNode_1, target_1);
target_1.style.visibility = 'collapse';
setTimeout((/**
* @return {?}
*/
function () {
target_1.parentNode.removeChild(cloneNode_1);
target_1.style.visibility = 'visible';
}), 0);
}
return;
}
this.nodeDraggingScope.draggedNodes = nodes;
for (var i = 0; i < elements.length; i++) {
this.draggedElements.push(elements[i][0]);
this.dragOffsets.push({
x: offsetsX[i],
y: offsetsY[i]
});
}
if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {
for (var i = 0; i < this.draggedElements.length; i++) {
/** @type {?} */
var dragOffset = this.dragOffsets[i];
/** @type {?} */
var draggedNode = this.nodeDraggingScope.draggedNodes[i];
/** @type {?} */
var shadowElement = $("<div style=\"position: absolute; opacity: 0.7; " +
("top: " + this.getYCoordinate(dragOffset.y + event.clientY) + "px; ") +
("left: " + this.getXCoordinate(dragOffset.x + event.clientX) + "px; \">") +
("<div class=\"innerNode\"><p style=\"padding: 0 15px;\">" + draggedNode.name + "</p> </div></div>"));
/** @type {?} */
var targetInnerNode = $(this.draggedElements[i]).children()[0];
shadowElement.children()[0].style.backgroundColor = targetInnerNode.style.backgroundColor;
this.nodeDraggingScope.shadowElements.push(shadowElement);
this.modelService.canvasHtmlElement.appendChild(this.nodeDraggingScope.shadowElements[i][0]);
}
}
originalEvent.dataTransfer.setData('text', 'Just to support firefox');
if (originalEvent.dataTransfer.setDragImage) {
originalEvent.dataTransfer.setDragImage(this.modelService.getDragImage(), 0, 0);
}
else {
this.draggedElements.forEach((/**
* @param {?} draggedElement
* @return {?}
*/
function (draggedElement) {
/** @type {?} */
var cloneNode = draggedElement.cloneNode(true);
draggedElement.parentNode.insertBefore(cloneNode, draggedElement);
draggedElement.style.visibility = 'collapse';
setTimeout((/**
* @return {?}
*/
function () {
draggedElement.parentNode.removeChild(cloneNode);
draggedElement.style.visibility = 'visible';
}), 0);
}));
if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {
for (var i = 0; i < this.draggedElements.length; i++) {
this.destinationHtmlElements.push(this.draggedElements[i]);
this.oldDisplayStyles.push(this.destinationHtmlElements[i].style.display);
this.destinationHtmlElements[i].style.display = 'none';
}
this.nodeDraggingScope.shadowDragStarted = true;
}
}
};
/**
* @param {?} event
* @return {?}
*/
FcNodeDraggingService.prototype.drop = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (this.modelService.isDropSource()) {
event.preventDefault();
return false;
}
/** @type {?} */
var dropNode = null;
/** @type {?} */
var originalEvent = ((/** @type {?} */ (event))).originalEvent || event;
/** @type {?} */
var infoText = originalEvent.dataTransfer.getData('text');
if (infoText) {
/** @type {?} */
var dropNodeInfo = null;
try {
dropNodeInfo = JSON.parse(infoText);
}
catch (e) { }
if (dropNodeInfo && dropNodeInfo.dropTargetId) {
if (this.modelService.canvasHtmlElement.id &&
this.modelService.canvasHtmlElement.id === dropNodeInfo.dropTargetId) {
dropNode = dropNodeInfo.node;
/** @type {?} */
var offset = $(this.modelService.canvasHtmlElement).offset();
/** @type {?} */
var x = event.clientX - offset.left;
/** @type {?} */
var y = event.clientY - offset.top;
dropNode.x = Math.round(this.getXCoordinate(dropNodeInfo.offsetX + x));
dropNode.y = Math.round(this.getYCoordinate(dropNodeInfo.offsetY + y));
}
}
}
if (dropNode) {
this.modelService.dropNode(event, dropNode);
event.preventDefault();
return false;
}
else if (this.nodeDraggingScope.draggedNodes.length) {
return this.applyFunction((/**
* @return {?}
*/
function () {
for (var i = 0; i < _this.nodeDraggingScope.draggedNodes.length; i++) {
/** @type {?} */
var draggedNode = _this.nodeDraggingScope.draggedNodes[i];
/** @type {?} */
var dragOffset = _this.dragOffsets[i];
draggedNode.x = Math.round(_this.getXCoordinate(dragOffset.x + event.clientX));
draggedNode.y = Math.round(_this.getYCoordinate(dragOffset.y + event.clientY));
}
event.preventDefault();
_this.modelService.notifyModelChanged();
return false;
}));
}
};
/**
* @param {?} event
* @return {?}
*/
FcNodeDraggingService.prototype.dragover = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (nodeDropScope.dropElement) {
/** @type {?} */
var offsetInfo = nodeDropScope.dropElement.offsetInfo;
nodeDropScope.dropElement.style.left = (offsetInfo.offsetX + event.clientX) + 'px';
nodeDropScope.dropElement.style.top = (offsetInfo.offsetY + event.clientY) + 'px';
if (this.nodeDraggingScope.shadowDragStarted) {
this.applyFunction((/**
* @return {?}
*/
function () {
_this.destinationHtmlElements[0].style.display = _this.oldDisplayStyles[0];
_this.nodeDraggingScope.shadowDragStarted = false;
}));
}
event.preventDefault();
return;
}
if (this.modelService.isDropSource()) {
event.preventDefault();
return;
}
if (!this.nodeDraggingScope.draggedNodes.length) {
event.preventDefault();
return;
}
if (this.dragAnimation === FlowchartConstants.dragAnimationRepaint) {
if (this.nodeDraggingScope.draggedNodes.length) {
return this.applyFunction((/**
* @return {?}
*/
function () {
for (var i = 0; i < _this.nodeDraggingScope.draggedNodes.length; i++) {
/** @type {?} */
var draggedNode = _this.nodeDraggingScope.draggedNodes[i];
/** @type {?} */
var dragOffset = _this.dragOffsets[i];
draggedNode.x = _this.getXCoordinate(dragOffset.x + event.clientX);
draggedNode.y = _this.getYCoordinate(dragOffset.y + event.clientY);
_this.resizeCanvas(draggedNode, _this.draggedElements[i]);
}
event.preventDefault();
_this.modelService.notifyModelChanged();
return false;
}));
}
}
else if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {
if (this.nodeDraggingScope.draggedNodes.length) {
if (this.nodeDraggingScope.shadowDragStarted) {
this.applyFunction((/**
* @return {?}
*/
function () {
for (var i = 0; i < _this.nodeDraggingScope.draggedNodes.length; i++) {
_this.destinationHtmlElements[i].style.display = _this.oldDisplayStyles[i];
}
_this.nodeDraggingScope.shadowDragStarted = false;
}));
}
for (var i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {
/** @type {?} */
var draggedNode = this.nodeDraggingScope.draggedNodes[i];
/** @type {?} */
var dragOffset = this.dragOffsets[i];
this.nodeDraggingScope.shadowElements[i].css('left', this.getXCoordinate(dragOffset.x + event.clientX) + 'px');
this.nodeDraggingScope.shadowElements[i].css('top', this.getYCoordinate(dragOffset.y + event.clientY) + 'px');
this.resizeCanvas(draggedNode, this.draggedElements[i]);
}
event.preventDefault();
}
}
};
/**
* @param {?} event
* @return {?}
*/
FcNodeDraggingService.prototype.dragend = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
this.applyFunction((/**
* @return {?}
*/
function () {
if (nodeDropScope.dropElement) {
nodeDropScope.dropElement.parentNode.removeChild(nodeDropScope.dropElement);
nodeDropScope.dropElement = null;
}
if (_this.modelService.isDropSource()) {
return;
}
if (_this.nodeDraggingScope.shadowElements.length) {
for (var i = 0; i < _this.nodeDraggingScope.draggedNodes.length; i++) {
/** @type {?} */
var draggedNode = _this.nodeDraggingScope.draggedNodes[i];
/** @type {?} */
var shadowElement = _this.nodeDraggingScope.shadowElements[i];
draggedNode.x = parseInt(shadowElement.css('left').replace('px', ''), 10);
draggedNode.y = parseInt(shadowElement.css('top').replace('px', ''), 10);
_this.modelService.canvasHtmlElement.removeChild(shadowElement[0]);
}
_this.nodeDraggingScope.shadowElements.length = 0;
_this.modelService.notifyModelChanged();
}
if (_this.nodeDraggingScope.draggedNodes.length) {
_this.nodeDraggingScope.draggedNodes.length = 0;
_this.draggedElements.length = 0;
_this.dragOffsets.length = 0;
}
}));
};
return FcNodeDraggingService;
}());
export { FcNodeDraggingService };
if (false) {
/** @type {?} */
FcNodeDraggingService.prototype.nodeDraggingScope;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.dragOffsets;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.draggedElements;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.destinationHtmlElements;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.oldDisplayStyles;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.modelService;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.automaticResize;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.dragAnimation;
/**
* @type {?}
* @private
*/
FcNodeDraggingService.prototype.applyFunction;
}
/**
* @record
*/
export function NodeDraggingScope() { }
if (false) {
/** @type {?} */
NodeDraggingScope.prototype.draggedNodes;
/** @type {?} */
NodeDraggingScope.prototype.shadowElements;
/** @type {?} */
NodeDraggingScope.prototype.shadowDragStarted;
/** @type {?} */
NodeDraggingScope.prototype.dropElement;
}
/**
* @record
*/
export function NodeDropElement() { }
if (false) {
/** @type {?|undefined} */
NodeDropElement.prototype.offsetInfo;
}
/**
* @record
*/
export function NodeDropScope() { }
if (false) {
/** @type {?} */
NodeDropScope.prototype.dropElement;
}
/**
* @record
*/
export function DropNodeInfo() { }
if (false) {
/** @type {?} */
DropNodeInfo.prototype.node;
/** @type {?} */
DropNodeInfo.prototype.dropTargetId;
/** @type {?} */
DropNodeInfo.prototype.offsetX;
/** @type {?} */
DropNodeInfo.prototype.offsetY;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-dragging.service.js","sourceRoot":"ng://ngx-flowchart/","sources":["lib/node-dragging.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FcModelService } from './model.service';\nimport { FcCoords, FcNode, FlowchartConstants } from './ngx-flowchart.models';\n\nconst nodeDropScope: NodeDropScope = {\n  dropElement: null\n};\n\nexport class FcNodeDraggingService {\n\n  nodeDraggingScope: NodeDraggingScope = {\n    shadowDragStarted: false,\n    dropElement: null,\n    draggedNodes: [],\n    shadowElements: []\n  };\n\n  private dragOffsets: FcCoords[] = [];\n  private draggedElements: HTMLElement[] = [];\n\n  private destinationHtmlElements: HTMLElement[] = [];\n  private oldDisplayStyles: string[] = [];\n\n  private readonly modelService: FcModelService;\n  private readonly automaticResize: boolean;\n  private readonly dragAnimation: string;\n  private readonly applyFunction: <T>(fn: (...args: any[]) => T) => T;\n\n  constructor(modelService: FcModelService,\n              applyFunction: <T>(fn: (...args: any[]) => T) => T,\n              automaticResize: boolean, dragAnimation: string) {\n    this.modelService = modelService;\n    this.automaticResize = automaticResize;\n    this.dragAnimation = dragAnimation;\n    this.applyFunction = applyFunction;\n  }\n\n  private getCoordinate(coordinate: number, max: number): number {\n    coordinate = Math.max(coordinate, 0);\n    coordinate = Math.min(coordinate, max);\n    return coordinate;\n  }\n\n  private getXCoordinate(x: number): number {\n    return this.getCoordinate(x, this.modelService.canvasHtmlElement.offsetWidth);\n  }\n\n  private getYCoordinate(y: number): number {\n    return this.getCoordinate(y, this.modelService.canvasHtmlElement.offsetHeight);\n  }\n\n  private resizeCanvas(draggedNode: FcNode, nodeElement: HTMLElement) {\n    if (this.automaticResize && !this.modelService.isDropSource()) {\n      const canvasElement = this.modelService.canvasHtmlElement;\n      if (canvasElement.offsetWidth < draggedNode.x + nodeElement.offsetWidth + FlowchartConstants.canvasResizeThreshold) {\n        canvasElement.style.width = canvasElement.offsetWidth + FlowchartConstants.canvasResizeStep + 'px';\n      }\n      if (canvasElement.offsetHeight < draggedNode.y + nodeElement.offsetHeight + FlowchartConstants.canvasResizeThreshold) {\n        canvasElement.style.height = canvasElement.offsetHeight + FlowchartConstants.canvasResizeStep + 'px';\n      }\n    }\n  }\n\n  public isDraggingNode(node: FcNode): boolean {\n    return this.nodeDraggingScope.draggedNodes.includes(node);\n  }\n\n  public dragstart(event: DragEvent, node: FcNode) {\n    if (node.readonly) {\n      return;\n    }\n    this.dragOffsets.length = 0;\n    this.draggedElements.length = 0;\n    this.nodeDraggingScope.draggedNodes.length = 0;\n    this.nodeDraggingScope.shadowElements.length = 0;\n    this.destinationHtmlElements.length = 0;\n    this.oldDisplayStyles.length = 0;\n    const elements: Array<JQuery<HTMLElement>> = [];\n    const nodes: Array<FcNode> = [];\n    if (this.modelService.nodes.isSelected(node)) {\n      const selectedNodes = this.modelService.nodes.getSelectedNodes();\n      for (const selectedNode of selectedNodes) {\n        const element = $(this.modelService.nodes.getHtmlElement(selectedNode.id));\n        elements.push(element);\n        nodes.push(selectedNode);\n      }\n    } else {\n      elements.push($(event.target as HTMLElement));\n      nodes.push(node);\n    }\n    const offsetsX: number[] = [];\n    const offsetsY: number[] = [];\n    for (const element of elements) {\n      offsetsX.push(parseInt(element.css('left'), 10) - event.clientX);\n      offsetsY.push(parseInt(element.css('top'), 10) - event.clientY);\n    }\n    const originalEvent: DragEvent = (event as any).originalEvent || event;\n    if (this.modelService.isDropSource()) {\n      if (nodeDropScope.dropElement) {\n        nodeDropScope.dropElement.parentNode.removeChild(nodeDropScope.dropElement);\n        nodeDropScope.dropElement = null;\n      }\n      nodeDropScope.dropElement = elements[0][0].cloneNode(true) as NodeDropElement;\n      const offset = $(this.modelService.canvasHtmlElement).offset();\n      nodeDropScope.dropElement.offsetInfo = {\n        offsetX: Math.round(offsetsX[0] + offset.left),\n        offsetY: Math.round(offsetsY[0] + offset.top)\n      };\n      nodeDropScope.dropElement.style.position = 'absolute';\n      nodeDropScope.dropElement.style.pointerEvents = 'none';\n      nodeDropScope.dropElement.style.zIndex = '9999';\n\n      document.body.appendChild(nodeDropScope.dropElement);\n      const dropNodeInfo: DropNodeInfo = {\n        node,\n        dropTargetId: this.modelService.dropTargetId,\n        offsetX: Math.round(offsetsX[0] + offset.left),\n        offsetY: Math.round(offsetsY[0] + offset.top)\n      };\n      originalEvent.dataTransfer.setData('text', JSON.stringify(dropNodeInfo));\n\n      if (originalEvent.dataTransfer.setDragImage) {\n        originalEvent.dataTransfer.setDragImage(this.modelService.getDragImage(), 0, 0);\n      } else {\n        const target: HTMLElement = event.target as HTMLElement;\n        const cloneNode = target.cloneNode(true);\n        target.parentNode.insertBefore(cloneNode, target);\n        target.style.visibility = 'collapse';\n        setTimeout(() => {\n          target.parentNode.removeChild(cloneNode);\n          target.style.visibility = 'visible';\n        }, 0);\n      }\n      return;\n    }\n    this.nodeDraggingScope.draggedNodes = nodes;\n    for (let i = 0; i < elements.length; i++) {\n      this.draggedElements.push(elements[i][0]);\n      this.dragOffsets.push(\n        {\n          x: offsetsX[i],\n          y: offsetsY[i]\n        }\n      );\n    }\n\n    if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {\n      for (let i = 0; i < this.draggedElements.length; i++) {\n        const dragOffset = this.dragOffsets[i];\n        const draggedNode = this.nodeDraggingScope.draggedNodes[i];\n        const shadowElement = $(`<div style=\"position: absolute; opacity: 0.7; ` +\n                                `top: ${this.getYCoordinate(dragOffset.y + event.clientY)}px; ` +\n                                `left: ${this.getXCoordinate(dragOffset.x + event.clientX)}px; \">` +\n                                `<div class=\"innerNode\"><p style=\"padding: 0 15px;\">${draggedNode.name}</p> </div></div>`);\n        const targetInnerNode = $(this.draggedElements[i]).children()[0];\n        shadowElement.children()[0].style.backgroundColor = targetInnerNode.style.backgroundColor;\n        this.nodeDraggingScope.shadowElements.push(shadowElement);\n        this.modelService.canvasHtmlElement.appendChild(this.nodeDraggingScope.shadowElements[i][0]);\n      }\n    }\n    originalEvent.dataTransfer.setData('text', 'Just to support firefox');\n    if (originalEvent.dataTransfer.setDragImage) {\n      originalEvent.dataTransfer.setDragImage(this.modelService.getDragImage(), 0, 0);\n    } else {\n      this.draggedElements.forEach((draggedElement) => {\n        const cloneNode = draggedElement.cloneNode(true);\n        draggedElement.parentNode.insertBefore(cloneNode, draggedElement);\n        draggedElement.style.visibility = 'collapse';\n        setTimeout(() => {\n          draggedElement.parentNode.removeChild(cloneNode);\n          draggedElement.style.visibility = 'visible';\n        }, 0);\n      });\n      if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {\n        for (let i = 0; i < this.draggedElements.length; i++) {\n          this.destinationHtmlElements.push(this.draggedElements[i]);\n          this.oldDisplayStyles.push(this.destinationHtmlElements[i].style.display);\n          this.destinationHtmlElements[i].style.display = 'none';\n        }\n        this.nodeDraggingScope.shadowDragStarted = true;\n      }\n    }\n  }\n\n  public drop(event: DragEvent): boolean {\n    if (this.modelService.isDropSource()) {\n      event.preventDefault();\n      return false;\n    }\n    let dropNode: FcNode = null;\n    const originalEvent: DragEvent = (event as any).originalEvent || event;\n    const infoText = originalEvent.dataTransfer.getData('text');\n    if (infoText) {\n      let dropNodeInfo: DropNodeInfo = null;\n      try {\n        dropNodeInfo = JSON.parse(infoText);\n      } catch (e) {}\n      if (dropNodeInfo && dropNodeInfo.dropTargetId) {\n        if (this.modelService.canvasHtmlElement.id &&\n          this.modelService.canvasHtmlElement.id === dropNodeInfo.dropTargetId) {\n          dropNode = dropNodeInfo.node;\n          const offset = $(this.modelService.canvasHtmlElement).offset();\n          const x = event.clientX - offset.left;\n          const y = event.clientY - offset.top;\n          dropNode.x = Math.round(this.getXCoordinate(dropNodeInfo.offsetX + x));\n          dropNode.y = Math.round(this.getYCoordinate(dropNodeInfo.offsetY + y));\n        }\n      }\n    }\n    if (dropNode) {\n      this.modelService.dropNode(event, dropNode);\n      event.preventDefault();\n      return false;\n    } else if (this.nodeDraggingScope.draggedNodes.length) {\n      return this.applyFunction(() => {\n        for (let i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {\n          const draggedNode = this.nodeDraggingScope.draggedNodes[i];\n          const dragOffset = this.dragOffsets[i];\n          draggedNode.x = Math.round(this.getXCoordinate(dragOffset.x + event.clientX));\n          draggedNode.y = Math.round(this.getYCoordinate(dragOffset.y + event.clientY));\n        }\n        event.preventDefault();\n        this.modelService.notifyModelChanged();\n        return false;\n      });\n    }\n  }\n\n  public dragover(event: DragEvent) {\n    if (nodeDropScope.dropElement) {\n      const offsetInfo = nodeDropScope.dropElement.offsetInfo;\n      nodeDropScope.dropElement.style.left = (offsetInfo.offsetX + event.clientX) + 'px';\n      nodeDropScope.dropElement.style.top = (offsetInfo.offsetY + event.clientY) + 'px';\n      if (this.nodeDraggingScope.shadowDragStarted) {\n        this.applyFunction(() => {\n          this.destinationHtmlElements[0].style.display = this.oldDisplayStyles[0];\n          this.nodeDraggingScope.shadowDragStarted = false;\n        });\n      }\n      event.preventDefault();\n      return;\n    }\n    if (this.modelService.isDropSource()) {\n      event.preventDefault();\n      return;\n    }\n    if (!this.nodeDraggingScope.draggedNodes.length) {\n      event.preventDefault();\n      return;\n    }\n    if (this.dragAnimation === FlowchartConstants.dragAnimationRepaint) {\n      if (this.nodeDraggingScope.draggedNodes.length) {\n        return this.applyFunction(() => {\n          for (let i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {\n            const draggedNode = this.nodeDraggingScope.draggedNodes[i];\n            const dragOffset = this.dragOffsets[i];\n            draggedNode.x = this.getXCoordinate(dragOffset.x + event.clientX);\n            draggedNode.y = this.getYCoordinate(dragOffset.y + event.clientY);\n            this.resizeCanvas(draggedNode, this.draggedElements[i]);\n          }\n          event.preventDefault();\n          this.modelService.notifyModelChanged();\n          return false;\n        });\n      }\n    } else if (this.dragAnimation === FlowchartConstants.dragAnimationShadow) {\n      if (this.nodeDraggingScope.draggedNodes.length) {\n        if (this.nodeDraggingScope.shadowDragStarted) {\n          this.applyFunction(() => {\n            for (let i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {\n              this.destinationHtmlElements[i].style.display = this.oldDisplayStyles[i];\n            }\n            this.nodeDraggingScope.shadowDragStarted = false;\n          });\n        }\n        for (let i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {\n          const draggedNode = this.nodeDraggingScope.draggedNodes[i];\n          const dragOffset = this.dragOffsets[i];\n          this.nodeDraggingScope.shadowElements[i].css('left', this.getXCoordinate(dragOffset.x + event.clientX) + 'px');\n          this.nodeDraggingScope.shadowElements[i].css('top', this.getYCoordinate(dragOffset.y + event.clientY) + 'px');\n          this.resizeCanvas(draggedNode, this.draggedElements[i]);\n        }\n        event.preventDefault();\n      }\n    }\n  }\n\n  public dragend(event: DragEvent) {\n    this.applyFunction(() => {\n      if (nodeDropScope.dropElement) {\n        nodeDropScope.dropElement.parentNode.removeChild(nodeDropScope.dropElement);\n        nodeDropScope.dropElement = null;\n      }\n      if (this.modelService.isDropSource()) {\n        return;\n      }\n      if (this.nodeDraggingScope.shadowElements.length) {\n        for (let i = 0; i < this.nodeDraggingScope.draggedNodes.length; i++) {\n          const draggedNode = this.nodeDraggingScope.draggedNodes[i];\n          const shadowElement = this.nodeDraggingScope.shadowElements[i];\n          draggedNode.x = parseInt(shadowElement.css('left').replace('px', ''), 10);\n          draggedNode.y = parseInt(shadowElement.css('top').replace('px', ''), 10);\n          this.modelService.canvasHtmlElement.removeChild(shadowElement[0]);\n        }\n        this.nodeDraggingScope.shadowElements.length = 0;\n        this.modelService.notifyModelChanged();\n      }\n\n      if (this.nodeDraggingScope.draggedNodes.length) {\n        this.nodeDraggingScope.draggedNodes.length = 0;\n        this.draggedElements.length = 0;\n        this.dragOffsets.length = 0;\n      }\n    });\n  }\n\n}\n\nexport interface NodeDraggingScope {\n  draggedNodes: Array<FcNode>;\n  shadowElements: Array<JQuery<HTMLElement>>;\n  shadowDragStarted: boolean;\n  dropElement: HTMLElement;\n}\n\nexport interface NodeDropElement extends HTMLElement {\n  offsetInfo?: {\n    offsetX: number;\n    offsetY: number;\n  };\n}\n\nexport interface NodeDropScope {\n  dropElement: NodeDropElement;\n}\n\nexport interface DropNodeInfo {\n  node: FcNode;\n  dropTargetId: string;\n  offsetX: number;\n  offsetY: number;\n}\n"]}