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.
217 lines
18 KiB
JavaScript
217 lines
18 KiB
JavaScript
/**
|
|
* @fileoverview added by tsickle
|
|
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
*/
|
|
import scrollparent from './scrollparent';
|
|
/**
|
|
* @record
|
|
*/
|
|
function Rectangle() { }
|
|
if (false) {
|
|
/** @type {?} */
|
|
Rectangle.prototype.x1;
|
|
/** @type {?} */
|
|
Rectangle.prototype.x2;
|
|
/** @type {?} */
|
|
Rectangle.prototype.y1;
|
|
/** @type {?} */
|
|
Rectangle.prototype.y2;
|
|
}
|
|
var FcRectangleSelectService = /** @class */ (function () {
|
|
function FcRectangleSelectService(modelService, selectElement, applyFunction) {
|
|
this.selectRect = {
|
|
x1: 0,
|
|
x2: 0,
|
|
y1: 0,
|
|
y2: 0
|
|
};
|
|
this.modelService = modelService;
|
|
this.selectElement = selectElement;
|
|
this.$canvasElement = $(this.modelService.canvasHtmlElement);
|
|
this.$scrollParent = $(scrollparent(this.modelService.canvasHtmlElement));
|
|
this.applyFunction = applyFunction;
|
|
}
|
|
/**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.mousedown = /**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
function (e) {
|
|
if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0
|
|
&& this.selectElement.hidden) {
|
|
this.selectElement.hidden = false;
|
|
/** @type {?} */
|
|
var offset = this.$canvasElement.offset();
|
|
this.selectRect.x1 = Math.round(e.pageX - offset.left);
|
|
this.selectRect.y1 = Math.round(e.pageY - offset.top);
|
|
this.selectRect.x2 = this.selectRect.x1;
|
|
this.selectRect.y2 = this.selectRect.y1;
|
|
this.updateSelectRect();
|
|
}
|
|
};
|
|
/**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.mousemove = /**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
function (e) {
|
|
if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0
|
|
&& !this.selectElement.hidden) {
|
|
/** @type {?} */
|
|
var offset = this.$canvasElement.offset();
|
|
this.selectRect.x2 = Math.round(e.pageX - offset.left);
|
|
this.selectRect.y2 = Math.round(e.pageY - offset.top);
|
|
this.updateScroll(offset);
|
|
this.updateSelectRect();
|
|
}
|
|
};
|
|
/**
|
|
* @private
|
|
* @param {?} offset
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.updateScroll = /**
|
|
* @private
|
|
* @param {?} offset
|
|
* @return {?}
|
|
*/
|
|
function (offset) {
|
|
/** @type {?} */
|
|
var rect = this.$scrollParent[0].getBoundingClientRect();
|
|
/** @type {?} */
|
|
var bottom = rect.bottom - offset.top;
|
|
/** @type {?} */
|
|
var right = rect.right - offset.left;
|
|
/** @type {?} */
|
|
var top = rect.top - offset.top;
|
|
/** @type {?} */
|
|
var left = rect.left - offset.left;
|
|
if (this.selectRect.y2 - top < 25) {
|
|
/** @type {?} */
|
|
var topScroll = 25 - (this.selectRect.y2 - top);
|
|
/** @type {?} */
|
|
var scroll_1 = this.$scrollParent.scrollTop();
|
|
this.$scrollParent.scrollTop(scroll_1 - topScroll);
|
|
}
|
|
else if (bottom - this.selectRect.y2 < 40) {
|
|
/** @type {?} */
|
|
var bottomScroll = 40 - (bottom - this.selectRect.y2);
|
|
/** @type {?} */
|
|
var scroll_2 = this.$scrollParent.scrollTop();
|
|
this.$scrollParent.scrollTop(scroll_2 + bottomScroll);
|
|
}
|
|
if (this.selectRect.x2 - left < 25) {
|
|
/** @type {?} */
|
|
var leftScroll = 25 - (this.selectRect.x2 - left);
|
|
/** @type {?} */
|
|
var scroll_3 = this.$scrollParent.scrollLeft();
|
|
this.$scrollParent.scrollLeft(scroll_3 - leftScroll);
|
|
}
|
|
else if (right - this.selectRect.x2 < 40) {
|
|
/** @type {?} */
|
|
var rightScroll = 40 - (right - this.selectRect.x2);
|
|
/** @type {?} */
|
|
var scroll_4 = this.$scrollParent.scrollLeft();
|
|
this.$scrollParent.scrollLeft(scroll_4 + rightScroll);
|
|
}
|
|
};
|
|
/**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.mouseup = /**
|
|
* @param {?} e
|
|
* @return {?}
|
|
*/
|
|
function (e) {
|
|
if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0
|
|
&& !this.selectElement.hidden) {
|
|
/** @type {?} */
|
|
var rectBox = (/** @type {?} */ (this.selectElement.getBoundingClientRect()));
|
|
this.selectElement.hidden = true;
|
|
this.selectObjects(rectBox);
|
|
}
|
|
};
|
|
/**
|
|
* @private
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.updateSelectRect = /**
|
|
* @private
|
|
* @return {?}
|
|
*/
|
|
function () {
|
|
/** @type {?} */
|
|
var x3 = Math.min(this.selectRect.x1, this.selectRect.x2);
|
|
/** @type {?} */
|
|
var x4 = Math.max(this.selectRect.x1, this.selectRect.x2);
|
|
/** @type {?} */
|
|
var y3 = Math.min(this.selectRect.y1, this.selectRect.y2);
|
|
/** @type {?} */
|
|
var y4 = Math.max(this.selectRect.y1, this.selectRect.y2);
|
|
this.selectElement.style.left = x3 + 'px';
|
|
this.selectElement.style.top = y3 + 'px';
|
|
this.selectElement.style.width = x4 - x3 + 'px';
|
|
this.selectElement.style.height = y4 - y3 + 'px';
|
|
};
|
|
/**
|
|
* @private
|
|
* @param {?} rectBox
|
|
* @return {?}
|
|
*/
|
|
FcRectangleSelectService.prototype.selectObjects = /**
|
|
* @private
|
|
* @param {?} rectBox
|
|
* @return {?}
|
|
*/
|
|
function (rectBox) {
|
|
var _this = this;
|
|
this.applyFunction((/**
|
|
* @return {?}
|
|
*/
|
|
function () {
|
|
_this.modelService.selectAllInRect(rectBox);
|
|
}));
|
|
};
|
|
return FcRectangleSelectService;
|
|
}());
|
|
export { FcRectangleSelectService };
|
|
if (false) {
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.selectRect;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.modelService;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.selectElement;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.$canvasElement;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.$scrollParent;
|
|
/**
|
|
* @type {?}
|
|
* @private
|
|
*/
|
|
FcRectangleSelectService.prototype.applyFunction;
|
|
}
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rectangleselect.service.js","sourceRoot":"ng://ngx-flowchart/","sources":["lib/rectangleselect.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FcModelService } from './model.service';\nimport { FcRectBox } from 'ngx-flowchart-dev';\nimport scrollparent from './scrollparent';\n\ninterface Rectangle {\n  x1: number;\n  x2: number;\n  y1: number;\n  y2: number;\n}\n\nexport class FcRectangleSelectService {\n\n  private readonly selectRect: Rectangle = {\n    x1: 0,\n    x2: 0,\n    y1: 0,\n    y2: 0\n  };\n\n  private readonly modelService: FcModelService;\n  private readonly selectElement: HTMLElement;\n  private readonly $canvasElement: JQuery<HTMLElement>;\n  private readonly $scrollParent: JQuery<HTMLElement>;\n  private readonly applyFunction: <T>(fn: (...args: any[]) => T) => T;\n\n  constructor(modelService: FcModelService,\n              selectElement: HTMLElement,\n              applyFunction: <T>(fn: (...args: any[]) => T) => T) {\n    this.modelService = modelService;\n    this.selectElement = selectElement;\n    this.$canvasElement = $(this.modelService.canvasHtmlElement);\n    this.$scrollParent = $(scrollparent(this.modelService.canvasHtmlElement));\n    this.applyFunction = applyFunction;\n  }\n\n  public mousedown(e: MouseEvent) {\n    if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0\n      && this.selectElement.hidden) {\n      this.selectElement.hidden = false;\n      const offset = this.$canvasElement.offset();\n      this.selectRect.x1 = Math.round(e.pageX - offset.left);\n      this.selectRect.y1 = Math.round(e.pageY - offset.top);\n      this.selectRect.x2 = this.selectRect.x1;\n      this.selectRect.y2 = this.selectRect.y1;\n      this.updateSelectRect();\n    }\n  }\n\n  public mousemove(e: MouseEvent) {\n    if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0\n      && !this.selectElement.hidden) {\n      const offset = this.$canvasElement.offset();\n      this.selectRect.x2 = Math.round(e.pageX - offset.left);\n      this.selectRect.y2 = Math.round(e.pageY - offset.top);\n      this.updateScroll(offset);\n      this.updateSelectRect();\n    }\n  }\n\n  private updateScroll(offset: JQuery.Coordinates) {\n    const rect = this.$scrollParent[0].getBoundingClientRect();\n    const bottom = rect.bottom - offset.top;\n    const right = rect.right - offset.left;\n    const top = rect.top - offset.top;\n    const left = rect.left - offset.left;\n    if (this.selectRect.y2 - top < 25) {\n      const topScroll = 25 - (this.selectRect.y2 - top);\n      const scroll = this.$scrollParent.scrollTop();\n      this.$scrollParent.scrollTop(scroll - topScroll);\n    } else if (bottom - this.selectRect.y2 < 40) {\n      const bottomScroll = 40 - (bottom - this.selectRect.y2);\n      const scroll = this.$scrollParent.scrollTop();\n      this.$scrollParent.scrollTop(scroll + bottomScroll);\n    }\n    if (this.selectRect.x2 - left < 25) {\n      const leftScroll = 25 - (this.selectRect.x2 - left);\n      const scroll = this.$scrollParent.scrollLeft();\n      this.$scrollParent.scrollLeft(scroll - leftScroll);\n    } else if (right - this.selectRect.x2 < 40) {\n      const rightScroll = 40 - (right - this.selectRect.x2);\n      const scroll = this.$scrollParent.scrollLeft();\n      this.$scrollParent.scrollLeft(scroll + rightScroll);\n    }\n  }\n\n  public mouseup(e: MouseEvent) {\n    if (this.modelService.isEditable() && !e.ctrlKey && !e.metaKey && e.button === 0\n      && !this.selectElement.hidden) {\n      const rectBox = this.selectElement.getBoundingClientRect() as FcRectBox;\n      this.selectElement.hidden = true;\n      this.selectObjects(rectBox);\n    }\n  }\n\n  private updateSelectRect() {\n    const x3 = Math.min(this.selectRect.x1, this.selectRect.x2);\n    const x4 = Math.max(this.selectRect.x1, this.selectRect.x2);\n    const y3 = Math.min(this.selectRect.y1, this.selectRect.y2);\n    const y4 = Math.max(this.selectRect.y1, this.selectRect.y2);\n    this.selectElement.style.left = x3 + 'px';\n    this.selectElement.style.top = y3 + 'px';\n    this.selectElement.style.width = x4 - x3 + 'px';\n    this.selectElement.style.height = y4 - y3 + 'px';\n  }\n\n  private selectObjects(rectBox: FcRectBox) {\n    this.applyFunction(() => {\n      this.modelService.selectAllInRect(rectBox);\n    });\n  }\n\n}\n\n"]}
|