@clr/angular
Version:
Angular components for Clarity
333 lines • 56.1 kB
JavaScript
/*
* Copyright (c) 2016-2025 Broadcom. All Rights Reserved.
* The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries.
* This software is released under MIT license.
* The full license information can be found in LICENSE in the root directory of this project.
*/
import { Directionality } from '@angular/cdk/bidi';
import { coerceNumberProperty } from '@angular/cdk/coercion';
import { _RecycleViewRepeaterStrategy, _VIEW_REPEATER_STRATEGY } from '@angular/cdk/collections';
import { CdkVirtualForOf, CdkVirtualScrollable, CdkVirtualScrollViewport, FixedSizeVirtualScrollStrategy, ScrollDispatcher, ViewportRuler, VIRTUAL_SCROLL_STRATEGY, } from '@angular/cdk/scrolling';
import { VERSION as ANGULAR_VERSION, ChangeDetectorRef, Directive, ElementRef, EnvironmentInjector, EventEmitter, forwardRef, Inject, inject, Injector, Input, IterableDiffers, NgZone, Output, Renderer2, TemplateRef, ViewContainerRef, } from '@angular/core';
import { ClrDatagrid } from './datagrid';
import { Items } from './providers/items';
import * as i0 from "@angular/core";
import * as i1 from "./providers/items";
import * as i2 from "@angular/cdk/bidi";
import * as i3 from "@angular/cdk/scrolling";
import * as i4 from "./providers/columns.service";
import * as i5 from "./datagrid";
const defaultCdkFixedSizeVirtualScrollInputs = {
itemSize: 32,
minBufferPx: 200,
maxBufferPx: 400,
};
export class ClrDatagridVirtualScrollDirective {
constructor(changeDetectorRef, iterableDiffers, items, ngZone, renderer2, templateRef, viewContainerRef, directionality, scrollDispatcher, viewportRuler, datagrid, columnsService, injector) {
this.changeDetectorRef = changeDetectorRef;
this.iterableDiffers = iterableDiffers;
this.items = items;
this.ngZone = ngZone;
this.renderer2 = renderer2;
this.templateRef = templateRef;
this.viewContainerRef = viewContainerRef;
this.directionality = directionality;
this.scrollDispatcher = scrollDispatcher;
this.viewportRuler = viewportRuler;
this.datagrid = datagrid;
this.columnsService = columnsService;
this.injector = injector;
this.renderedRangeChange = new EventEmitter();
this.persistItems = true;
this._cdkFixedSizeVirtualScrollInputs = { ...defaultCdkFixedSizeVirtualScrollInputs };
this.subscriptions = [];
this.topIndex = 0;
this.mutationChanges = new MutationObserver((mutations) => {
mutations.forEach((mutation) => {
// it is possible this to be called twice because the old class is removed and the new added
if (mutation.target.classList.contains('datagrid-compact') && this.itemSize > 24) {
this.itemSize = 24;
}
});
});
this.viewRepeater = new _RecycleViewRepeaterStrategy();
this.cdkVirtualForInputs = {
cdkVirtualForTrackBy: index => index,
};
items.smartenUp();
datagrid.detailService.preventFocusScroll = true;
this.datagridElementRef = datagrid.el;
// default
this.cdkVirtualForTemplateCacheSize = 20;
this.mutationChanges.observe(this.datagridElementRef.nativeElement, {
attributeFilter: ['class'],
attributeOldValue: true,
});
this.virtualScrollStrategy = new FixedSizeVirtualScrollStrategy(this._cdkFixedSizeVirtualScrollInputs.itemSize, this._cdkFixedSizeVirtualScrollInputs.minBufferPx, this._cdkFixedSizeVirtualScrollInputs.maxBufferPx);
}
get cdkVirtualForOf() {
return this.cdkVirtualForInputs.cdkVirtualForOf;
}
set cdkVirtualForOf(value) {
this.cdkVirtualForInputs.cdkVirtualForOf = value;
this.items.all = value;
this.updateCdkVirtualForInputs();
}
get cdkVirtualForTrackBy() {
return this.cdkVirtualForInputs.cdkVirtualForTrackBy;
}
set cdkVirtualForTrackBy(value) {
this.cdkVirtualForInputs.cdkVirtualForTrackBy = value;
this.updateCdkVirtualForInputs();
}
get cdkVirtualForTemplate() {
return this?.cdkVirtualForInputs?.cdkVirtualForTemplate;
}
set cdkVirtualForTemplate(value) {
this.cdkVirtualForInputs.cdkVirtualForTemplate = value;
this.updateCdkVirtualForInputs();
}
get cdkVirtualForTemplateCacheSize() {
return this.cdkVirtualForInputs.cdkVirtualForTemplateCacheSize;
}
set cdkVirtualForTemplateCacheSize(value) {
this.cdkVirtualForInputs.cdkVirtualForTemplateCacheSize = coerceNumberProperty(value);
this.updateCdkVirtualForInputs();
}
get itemSize() {
return this._cdkFixedSizeVirtualScrollInputs.itemSize;
}
set itemSize(value) {
this._cdkFixedSizeVirtualScrollInputs.itemSize = coerceNumberProperty(value);
this.updateFixedSizeVirtualScrollInputs();
}
get minBufferPx() {
return this._cdkFixedSizeVirtualScrollInputs.minBufferPx;
}
set minBufferPx(value) {
this._cdkFixedSizeVirtualScrollInputs.minBufferPx = coerceNumberProperty(value);
this.updateFixedSizeVirtualScrollInputs();
}
get maxBufferPx() {
return this._cdkFixedSizeVirtualScrollInputs.maxBufferPx;
}
set maxBufferPx(value) {
this._cdkFixedSizeVirtualScrollInputs.maxBufferPx = coerceNumberProperty(value);
this.updateFixedSizeVirtualScrollInputs();
}
set dataRange(range) {
if (!range) {
return;
}
if (this.items.smart) {
this.items.smartenDown();
}
this.totalItems = range.total;
this.updateDataRange(range.skip, range.data);
}
get totalItems() {
return this._totalItems;
}
set totalItems(value) {
this._totalItems = value;
}
ngAfterViewInit() {
this.injector.runInContext(() => {
this.virtualScrollViewport = this.createVirtualScrollViewportForDatagrid(this.changeDetectorRef, this.ngZone, this.renderer2, this.directionality, this.scrollDispatcher, this.viewportRuler, this.datagridElementRef, this.virtualScrollStrategy);
this.cdkVirtualFor = createCdkVirtualForOfDirective(this.viewContainerRef, this.templateRef, this.iterableDiffers, this.viewRepeater, this.virtualScrollViewport, this.ngZone);
this.virtualScrollViewport.ngOnInit();
});
this.gridRoleElement = this.datagridElementRef.nativeElement.querySelector('[role="grid"]');
this.updateCdkVirtualForInputs();
this.subscriptions.push(this.items.change.subscribe(newItems => {
if (this.items.smart) {
this.cdkVirtualFor.cdkVirtualForOf = newItems;
}
}), this.cdkVirtualFor.dataStream.subscribe(data => {
this.updateAriaRowCount(data.length);
}), this.virtualScrollViewport.scrolledIndexChange.subscribe(index => {
this.topIndex = index;
}), this.virtualScrollViewport.renderedRangeStream.subscribe(renderedRange => {
this.renderedRangeChange.emit(renderedRange);
}), this.datagrid.refresh.subscribe(datagridState => {
if (datagridState.filters) {
this.scrollToIndex(0);
}
}), this.columnsService.columnsStateChange.subscribe(() => {
this.viewRepeater.detach();
}));
}
ngDoCheck() {
this.cdkVirtualFor?.ngDoCheck();
this.updateAriaRowIndexes();
}
ngOnDestroy() {
this.cdkVirtualFor?.ngOnDestroy();
this.virtualScrollViewport?.ngOnDestroy();
this.mutationChanges?.disconnect();
this.subscriptions.forEach(subscription => {
subscription.unsubscribe();
});
}
scrollUp(offset, behavior = 'auto') {
this.scrollToIndex(this.topIndex - offset, behavior);
}
scrollDown(offset, behavior = 'auto') {
this.scrollToIndex(this.topIndex + offset, behavior);
}
scrollToIndex(index, behavior = 'auto') {
this.virtualScrollViewport?.scrollToIndex(index, behavior);
}
updateDataRange(skip, data) {
let items = this.cdkVirtualForOf;
if (!this.persistItems || !items || items?.length !== this.totalItems) {
items = Array(this.totalItems);
}
items.splice(skip, data.length, ...data);
this.cdkVirtualForOf = Array.from(items);
}
updateCdkVirtualForInputs() {
if (this.cdkVirtualFor) {
for (const cdkVirtualForInputKey of Object.keys(this.cdkVirtualForInputs)) {
if (this.cdkVirtualFor[cdkVirtualForInputKey] !== this.cdkVirtualForInputs[cdkVirtualForInputKey]) {
this.cdkVirtualFor[cdkVirtualForInputKey] = this.cdkVirtualForInputs[cdkVirtualForInputKey];
}
}
}
}
updateFixedSizeVirtualScrollInputs() {
if (this.virtualScrollStrategy) {
this.virtualScrollStrategy.updateItemAndBufferSize(this._cdkFixedSizeVirtualScrollInputs.itemSize, this._cdkFixedSizeVirtualScrollInputs.minBufferPx, this._cdkFixedSizeVirtualScrollInputs.maxBufferPx);
}
}
updateAriaRowCount(rowCount) {
this.gridRoleElement?.setAttribute('aria-rowcount', rowCount.toString());
}
updateAriaRowIndexes() {
for (let i = 0; i < this.viewContainerRef.length; i++) {
const viewRef = this.viewContainerRef.get(i);
const rootElements = viewRef.rootNodes;
const datagridRowElement = rootElements.find(rowElement => rowElement.tagName === 'CLR-DG-ROW');
const rowRoleElement = datagridRowElement?.querySelector('[role="row"]');
// aria-rowindex should start with one, not zero, so we have to add one to the zero-based index
rowRoleElement?.setAttribute('aria-rowindex', (viewRef.context.index + 1).toString());
}
}
createVirtualScrollViewportForDatagrid(changeDetectorRef, ngZone, renderer2, directionality, scrollDispatcher, viewportRuler, datagridElementRef, virtualScrollStrategy) {
const datagridDivElement = datagridElementRef.nativeElement.querySelector('.datagrid');
const datagridTableElement = datagridElementRef.nativeElement.querySelector('.datagrid-table');
const datagridRowsElement = datagridElementRef.nativeElement.querySelector('.datagrid-rows');
const datagridDivElementRef = { nativeElement: datagridDivElement };
let topOffset = 0;
let totalContentSize = 0;
function updateDatagridElementStyles() {
datagridRowsElement.style.transform = `translateY(${topOffset}px)`;
datagridRowsElement.style.height = `${totalContentSize - topOffset}px`;
}
const virtualScrollViewport = createCdkVirtualScrollViewport(datagridDivElementRef, changeDetectorRef, ngZone, renderer2, virtualScrollStrategy, directionality, scrollDispatcher, viewportRuler, null);
virtualScrollViewport._contentWrapper = {
nativeElement: {
style: {
set transform(value) {
topOffset = value === undefined ? 0 : +/translateY\(([0-9]+)px\)/.exec(value)?.[1];
updateDatagridElementStyles();
},
},
},
};
virtualScrollViewport.setTotalContentSize = (value) => {
totalContentSize = value;
datagridTableElement.style.height = `${totalContentSize}px`;
updateDatagridElementStyles();
};
return virtualScrollViewport;
}
}
ClrDatagridVirtualScrollDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrDatagridVirtualScrollDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.IterableDiffers }, { token: i1.Items }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i2.Directionality }, { token: i3.ScrollDispatcher }, { token: i3.ViewportRuler }, { token: forwardRef(() => ClrDatagrid) }, { token: i4.ColumnsService }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Directive });
ClrDatagridVirtualScrollDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.2", type: ClrDatagridVirtualScrollDirective, selector: "[clrVirtualScroll],[ClrVirtualScroll]", inputs: { persistItems: ["clrVirtualPersistItems", "persistItems"], cdkVirtualForOf: ["clrVirtualRowsOf", "cdkVirtualForOf"], cdkVirtualForTrackBy: ["clrVirtualRowsTrackBy", "cdkVirtualForTrackBy"], cdkVirtualForTemplate: ["clrVirtualRowsTemplate", "cdkVirtualForTemplate"], cdkVirtualForTemplateCacheSize: ["clrVirtualRowsTemplateCacheSize", "cdkVirtualForTemplateCacheSize"], itemSize: ["clrVirtualRowsItemSize", "itemSize"], minBufferPx: ["clrVirtualRowsMinBufferPx", "minBufferPx"], maxBufferPx: ["clrVirtualRowsMaxBufferPx", "maxBufferPx"], dataRange: ["clrVirtualDataRange", "dataRange"] }, outputs: { renderedRangeChange: "renderedRangeChange" }, providers: [Items], ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrDatagridVirtualScrollDirective, decorators: [{
type: Directive,
args: [{
selector: '[clrVirtualScroll],[ClrVirtualScroll]',
providers: [Items],
}]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.IterableDiffers }, { type: i1.Items }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i2.Directionality }, { type: i3.ScrollDispatcher }, { type: i3.ViewportRuler }, { type: i5.ClrDatagrid, decorators: [{
type: Inject,
args: [forwardRef(() => ClrDatagrid)]
}] }, { type: i4.ColumnsService }, { type: i0.EnvironmentInjector }]; }, propDecorators: { renderedRangeChange: [{
type: Output
}], persistItems: [{
type: Input,
args: ['clrVirtualPersistItems']
}], cdkVirtualForOf: [{
type: Input,
args: ['clrVirtualRowsOf']
}], cdkVirtualForTrackBy: [{
type: Input,
args: ['clrVirtualRowsTrackBy']
}], cdkVirtualForTemplate: [{
type: Input,
args: ['clrVirtualRowsTemplate']
}], cdkVirtualForTemplateCacheSize: [{
type: Input,
args: ['clrVirtualRowsTemplateCacheSize']
}], itemSize: [{
type: Input,
args: ['clrVirtualRowsItemSize']
}], minBufferPx: [{
type: Input,
args: ['clrVirtualRowsMinBufferPx']
}], maxBufferPx: [{
type: Input,
args: ['clrVirtualRowsMaxBufferPx']
}], dataRange: [{
type: Input,
args: ['clrVirtualDataRange']
}] } });
function createCdkVirtualScrollViewport(datagridDivElementRef, changeDetectorRef, ngZone, renderer2, virtualScrollStrategy, directionality, scrollDispatcher, viewportRuler, scrollable) {
if (+ANGULAR_VERSION.major < 19) {
return new CdkVirtualScrollViewport(datagridDivElementRef, changeDetectorRef, ngZone, virtualScrollStrategy, directionality, scrollDispatcher, viewportRuler, scrollable);
}
else {
const virtualScrollViewportInjector = Injector.create({
parent: inject(EnvironmentInjector),
providers: [
{ provide: ElementRef, useValue: datagridDivElementRef },
{ provide: ChangeDetectorRef, useValue: changeDetectorRef },
{ provide: NgZone, useValue: ngZone },
{ provide: Renderer2, useValue: renderer2 },
{ provide: VIRTUAL_SCROLL_STRATEGY, useValue: virtualScrollStrategy },
{ provide: Directionality, useValue: directionality },
{ provide: ScrollDispatcher, useValue: scrollDispatcher },
{ provide: ViewportRuler, useValue: viewportRuler },
{ provide: CdkVirtualScrollable, useValue: scrollable },
{ provide: CdkVirtualScrollViewport, useClass: CdkVirtualScrollViewport },
],
});
return virtualScrollViewportInjector.get(CdkVirtualScrollViewport);
}
}
function createCdkVirtualForOfDirective(viewContainerRef, templateRef, iterableDiffers, viewRepeater, virtualScrollViewport, ngZone) {
if (+ANGULAR_VERSION.major < 19) {
return new CdkVirtualForOf(viewContainerRef, templateRef, iterableDiffers, viewRepeater, virtualScrollViewport, ngZone);
}
else {
const virtualScrollViewportInjector = Injector.create({
parent: inject(EnvironmentInjector),
providers: [{ provide: CdkVirtualScrollViewport, useValue: virtualScrollViewport }],
});
const cdkVirtualForInjector = Injector.create({
parent: virtualScrollViewportInjector,
providers: [
{ provide: ViewContainerRef, useValue: viewContainerRef },
{ provide: TemplateRef, useValue: templateRef },
{ provide: IterableDiffers, useValue: iterableDiffers },
{ provide: _VIEW_REPEATER_STRATEGY, useValue: viewRepeater },
{ provide: NgZone, useValue: ngZone },
{ provide: CdkVirtualForOf, useClass: CdkVirtualForOf },
],
});
return cdkVirtualForInjector.get(CdkVirtualForOf);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datagrid-virtual-scroll.directive.js","sourceRoot":"","sources":["../../../../../projects/angular/src/data/datagrid/datagrid-virtual-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport { Directionality } from '@angular/cdk/bidi';\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\nimport { _RecycleViewRepeaterStrategy, _VIEW_REPEATER_STRATEGY, ListRange } from '@angular/cdk/collections';\nimport {\n  CdkFixedSizeVirtualScroll,\n  CdkVirtualForOf,\n  CdkVirtualForOfContext,\n  CdkVirtualScrollable,\n  CdkVirtualScrollableElement,\n  CdkVirtualScrollViewport,\n  FixedSizeVirtualScrollStrategy,\n  ScrollDispatcher,\n  ViewportRuler,\n  VIRTUAL_SCROLL_STRATEGY,\n  VirtualScrollStrategy,\n} from '@angular/cdk/scrolling';\nimport {\n  AfterViewInit,\n  VERSION as ANGULAR_VERSION,\n  ChangeDetectorRef,\n  Directive,\n  DoCheck,\n  ElementRef,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  inject,\n  Injector,\n  Input,\n  IterableDiffers,\n  NgZone,\n  OnDestroy,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { ClrDatagrid } from './datagrid';\nimport { ClrDatagridVirtualScrollRangeInterface } from './interfaces/virtual-scroll-data-range.interface';\nimport { ColumnsService } from './providers/columns.service';\nimport { Items } from './providers/items';\n\ntype CdkVirtualForInputKey =\n  | 'cdkVirtualForOf'\n  | 'cdkVirtualForTrackBy'\n  | 'cdkVirtualForTemplate'\n  | 'cdkVirtualForTemplateCacheSize';\n\ntype CdkVirtualForInputs<T> = Partial<Pick<CdkVirtualForOf<T>, CdkVirtualForInputKey>>;\n\ntype CdkFixedSizeVirtualScrollInputs = Pick<CdkFixedSizeVirtualScroll, 'itemSize' | 'minBufferPx' | 'maxBufferPx'>;\n\nconst defaultCdkFixedSizeVirtualScrollInputs: CdkFixedSizeVirtualScrollInputs = {\n  itemSize: 32,\n  minBufferPx: 200,\n  maxBufferPx: 400,\n};\n\n@Directive({\n  selector: '[clrVirtualScroll],[ClrVirtualScroll]',\n  providers: [Items],\n})\nexport class ClrDatagridVirtualScrollDirective<T> implements AfterViewInit, DoCheck, OnDestroy {\n  @Output() renderedRangeChange = new EventEmitter<ListRange>();\n  @Input('clrVirtualPersistItems') persistItems = true;\n\n  private _cdkFixedSizeVirtualScrollInputs = { ...defaultCdkFixedSizeVirtualScrollInputs };\n\n  private readonly datagridElementRef: ElementRef<HTMLElement>;\n\n  private gridRoleElement: HTMLElement | null | undefined;\n  private readonly virtualScrollStrategy: FixedSizeVirtualScrollStrategy;\n  private virtualScrollViewport: CdkVirtualScrollViewport;\n  private cdkVirtualFor: CdkVirtualForOf<T>;\n  private subscriptions: Subscription[] = [];\n  private topIndex = 0;\n  private mutationChanges: MutationObserver = new MutationObserver((mutations: MutationRecord[]) => {\n    mutations.forEach((mutation: MutationRecord) => {\n      // it is possible this to be called twice because the old class is removed and the new added\n      if ((mutation.target as HTMLElement).classList.contains('datagrid-compact') && this.itemSize > 24) {\n        this.itemSize = 24;\n      }\n    });\n  });\n\n  private viewRepeater = new _RecycleViewRepeaterStrategy<T, T, CdkVirtualForOfContext<T>>();\n  private cdkVirtualForInputs: CdkVirtualForInputs<T> = {\n    cdkVirtualForTrackBy: index => index,\n  };\n  private _totalItems: number;\n\n  constructor(\n    private readonly changeDetectorRef: ChangeDetectorRef,\n    private iterableDiffers: IterableDiffers,\n    private items: Items<T>,\n    private readonly ngZone: NgZone,\n    private readonly renderer2: Renderer2,\n    private readonly templateRef: TemplateRef<CdkVirtualForOfContext<T>>,\n    private readonly viewContainerRef: ViewContainerRef,\n    private readonly directionality: Directionality,\n    private readonly scrollDispatcher: ScrollDispatcher,\n    private readonly viewportRuler: ViewportRuler,\n    @Inject(forwardRef(() => ClrDatagrid)) private readonly datagrid: ClrDatagrid,\n    private columnsService: ColumnsService,\n    private readonly injector: EnvironmentInjector\n  ) {\n    items.smartenUp();\n    datagrid.detailService.preventFocusScroll = true;\n\n    this.datagridElementRef = datagrid.el;\n\n    // default\n    this.cdkVirtualForTemplateCacheSize = 20;\n\n    this.mutationChanges.observe(this.datagridElementRef.nativeElement, {\n      attributeFilter: ['class'],\n      attributeOldValue: true,\n    });\n\n    this.virtualScrollStrategy = new FixedSizeVirtualScrollStrategy(\n      this._cdkFixedSizeVirtualScrollInputs.itemSize,\n      this._cdkFixedSizeVirtualScrollInputs.minBufferPx,\n      this._cdkFixedSizeVirtualScrollInputs.maxBufferPx\n    );\n  }\n\n  @Input('clrVirtualRowsOf')\n  get cdkVirtualForOf() {\n    return this.cdkVirtualForInputs.cdkVirtualForOf;\n  }\n  set cdkVirtualForOf(value: CdkVirtualForInputs<T>['cdkVirtualForOf']) {\n    this.cdkVirtualForInputs.cdkVirtualForOf = value;\n    this.items.all = value as T[];\n    this.updateCdkVirtualForInputs();\n  }\n\n  @Input('clrVirtualRowsTrackBy')\n  get cdkVirtualForTrackBy() {\n    return this.cdkVirtualForInputs.cdkVirtualForTrackBy;\n  }\n  set cdkVirtualForTrackBy(value: CdkVirtualForInputs<T>['cdkVirtualForTrackBy']) {\n    this.cdkVirtualForInputs.cdkVirtualForTrackBy = value;\n    this.updateCdkVirtualForInputs();\n  }\n\n  @Input('clrVirtualRowsTemplate')\n  get cdkVirtualForTemplate() {\n    return this?.cdkVirtualForInputs?.cdkVirtualForTemplate;\n  }\n  set cdkVirtualForTemplate(value: CdkVirtualForInputs<T>['cdkVirtualForTemplate']) {\n    this.cdkVirtualForInputs.cdkVirtualForTemplate = value;\n    this.updateCdkVirtualForInputs();\n  }\n\n  @Input('clrVirtualRowsTemplateCacheSize')\n  get cdkVirtualForTemplateCacheSize() {\n    return this.cdkVirtualForInputs.cdkVirtualForTemplateCacheSize;\n  }\n  set cdkVirtualForTemplateCacheSize(value: CdkVirtualForInputs<T>['cdkVirtualForTemplateCacheSize']) {\n    this.cdkVirtualForInputs.cdkVirtualForTemplateCacheSize = coerceNumberProperty(value);\n    this.updateCdkVirtualForInputs();\n  }\n\n  @Input('clrVirtualRowsItemSize')\n  get itemSize() {\n    return this._cdkFixedSizeVirtualScrollInputs.itemSize;\n  }\n  set itemSize(value: CdkFixedSizeVirtualScrollInputs['itemSize']) {\n    this._cdkFixedSizeVirtualScrollInputs.itemSize = coerceNumberProperty(value);\n    this.updateFixedSizeVirtualScrollInputs();\n  }\n\n  @Input('clrVirtualRowsMinBufferPx')\n  get minBufferPx() {\n    return this._cdkFixedSizeVirtualScrollInputs.minBufferPx;\n  }\n  set minBufferPx(value: CdkFixedSizeVirtualScrollInputs['minBufferPx']) {\n    this._cdkFixedSizeVirtualScrollInputs.minBufferPx = coerceNumberProperty(value);\n    this.updateFixedSizeVirtualScrollInputs();\n  }\n\n  @Input('clrVirtualRowsMaxBufferPx')\n  get maxBufferPx() {\n    return this._cdkFixedSizeVirtualScrollInputs.maxBufferPx;\n  }\n  set maxBufferPx(value: CdkFixedSizeVirtualScrollInputs['maxBufferPx']) {\n    this._cdkFixedSizeVirtualScrollInputs.maxBufferPx = coerceNumberProperty(value);\n    this.updateFixedSizeVirtualScrollInputs();\n  }\n\n  @Input('clrVirtualDataRange')\n  set dataRange(range: ClrDatagridVirtualScrollRangeInterface<T>) {\n    if (!range) {\n      return;\n    }\n\n    if (this.items.smart) {\n      this.items.smartenDown();\n    }\n\n    this.totalItems = range.total;\n\n    this.updateDataRange(range.skip, range.data);\n  }\n\n  get totalItems() {\n    return this._totalItems;\n  }\n\n  private set totalItems(value: number) {\n    this._totalItems = value;\n  }\n\n  ngAfterViewInit() {\n    this.injector.runInContext(() => {\n      this.virtualScrollViewport = this.createVirtualScrollViewportForDatagrid(\n        this.changeDetectorRef,\n        this.ngZone,\n        this.renderer2,\n        this.directionality,\n        this.scrollDispatcher,\n        this.viewportRuler,\n        this.datagridElementRef,\n        this.virtualScrollStrategy\n      );\n\n      this.cdkVirtualFor = createCdkVirtualForOfDirective(\n        this.viewContainerRef,\n        this.templateRef,\n        this.iterableDiffers,\n        this.viewRepeater,\n        this.virtualScrollViewport,\n        this.ngZone\n      );\n\n      this.virtualScrollViewport.ngOnInit();\n    });\n\n    this.gridRoleElement = this.datagridElementRef.nativeElement.querySelector<HTMLElement>('[role=\"grid\"]');\n\n    this.updateCdkVirtualForInputs();\n\n    this.subscriptions.push(\n      this.items.change.subscribe(newItems => {\n        if (this.items.smart) {\n          this.cdkVirtualFor.cdkVirtualForOf = newItems;\n        }\n      }),\n      this.cdkVirtualFor.dataStream.subscribe(data => {\n        this.updateAriaRowCount(data.length);\n      }),\n      this.virtualScrollViewport.scrolledIndexChange.subscribe(index => {\n        this.topIndex = index;\n      }),\n      this.virtualScrollViewport.renderedRangeStream.subscribe(renderedRange => {\n        this.renderedRangeChange.emit(renderedRange);\n      }),\n      this.datagrid.refresh.subscribe(datagridState => {\n        if (datagridState.filters) {\n          this.scrollToIndex(0);\n        }\n      }),\n      this.columnsService.columnsStateChange.subscribe(() => {\n        this.viewRepeater.detach();\n      })\n    );\n  }\n\n  ngDoCheck() {\n    this.cdkVirtualFor?.ngDoCheck();\n    this.updateAriaRowIndexes();\n  }\n\n  ngOnDestroy() {\n    this.cdkVirtualFor?.ngOnDestroy();\n    this.virtualScrollViewport?.ngOnDestroy();\n    this.mutationChanges?.disconnect();\n    this.subscriptions.forEach(subscription => {\n      subscription.unsubscribe();\n    });\n  }\n\n  scrollUp(offset: number, behavior: ScrollBehavior = 'auto') {\n    this.scrollToIndex(this.topIndex - offset, behavior);\n  }\n\n  scrollDown(offset: number, behavior: ScrollBehavior = 'auto') {\n    this.scrollToIndex(this.topIndex + offset, behavior);\n  }\n\n  scrollToIndex(index: number, behavior: ScrollBehavior = 'auto') {\n    this.virtualScrollViewport?.scrollToIndex(index, behavior);\n  }\n\n  private updateDataRange(skip: number, data: T[]) {\n    let items = this.cdkVirtualForOf as T[];\n\n    if (!this.persistItems || !items || items?.length !== this.totalItems) {\n      items = Array(this.totalItems);\n    }\n\n    items.splice(skip, data.length, ...data);\n\n    this.cdkVirtualForOf = Array.from(items);\n  }\n\n  private updateCdkVirtualForInputs() {\n    if (this.cdkVirtualFor) {\n      for (const cdkVirtualForInputKey of Object.keys(this.cdkVirtualForInputs) as CdkVirtualForInputKey[]) {\n        if (this.cdkVirtualFor[cdkVirtualForInputKey] !== this.cdkVirtualForInputs[cdkVirtualForInputKey]) {\n          (this.cdkVirtualFor as any)[cdkVirtualForInputKey] = this.cdkVirtualForInputs[cdkVirtualForInputKey];\n        }\n      }\n    }\n  }\n\n  private updateFixedSizeVirtualScrollInputs() {\n    if (this.virtualScrollStrategy) {\n      this.virtualScrollStrategy.updateItemAndBufferSize(\n        this._cdkFixedSizeVirtualScrollInputs.itemSize,\n        this._cdkFixedSizeVirtualScrollInputs.minBufferPx,\n        this._cdkFixedSizeVirtualScrollInputs.maxBufferPx\n      );\n    }\n  }\n\n  private updateAriaRowCount(rowCount: number) {\n    this.gridRoleElement?.setAttribute('aria-rowcount', rowCount.toString());\n  }\n\n  private updateAriaRowIndexes() {\n    for (let i = 0; i < this.viewContainerRef.length; i++) {\n      const viewRef = this.viewContainerRef.get(i) as EmbeddedViewRef<CdkVirtualForOfContext<T>>;\n\n      const rootElements: HTMLElement[] = viewRef.rootNodes;\n      const datagridRowElement = rootElements.find(rowElement => rowElement.tagName === 'CLR-DG-ROW');\n      const rowRoleElement = datagridRowElement?.querySelector('[role=\"row\"]');\n\n      // aria-rowindex should start with one, not zero, so we have to add one to the zero-based index\n      rowRoleElement?.setAttribute('aria-rowindex', (viewRef.context.index + 1).toString());\n    }\n  }\n\n  private createVirtualScrollViewportForDatagrid(\n    changeDetectorRef: ChangeDetectorRef,\n    ngZone: NgZone,\n    renderer2: Renderer2,\n    directionality: Directionality,\n    scrollDispatcher: ScrollDispatcher,\n    viewportRuler: ViewportRuler,\n    datagridElementRef: ElementRef<HTMLElement>,\n    virtualScrollS