@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
330 lines • 37.8 kB
JavaScript
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';
let ScrollerComponent = class ScrollerComponent {
constructor(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;
}
get maxHeightU() {
if (this.maxHeight === null) {
return 'unset';
}
return this.maxHeight;
}
get autoWidth() {
return this.state.settings.columnAutoWidth;
}
get touchFix() {
return (this.state.iOS || this.state.android) && this.state.settings.enableTouchScroll;
}
get scrollerH() {
if (this.touchFix) {
return this.datah;
}
return this.data;
}
get scrollerV() {
if (this.touchFix) {
return this.dataArea;
}
return this.data;
}
get clientRect() {
return this.elementRef.nativeElement.getBoundingClientRect();
}
get centerRect() {
if (this.touchFix) {
return this.datah.nativeElement.getBoundingClientRect();
}
return this.data.nativeElement.getBoundingClientRect();
}
get headerRect() {
return this.header.nativeElement.getBoundingClientRect();
}
get headerRectLeft() {
return null;
}
get headerRectRight() {
return null;
}
dataScroll(e) {
this.doScroll(e);
this.scroll.emit(e);
}
dataScrollH(e) {
this.doScroll(e, true);
this.scroll.emit(e);
}
get isAutoScroll() {
return this.autoScrollInProgress;
}
get scrollTop() {
if (this.touchFix) {
return this.dataArea.nativeElement.scrollTop;
}
return this.data.nativeElement.scrollTop;
}
get scrollLeft() {
if (this.touchFix) {
return this.datah.nativeElement.scrollLeft;
}
return this.data.nativeElement.scrollLeft;
}
get scrollWidth() {
if (this.touchFix) {
return this.datah.nativeElement.scrollWidth;
}
return this.data.nativeElement.scrollWidth;
}
get scrollHeight() {
return this.data.nativeElement.scrollHeight;
}
get viewPortHeight() {
if (this.touchFix) {
return this.dataArea.nativeElement.clientHeight;
}
return this.data.nativeElement.clientHeight;
}
get viewPortWidth() {
if (this.touchFix) {
return this.dataArea.nativeElement.clientWidth;
}
else {
return this.data.nativeElement.clientWidth;
}
}
prepareAutoScroll() {
this._scrollRect = this.centerRect;
}
startAutoScroll() {
if (this.autoScrollInProgress) {
return;
}
if (!this.scrollTimer) {
this.scrollTimer = timer(this.state.st.autoScrollInterval, this.state.st.autoScrollInterval);
this.scrollSubscription = this.scrollTimer.subscribe((t) => this.scrollIfNeeded());
}
this.autoScrollInProgress = true;
}
stopAutoScroll() {
this._scrollRect = null;
this.scrollSpeedY = 0;
this.scrollSpeedX = 0;
if (this.scrollSubscription) {
this.scrollSubscription.unsubscribe();
this.scrollTimer = null;
}
this.autoScrollInProgress = false;
}
// Прокрутка при необходимости
scrollIfNeeded() {
const sl = this.scrollLeft;
const st = this.scrollTop;
const sw = this.scrollWidth;
const sh = this.scrollHeight;
let needSl = sl;
let needSt = st;
const r0 = this.elementRef.nativeElement.getBoundingClientRect();
if (this.scrollSpeedY < 0) {
// листаем влево
if (st >= -this.scrollSpeedY) {
needSt = st + this.scrollSpeedY;
}
else {
needSt = 0;
}
}
if (this.scrollSpeedY > 0) {
// листаем вправо
const 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) {
// листаем вправо
const 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);
}
}
scrollTo(x, y = -1) {
if (y >= 0) {
this.scrollerV.nativeElement.scrollTop = y;
}
if (x >= 0) {
this.scrollerH.nativeElement.scrollLeft = x;
}
}
// После сжатия контента возможны отрицательные значения ScrollLeft. Здесь мы
// проверим и исправим это...
fixScroll() {
if (this.scrollerH.nativeElement.scrollLeft < 0) {
this.scrollerH.nativeElement.scrollLeft = 0;
}
}
checkAutoScrollX(xx, checkParts = false) {
const 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;
}
checkAutoScrollY(yy) {
const 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();
}
}
scrollParts() { }
doScroll(e, h = false) {
const 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();
}
}
focus() {
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);
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}"]}