Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ng-table-virtual-scroll

Package Overview
Dependencies
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ng-table-virtual-scroll - npm Package Compare versions

Comparing version 1.2.0 to 1.2.1

25

bundles/ng-table-virtual-scroll.umd.js

@@ -531,3 +531,4 @@ (function (global, factory) {

var TableItemSizeDirective = /** @class */ (function () {
function TableItemSizeDirective() {
function TableItemSizeDirective(zone) {
this.zone = zone;
this.alive = true;

@@ -597,3 +598,14 @@ // tslint:disable-next-line:no-input-rename

var dataSource_1 = this.table.dataSource;
this.scrollStrategy.renderedRangeStream.subscribe(dataSource_1.renderedRangeStream);
this.scrollStrategy.renderedRangeStream.subscribe((/**
* @param {?} range
* @return {?}
*/
function (range) {
_this.zone.run((/**
* @return {?}
*/
function () {
dataSource_1.renderedRangeStream.next(range);
}));
}));
dataSource_1.connect()

@@ -676,2 +688,6 @@ .pipe(operators.map((/**

];
/** @nocollapse */
TableItemSizeDirective.ctorParameters = function () { return [
{ type: core.NgZone }
]; };
TableItemSizeDirective.propDecorators = {

@@ -701,2 +717,7 @@ rowHeight: [{ type: core.Input, args: ['tvsItemSize',] }],

TableItemSizeDirective.prototype.scrollStrategy;
/**
* @type {?}
* @private
*/
TableItemSizeDirective.prototype.zone;
}

@@ -703,0 +724,0 @@

2

bundles/ng-table-virtual-scroll.umd.min.js

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/cdk/scrolling"),require("rxjs/operators"),require("rxjs"),require("@angular/material")):"function"==typeof define&&define.amd?define("ng-table-virtual-scroll",["exports","@angular/core","@angular/cdk/scrolling","rxjs/operators","rxjs","@angular/material"],e):e((t=t||self)["ng-table-virtual-scroll"]={},t.ng.core,t.ng.cdk.scrolling,t.rxjs.operators,t.rxjs,t.ng.material)}(this,function(t,e,r,i,n,a){"use strict";var o=function(t,e){return(o=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)e.hasOwnProperty(r)&&(t[r]=e[r])})(t,e)};function s(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var i,n,a=r.call(t),o=[];try{for(;(void 0===e||e-- >0)&&!(i=a.next()).done;)o.push(i.value)}catch(t){n={error:t}}finally{try{i&&!i.done&&(r=a.return)&&r.call(a)}finally{if(n)throw n.error}}return o}var u=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return function(t,e){function r(){this.constructor=t}o(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}(e,t),e.prototype._updateChangeSubscription=function(){var t=this;this.initRenderedRangeStream();var e=this._sort,r=this._paginator,a=this._internalPageChanges,o=this._filter,u=this._renderData,h=e?n.merge(e.sortChange,e.initialized):n.of(null),l=r?n.merge(r.page,a,r.initialized):n.of(null),c=this._data,p=n.combineLatest([c,o]).pipe(i.map(function(e){var r=s(e,1)[0];return t._filterData(r)})),f=n.combineLatest([p,h]).pipe(i.map(function(e){var r=s(e,1)[0];return t._orderData(r)})),d=n.combineLatest([f,l]).pipe(i.map(function(e){var r=s(e,1)[0];return t._pageData(r)})),g=n.combineLatest([d,this.renderedRangeStream.asObservable()]).pipe(i.map(function(t){var e=s(t,2),r=e[0],i=e[1],n=i.start,a=i.end;return null==n||null==a?r:r.slice(n,a)}));this._renderChangesSubscription.unsubscribe(),this._renderChangesSubscription=g.subscribe(function(t){return u.next(t)})},e.prototype.initRenderedRangeStream=function(){this.renderedRangeStream||(this.renderedRangeStream=new n.Subject)},e}(a.MatTableDataSource);var h=function(){function t(){this.indexChange=new n.Subject,this.stickyChange=new n.Subject,this.renderedRangeStream=new n.Subject,this.scrolledIndexChange=this.indexChange.pipe(i.distinctUntilChanged()),this._dataLength=0}return Object.defineProperty(t.prototype,"dataLength",{get:function(){return this._dataLength},set:function(t){this._dataLength=t,this.onDataLengthChanged()},enumerable:!0,configurable:!0}),t.prototype.attach=function(t){this.viewport=t,this.viewport.renderedRangeStream.subscribe(this.renderedRangeStream),this.onDataLengthChanged(),this.updateContent()},t.prototype.detach=function(){},t.prototype.onContentScrolled=function(){this.updateContent()},t.prototype.onDataLengthChanged=function(){this.viewport&&this.viewport.setTotalContentSize(this.dataLength*this.rowHeight+this.headerHeight)},t.prototype.onContentRendered=function(){},t.prototype.onRenderedOffsetChanged=function(){},t.prototype.scrollToIndex=function(t,e){},t.prototype.setConfig=function(t){var e=t.rowHeight,r=t.headerHeight,i=t.bufferMultiplier;this.rowHeight!==e&&this.headerHeight!==r&&this.bufferMultiplier!==i&&(this.rowHeight=e,this.headerHeight=r,this.bufferMultiplier=i,this.updateContent())},t.prototype.updateContent=function(){if(this.viewport&&this.rowHeight){var t=this.viewport.measureScrollOffset(),e=Math.ceil(this.viewport.getViewportSize()/this.rowHeight),r=Math.max(t-this.headerHeight,0),i=Math.ceil(e*this.bufferMultiplier),n=Math.round(r/this.rowHeight),a=Math.max(0,n),o=Math.max(0,a-i),s=Math.min(this.dataLength,a+e+i),u=o*this.rowHeight;this.viewport.setRenderedContentOffset(u),this.viewport.setRenderedRange({start:o,end:s}),this.indexChange.next(a),this.stickyChange.next(u)}},t.decorators=[{type:e.Injectable}],t}();function l(t){return t.scrollStrategy}var c={rowHeight:48,headerHeight:56,bufferMultiplier:.7},p=function(){function t(){this.alive=!0,this.rowHeight=c.rowHeight,this.headerHeight=c.headerHeight,this.bufferMultiplier=c.bufferMultiplier,this.scrollStrategy=new h}return t.prototype.ngOnDestroy=function(){this.alive=!1},t.prototype.isAlive=function(){var t=this;return function(){return t.alive}},t.prototype.isStickyEnabled=function(){return!!this.scrollStrategy.viewport&&this.table._headerRowDefs.map(function(t){return t.sticky}).reduce(function(t,e){return t&&e},!0)},t.prototype.ngAfterViewInit=function(){var t=this;if(!(this.table.dataSource instanceof u))throw new Error("[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]");var e=this.table.dataSource;this.scrollStrategy.renderedRangeStream.subscribe(e.renderedRangeStream),e.connect().pipe(i.map(function(){return e.data.length}),i.distinctUntilChanged(),i.takeWhile(this.isAlive())).subscribe(function(e){t.scrollStrategy.dataLength=e}),this.scrollStrategy.stickyChange.pipe(i.filter(function(){return t.isStickyEnabled()}),i.takeWhile(this.isAlive())).subscribe(function(e){t.setSticky(e)})},t.prototype.ngOnChanges=function(){var t={rowHeight:+this.rowHeight||c.rowHeight,headerHeight:+this.headerHeight||c.headerHeight,bufferMultiplier:+this.bufferMultiplier||c.bufferMultiplier};this.scrollStrategy.setConfig(t)},t.prototype.setSticky=function(t){var e="-"+t+"px";this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll("th").forEach(function(t){t.style.top=e})},t.decorators=[{type:e.Directive,args:[{selector:"cdk-virtual-scroll-viewport[tvsItemSize]",providers:[{provide:r.VIRTUAL_SCROLL_STRATEGY,useFactory:l,deps:[e.forwardRef(function(){return t})]}]}]}],t.propDecorators={rowHeight:[{type:e.Input,args:["tvsItemSize"]}],headerHeight:[{type:e.Input}],bufferMultiplier:[{type:e.Input}],table:[{type:e.ContentChild,args:[a.MatTable,{static:!0}]}]},t}();var f=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{declarations:[p],imports:[],exports:[p]}]}],t}();t.FixedSizeTableVirtualScrollStrategy=h,t.TableItemSizeDirective=p,t.TableVirtualScrollDataSource=u,t.TableVirtualScrollModule=f,t._tableVirtualScrollDirectiveStrategyFactory=l,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/cdk/scrolling"),require("rxjs/operators"),require("rxjs"),require("@angular/material")):"function"==typeof define&&define.amd?define("ng-table-virtual-scroll",["exports","@angular/core","@angular/cdk/scrolling","rxjs/operators","rxjs","@angular/material"],e):e((t=t||self)["ng-table-virtual-scroll"]={},t.ng.core,t.ng.cdk.scrolling,t.rxjs.operators,t.rxjs,t.ng.material)}(this,function(t,e,r,i,n,o){"use strict";var a=function(t,e){return(a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)e.hasOwnProperty(r)&&(t[r]=e[r])})(t,e)};function s(t,e){var r="function"==typeof Symbol&&t[Symbol.iterator];if(!r)return t;var i,n,o=r.call(t),a=[];try{for(;(void 0===e||e-- >0)&&!(i=o.next()).done;)a.push(i.value)}catch(t){n={error:t}}finally{try{i&&!i.done&&(r=o.return)&&r.call(o)}finally{if(n)throw n.error}}return a}var u=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return function(t,e){function r(){this.constructor=t}a(t,e),t.prototype=null===e?Object.create(e):(r.prototype=e.prototype,new r)}(e,t),e.prototype._updateChangeSubscription=function(){var t=this;this.initRenderedRangeStream();var e=this._sort,r=this._paginator,o=this._internalPageChanges,a=this._filter,u=this._renderData,h=e?n.merge(e.sortChange,e.initialized):n.of(null),l=r?n.merge(r.page,o,r.initialized):n.of(null),c=this._data,p=n.combineLatest([c,a]).pipe(i.map(function(e){var r=s(e,1)[0];return t._filterData(r)})),f=n.combineLatest([p,h]).pipe(i.map(function(e){var r=s(e,1)[0];return t._orderData(r)})),d=n.combineLatest([f,l]).pipe(i.map(function(e){var r=s(e,1)[0];return t._pageData(r)})),g=n.combineLatest([d,this.renderedRangeStream.asObservable()]).pipe(i.map(function(t){var e=s(t,2),r=e[0],i=e[1],n=i.start,o=i.end;return null==n||null==o?r:r.slice(n,o)}));this._renderChangesSubscription.unsubscribe(),this._renderChangesSubscription=g.subscribe(function(t){return u.next(t)})},e.prototype.initRenderedRangeStream=function(){this.renderedRangeStream||(this.renderedRangeStream=new n.Subject)},e}(o.MatTableDataSource);var h=function(){function t(){this.indexChange=new n.Subject,this.stickyChange=new n.Subject,this.renderedRangeStream=new n.Subject,this.scrolledIndexChange=this.indexChange.pipe(i.distinctUntilChanged()),this._dataLength=0}return Object.defineProperty(t.prototype,"dataLength",{get:function(){return this._dataLength},set:function(t){this._dataLength=t,this.onDataLengthChanged()},enumerable:!0,configurable:!0}),t.prototype.attach=function(t){this.viewport=t,this.viewport.renderedRangeStream.subscribe(this.renderedRangeStream),this.onDataLengthChanged(),this.updateContent()},t.prototype.detach=function(){},t.prototype.onContentScrolled=function(){this.updateContent()},t.prototype.onDataLengthChanged=function(){this.viewport&&this.viewport.setTotalContentSize(this.dataLength*this.rowHeight+this.headerHeight)},t.prototype.onContentRendered=function(){},t.prototype.onRenderedOffsetChanged=function(){},t.prototype.scrollToIndex=function(t,e){},t.prototype.setConfig=function(t){var e=t.rowHeight,r=t.headerHeight,i=t.bufferMultiplier;this.rowHeight!==e&&this.headerHeight!==r&&this.bufferMultiplier!==i&&(this.rowHeight=e,this.headerHeight=r,this.bufferMultiplier=i,this.updateContent())},t.prototype.updateContent=function(){if(this.viewport&&this.rowHeight){var t=this.viewport.measureScrollOffset(),e=Math.ceil(this.viewport.getViewportSize()/this.rowHeight),r=Math.max(t-this.headerHeight,0),i=Math.ceil(e*this.bufferMultiplier),n=Math.round(r/this.rowHeight),o=Math.max(0,n),a=Math.max(0,o-i),s=Math.min(this.dataLength,o+e+i),u=a*this.rowHeight;this.viewport.setRenderedContentOffset(u),this.viewport.setRenderedRange({start:a,end:s}),this.indexChange.next(o),this.stickyChange.next(u)}},t.decorators=[{type:e.Injectable}],t}();function l(t){return t.scrollStrategy}var c={rowHeight:48,headerHeight:56,bufferMultiplier:.7},p=function(){function t(t){this.zone=t,this.alive=!0,this.rowHeight=c.rowHeight,this.headerHeight=c.headerHeight,this.bufferMultiplier=c.bufferMultiplier,this.scrollStrategy=new h}return t.prototype.ngOnDestroy=function(){this.alive=!1},t.prototype.isAlive=function(){var t=this;return function(){return t.alive}},t.prototype.isStickyEnabled=function(){return!!this.scrollStrategy.viewport&&this.table._headerRowDefs.map(function(t){return t.sticky}).reduce(function(t,e){return t&&e},!0)},t.prototype.ngAfterViewInit=function(){var t=this;if(!(this.table.dataSource instanceof u))throw new Error("[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]");var e=this.table.dataSource;this.scrollStrategy.renderedRangeStream.subscribe(function(r){t.zone.run(function(){e.renderedRangeStream.next(r)})}),e.connect().pipe(i.map(function(){return e.data.length}),i.distinctUntilChanged(),i.takeWhile(this.isAlive())).subscribe(function(e){t.scrollStrategy.dataLength=e}),this.scrollStrategy.stickyChange.pipe(i.filter(function(){return t.isStickyEnabled()}),i.takeWhile(this.isAlive())).subscribe(function(e){t.setSticky(e)})},t.prototype.ngOnChanges=function(){var t={rowHeight:+this.rowHeight||c.rowHeight,headerHeight:+this.headerHeight||c.headerHeight,bufferMultiplier:+this.bufferMultiplier||c.bufferMultiplier};this.scrollStrategy.setConfig(t)},t.prototype.setSticky=function(t){var e="-"+t+"px";this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll("th").forEach(function(t){t.style.top=e})},t.decorators=[{type:e.Directive,args:[{selector:"cdk-virtual-scroll-viewport[tvsItemSize]",providers:[{provide:r.VIRTUAL_SCROLL_STRATEGY,useFactory:l,deps:[e.forwardRef(function(){return t})]}]}]}],t.ctorParameters=function(){return[{type:e.NgZone}]},t.propDecorators={rowHeight:[{type:e.Input,args:["tvsItemSize"]}],headerHeight:[{type:e.Input}],bufferMultiplier:[{type:e.Input}],table:[{type:e.ContentChild,args:[o.MatTable,{static:!0}]}]},t}();var f=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{declarations:[p],imports:[],exports:[p]}]}],t}();t.FixedSizeTableVirtualScrollStrategy=h,t.TableItemSizeDirective=p,t.TableVirtualScrollDataSource=u,t.TableVirtualScrollModule=f,t._tableVirtualScrollDirectiveStrategyFactory=l,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=ng-table-virtual-scroll.umd.min.js.map

@@ -5,3 +5,3 @@ /**

*/
import { ContentChild, Directive, forwardRef, Input } from '@angular/core';
import { ContentChild, Directive, forwardRef, Input, NgZone } from '@angular/core';
import { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';

@@ -26,3 +26,7 @@ import { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';

export class TableItemSizeDirective {
constructor() {
/**
* @param {?} zone
*/
constructor(zone) {
this.zone = zone;
this.alive = true;

@@ -76,3 +80,14 @@ // tslint:disable-next-line:no-input-rename

const dataSource = this.table.dataSource;
this.scrollStrategy.renderedRangeStream.subscribe(dataSource.renderedRangeStream);
this.scrollStrategy.renderedRangeStream.subscribe((/**
* @param {?} range
* @return {?}
*/
range => {
this.zone.run((/**
* @return {?}
*/
() => {
dataSource.renderedRangeStream.next(range);
}));
}));
dataSource.connect()

@@ -149,2 +164,6 @@ .pipe(map((/**

];
/** @nocollapse */
TableItemSizeDirective.ctorParameters = () => [
{ type: NgZone }
];
TableItemSizeDirective.propDecorators = {

@@ -172,3 +191,8 @@ rowHeight: [{ type: Input, args: ['tvsItemSize',] }],

TableItemSizeDirective.prototype.scrollStrategy;
/**
* @type {?}
* @private
*/
TableItemSizeDirective.prototype.zone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"ng://ng-table-virtual-scroll/","sources":["lib/table-item-size.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ContentChild, Directive, forwardRef, Input, OnChanges, OnDestroy } from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  bufferMultiplier: 0.7\n};\n\n@Directive({\n  selector: 'cdk-virtual-scroll-viewport[tvsItemSize]',\n  providers: [{\n    provide: VIRTUAL_SCROLL_STRATEGY,\n    useFactory: _tableVirtualScrollDirectiveStrategyFactory,\n    deps: [forwardRef(() => TableItemSizeDirective)]\n  }]\n})\nexport class TableItemSizeDirective implements OnChanges, AfterViewInit, OnDestroy {\n  private alive = true;\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight = defaults.rowHeight;\n\n  @Input()\n  headerHeight = defaults.headerHeight;\n\n  @Input()\n  bufferMultiplier = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, {static: true})\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  ngOnDestroy() {\n    this.alive = false;\n  }\n\n  private isAlive() {\n    return () => this.alive;\n  }\n\n  private isStickyEnabled(): boolean {\n    return !!this.scrollStrategy.viewport && (this.table['_headerRowDefs'] as CdkHeaderRowDef[])\n      .map(def => def.sticky)\n      .reduce((prevState, state) => prevState && state, true);\n  }\n\n  ngAfterViewInit() {\n    if (this.table.dataSource instanceof TableVirtualScrollDataSource) {\n      const dataSource = this.table.dataSource;\n      this.scrollStrategy.renderedRangeStream.subscribe(dataSource.renderedRangeStream);\n      dataSource.connect()\n        .pipe(\n          map(() => dataSource.data.length),\n          distinctUntilChanged(),\n          takeWhile(this.isAlive())\n        )\n        .subscribe((length) => {\n          this.scrollStrategy.dataLength = length;\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        takeWhile(this.isAlive())\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: +this.headerHeight || defaults.headerHeight,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset) {\n    const offsetString = `-${offset}px`;\n\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll('th')\n      .forEach(el => {\n        el.style.top = offsetString;\n      });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"ng://ng-table-virtual-scroll/","sources":["lib/table-item-size.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ContentChild, Directive, forwardRef, Input, NgZone, OnChanges, OnDestroy } from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  bufferMultiplier: 0.7\n};\n\n@Directive({\n  selector: 'cdk-virtual-scroll-viewport[tvsItemSize]',\n  providers: [{\n    provide: VIRTUAL_SCROLL_STRATEGY,\n    useFactory: _tableVirtualScrollDirectiveStrategyFactory,\n    deps: [forwardRef(() => TableItemSizeDirective)]\n  }]\n})\nexport class TableItemSizeDirective implements OnChanges, AfterViewInit, OnDestroy {\n  private alive = true;\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight = defaults.rowHeight;\n\n  @Input()\n  headerHeight = defaults.headerHeight;\n\n  @Input()\n  bufferMultiplier = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, {static: true})\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  constructor(private zone: NgZone) {\n  }\n\n  ngOnDestroy() {\n    this.alive = false;\n  }\n\n  private isAlive() {\n    return () => this.alive;\n  }\n\n  private isStickyEnabled(): boolean {\n    return !!this.scrollStrategy.viewport && (this.table['_headerRowDefs'] as CdkHeaderRowDef[])\n      .map(def => def.sticky)\n      .reduce((prevState, state) => prevState && state, true);\n  }\n\n  ngAfterViewInit() {\n    if (this.table.dataSource instanceof TableVirtualScrollDataSource) {\n      const dataSource = this.table.dataSource;\n      this.scrollStrategy.renderedRangeStream.subscribe(range => {\n        this.zone.run(() => {\n          dataSource.renderedRangeStream.next(range);\n        });\n      });\n      dataSource.connect()\n        .pipe(\n          map(() => dataSource.data.length),\n          distinctUntilChanged(),\n          takeWhile(this.isAlive())\n        )\n        .subscribe((length) => {\n          this.scrollStrategy.dataLength = length;\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        takeWhile(this.isAlive())\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: +this.headerHeight || defaults.headerHeight,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset) {\n    const offsetString = `-${offset}px`;\n\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll('th')\n      .forEach(el => {\n        el.style.top = offsetString;\n      });\n  }\n}\n"]}

@@ -5,3 +5,3 @@ /**

*/
import { ContentChild, Directive, forwardRef, Input } from '@angular/core';
import { ContentChild, Directive, forwardRef, Input, NgZone } from '@angular/core';
import { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';

@@ -26,3 +26,4 @@ import { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';

var TableItemSizeDirective = /** @class */ (function () {
function TableItemSizeDirective() {
function TableItemSizeDirective(zone) {
this.zone = zone;
this.alive = true;

@@ -92,3 +93,14 @@ // tslint:disable-next-line:no-input-rename

var dataSource_1 = this.table.dataSource;
this.scrollStrategy.renderedRangeStream.subscribe(dataSource_1.renderedRangeStream);
this.scrollStrategy.renderedRangeStream.subscribe((/**
* @param {?} range
* @return {?}
*/
function (range) {
_this.zone.run((/**
* @return {?}
*/
function () {
dataSource_1.renderedRangeStream.next(range);
}));
}));
dataSource_1.connect()

@@ -171,2 +183,6 @@ .pipe(map((/**

];
/** @nocollapse */
TableItemSizeDirective.ctorParameters = function () { return [
{ type: NgZone }
]; };
TableItemSizeDirective.propDecorators = {

@@ -197,3 +213,8 @@ rowHeight: [{ type: Input, args: ['tvsItemSize',] }],

TableItemSizeDirective.prototype.scrollStrategy;
/**
* @type {?}
* @private
*/
TableItemSizeDirective.prototype.zone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"ng://ng-table-virtual-scroll/","sources":["lib/table-item-size.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAiB,YAAY,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAwB,MAAM,eAAe,CAAC;AAChH,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC9E,OAAO,EAAE,4BAA4B,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,mCAAmC,EAAE,MAAM,4CAA4C,CAAC;;;;;AAGjG,MAAM,UAAU,2CAA2C,CAAC,QAAgC;IAC1F,OAAO,QAAQ,CAAC,cAAc,CAAC;AACjC,CAAC;;IAEK,QAAQ,GAAG;IACf,SAAS,EAAE,EAAE;IACb,YAAY,EAAE,EAAE;IAChB,gBAAgB,EAAE,GAAG;CACtB;AAED;IAAA;QASU,UAAK,GAAG,IAAI,CAAC;;QAIrB,cAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;QAG/B,iBAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;QAGrC,qBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;QAK7C,mBAAc,GAAG,IAAI,mCAAmC,EAAE,CAAC;IA6D7D,CAAC;;;;IA3DC,4CAAW;;;IAAX;QACE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;;;;;IAEO,wCAAO;;;;IAAf;QAAA,iBAEC;QADC;;;QAAO,cAAM,OAAA,KAAI,CAAC,KAAK,EAAV,CAAU,EAAC;IAC1B,CAAC;;;;;IAEO,gDAAe;;;;IAAvB;QACE,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,IAAI,CAAC,mBAAA,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAqB,CAAC;aACzF,GAAG;;;;QAAC,UAAA,GAAG,IAAI,OAAA,GAAG,CAAC,MAAM,EAAV,CAAU,EAAC;aACtB,MAAM;;;;;QAAC,UAAC,SAAS,EAAE,KAAK,IAAK,OAAA,SAAS,IAAI,KAAK,EAAlB,CAAkB,GAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;;;;IAED,gDAAe;;;IAAf;QAAA,iBAyBC;QAxBC,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,YAAY,4BAA4B,EAAE;;gBAC3D,YAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU;YACxC,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,SAAS,CAAC,YAAU,CAAC,mBAAmB,CAAC,CAAC;YAClF,YAAU,CAAC,OAAO,EAAE;iBACjB,IAAI,CACH,GAAG;;;YAAC,cAAM,OAAA,YAAU,CAAC,IAAI,CAAC,MAAM,EAAtB,CAAsB,EAAC,EACjC,oBAAoB,EAAE,EACtB,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAC1B;iBACA,SAAS;;;;YAAC,UAAC,MAAM;gBAChB,KAAI,CAAC,cAAc,CAAC,UAAU,GAAG,MAAM,CAAC;YAC1C,CAAC,EAAC,CAAC;SACN;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,2FAA2F,CAAC,CAAC;SAC9G;QAED,IAAI,CAAC,cAAc,CAAC,YAAY;aAC7B,IAAI,CACH,MAAM;;;QAAC,cAAM,OAAA,KAAI,CAAC,eAAe,EAAE,EAAtB,CAAsB,EAAC,EACpC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAC1B;aACA,SAAS;;;;QAAC,UAAC,YAAY;YACtB,KAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAC/B,CAAC,EAAC,CAAC;IACP,CAAC;;;;IAED,4CAAW;;;IAAX;;YACQ,MAAM,GAAG;YACb,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,SAAS;YAChD,YAAY,EAAE,CAAC,IAAI,CAAC,YAAY,IAAI,QAAQ,CAAC,YAAY;YACzD,gBAAgB,EAAE,CAAC,IAAI,CAAC,gBAAgB,IAAI,QAAQ,CAAC,gBAAgB;SACtE;QACD,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;;;;;IAGD,0CAAS;;;;IAAT,UAAU,MAAM;;YACR,YAAY,GAAG,MAAI,MAAM,OAAI;QAEnC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,CAAC;aACzE,OAAO;;;;QAAC,UAAA,EAAE;YACT,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,YAAY,CAAC;QAC9B,CAAC,EAAC,CAAC;IACP,CAAC;;gBApFF,SAAS,SAAC;oBACT,QAAQ,EAAE,0CAA0C;oBACpD,SAAS,EAAE,CAAC;4BACV,OAAO,EAAE,uBAAuB;4BAChC,UAAU,EAAE,2CAA2C;4BACvD,IAAI,EAAE,CAAC,UAAU;;;gCAAC,cAAM,OAAA,sBAAsB,EAAtB,CAAsB,EAAC,CAAC;yBACjD,CAAC;iBACH;;;4BAKE,KAAK,SAAC,aAAa;+BAGnB,KAAK;mCAGL,KAAK;wBAGL,YAAY,SAAC,QAAQ,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;;IAgExC,6BAAC;CAAA,AArFD,IAqFC;SA7EY,sBAAsB;;;;;;IACjC,uCAAqB;;IAGrB,2CAC+B;;IAE/B,8CACqC;;IAErC,kDAC6C;;IAE7C,uCACqB;;IAErB,gDAA2D","sourcesContent":["import { AfterViewInit, ContentChild, Directive, forwardRef, Input, OnChanges, OnDestroy } from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  bufferMultiplier: 0.7\n};\n\n@Directive({\n  selector: 'cdk-virtual-scroll-viewport[tvsItemSize]',\n  providers: [{\n    provide: VIRTUAL_SCROLL_STRATEGY,\n    useFactory: _tableVirtualScrollDirectiveStrategyFactory,\n    deps: [forwardRef(() => TableItemSizeDirective)]\n  }]\n})\nexport class TableItemSizeDirective implements OnChanges, AfterViewInit, OnDestroy {\n  private alive = true;\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight = defaults.rowHeight;\n\n  @Input()\n  headerHeight = defaults.headerHeight;\n\n  @Input()\n  bufferMultiplier = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, {static: true})\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  ngOnDestroy() {\n    this.alive = false;\n  }\n\n  private isAlive() {\n    return () => this.alive;\n  }\n\n  private isStickyEnabled(): boolean {\n    return !!this.scrollStrategy.viewport && (this.table['_headerRowDefs'] as CdkHeaderRowDef[])\n      .map(def => def.sticky)\n      .reduce((prevState, state) => prevState && state, true);\n  }\n\n  ngAfterViewInit() {\n    if (this.table.dataSource instanceof TableVirtualScrollDataSource) {\n      const dataSource = this.table.dataSource;\n      this.scrollStrategy.renderedRangeStream.subscribe(dataSource.renderedRangeStream);\n      dataSource.connect()\n        .pipe(\n          map(() => dataSource.data.length),\n          distinctUntilChanged(),\n          takeWhile(this.isAlive())\n        )\n        .subscribe((length) => {\n          this.scrollStrategy.dataLength = length;\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        takeWhile(this.isAlive())\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: +this.headerHeight || defaults.headerHeight,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset) {\n    const offsetString = `-${offset}px`;\n\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll('th')\n      .forEach(el => {\n        el.style.top = offsetString;\n      });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"ng://ng-table-virtual-scroll/","sources":["lib/table-item-size.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ContentChild, Directive, forwardRef, Input, NgZone, OnChanges, OnDestroy } from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { distinctUntilChanged, filter, map, takeWhile } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  bufferMultiplier: 0.7\n};\n\n@Directive({\n  selector: 'cdk-virtual-scroll-viewport[tvsItemSize]',\n  providers: [{\n    provide: VIRTUAL_SCROLL_STRATEGY,\n    useFactory: _tableVirtualScrollDirectiveStrategyFactory,\n    deps: [forwardRef(() => TableItemSizeDirective)]\n  }]\n})\nexport class TableItemSizeDirective implements OnChanges, AfterViewInit, OnDestroy {\n  private alive = true;\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight = defaults.rowHeight;\n\n  @Input()\n  headerHeight = defaults.headerHeight;\n\n  @Input()\n  bufferMultiplier = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, {static: true})\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  constructor(private zone: NgZone) {\n  }\n\n  ngOnDestroy() {\n    this.alive = false;\n  }\n\n  private isAlive() {\n    return () => this.alive;\n  }\n\n  private isStickyEnabled(): boolean {\n    return !!this.scrollStrategy.viewport && (this.table['_headerRowDefs'] as CdkHeaderRowDef[])\n      .map(def => def.sticky)\n      .reduce((prevState, state) => prevState && state, true);\n  }\n\n  ngAfterViewInit() {\n    if (this.table.dataSource instanceof TableVirtualScrollDataSource) {\n      const dataSource = this.table.dataSource;\n      this.scrollStrategy.renderedRangeStream.subscribe(range => {\n        this.zone.run(() => {\n          dataSource.renderedRangeStream.next(range);\n        });\n      });\n      dataSource.connect()\n        .pipe(\n          map(() => dataSource.data.length),\n          distinctUntilChanged(),\n          takeWhile(this.isAlive())\n        )\n        .subscribe((length) => {\n          this.scrollStrategy.dataLength = length;\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        takeWhile(this.isAlive())\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: +this.headerHeight || defaults.headerHeight,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset) {\n    const offsetString = `-${offset}px`;\n\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll('th')\n      .forEach(el => {\n        el.style.top = offsetString;\n      });\n  }\n}\n"]}

@@ -1,2 +0,2 @@

import { Injectable, Directive, forwardRef, Input, ContentChild, NgModule } from '@angular/core';
import { Injectable, Directive, forwardRef, NgZone, Input, ContentChild, NgModule } from '@angular/core';
import { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';

@@ -268,3 +268,7 @@ import { map, distinctUntilChanged, takeWhile, filter } from 'rxjs/operators';

class TableItemSizeDirective {
constructor() {
/**
* @param {?} zone
*/
constructor(zone) {
this.zone = zone;
this.alive = true;

@@ -318,3 +322,14 @@ // tslint:disable-next-line:no-input-rename

const dataSource = this.table.dataSource;
this.scrollStrategy.renderedRangeStream.subscribe(dataSource.renderedRangeStream);
this.scrollStrategy.renderedRangeStream.subscribe((/**
* @param {?} range
* @return {?}
*/
range => {
this.zone.run((/**
* @return {?}
*/
() => {
dataSource.renderedRangeStream.next(range);
}));
}));
dataSource.connect()

@@ -391,2 +406,6 @@ .pipe(map((/**

];
/** @nocollapse */
TableItemSizeDirective.ctorParameters = () => [
{ type: NgZone }
];
TableItemSizeDirective.propDecorators = {

@@ -414,2 +433,7 @@ rowHeight: [{ type: Input, args: ['tvsItemSize',] }],

TableItemSizeDirective.prototype.scrollStrategy;
/**
* @type {?}
* @private
*/
TableItemSizeDirective.prototype.zone;
}

@@ -416,0 +440,0 @@

@@ -1,2 +0,2 @@

import { Injectable, Directive, forwardRef, Input, ContentChild, NgModule } from '@angular/core';
import { Injectable, Directive, forwardRef, NgZone, Input, ContentChild, NgModule } from '@angular/core';
import { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';

@@ -335,3 +335,4 @@ import { map, distinctUntilChanged, takeWhile, filter } from 'rxjs/operators';

var TableItemSizeDirective = /** @class */ (function () {
function TableItemSizeDirective() {
function TableItemSizeDirective(zone) {
this.zone = zone;
this.alive = true;

@@ -401,3 +402,14 @@ // tslint:disable-next-line:no-input-rename

var dataSource_1 = this.table.dataSource;
this.scrollStrategy.renderedRangeStream.subscribe(dataSource_1.renderedRangeStream);
this.scrollStrategy.renderedRangeStream.subscribe((/**
* @param {?} range
* @return {?}
*/
function (range) {
_this.zone.run((/**
* @return {?}
*/
function () {
dataSource_1.renderedRangeStream.next(range);
}));
}));
dataSource_1.connect()

@@ -480,2 +492,6 @@ .pipe(map((/**

];
/** @nocollapse */
TableItemSizeDirective.ctorParameters = function () { return [
{ type: NgZone }
]; };
TableItemSizeDirective.propDecorators = {

@@ -505,2 +521,7 @@ rowHeight: [{ type: Input, args: ['tvsItemSize',] }],

TableItemSizeDirective.prototype.scrollStrategy;
/**
* @type {?}
* @private
*/
TableItemSizeDirective.prototype.zone;
}

@@ -507,0 +528,0 @@

@@ -1,2 +0,2 @@

import { AfterViewInit, OnChanges, OnDestroy } from '@angular/core';
import { AfterViewInit, NgZone, OnChanges, OnDestroy } from '@angular/core';
import { MatTable } from '@angular/material';

@@ -6,2 +6,3 @@ import { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';

export declare class TableItemSizeDirective implements OnChanges, AfterViewInit, OnDestroy {
private zone;
private alive;

@@ -13,2 +14,3 @@ rowHeight: number;

scrollStrategy: FixedSizeTableVirtualScrollStrategy;
constructor(zone: NgZone);
ngOnDestroy(): void;

@@ -15,0 +17,0 @@ private isAlive;

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"TableVirtualScrollModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"TableItemSizeDirective"}],"imports":[],"exports":[{"__symbolic":"reference","name":"TableItemSizeDirective"}]}]}],"members":{}},"_tableVirtualScrollDirectiveStrategyFactory":{"__symbolic":"function","parameters":["tableDir"],"value":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"tableDir"},"member":"scrollStrategy"}},"TableItemSizeDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":18,"character":1},"arguments":[{"selector":"cdk-virtual-scroll-viewport[tvsItemSize]","providers":[{"provide":{"__symbolic":"reference","module":"@angular/cdk/scrolling","name":"VIRTUAL_SCROLL_STRATEGY","line":21,"character":13},"useFactory":{"__symbolic":"reference","name":"_tableVirtualScrollDirectiveStrategyFactory"},"deps":[{"__symbolic":"reference","name":"TableItemSizeDirective"}]}]}]}],"members":{"rowHeight":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3},"arguments":["tvsItemSize"]}]}],"headerHeight":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"bufferMultiplier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"table":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":39,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatTable","line":39,"character":16},{"static":true}]}]}],"ngOnDestroy":[{"__symbolic":"method"}],"isAlive":[{"__symbolic":"method"}],"isStickyEnabled":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"setSticky":[{"__symbolic":"method"}]}},"FixedSizeTableVirtualScrollStrategy":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1}}],"members":{"attach":[{"__symbolic":"method"}],"detach":[{"__symbolic":"method"}],"onContentScrolled":[{"__symbolic":"method"}],"onDataLengthChanged":[{"__symbolic":"method"}],"onContentRendered":[{"__symbolic":"method"}],"onRenderedOffsetChanged":[{"__symbolic":"method"}],"scrollToIndex":[{"__symbolic":"method"}],"setConfig":[{"__symbolic":"method"}],"updateContent":[{"__symbolic":"method"}]}},"TableVirtualScrollDataSource":{"__symbolic":"class","arity":1,"extends":{"__symbolic":"reference","module":"@angular/material","name":"MatTableDataSource","line":5,"character":53},"members":{"_updateChangeSubscription":[{"__symbolic":"method"}],"initRenderedRangeStream":[{"__symbolic":"method"}]}}},"origins":{"TableVirtualScrollModule":"./lib/table-virtual-scroll.module","_tableVirtualScrollDirectiveStrategyFactory":"./lib/table-item-size.directive","TableItemSizeDirective":"./lib/table-item-size.directive","FixedSizeTableVirtualScrollStrategy":"./lib/fixed-size-table-virtual-scroll-strategy","TableVirtualScrollDataSource":"./lib/table-data-source"},"importAs":"ng-table-virtual-scroll"}
{"__symbolic":"module","version":4,"metadata":{"TableVirtualScrollModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"TableItemSizeDirective"}],"imports":[],"exports":[{"__symbolic":"reference","name":"TableItemSizeDirective"}]}]}],"members":{}},"_tableVirtualScrollDirectiveStrategyFactory":{"__symbolic":"function","parameters":["tableDir"],"value":{"__symbolic":"select","expression":{"__symbolic":"reference","name":"tableDir"},"member":"scrollStrategy"}},"TableItemSizeDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":18,"character":1},"arguments":[{"selector":"cdk-virtual-scroll-viewport[tvsItemSize]","providers":[{"provide":{"__symbolic":"reference","module":"@angular/cdk/scrolling","name":"VIRTUAL_SCROLL_STRATEGY","line":21,"character":13},"useFactory":{"__symbolic":"reference","name":"_tableVirtualScrollDirectiveStrategyFactory"},"deps":[{"__symbolic":"reference","name":"TableItemSizeDirective"}]}]}]}],"members":{"rowHeight":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3},"arguments":["tvsItemSize"]}]}],"headerHeight":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"bufferMultiplier":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"table":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":39,"character":3},"arguments":[{"__symbolic":"reference","module":"@angular/material","name":"MatTable","line":39,"character":16},{"static":true}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":44,"character":28}]}],"ngOnDestroy":[{"__symbolic":"method"}],"isAlive":[{"__symbolic":"method"}],"isStickyEnabled":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"setSticky":[{"__symbolic":"method"}]}},"FixedSizeTableVirtualScrollStrategy":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":6,"character":1}}],"members":{"attach":[{"__symbolic":"method"}],"detach":[{"__symbolic":"method"}],"onContentScrolled":[{"__symbolic":"method"}],"onDataLengthChanged":[{"__symbolic":"method"}],"onContentRendered":[{"__symbolic":"method"}],"onRenderedOffsetChanged":[{"__symbolic":"method"}],"scrollToIndex":[{"__symbolic":"method"}],"setConfig":[{"__symbolic":"method"}],"updateContent":[{"__symbolic":"method"}]}},"TableVirtualScrollDataSource":{"__symbolic":"class","arity":1,"extends":{"__symbolic":"reference","module":"@angular/material","name":"MatTableDataSource","line":5,"character":53},"members":{"_updateChangeSubscription":[{"__symbolic":"method"}],"initRenderedRangeStream":[{"__symbolic":"method"}]}}},"origins":{"TableVirtualScrollModule":"./lib/table-virtual-scroll.module","_tableVirtualScrollDirectiveStrategyFactory":"./lib/table-item-size.directive","TableItemSizeDirective":"./lib/table-item-size.directive","FixedSizeTableVirtualScrollStrategy":"./lib/fixed-size-table-virtual-scroll-strategy","TableVirtualScrollDataSource":"./lib/table-data-source"},"importAs":"ng-table-virtual-scroll"}
{
"name": "ng-table-virtual-scroll",
"version": "1.2.0",
"version": "1.2.1",
"description": "Virtual scroll for for Angular Material Table",

@@ -5,0 +5,0 @@ "homepage": "https://github.com/diprokon/ng-table-virtual-scroll",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc