UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

111 lines 15.8 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'; let BaseComponent = class BaseComponent { constructor() { this.uiAction = null; this.windowResizeBound = null; this.touchMoveListenFunc = null; this.touchEndListenFunc = null; this.touchCancelListenFunc = null; this._touchListener = null; } addWindowResizeListener() { if (!this.windowResizeBound) { this.windowResizeBound = this.windowResize.bind(this); } window.addEventListener('resize', this.windowResizeBound, false); } addDocumentMouseListeners() { 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); } removeDocumentMouseListeners() { if (this.documentMouseMoveBound) { document.removeEventListener('mousemove', this.documentMouseMoveBound, false); } if (this.documentMouseUpBound) { document.removeEventListener('mouseup', this.documentMouseUpBound, false); } this.documentMouseMoveBound = null; this.documentMouseUpBound = null; } addTouchListeners(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; } removeTouchListeners() { 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; } removeTouchMoveListeners() { // 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; } windowResize(e) { } touchStart(e) { } touchEnd(e) { } touchCancel(e) { } documentMouseMove(e) { } documentMouseUp(e) { this.removeDocumentMouseListeners(); } canDrop(mouseAction, show) { } dragInProcess(value) { } resizeInProcess(value) { } showHeaderBtn(fieldName) { } hideHeaderBtns() { } ngOnDestroy() { if (this.windowResizeBound) { window.removeEventListener('resize', this.windowResizeBound, false); } this.windowResizeBound = null; this.removeDocumentMouseListeners(); this.removeTouchMoveListeners(); this.removeTouchListeners(); } }; BaseComponent = tslib_1.__decorate([ Injectable() ], 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"]}