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.3.7 to 1.3.8

4

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

@@ -487,4 +487,4 @@ (function (global, factory) {

}
var stickyHeaderSelector = '.mat-header-row .mat-table-sticky';
var stickyFooterSelector = '.mat-footer-row .mat-table-sticky';
var stickyHeaderSelector = '.mat-header-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
var stickyFooterSelector = '.mat-footer-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
var defaults = {

@@ -491,0 +491,0 @@ rowHeight: 48,

@@ -15,3 +15,3 @@ !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/table")):"function"==typeof define&&define.amd?define("ng-table-virtual-scroll",["exports","@angular/core","@angular/cdk/scrolling","rxjs/operators","rxjs","@angular/material/table"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["ng-table-virtual-scroll"]={},t.ng.core,t.ng.cdk.scrolling,t.rxjs.operators,t.rxjs,t.ng.material.table)}(this,(function(t,e,r,i,n,o){"use strict";

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */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)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r])})(t,e)};Object.create;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}Object.create;var h=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");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,e=this;this.initStreams();var r=this._sort,o=this._paginator,a=this._internalPageChanges,h=this._filter,c=this._renderData,l=r?n.merge(r.sortChange,r.initialized):n.of(null),u=o?n.merge(o.page,a,o.initialized):n.of(null),p=this._data,d=n.combineLatest([p,h]).pipe(i.map((function(t){var r=s(t,1)[0];return e._filterData(r)}))),f=n.combineLatest([d,l]).pipe(i.map((function(t){var r=s(t,1)[0];return e._orderData(r)}))),g=n.combineLatest([f,u]).pipe(i.map((function(t){var r=s(t,1)[0];return e._pageData(r)})));null===(t=this._renderChangesSubscription)||void 0===t||t.unsubscribe(),this._renderChangesSubscription=new n.Subscription,this._renderChangesSubscription.add(g.subscribe((function(t){return e.dataToRender$.next(t)}))),this._renderChangesSubscription.add(this.dataOfRange$.subscribe((function(t){return c.next(t)})))},e.prototype.initStreams=function(){this.streamsReady||(this.dataToRender$=new n.ReplaySubject(1),this.dataOfRange$=new n.ReplaySubject(1),this.streamsReady=!0)},e}(o.MatTableDataSource),c=function(){function t(){this.indexChange=new n.Subject,this.stickyChange=new n.Subject,this.renderedRangeStream=new n.BehaviorSubject({start:0,end:0}),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:!1,configurable:!0}),t.prototype.attach=function(t){this.viewport=t,this.viewport.renderedRangeStream.subscribe(this.renderedRangeStream),this.onDataLengthChanged()},t.prototype.detach=function(){this.indexChange.complete(),this.stickyChange.complete(),this.renderedRangeStream.complete()},t.prototype.onContentScrolled=function(){this.updateContent()},t.prototype.onDataLengthChanged=function(){this.viewport&&this.viewport.setTotalContentSize(this.dataLength*this.rowHeight+this.headerHeight+this.footerHeight),this.updateContent()},t.prototype.onContentRendered=function(){},t.prototype.onRenderedOffsetChanged=function(){},t.prototype.scrollToIndex=function(t,e){this.viewport&&this.rowHeight&&this.viewport.scrollToOffset((t-1)*this.rowHeight+this.headerHeight,e)},t.prototype.setConfig=function(t){var e=t.rowHeight,r=t.headerHeight,i=t.footerHeight,n=t.bufferMultiplier;this.rowHeight===e&&this.headerHeight===r&&this.footerHeight===i&&this.bufferMultiplier===n||(this.rowHeight=e,this.headerHeight=r,this.footerHeight=i,this.bufferMultiplier=n,this.onDataLengthChanged())},t.prototype.updateContent=function(){if(this.viewport&&this.rowHeight){var t=this.viewport.getOffsetToRenderedContentStart(),e=t/this.rowHeight,r=Math.ceil(this.viewport.getViewportSize()/this.rowHeight),i=Math.ceil(r*this.bufferMultiplier),n=e+r+2*i,o=t+i*this.rowHeight,a=this.viewport.measureScrollOffset(),s=(a-o)/this.rowHeight,h=a/this.rowHeight;this.indexChange.next(h);if(Math.abs(s)<1)return this.viewport.setRenderedContentOffset(t),void this.viewport.setRenderedRange({start:e,end:n});if(0===t&&s<0)return this.viewport.setRenderedContentOffset(t),void this.viewport.setRenderedRange({start:e,end:n});var c=Math.sign(s)*Math.floor(Math.abs(s)),l=Math.max(0,t+c*this.rowHeight);this.viewport.setRenderedContentOffset(l);var u=Math.max(0,e+c),p=u+r+2*i;this.viewport.setRenderedRange({start:u,end:p}),this.stickyChange.next(l)}},t}();function l(t){return t.scrollStrategy}c.decorators=[{type:e.Injectable}];var u=".mat-header-row .mat-table-sticky",p=48,d=56,f=!0,g=48,y=!1,b=.7,S=function(){function t(t){this.zone=t,this.destroyed$=new n.Subject,this.rowHeight=p,this.headerEnabled=f,this.headerHeight=d,this.footerEnabled=y,this.footerHeight=g,this.bufferMultiplier=b,this.scrollStrategy=new c,this.dataSourceChanges=new n.Subject}return t.prototype.ngOnDestroy=function(){this.destroyed$.next(),this.destroyed$.complete(),this.dataSourceChanges.complete()},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.ngAfterContentInit=function(){var t=this,e=this.table._switchDataSource;this.table._switchDataSource=function(r){e.call(t.table,r),t.connectDataSource(r)},this.connectDataSource(this.table.dataSource),this.scrollStrategy.stickyChange.pipe(i.filter((function(){return t.isStickyEnabled()})),i.tap((function(){t.stickyPositions||t.initStickyPositions()})),i.takeUntil(this.destroyed$)).subscribe((function(e){t.setSticky(e)}))},t.prototype.connectDataSource=function(t){var e=this;if(this.dataSourceChanges.next(),!(t instanceof h))throw new Error("[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]");t.dataToRender$.pipe(i.distinctUntilChanged(),i.takeUntil(this.dataSourceChanges),i.takeUntil(this.destroyed$),i.tap((function(t){return e.scrollStrategy.dataLength=t.length})),i.switchMap((function(t){return e.scrollStrategy.renderedRangeStream.pipe(i.map((function(e){var r=e.start,i=e.end;return"number"!=typeof r||"number"!=typeof i?t:t.slice(r,i)})))}))).subscribe((function(r){e.zone.run((function(){t.dataOfRange$.next(r)}))}))},t.prototype.ngOnChanges=function(){var t={rowHeight:+this.rowHeight||p,headerHeight:this.headerEnabled?+this.headerHeight||d:0,footerHeight:this.footerEnabled?+this.footerHeight||g:0,bufferMultiplier:+this.bufferMultiplier||b};this.scrollStrategy.setConfig(t)},t.prototype.setSticky=function(t){var e=this;this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(u).forEach((function(r){var i=r.parentElement,n=0;e.stickyPositions.has(i)&&(n=e.stickyPositions.get(i)),r.style.top=n-t+"px"})),this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(".mat-footer-row .mat-table-sticky").forEach((function(r){var i=r.parentElement,n=0;e.stickyPositions.has(i)&&(n=e.stickyPositions.get(i)),r.style.bottom=-n+t+"px"}))},t.prototype.initStickyPositions=function(){var t=this;this.stickyPositions=new Map,this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(u).forEach((function(e){var r=e.parentElement;t.stickyPositions.has(r)||t.stickyPositions.set(r,r.offsetTop)}))},t}();S.decorators=[{type:e.Directive,args:[{selector:"cdk-virtual-scroll-viewport[tvsItemSize]",providers:[{provide:r.VIRTUAL_SCROLL_STRATEGY,useFactory:l,deps:[e.forwardRef((function(){return S}))]}]}]}],S.ctorParameters=function(){return[{type:e.NgZone}]},S.propDecorators={rowHeight:[{type:e.Input,args:["tvsItemSize"]}],headerEnabled:[{type:e.Input}],headerHeight:[{type:e.Input}],footerEnabled:[{type:e.Input}],footerHeight:[{type:e.Input}],bufferMultiplier:[{type:e.Input}],table:[{type:e.ContentChild,args:[o.MatTable,{static:!1}]}]};var v=function(){};v.decorators=[{type:e.NgModule,args:[{declarations:[S],imports:[],exports:[S]}]}],t.FixedSizeTableVirtualScrollStrategy=c,t.TableItemSizeDirective=S,t.TableVirtualScrollDataSource=h,t.TableVirtualScrollModule=v,t._tableVirtualScrollDirectiveStrategyFactory=l,Object.defineProperty(t,"__esModule",{value:!0})}));
***************************************************************************** */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)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r])})(t,e)};Object.create;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}Object.create;var h=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");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,e=this;this.initStreams();var r=this._sort,o=this._paginator,a=this._internalPageChanges,h=this._filter,c=this._renderData,l=r?n.merge(r.sortChange,r.initialized):n.of(null),u=o?n.merge(o.page,a,o.initialized):n.of(null),p=this._data,d=n.combineLatest([p,h]).pipe(i.map((function(t){var r=s(t,1)[0];return e._filterData(r)}))),f=n.combineLatest([d,l]).pipe(i.map((function(t){var r=s(t,1)[0];return e._orderData(r)}))),g=n.combineLatest([f,u]).pipe(i.map((function(t){var r=s(t,1)[0];return e._pageData(r)})));null===(t=this._renderChangesSubscription)||void 0===t||t.unsubscribe(),this._renderChangesSubscription=new n.Subscription,this._renderChangesSubscription.add(g.subscribe((function(t){return e.dataToRender$.next(t)}))),this._renderChangesSubscription.add(this.dataOfRange$.subscribe((function(t){return c.next(t)})))},e.prototype.initStreams=function(){this.streamsReady||(this.dataToRender$=new n.ReplaySubject(1),this.dataOfRange$=new n.ReplaySubject(1),this.streamsReady=!0)},e}(o.MatTableDataSource),c=function(){function t(){this.indexChange=new n.Subject,this.stickyChange=new n.Subject,this.renderedRangeStream=new n.BehaviorSubject({start:0,end:0}),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:!1,configurable:!0}),t.prototype.attach=function(t){this.viewport=t,this.viewport.renderedRangeStream.subscribe(this.renderedRangeStream),this.onDataLengthChanged()},t.prototype.detach=function(){this.indexChange.complete(),this.stickyChange.complete(),this.renderedRangeStream.complete()},t.prototype.onContentScrolled=function(){this.updateContent()},t.prototype.onDataLengthChanged=function(){this.viewport&&this.viewport.setTotalContentSize(this.dataLength*this.rowHeight+this.headerHeight+this.footerHeight),this.updateContent()},t.prototype.onContentRendered=function(){},t.prototype.onRenderedOffsetChanged=function(){},t.prototype.scrollToIndex=function(t,e){this.viewport&&this.rowHeight&&this.viewport.scrollToOffset((t-1)*this.rowHeight+this.headerHeight,e)},t.prototype.setConfig=function(t){var e=t.rowHeight,r=t.headerHeight,i=t.footerHeight,n=t.bufferMultiplier;this.rowHeight===e&&this.headerHeight===r&&this.footerHeight===i&&this.bufferMultiplier===n||(this.rowHeight=e,this.headerHeight=r,this.footerHeight=i,this.bufferMultiplier=n,this.onDataLengthChanged())},t.prototype.updateContent=function(){if(this.viewport&&this.rowHeight){var t=this.viewport.getOffsetToRenderedContentStart(),e=t/this.rowHeight,r=Math.ceil(this.viewport.getViewportSize()/this.rowHeight),i=Math.ceil(r*this.bufferMultiplier),n=e+r+2*i,o=t+i*this.rowHeight,a=this.viewport.measureScrollOffset(),s=(a-o)/this.rowHeight,h=a/this.rowHeight;this.indexChange.next(h);if(Math.abs(s)<1)return this.viewport.setRenderedContentOffset(t),void this.viewport.setRenderedRange({start:e,end:n});if(0===t&&s<0)return this.viewport.setRenderedContentOffset(t),void this.viewport.setRenderedRange({start:e,end:n});var c=Math.sign(s)*Math.floor(Math.abs(s)),l=Math.max(0,t+c*this.rowHeight);this.viewport.setRenderedContentOffset(l);var u=Math.max(0,e+c),p=u+r+2*i;this.viewport.setRenderedRange({start:u,end:p}),this.stickyChange.next(l)}},t}();function l(t){return t.scrollStrategy}c.decorators=[{type:e.Injectable}];var u=".mat-header-row .mat-table-sticky, .mat-header-row.mat-table-sticky",p=48,d=56,f=!0,g=48,y=!1,b=.7,S=function(){function t(t){this.zone=t,this.destroyed$=new n.Subject,this.rowHeight=p,this.headerEnabled=f,this.headerHeight=d,this.footerEnabled=y,this.footerHeight=g,this.bufferMultiplier=b,this.scrollStrategy=new c,this.dataSourceChanges=new n.Subject}return t.prototype.ngOnDestroy=function(){this.destroyed$.next(),this.destroyed$.complete(),this.dataSourceChanges.complete()},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.ngAfterContentInit=function(){var t=this,e=this.table._switchDataSource;this.table._switchDataSource=function(r){e.call(t.table,r),t.connectDataSource(r)},this.connectDataSource(this.table.dataSource),this.scrollStrategy.stickyChange.pipe(i.filter((function(){return t.isStickyEnabled()})),i.tap((function(){t.stickyPositions||t.initStickyPositions()})),i.takeUntil(this.destroyed$)).subscribe((function(e){t.setSticky(e)}))},t.prototype.connectDataSource=function(t){var e=this;if(this.dataSourceChanges.next(),!(t instanceof h))throw new Error("[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]");t.dataToRender$.pipe(i.distinctUntilChanged(),i.takeUntil(this.dataSourceChanges),i.takeUntil(this.destroyed$),i.tap((function(t){return e.scrollStrategy.dataLength=t.length})),i.switchMap((function(t){return e.scrollStrategy.renderedRangeStream.pipe(i.map((function(e){var r=e.start,i=e.end;return"number"!=typeof r||"number"!=typeof i?t:t.slice(r,i)})))}))).subscribe((function(r){e.zone.run((function(){t.dataOfRange$.next(r)}))}))},t.prototype.ngOnChanges=function(){var t={rowHeight:+this.rowHeight||p,headerHeight:this.headerEnabled?+this.headerHeight||d:0,footerHeight:this.footerEnabled?+this.footerHeight||g:0,bufferMultiplier:+this.bufferMultiplier||b};this.scrollStrategy.setConfig(t)},t.prototype.setSticky=function(t){var e=this;this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(u).forEach((function(r){var i=r.parentElement,n=0;e.stickyPositions.has(i)&&(n=e.stickyPositions.get(i)),r.style.top=n-t+"px"})),this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(".mat-footer-row .mat-table-sticky, .mat-header-row.mat-table-sticky").forEach((function(r){var i=r.parentElement,n=0;e.stickyPositions.has(i)&&(n=e.stickyPositions.get(i)),r.style.bottom=-n+t+"px"}))},t.prototype.initStickyPositions=function(){var t=this;this.stickyPositions=new Map,this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(u).forEach((function(e){var r=e.parentElement;t.stickyPositions.has(r)||t.stickyPositions.set(r,r.offsetTop)}))},t}();S.decorators=[{type:e.Directive,args:[{selector:"cdk-virtual-scroll-viewport[tvsItemSize]",providers:[{provide:r.VIRTUAL_SCROLL_STRATEGY,useFactory:l,deps:[e.forwardRef((function(){return S}))]}]}]}],S.ctorParameters=function(){return[{type:e.NgZone}]},S.propDecorators={rowHeight:[{type:e.Input,args:["tvsItemSize"]}],headerEnabled:[{type:e.Input}],headerHeight:[{type:e.Input}],footerEnabled:[{type:e.Input}],footerHeight:[{type:e.Input}],bufferMultiplier:[{type:e.Input}],table:[{type:e.ContentChild,args:[o.MatTable,{static:!1}]}]};var v=function(){};v.decorators=[{type:e.NgModule,args:[{declarations:[S],imports:[],exports:[S]}]}],t.FixedSizeTableVirtualScrollStrategy=c,t.TableItemSizeDirective=S,t.TableVirtualScrollDataSource=h,t.TableVirtualScrollModule=v,t._tableVirtualScrollDirectiveStrategyFactory=l,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=ng-table-virtual-scroll.umd.min.js.map

