@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
112 lines • 16.6 kB
JavaScript
import * as tslib_1 from "tslib";
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* alx@truedirective.com
* @link https://truedirective.com/
* @license MIT
*/
import { Injectable } from '@angular/core';
var BaseComponent = /** @class */ (function () {
function BaseComponent() {
this.uiAction = null;
this.windowResizeBound = null;
this.touchMoveListenFunc = null;
this.touchEndListenFunc = null;
this.touchCancelListenFunc = null;
this._touchListener = null;
}
BaseComponent.prototype.addWindowResizeListener = function () {
if (!this.windowResizeBound) {
this.windowResizeBound = this.windowResize.bind(this);
}
window.addEventListener('resize', this.windowResizeBound, false);
};
BaseComponent.prototype.addDocumentMouseListeners = function () {
if (!this.documentMouseMoveBound) {
this.documentMouseMoveBound = this.documentMouseMove.bind(this);
}
if (!this.documentMouseUpBound) {
this.documentMouseUpBound = this.documentMouseUp.bind(this);
}
document.addEventListener('mousemove', this.documentMouseMoveBound, false);
document.addEventListener('mouseup', this.documentMouseUpBound, false);
};
BaseComponent.prototype.removeDocumentMouseListeners = function () {
if (this.documentMouseMoveBound) {
document.removeEventListener('mousemove', this.documentMouseMoveBound, false);
}
if (this.documentMouseUpBound) {
document.removeEventListener('mouseup', this.documentMouseUpBound, false);
}
this.documentMouseMoveBound = null;
this.documentMouseUpBound = null;
};
BaseComponent.prototype.addTouchListeners = function (element) {
this.removeTouchListeners();
this.touchStartBound = this.touchStart.bind(this);
this.touchEndBound = this.touchEnd.bind(this);
this.touchCancelBound = this.touchCancel.bind(this);
element.addEventListener('touchstart', this.touchStartBound, { capture: false, passive: true, once: false });
element.addEventListener('touchend', this.touchEndBound, { capture: false, passive: true, once: false });
element.addEventListener('touchcancel', this.touchCancelBound, { capture: false, passive: true, once: false });
this._touchListener = element;
};
BaseComponent.prototype.removeTouchListeners = function () {
if (this.touchEndBound) {
this._touchListener.removeEventListener('touchend', this.touchEndBound, false);
}
if (this.touchStartBound) {
this._touchListener.removeEventListener('touchstart', this.touchStartBound, false);
}
if (this.touchCancelBound) {
this._touchListener.removeEventListener('touchcancel', this.touchCancelBound, false);
}
this.touchStartBound = null;
this.touchEndBound = null;
this.touchCancelBound = null;
this._touchListener = null;
};
BaseComponent.prototype.removeTouchMoveListeners = function () {
// remove previous listeners
if (this.touchMoveListenFunc) {
this.touchMoveListenFunc();
}
if (this.touchEndListenFunc) {
this.touchEndListenFunc();
}
if (this.touchCancelListenFunc) {
this.touchCancelListenFunc();
}
this.touchMoveListenFunc = null;
this.touchEndListenFunc = null;
this.touchCancelListenFunc = null;
};
BaseComponent.prototype.windowResize = function (e) { };
BaseComponent.prototype.touchStart = function (e) { };
BaseComponent.prototype.touchEnd = function (e) { };
BaseComponent.prototype.touchCancel = function (e) { };
BaseComponent.prototype.documentMouseMove = function (e) { };
BaseComponent.prototype.documentMouseUp = function (e) {
this.removeDocumentMouseListeners();
};
BaseComponent.prototype.canDrop = function (mouseAction, show) { };
BaseComponent.prototype.dragInProcess = function (value) { };
BaseComponent.prototype.resizeInProcess = function (value) { };
BaseComponent.prototype.showHeaderBtn = function (fieldName) { };
BaseComponent.prototype.hideHeaderBtns = function () { };
BaseComponent.prototype.ngOnDestroy = function () {
if (this.windowResizeBound) {
window.removeEventListener('resize', this.windowResizeBound, false);
}
this.windowResizeBound = null;
this.removeDocumentMouseListeners();
this.removeTouchMoveListeners();
this.removeTouchListeners();
};
BaseComponent = tslib_1.__decorate([
Injectable()
], BaseComponent);
return BaseComponent;
}());
export { BaseComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/base.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * alx@truedirective.com\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Injectable, ChangeDetectorRef, ViewRef, OnDestroy } from '@angular/core';\r\nimport { ElementRef } from '@angular/core';\r\nimport { UIAction } from '@true-directive/base';\r\n\r\n@Injectable()\r\nexport abstract class BaseComponent implements OnDestroy {\r\n\r\n  protected uiAction: UIAction = null;\r\n\r\n  // Слушатели событий документа. Нужны только при перетаскивании колонок и выделении области\r\n  private documentMouseMoveBound: any;\r\n  private documentMouseUpBound: any;\r\n\r\n  private touchStartBound: any;\r\n  private touchEndBound: any;\r\n  private touchCancelBound: any;\r\n\r\n  protected windowResizeBound: any = null;\r\n\r\n  protected touchMoveListenFunc: any = null;\r\n  protected touchEndListenFunc: any = null;\r\n  protected touchCancelListenFunc: any  = null;\r\n\r\n  private _touchListener: HTMLElement = null;\r\n\r\n  protected addWindowResizeListener() {\r\n    if (!this.windowResizeBound) {\r\n      this.windowResizeBound = this.windowResize.bind(this);\r\n    }\r\n\r\n    window.addEventListener('resize', this.windowResizeBound, false);\r\n  }\r\n\r\n  protected addDocumentMouseListeners() {\r\n    if (!this.documentMouseMoveBound) {\r\n      this.documentMouseMoveBound = this.documentMouseMove.bind(this);\r\n    }\r\n\r\n    if (!this.documentMouseUpBound) {\r\n      this.documentMouseUpBound = this.documentMouseUp.bind(this);\r\n    }\r\n\r\n    document.addEventListener('mousemove', this.documentMouseMoveBound, false);\r\n    document.addEventListener('mouseup', this.documentMouseUpBound, false);\r\n  }\r\n\r\n  protected removeDocumentMouseListeners() {\r\n\r\n    if (this.documentMouseMoveBound) {\r\n      document.removeEventListener('mousemove', this.documentMouseMoveBound, false);\r\n    }\r\n\r\n    if (this.documentMouseUpBound) {\r\n      document.removeEventListener('mouseup', this.documentMouseUpBound, false);\r\n    }\r\n\r\n    this.documentMouseMoveBound = null;\r\n    this.documentMouseUpBound = null;\r\n  }\r\n\r\n  protected addTouchListeners(element: HTMLElement) {\r\n    this.removeTouchListeners();\r\n    this.touchStartBound = this.touchStart.bind(this);\r\n    this.touchEndBound = this.touchEnd.bind(this);\r\n    this.touchCancelBound = this.touchCancel.bind(this);\r\n    element.addEventListener('touchstart', this.touchStartBound, {capture: false, passive: true, once: false});\r\n    element.addEventListener('touchend', this.touchEndBound, {capture: false, passive: true, once: false});\r\n    element.addEventListener('touchcancel', this.touchCancelBound, {capture: false, passive: true, once: false});\r\n    this._touchListener = element;\r\n  }\r\n\r\n  protected removeTouchListeners() {\r\n    if (this.touchEndBound) {\r\n      this._touchListener.removeEventListener('touchend', this.touchEndBound, false);\r\n    }\r\n\r\n    if (this.touchStartBound) {\r\n      this._touchListener.removeEventListener('touchstart', this.touchStartBound, false);\r\n    }\r\n\r\n    if (this.touchCancelBound) {\r\n      this._touchListener.removeEventListener('touchcancel', this.touchCancelBound, false);\r\n    }\r\n\r\n    this.touchStartBound = null;\r\n    this.touchEndBound = null;\r\n    this.touchCancelBound = null;\r\n    this._touchListener = null;\r\n  }\r\n\r\n  protected removeTouchMoveListeners() {\r\n    // remove previous listeners\r\n    if (this.touchMoveListenFunc) {\r\n      this.touchMoveListenFunc();\r\n    }\r\n    if (this.touchEndListenFunc) {\r\n      this.touchEndListenFunc();\r\n    }\r\n    if (this.touchCancelListenFunc) {\r\n      this.touchCancelListenFunc();\r\n    }\r\n    this.touchMoveListenFunc = null;\r\n    this.touchEndListenFunc = null;\r\n    this.touchCancelListenFunc = null;\r\n  }\r\n\r\n  protected windowResize(e: any) { }\r\n\r\n  public touchStart(e: any) { }\r\n\r\n  public touchEnd(e: any) { }\r\n\r\n  public touchCancel(e: any) { }\r\n\r\n  protected documentMouseMove(e: MouseEvent) { }\r\n\r\n  protected documentMouseUp(e: MouseEvent) {\r\n    this.removeDocumentMouseListeners();\r\n  }\r\n\r\n  public canDrop(mouseAction: UIAction, show: boolean): any { }\r\n\r\n  public dragInProcess(value: boolean) { }\r\n\r\n  public resizeInProcess(value: boolean) { }\r\n\r\n  public showHeaderBtn(fieldName: string) { }\r\n\r\n  public hideHeaderBtns() { }\r\n\r\n  ngOnDestroy() {\r\n\r\n    if (this.windowResizeBound) {\r\n      window.removeEventListener('resize', this.windowResizeBound, false);\r\n    }\r\n\r\n    this.windowResizeBound = null;\r\n\r\n    this.removeDocumentMouseListeners();\r\n    this.removeTouchMoveListeners();\r\n    this.removeTouchListeners();\r\n  }\r\n}\r\n"]}