UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

403 lines 41.9 kB
import * as tslib_1 from "tslib"; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Component, Input, Output, ViewChild, ChangeDetectorRef, ElementRef, Renderer2, Inject, HostBinding, EventEmitter } from '@angular/core'; import { timer } from 'rxjs'; import { GridStateService } from './grid-state.service'; var ScrollerComponent = /** @class */ (function () { function ScrollerComponent(state, elementRef, changeDetector, renderer) { this.state = state; this.elementRef = elementRef; this.changeDetector = changeDetector; this.renderer = renderer; this.maxHeight = null; this.autoscrollx = new EventEmitter(); this.scroll = new EventEmitter(); this.scrollX = 0; this.scrollY = 0; this.scrollTimer = null; this.scrollSubscription = null; this.autoScrollInProgress = false; this.scrollSpeedX = 0; this.scrollSpeedY = 0; this._scrollRect = null; } Object.defineProperty(ScrollerComponent.prototype, "maxHeightU", { get: function () { if (this.maxHeight === null) { return 'unset'; } return this.maxHeight; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "autoWidth", { get: function () { return this.state.settings.columnAutoWidth; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "touchFix", { get: function () { return (this.state.iOS || this.state.android) && this.state.settings.enableTouchScroll; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollerH", { get: function () { if (this.touchFix) { return this.datah; } return this.data; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollerV", { get: function () { if (this.touchFix) { return this.dataArea; } return this.data; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "clientRect", { get: function () { return this.elementRef.nativeElement.getBoundingClientRect(); }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "centerRect", { get: function () { if (this.touchFix) { return this.datah.nativeElement.getBoundingClientRect(); } return this.data.nativeElement.getBoundingClientRect(); }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "headerRect", { get: function () { return this.header.nativeElement.getBoundingClientRect(); }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "headerRectLeft", { get: function () { return null; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "headerRectRight", { get: function () { return null; }, enumerable: true, configurable: true }); ScrollerComponent.prototype.dataScroll = function (e) { this.doScroll(e); this.scroll.emit(e); }; ScrollerComponent.prototype.dataScrollH = function (e) { this.doScroll(e, true); this.scroll.emit(e); }; Object.defineProperty(ScrollerComponent.prototype, "isAutoScroll", { get: function () { return this.autoScrollInProgress; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollTop", { get: function () { if (this.touchFix) { return this.dataArea.nativeElement.scrollTop; } return this.data.nativeElement.scrollTop; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollLeft", { get: function () { if (this.touchFix) { return this.datah.nativeElement.scrollLeft; } return this.data.nativeElement.scrollLeft; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollWidth", { get: function () { if (this.touchFix) { return this.datah.nativeElement.scrollWidth; } return this.data.nativeElement.scrollWidth; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "scrollHeight", { get: function () { return this.data.nativeElement.scrollHeight; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "viewPortHeight", { get: function () { if (this.touchFix) { return this.dataArea.nativeElement.clientHeight; } return this.data.nativeElement.clientHeight; }, enumerable: true, configurable: true }); Object.defineProperty(ScrollerComponent.prototype, "viewPortWidth", { get: function () { if (this.touchFix) { return this.dataArea.nativeElement.clientWidth; } else { return this.data.nativeElement.clientWidth; } }, enumerable: true, configurable: true }); ScrollerComponent.prototype.prepareAutoScroll = function () { this._scrollRect = this.centerRect; }; ScrollerComponent.prototype.startAutoScroll = function () { var _this = this; if (this.autoScrollInProgress) { return; } if (!this.scrollTimer) { this.scrollTimer = timer(this.state.st.autoScrollInterval, this.state.st.autoScrollInterval); this.scrollSubscription = this.scrollTimer.subscribe(function (t) { return _this.scrollIfNeeded(); }); } this.autoScrollInProgress = true; }; ScrollerComponent.prototype.stopAutoScroll = function () { this._scrollRect = null; this.scrollSpeedY = 0; this.scrollSpeedX = 0; if (this.scrollSubscription) { this.scrollSubscription.unsubscribe(); this.scrollTimer = null; } this.autoScrollInProgress = false; }; // Прокрутка при необходимости ScrollerComponent.prototype.scrollIfNeeded = function () { var sl = this.scrollLeft; var st = this.scrollTop; var sw = this.scrollWidth; var sh = this.scrollHeight; var needSl = sl; var needSt = st; var r0 = this.elementRef.nativeElement.getBoundingClientRect(); if (this.scrollSpeedY < 0) { // листаем влево if (st >= -this.scrollSpeedY) { needSt = st + this.scrollSpeedY; } else { needSt = 0; } } if (this.scrollSpeedY > 0) { // листаем вправо var maxScrollTop = sh - this.scrollerV.nativeElement.clientHeight; if (sl <= (maxScrollTop - this.scrollSpeedY)) { needSt = st + this.scrollSpeedY; } else { needSt = maxScrollTop; } } if (st !== needSt) { this.scrollerV.nativeElement.scrollTop = needSt; return; // По двум направлениям не будем это делать } if (this.scrollSpeedX < 0) { // листаем влево if (sl >= -this.scrollSpeedX) { needSl = sl + this.scrollSpeedX; } else { needSl = 0; } } if (this.scrollSpeedX > 0) { // листаем вправо var maxScrollLeft = sw - this.scrollerH.nativeElement.clientWidth; if (sl <= (maxScrollLeft - this.scrollSpeedX)) { needSl = sl + this.scrollSpeedX; } else { needSl = maxScrollLeft; } } if (sl !== needSl) { this.scrollerH.nativeElement.scrollLeft = needSl; this.autoscrollx.emit(needSl - sl); } }; ScrollerComponent.prototype.scrollTo = function (x, y) { if (y === void 0) { y = -1; } if (y >= 0) { this.scrollerV.nativeElement.scrollTop = y; } if (x >= 0) { this.scrollerH.nativeElement.scrollLeft = x; } }; // После сжатия контента возможны отрицательные значения ScrollLeft. Здесь мы // проверим и исправим это... ScrollerComponent.prototype.fixScroll = function () { if (this.scrollerH.nativeElement.scrollLeft < 0) { this.scrollerH.nativeElement.scrollLeft = 0; } }; ScrollerComponent.prototype.checkAutoScrollX = function (xx, checkParts) { if (checkParts === void 0) { checkParts = false; } var r0 = this._scrollRect; if (!r0) { return null; } if (xx <= r0.left) { // листаем влево this.scrollSpeedX = -this.state.st.autoScrollStep; } else { if (xx >= r0.right) { // вправо this.scrollSpeedX = this.state.st.autoScrollStep; } else { this.scrollSpeedX = 0; } } if (this.scrollSpeedX !== 0) { this.startAutoScroll(); } return r0; }; ScrollerComponent.prototype.checkAutoScrollY = function (yy) { var r0 = this._scrollRect; if (!r0) { return null; } if (yy < r0.top) { // листаем вверх this.scrollSpeedY = -this.state.st.autoScrollStep; } else { if (yy > r0.bottom) { // вниз this.scrollSpeedY = this.state.st.autoScrollStep; } else { this.scrollSpeedY = 0; } } if (this.scrollSpeedY !== 0) { this.startAutoScroll(); } }; ScrollerComponent.prototype.scrollParts = function () { }; ScrollerComponent.prototype.doScroll = function (e, h) { if (h === void 0) { h = false; } var l = e.target; if ((!this.touchFix || h) && this.scrollX !== l.scrollLeft) { this.scrollX = l.scrollLeft; if (this.state.settings.showHeader) { this.header.nativeElement.scrollLeft = this.scrollX; } if (this.state.settings.showFooter) { this.footer.nativeElement.scrollLeft = this.scrollX; } } if (this.scrollY !== l.scrollTop) { this.scrollParts(); } }; ScrollerComponent.prototype.focus = function () { this.elementRef.nativeElement.focus(); }; tslib_1.__decorate([ ViewChild('header', { static: false }), tslib_1.__metadata("design:type", Object) ], ScrollerComponent.prototype, "header", void 0); tslib_1.__decorate([ ViewChild('dataArea', { static: true }), tslib_1.__metadata("design:type", Object) ], ScrollerComponent.prototype, "dataArea", void 0); tslib_1.__decorate([ ViewChild('data', { static: true }), tslib_1.__metadata("design:type", Object) ], ScrollerComponent.prototype, "data", void 0); tslib_1.__decorate([ ViewChild('datah', { static: true }), tslib_1.__metadata("design:type", Object) ], ScrollerComponent.prototype, "datah", void 0); tslib_1.__decorate([ ViewChild('footer', { static: false }), tslib_1.__metadata("design:type", Object) ], ScrollerComponent.prototype, "footer", void 0); tslib_1.__decorate([ Input('maxHeight'), tslib_1.__metadata("design:type", String) ], ScrollerComponent.prototype, "maxHeight", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], ScrollerComponent.prototype, "autoscrollx", void 0); tslib_1.__decorate([ Output(), tslib_1.__metadata("design:type", EventEmitter) ], ScrollerComponent.prototype, "scroll", void 0); tslib_1.__decorate([ HostBinding('class.true-v-scroll'), tslib_1.__metadata("design:type", Object), tslib_1.__metadata("design:paramtypes", []) ], ScrollerComponent.prototype, "autoWidth", null); tslib_1.__decorate([ HostBinding('class.true-fix-touch'), tslib_1.__metadata("design:type", Object), tslib_1.__metadata("design:paramtypes", []) ], ScrollerComponent.prototype, "touchFix", null); ScrollerComponent = tslib_1.__decorate([ Component({ selector: 'true-scroller', template: "<div class=\"true-scroller-header-area\" *ngIf=\"state.settings.showHeader\">\r\n <div #header class=\"true-scroller-header\" [ngClass]=\"state.settings.appearance.headerAreaClass\">\r\n <ng-content select=\"[true-header]\"></ng-content>\r\n </div>\r\n</div>\r\n\r\n<div #dataArea class=\"true-scroller-data-area-scroller\" (scroll)=\"dataScroll($event)\">\r\n <div class=\"true-scroller-data-area\" [style.max-height]=\"maxHeightU\">\r\n <div #data class=\"true-scroller-data\" [ngClass]=\"state.sta.scrollboxClass\" (scroll)=\"dataScroll($event)\">\r\n <div #datah class=\"true-scroller-data-h\" (scroll)=\"dataScrollH($event)\">\r\n <ng-content select=\"[true-data]\"></ng-content>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"true-scroller-footer-area\" *ngIf=\"state.settings.showFooter\">\r\n <div #footer class=\"true-scroller-footer\"\r\n [ngClass]=\"state.settings.appearance.footerAreaClass\" >\r\n <ng-content select=\"[true-footer]\"></ng-content>\r\n </div>\r\n</div>\r\n", styles: [":host{overflow-y:hidden;display:-webkit-box;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;flex-direction:column;-webkit-box-pack:justify;justify-content:space-between;height:100%}:host:focus{outline:0}.true-scroller-footer-area,.true-scroller-header-area{overflow-x:hidden;flex-shrink:0;-webkit-box-flex:0;flex-grow:0;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;height:auto}.true-scroller-hidden{height:0!important}.true-scroller-header{overflow-x:hidden;-webkit-box-flex:1;flex-grow:1;box-sizing:border-box}.true-scroller-data-area-scroller{-webkit-box-flex:1;flex:1 1 auto;overflow-y:hidden;-ms-grid-row-align:stretch;align-self:stretch;height:100%}.true-scroller-data-area{height:100%;overflow-x:hidden;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;-webkit-box-pack:justify;justify-content:space-between;-webkit-box-align:stretch;align-items:stretch}.true-scroller-data{-webkit-box-flex:1;flex:1 1 auto;overflow-y:auto;overflow-x:auto;box-sizing:border-box;max-width:100%}.true-scroller-data-h{overflow-x:visible;-webkit-overflow-scrolling:touch}:host.true-v-scroll .true-scroller-data{overflow-x:hidden!important;overflow-y:scroll!important;-webkit-overflow-scrolling:touch}:host.true-v-scroll .true-scroller-data .true-scroller-data-h{overflow-x:hidden!important}.true-scroller-footer{overflow-x:hidden;-webkit-box-flex:1;flex-grow:1}:host.true-fix-touch:not(.true-v-scroll) .true-scroller-data-area-scroller{height:1px;overflow-y:auto;-webkit-overflow-scrolling:touch}:host.true-fix-touch .true-scroller-data-area{height:auto;min-height:100%;display:-webkit-box;align-content:stretch;-webkit-overflow-scrolling:touch}:host.true-fix-touch .true-scroller-data{overflow-x:hidden!important;overflow-y:hidden!important;display:-webkit-box;display:flex;-webkit-box-align:stretch;align-items:stretch;-webkit-box-pack:center;justify-content:center;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row}:host.true-fix-touch:not(.true-v-scroll) .true-scroller-data-h{overflow-x:auto;-webkit-overflow-scrolling:touch}:host.true-fix-touch.true-v-scroll .true-scroller-data-area-scroller{overflow-y:scroll!important;-webkit-overflow-scrolling:touch}"] }), tslib_1.__param(0, Inject('gridState')), tslib_1.__metadata("design:paramtypes", [GridStateService, ElementRef, ChangeDetectorRef, Renderer2]) ], ScrollerComponent); return ScrollerComponent; }()); export { ScrollerComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroller.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/scroller.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Input, Output, ViewChild, ChangeDetectorRef,\r\n         ElementRef, Renderer2, Inject, HostBinding,\r\n         EventEmitter } from '@angular/core';\r\nimport { timer } from 'rxjs';\r\n\r\nimport { GridStateService } from './grid-state.service';\r\n\r\n@Component({\r\n  selector: 'true-scroller',\r\n  templateUrl: './scroller.component.html',\r\n  styleUrls: ['./styles/scroller.behavior.scss']\r\n})\r\nexport class ScrollerComponent {\r\n\r\n  @ViewChild('header', {static: false})\r\n  public header: any;\r\n\r\n  @ViewChild('dataArea', {static: true})\r\n  public dataArea: any;\r\n\r\n  @ViewChild('data', {static: true})\r\n  public data: any;\r\n\r\n  @ViewChild('datah', {static: true})\r\n  public datah: any;\r\n\r\n  @ViewChild('footer', {static: false})\r\n  public footer: any;\r\n\r\n  @Input('maxHeight')\r\n  public maxHeight: string = null;\r\n\r\n  public get maxHeightU(): string {\r\n    if (this.maxHeight === null) {\r\n      return 'unset';\r\n    }\r\n    return this.maxHeight;\r\n  }\r\n\r\n  @Output()\r\n  autoscrollx: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  @Output()\r\n  scroll: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @HostBinding('class.true-v-scroll')\r\n  get autoWidth() {\r\n    return this.state.settings.columnAutoWidth;\r\n  }\r\n\r\n  @HostBinding('class.true-fix-touch')\r\n  get touchFix() {\r\n    return (this.state.iOS || this.state.android) && this.state.settings.enableTouchScroll;\r\n  }\r\n\r\n  protected scrollX = 0;\r\n  protected scrollY = 0;\r\n  private scrollTimer: any = null;\r\n  private scrollSubscription: any = null;\r\n\r\n  private autoScrollInProgress = false;\r\n\r\n  public  scrollSpeedX = 0;\r\n  public  scrollSpeedY = 0;\r\n\r\n  protected _scrollRect: any = null;\r\n\r\n  public get scrollerH() {\r\n    if (this.touchFix) {\r\n      return this.datah;\r\n    }\r\n    return this.data;\r\n  }\r\n\r\n  public get scrollerV() {\r\n    if (this.touchFix) {\r\n      return this.dataArea;\r\n    }\r\n    return this.data;\r\n  }\r\n\r\n  public get clientRect(): any {\r\n    return this.elementRef.nativeElement.getBoundingClientRect();\r\n  }\r\n\r\n  public get centerRect(): any {\r\n    if (this.touchFix) {\r\n      return this.datah.nativeElement.getBoundingClientRect();\r\n    }\r\n    return this.data.nativeElement.getBoundingClientRect();\r\n  }\r\n\r\n  public get headerRect(): any {\r\n    return this.header.nativeElement.getBoundingClientRect();\r\n  }\r\n\r\n  public get headerRectLeft(): any {\r\n    return null;\r\n  }\r\n\r\n  public get headerRectRight(): any {\r\n    return null;\r\n  }\r\n\r\n  dataScroll(e: any) {\r\n    this.doScroll(e);\r\n    this.scroll.emit(e);\r\n  }\r\n\r\n  dataScrollH(e: any) {\r\n    this.doScroll(e, true);\r\n    this.scroll.emit(e);\r\n  }\r\n\r\n  get isAutoScroll() {\r\n    return this.autoScrollInProgress;\r\n  }\r\n\r\n  get scrollTop() {\r\n    if (this.touchFix) {\r\n      return this.dataArea.nativeElement.scrollTop;\r\n    }\r\n    return this.data.nativeElement.scrollTop;\r\n  }\r\n\r\n  get scrollLeft() {\r\n    if (this.touchFix) {\r\n      return this.datah.nativeElement.scrollLeft;\r\n    }\r\n    return this.data.nativeElement.scrollLeft;\r\n  }\r\n\r\n  get scrollWidth() {\r\n    if (this.touchFix) {\r\n      return this.datah.nativeElement.scrollWidth;\r\n    }\r\n    return this.data.nativeElement.scrollWidth;\r\n  }\r\n\r\n  get scrollHeight() {\r\n    return this.data.nativeElement.scrollHeight;\r\n  }\r\n\r\n  get viewPortHeight() {\r\n    if (this.touchFix) {\r\n      return this.dataArea.nativeElement.clientHeight;\r\n    }\r\n    return this.data.nativeElement.clientHeight;\r\n  }\r\n\r\n  get viewPortWidth() {\r\n    if (this.touchFix) {\r\n      return this.dataArea.nativeElement.clientWidth;\r\n    } else {\r\n      return this.data.nativeElement.clientWidth;\r\n    }\r\n  }\r\n\r\n  public prepareAutoScroll() {\r\n    this._scrollRect = this.centerRect;\r\n  }\r\n\r\n  public startAutoScroll() {\r\n\r\n    if (this.autoScrollInProgress) {\r\n      return;\r\n    }\r\n\r\n    if (!this.scrollTimer) {\r\n      this.scrollTimer = timer(this.state.st.autoScrollInterval, this.state.st.autoScrollInterval);\r\n      this.scrollSubscription = this.scrollTimer.subscribe((t: any) => this.scrollIfNeeded());\r\n    }\r\n\r\n    this.autoScrollInProgress = true;\r\n  }\r\n\r\n  public stopAutoScroll() {\r\n    this._scrollRect = null;\r\n    this.scrollSpeedY = 0;\r\n    this.scrollSpeedX = 0;\r\n    if (this.scrollSubscription) {\r\n      this.scrollSubscription.unsubscribe();\r\n      this.scrollTimer = null;\r\n    }\r\n\r\n    this.autoScrollInProgress = false;\r\n  }\r\n\r\n  // Прокрутка при необходимости\r\n  public scrollIfNeeded() {\r\n\r\n    const sl = this.scrollLeft;\r\n    const st = this.scrollTop;\r\n    const sw = this.scrollWidth;\r\n    const sh = this.scrollHeight;\r\n\r\n    let needSl = sl;\r\n    let needSt = st;\r\n\r\n    const r0 = this.elementRef.nativeElement.getBoundingClientRect();\r\n\r\n    if (this.scrollSpeedY < 0) {\r\n      // листаем влево\r\n      if (st >= -this.scrollSpeedY) {\r\n        needSt = st + this.scrollSpeedY;\r\n      } else {\r\n        needSt = 0;\r\n      }\r\n    }\r\n\r\n    if (this.scrollSpeedY > 0) {\r\n      // листаем вправо\r\n      const maxScrollTop = sh - this.scrollerV.nativeElement.clientHeight;\r\n      if (sl <= (maxScrollTop - this.scrollSpeedY)) {\r\n        needSt = st + this.scrollSpeedY;\r\n      } else {\r\n        needSt = maxScrollTop;\r\n      }\r\n    }\r\n\r\n    if (st !== needSt) {\r\n      this.scrollerV.nativeElement.scrollTop = needSt;\r\n      return; // По двум направлениям не будем это делать\r\n    }\r\n\r\n    if (this.scrollSpeedX < 0) {\r\n      // листаем влево\r\n      if (sl >= -this.scrollSpeedX) {\r\n        needSl = sl + this.scrollSpeedX;\r\n      } else {\r\n        needSl = 0;\r\n      }\r\n    }\r\n\r\n    if (this.scrollSpeedX > 0) {\r\n      // листаем вправо\r\n      const maxScrollLeft = sw - this.scrollerH.nativeElement.clientWidth;\r\n      if (sl <= (maxScrollLeft - this.scrollSpeedX)) {\r\n        needSl = sl + this.scrollSpeedX;\r\n      } else {\r\n        needSl = maxScrollLeft;\r\n      }\r\n    }\r\n\r\n    if (sl !== needSl) {\r\n      this.scrollerH.nativeElement.scrollLeft = needSl;\r\n      this.autoscrollx.emit(needSl - sl);\r\n    }\r\n  }\r\n\r\n  public scrollTo(x: number, y: number = -1) {\r\n    if (y >= 0) {\r\n      this.scrollerV.nativeElement.scrollTop = y;\r\n    }\r\n    if (x >= 0) {\r\n      this.scrollerH.nativeElement.scrollLeft = x;\r\n    }\r\n  }\r\n\r\n  // После сжатия контента возможны отрицательные значения ScrollLeft. Здесь мы\r\n  // проверим и исправим это...\r\n  public fixScroll() {\r\n    if (this.scrollerH.nativeElement.scrollLeft < 0) {\r\n      this.scrollerH.nativeElement.scrollLeft = 0;\r\n    }\r\n  }\r\n\r\n  public checkAutoScrollX(xx: number, checkParts: boolean = false): any {\r\n\r\n    const r0 = this._scrollRect;\r\n\r\n    if (!r0) {\r\n      return null;\r\n    }\r\n\r\n    if (xx <= r0.left) {\r\n      // листаем влево\r\n      this.scrollSpeedX = -this.state.st.autoScrollStep;\r\n    } else {\r\n      if (xx >= r0.right) {\r\n        // вправо\r\n        this.scrollSpeedX = this.state.st.autoScrollStep;\r\n      } else {\r\n        this.scrollSpeedX = 0;\r\n      }\r\n    }\r\n\r\n    if (this.scrollSpeedX !== 0) {\r\n      this.startAutoScroll();\r\n    }\r\n\r\n    return r0;\r\n  }\r\n\r\n  public checkAutoScrollY(yy: number): any {\r\n    const r0 = this._scrollRect;\r\n    if (!r0) {\r\n      return null;\r\n    }\r\n\r\n    if (yy < r0.top) {\r\n      // листаем вверх\r\n      this.scrollSpeedY = -this.state.st.autoScrollStep;\r\n    } else {\r\n      if (yy > r0.bottom) {\r\n        // вниз\r\n        this.scrollSpeedY = this.state.st.autoScrollStep;\r\n      } else {\r\n        this.scrollSpeedY = 0;\r\n      }\r\n    }\r\n\r\n    if (this.scrollSpeedY !== 0) {\r\n      this.startAutoScroll();\r\n    }\r\n  }\r\n\r\n  public scrollParts() { }\r\n\r\n  doScroll(e: any, h: boolean = false) {\r\n    const l = e.target;\r\n\r\n    if ((!this.touchFix || h) && this.scrollX !== l.scrollLeft) {\r\n      this.scrollX = l.scrollLeft;\r\n      if (this.state.settings.showHeader) {        \r\n        this.header.nativeElement.scrollLeft = this.scrollX;\r\n      }\r\n      if (this.state.settings.showFooter) {\r\n        this.footer.nativeElement.scrollLeft = this.scrollX;\r\n      }\r\n    }\r\n\r\n    if (this.scrollY !== l.scrollTop) {\r\n      this.scrollParts();\r\n    }\r\n  }\r\n\r\n  public focus() {\r\n    this.elementRef.nativeElement.focus();\r\n  }\r\n\r\n  constructor(\r\n    @Inject('gridState') public state: GridStateService,\r\n    protected elementRef: ElementRef,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected renderer: Renderer2) { }\r\n}"]}