@@ -11,4 +11,4 @@ import { ContentChild, Directive, forwardRef, Input, NgZone } from '@angular/core';

}
const stickyHeaderSelector = '.mat-header-row .mat-table-sticky';
const stickyFooterSelector = '.mat-footer-row .mat-table-sticky';
const stickyHeaderSelector = '.mat-header-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
const stickyFooterSelector = '.mat-footer-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
const defaults = {

@@ -146,2 +146,2 @@ rowHeight: 48,

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"","sources":["../../../../projects/ng-table-virtual-scroll/src/lib/table-item-size.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,YAAY,EACZ,SAAS,EACT,UAAU,EACV,KAAK,EACL,MAAM,EAGP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAa,oBAAoB,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACzG,OAAO,EAAE,4BAA4B,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,EAAE,mCAAmC,EAAE,MAAM,4CAA4C,CAAC;AAEjG,OAAO,EAAM,OAAO,EAAS,MAAM,MAAM,CAAC;AAE1C,MAAM,UAAU,2CAA2C,CAAC,QAAgC;IAC1F,OAAO,QAAQ,CAAC,cAAc,CAAC;AACjC,CAAC;AAED,MAAM,oBAAoB,GAAG,mCAAmC,CAAC;AACjE,MAAM,oBAAoB,GAAG,mCAAmC,CAAC;AAEjE,MAAM,QAAQ,GAAG;IACf,SAAS,EAAE,EAAE;IACb,YAAY,EAAE,EAAE;IAChB,aAAa,EAAE,IAAI;IACnB,YAAY,EAAE,EAAE;IAChB,aAAa,EAAE,KAAK;IACpB,gBAAgB,EAAE,GAAG;CACtB,CAAC;AAUF,MAAM,OAAO,sBAAsB;IA+BjC,YAAoB,IAAY;QAAZ,SAAI,GAAJ,IAAI,CAAQ;QA9BxB,eAAU,GAAG,IAAI,OAAO,EAAE,CAAC;QAEnC,2CAA2C;QAE3C,cAAS,GAAoB,QAAQ,CAAC,SAAS,CAAC;QAGhD,kBAAa,GAAY,QAAQ,CAAC,aAAa,CAAC;QAGhD,iBAAY,GAAoB,QAAQ,CAAC,YAAY,CAAC;QAGtD,kBAAa,GAAY,QAAQ,CAAC,aAAa,CAAC;QAGhD,iBAAY,GAAoB,QAAQ,CAAC,YAAY,CAAC;QAGtD,qBAAgB,GAAoB,QAAQ,CAAC,gBAAgB,CAAC;QAK9D,mBAAc,GAAG,IAAI,mCAAmC,EAAE,CAAC;QAE3D,sBAAiB,GAAG,IAAI,OAAO,EAAQ,CAAC;IAKxC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;QAC3B,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAEO,eAAe;QACrB,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,IAAK,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAuB;aACzF,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC;aACtB,MAAM,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE,CAAC,SAAS,IAAI,KAAK,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,kBAAkB;QAChB,MAAM,sBAAsB,GAAG,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;QAC/D,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,UAAe,EAAE,EAAE;YACpD,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;YACpD,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC,CAAC;QAEF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE9C,IAAI,CAAC,cAAc,CAAC,YAAY;aAC7B,IAAI,CACH,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;QACpC,uDAAuD;QACvD,4DAA4D;QAC5D,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;aAC5B;QACH,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,iBAAiB,CAAC,UAAe;QAC/B,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;QAC9B,IAAI,UAAU,YAAY,4BAA4B,EAAE;YACtD,UAAU;iBACP,aAAa;iBACb,IAAI,CACH,oBAAoB,EAAE,EACtB,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,EACjC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAC1B,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,EACzD,SAAS,CAAC,IAAI,CAAC,EAAE,CACf,IAAI,CAAC,cAAc;iBAChB,mBAAmB;iBACnB,IAAI,CACH,GAAG,CAAC,CAAC,EACE,KAAK,EACL,GAAG,EACJ,EAAE,EAAE,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CACjG,CACJ,CACF;iBACA,SAAS,CAAC,IAAI,CAAC,EAAE;gBAChB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;oBACjB,UAAU,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACrC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACN;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,2FAA2F,CAAC,CAAC;SAC9G;IACH,CAAC;IAED,WAAW;QACT,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,SAAS;YAChD,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAClF,YAAY,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAClF,gBAAgB,EAAE,CAAC,IAAI,CAAC,gBAAgB,IAAI,QAAQ,CAAC,gBAAgB;SACtE,CAAC;QACF,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAGD,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,oBAAoB,CAAC;aACzF,OAAO,CAAC,CAAC,EAAe,EAAE,EAAE;YAC3B,MAAM,MAAM,GAAG,EAAE,CAAC,aAAa,CAAC;YAChC,IAAI,UAAU,GAAG,CAAC,CAAC;YACnB,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBACpC,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;aAC/C;YACD,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,UAAU,GAAG,MAAM,IAAI,CAAC;QAC5C,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,oBAAoB,CAAC;aACzF,OAAO,CAAC,CAAC,EAAe,EAAE,EAAE;YAC3B,MAAM,MAAM,GAAG,EAAE,CAAC,aAAa,CAAC;YAChC,IAAI,UAAU,GAAG,CAAC,CAAC;YACnB,IAAI,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBACpC,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;aAC/C;YACD,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,UAAU,GAAG,MAAM,IAAI,CAAC;QAChD,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,eAAe,GAAG,IAAI,GAAG,EAAuB,CAAC;QACtD,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,oBAAoB,CAAC;aACzF,OAAO,CAAC,EAAE,CAAC,EAAE;YACZ,MAAM,MAAM,GAAG,EAAE,CAAC,aAAa,CAAC;YAChC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBACrC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;aACpD;QACH,CAAC,CAAC,CAAC;IACP,CAAC;;;YAxJF,SAAS,SAAC;gBACT,QAAQ,EAAE,0CAA0C;gBACpD,SAAS,EAAE,CAAC;wBACV,OAAO,EAAE,uBAAuB;wBAChC,UAAU,EAAE,2CAA2C;wBACvD,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,CAAC;qBACjD,CAAC;aACH;;;YAnCC,MAAM;;;wBAwCL,KAAK,SAAC,aAAa;4BAGnB,KAAK;2BAGL,KAAK;4BAGL,KAAK;2BAGL,KAAK;+BAGL,KAAK;oBAGL,YAAY,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import {\n  AfterContentInit,\n  ContentChild,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy\n} from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { delayWhen, distinctUntilChanged, filter, map, switchMap, takeUntil, tap } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material/table';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\nimport { of, Subject, timer } from 'rxjs';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst stickyHeaderSelector = '.mat-header-row .mat-table-sticky';\nconst stickyFooterSelector = '.mat-footer-row .mat-table-sticky';\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  headerEnabled: true,\n  footerHeight: 48,\n  footerEnabled: false,\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, AfterContentInit, OnDestroy {\n  private destroyed$ = new Subject();\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight: string | number = defaults.rowHeight;\n\n  @Input()\n  headerEnabled: boolean = defaults.headerEnabled;\n\n  @Input()\n  headerHeight: string | number = defaults.headerHeight;\n\n  @Input()\n  footerEnabled: boolean = defaults.footerEnabled;\n\n  @Input()\n  footerHeight: string | number = defaults.footerHeight;\n\n  @Input()\n  bufferMultiplier: string | number = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, { static: false })\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  dataSourceChanges = new Subject<void>();\n\n  private stickyPositions: Map<HTMLElement, number>;\n\n  constructor(private zone: NgZone) {\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n    this.dataSourceChanges.complete();\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  ngAfterContentInit() {\n    const switchDataSourceOrigin = this.table['_switchDataSource'];\n    this.table['_switchDataSource'] = (dataSource: any) => {\n      switchDataSourceOrigin.call(this.table, dataSource);\n      this.connectDataSource(dataSource);\n    };\n\n    this.connectDataSource(this.table.dataSource);\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        // breaks sticky header on the top. needs investigation\n        // delayWhen(() => !this.stickyPositions ? timer(0) : of()),\n        tap(() => {\n          if (!this.stickyPositions) {\n            this.initStickyPositions();\n          }\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  connectDataSource(dataSource: any) {\n    this.dataSourceChanges.next();\n    if (dataSource instanceof TableVirtualScrollDataSource) {\n      dataSource\n        .dataToRender$\n        .pipe(\n          distinctUntilChanged(),\n          takeUntil(this.dataSourceChanges),\n          takeUntil(this.destroyed$),\n          tap(data => this.scrollStrategy.dataLength = data.length),\n          switchMap(data =>\n            this.scrollStrategy\n              .renderedRangeStream\n              .pipe(\n                map(({\n                       start,\n                       end\n                     }) => typeof start !== 'number' || typeof end !== 'number' ? data : data.slice(start, end))\n              )\n          )\n        )\n        .subscribe(data => {\n          this.zone.run(() => {\n            dataSource.dataOfRange$.next(data);\n          });\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: this.headerEnabled ? +this.headerHeight || defaults.headerHeight : 0,\n      footerHeight: this.footerEnabled ? +this.footerHeight || defaults.footerHeight : 0,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset: number) {\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyHeaderSelector)\n      .forEach((el: HTMLElement) => {\n        const parent = el.parentElement;\n        let baseOffset = 0;\n        if (this.stickyPositions.has(parent)) {\n          baseOffset = this.stickyPositions.get(parent);\n        }\n        el.style.top = `${baseOffset - offset}px`;\n      });\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyFooterSelector)\n      .forEach((el: HTMLElement) => {\n        const parent = el.parentElement;\n        let baseOffset = 0;\n        if (this.stickyPositions.has(parent)) {\n          baseOffset = this.stickyPositions.get(parent);\n        }\n        el.style.bottom = `${-baseOffset + offset}px`;\n      });\n  }\n\n  private initStickyPositions() {\n    this.stickyPositions = new Map<HTMLElement, number>();\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyHeaderSelector)\n      .forEach(el => {\n        const parent = el.parentElement;\n        if (!this.stickyPositions.has(parent)) {\n          this.stickyPositions.set(parent, parent.offsetTop);\n        }\n      });\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-item-size.directive.js","sourceRoot":"","sources":["../../../../projects/ng-table-virtual-scroll/src/lib/table-item-size.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ContentChild,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy\n} from '@angular/core';\nimport { VIRTUAL_SCROLL_STRATEGY } from '@angular/cdk/scrolling';\nimport { delayWhen, distinctUntilChanged, filter, map, switchMap, takeUntil, tap } from 'rxjs/operators';\nimport { TableVirtualScrollDataSource } from './table-data-source';\nimport { MatTable } from '@angular/material/table';\nimport { FixedSizeTableVirtualScrollStrategy } from './fixed-size-table-virtual-scroll-strategy';\nimport { CdkHeaderRowDef } from '@angular/cdk/table';\nimport { of, Subject, timer } from 'rxjs';\n\nexport function _tableVirtualScrollDirectiveStrategyFactory(tableDir: TableItemSizeDirective) {\n  return tableDir.scrollStrategy;\n}\n\nconst stickyHeaderSelector = '.mat-header-row .mat-table-sticky, .mat-header-row.mat-table-sticky';\nconst stickyFooterSelector = '.mat-footer-row .mat-table-sticky, .mat-header-row.mat-table-sticky';\n\nconst defaults = {\n  rowHeight: 48,\n  headerHeight: 56,\n  headerEnabled: true,\n  footerHeight: 48,\n  footerEnabled: false,\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, AfterContentInit, OnDestroy {\n  private destroyed$ = new Subject();\n\n  // tslint:disable-next-line:no-input-rename\n  @Input('tvsItemSize')\n  rowHeight: string | number = defaults.rowHeight;\n\n  @Input()\n  headerEnabled: boolean = defaults.headerEnabled;\n\n  @Input()\n  headerHeight: string | number = defaults.headerHeight;\n\n  @Input()\n  footerEnabled: boolean = defaults.footerEnabled;\n\n  @Input()\n  footerHeight: string | number = defaults.footerHeight;\n\n  @Input()\n  bufferMultiplier: string | number = defaults.bufferMultiplier;\n\n  @ContentChild(MatTable, { static: false })\n  table: MatTable<any>;\n\n  scrollStrategy = new FixedSizeTableVirtualScrollStrategy();\n\n  dataSourceChanges = new Subject<void>();\n\n  private stickyPositions: Map<HTMLElement, number>;\n\n  constructor(private zone: NgZone) {\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n    this.dataSourceChanges.complete();\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  ngAfterContentInit() {\n    const switchDataSourceOrigin = this.table['_switchDataSource'];\n    this.table['_switchDataSource'] = (dataSource: any) => {\n      switchDataSourceOrigin.call(this.table, dataSource);\n      this.connectDataSource(dataSource);\n    };\n\n    this.connectDataSource(this.table.dataSource);\n\n    this.scrollStrategy.stickyChange\n      .pipe(\n        filter(() => this.isStickyEnabled()),\n        // breaks sticky header on the top. needs investigation\n        // delayWhen(() => !this.stickyPositions ? timer(0) : of()),\n        tap(() => {\n          if (!this.stickyPositions) {\n            this.initStickyPositions();\n          }\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((stickyOffset) => {\n        this.setSticky(stickyOffset);\n      });\n  }\n\n  connectDataSource(dataSource: any) {\n    this.dataSourceChanges.next();\n    if (dataSource instanceof TableVirtualScrollDataSource) {\n      dataSource\n        .dataToRender$\n        .pipe(\n          distinctUntilChanged(),\n          takeUntil(this.dataSourceChanges),\n          takeUntil(this.destroyed$),\n          tap(data => this.scrollStrategy.dataLength = data.length),\n          switchMap(data =>\n            this.scrollStrategy\n              .renderedRangeStream\n              .pipe(\n                map(({\n                       start,\n                       end\n                     }) => typeof start !== 'number' || typeof end !== 'number' ? data : data.slice(start, end))\n              )\n          )\n        )\n        .subscribe(data => {\n          this.zone.run(() => {\n            dataSource.dataOfRange$.next(data);\n          });\n        });\n    } else {\n      throw new Error('[tvsItemSize] requires TableVirtualScrollDataSource be set as [dataSource] of [mat-table]');\n    }\n  }\n\n  ngOnChanges() {\n    const config = {\n      rowHeight: +this.rowHeight || defaults.rowHeight,\n      headerHeight: this.headerEnabled ? +this.headerHeight || defaults.headerHeight : 0,\n      footerHeight: this.footerEnabled ? +this.footerHeight || defaults.footerHeight : 0,\n      bufferMultiplier: +this.bufferMultiplier || defaults.bufferMultiplier\n    };\n    this.scrollStrategy.setConfig(config);\n  }\n\n\n  setSticky(offset: number) {\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyHeaderSelector)\n      .forEach((el: HTMLElement) => {\n        const parent = el.parentElement;\n        let baseOffset = 0;\n        if (this.stickyPositions.has(parent)) {\n          baseOffset = this.stickyPositions.get(parent);\n        }\n        el.style.top = `${baseOffset - offset}px`;\n      });\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyFooterSelector)\n      .forEach((el: HTMLElement) => {\n        const parent = el.parentElement;\n        let baseOffset = 0;\n        if (this.stickyPositions.has(parent)) {\n          baseOffset = this.stickyPositions.get(parent);\n        }\n        el.style.bottom = `${-baseOffset + offset}px`;\n      });\n  }\n\n  private initStickyPositions() {\n    this.stickyPositions = new Map<HTMLElement, number>();\n    this.scrollStrategy.viewport.elementRef.nativeElement.querySelectorAll(stickyHeaderSelector)\n      .forEach(el => {\n        const parent = el.parentElement;\n        if (!this.stickyPositions.has(parent)) {\n          this.stickyPositions.set(parent, parent.offsetTop);\n        }\n      });\n  }\n}\n"]}

@@ -149,4 +149,4 @@ import { Injectable, Directive, forwardRef, NgZone, Input, ContentChild, NgModule } from '@angular/core';

}
const stickyHeaderSelector = '.mat-header-row .mat-table-sticky';
const stickyFooterSelector = '.mat-footer-row .mat-table-sticky';
const stickyHeaderSelector = '.mat-header-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
const stickyFooterSelector = '.mat-footer-row .mat-table-sticky, .mat-header-row.mat-table-sticky';
const defaults = {

@@ -153,0 +153,0 @@ rowHeight: 48,

{
"name": "ng-table-virtual-scroll",
"version": "1.3.7",
"version": "1.3.8",
"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

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