UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

112 lines 16.6 kB
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"]}