@politie/ngx-list-service
Advanced tools
Comparing version 1.0.1 to 1.0.2
@@ -319,7 +319,8 @@ (function (global, factory) { | ||
this.filterFunction$ = new rxjs.BehaviorSubject(null); | ||
this.sortOptions$ = new rxjs.BehaviorSubject({ key: null, order: 'asc' }); | ||
this.sortOptions$ = new rxjs.BehaviorSubject(null); | ||
this.currentIndex$ = new rxjs.BehaviorSubject(0); | ||
this.originalList$ = new rxjs.Subject(); | ||
this.config = { | ||
data: [], | ||
sort: { key: null, order: 'asc' }, | ||
list: [], | ||
filterFunction: null, | ||
@@ -351,7 +352,10 @@ sortFunction: null, | ||
} | ||
if (rxjs.isObservable(this.config.data)) { | ||
this.config.data.subscribe(function (r) { return _this.update(r); }); | ||
if (this.config.sort) { | ||
this.sortOptions$.next(this.config.sort); | ||
} | ||
if (rxjs.isObservable(this.config.list)) { | ||
this.config.list.subscribe(function (r) { return _this.update(r); }); | ||
} | ||
else { | ||
this.update(this.config.data); | ||
this.update(this.config.list); | ||
} | ||
@@ -385,5 +389,6 @@ }; | ||
ListService.prototype.sort = function (key) { | ||
var _a, _b; | ||
var order; | ||
if (key === this.sortOptions$.getValue().key) { | ||
order = this.sortOptions$.getValue().order === 'asc' ? 'desc' : 'asc'; | ||
if (key === ((_a = this.sortOptions$.getValue()) === null || _a === void 0 ? void 0 : _a.key)) { | ||
order = ((_b = this.sortOptions$.getValue()) === null || _b === void 0 ? void 0 : _b.order) === 'asc' ? 'desc' : 'asc'; | ||
} | ||
@@ -404,4 +409,4 @@ else { | ||
this.filterFunction$ | ||
]).pipe(operators.map(function (_a) { | ||
var _b = __read(_a, 2), list = _b[0], filterFunction = _b[1]; | ||
]).pipe(operators.map(function (_c) { | ||
var _d = __read(_c, 2), list = _d[0], filterFunction = _d[1]; | ||
if (filterFunction) { | ||
@@ -423,5 +428,5 @@ return list.filter(filterFunction); | ||
this.filteredList$, | ||
this.sortOptions$ | ||
]).pipe(operators.map(function (_a) { | ||
var _b = __read(_a, 2), filteredList = _b[0], sorting = _b[1]; | ||
this.sortOptions$.pipe(operators.filter(function (i) { return i !== null; })) | ||
]).pipe(operators.map(function (_c) { | ||
var _d = __read(_c, 2), filteredList = _d[0], sorting = _d[1]; | ||
var list; | ||
@@ -466,4 +471,4 @@ if (sorting.key) { | ||
var _this = this; | ||
this.list$ = this.currentIndex$.pipe(operators.skip(1), operators.withLatestFrom(this.sortedList$), operators.map(function (_a) { | ||
var _b = __read(_a, 2), requestedIndex = _b[0], _c = _b[1], list = _c.list, sorting = _c.sorting; | ||
this.result$ = this.currentIndex$.pipe(operators.skip(1), operators.withLatestFrom(this.sortedList$), operators.map(function (_c) { | ||
var _d = __read(_c, 2), requestedIndex = _d[0], _e = _d[1], list = _e.list, sorting = _e.sorting; | ||
/** | ||
@@ -478,5 +483,6 @@ * Check the amount of pages that is needed for the given list | ||
/** | ||
* Create a slice based on the index and the pageSize | ||
* Create a page based on the index and the pageSize | ||
*/ | ||
var slice = totalPages === 0 ? list : list.slice((index * _this.config.pageSize), ((index * _this.config.pageSize) + _this.config.pageSize)); | ||
var sliceStart = index * _this.config.pageSize; | ||
var page = (totalPages === 0) ? list.slice() : list.slice(sliceStart, (sliceStart + _this.config.pageSize)); | ||
/** | ||
@@ -486,3 +492,3 @@ * Return the payload to the view, with the list, sorting and pagination options | ||
return { | ||
list: slice, | ||
page: page, | ||
sorting: sorting, | ||
@@ -493,3 +499,3 @@ pagination: { | ||
current: index + 1, | ||
size: slice.length, | ||
size: page.length, | ||
total: Math.max(totalPages, 1) | ||
@@ -496,0 +502,0 @@ }, |
@@ -15,3 +15,3 @@ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("rxjs"),require("rxjs/operators"),require("@angular/core")):"function"==typeof define&&define.amd?define("@politie/ngx-list-service",["exports","rxjs","rxjs/operators","@angular/core"],e):e(((t="undefined"!=typeof globalThis?globalThis:t||self).politie=t.politie||{},t.politie["ngx-list-service"]={}),t.rxjs,t.rxjs.operators,t.ng.core)}(this,(function(t,e,i,n){"use strict"; | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */Object.create;function r(t,e){var i="function"==typeof Symbol&&t[Symbol.iterator];if(!i)return t;var n,r,o=i.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(n=o.next()).done;)s.push(n.value)}catch(t){r={error:t}}finally{try{n&&!n.done&&(i=o.return)&&i.call(o)}finally{if(r)throw r.error}}return s}Object.create;var o=function(){function t(){this.filterFunction$=new e.BehaviorSubject(null),this.sortOptions$=new e.BehaviorSubject({key:null,order:"asc"}),this.currentIndex$=new e.BehaviorSubject(0),this.originalList$=new e.Subject,this.config={data:[],filterFunction:null,sortFunction:null,pageSize:0,resetToFirstPageOnUpdate:!0},this.createFilteredList$(),this.createSortedList$(),this.createList$()}return t.prototype.create=function(t){var i=this;this.config=Object.assign(Object.assign({},this.config),t),this.config.filterFunction&&this.filterFunction$.next(this.config.filterFunction),e.isObservable(this.config.data)?this.config.data.subscribe((function(t){return i.update(t)})):this.update(this.config.data)},t.prototype.update=function(t){this.originalList$.next(t.slice()),this.currentIndex$.next(0)},t.prototype.filter=function(t){this.filterFunction$.next(null!=t?t:this.config.filterFunction),this.currentIndex$.next(0)},t.prototype.sort=function(t){var e;e=t===this.sortOptions$.getValue().key&&"asc"===this.sortOptions$.getValue().order?"desc":"asc",this.sortOptions$.next({order:e,key:t}),this.currentIndex$.next(0)},t.prototype.createFilteredList$=function(){this.filteredList$=e.combineLatest([this.originalList$,this.filterFunction$]).pipe(i.map((function(t){var e=r(t,2),i=e[0],n=e[1];return n?i.filter(n):i})))},t.prototype.createSortedList$=function(){var t=this;this.sortedList$=e.combineLatest([this.filteredList$,this.sortOptions$]).pipe(i.map((function(e){var i=r(e,2),n=i[0],o=i[1];return{list:o.key?n.sort((function(e,i){var n,r;return t.config.sortFunction?(n=t.config.sortFunction(e,o.key),r=t.config.sortFunction(i,o.key)):(n=e[o.key],r=i[o.key]),"asc"===o.order?n<r?-1:n>r?1:0:"desc"===o.order?r<n?-1:r>n?1:0:0})):n,sorting:o}})))},t.prototype.createList$=function(){var t=this;this.list$=this.currentIndex$.pipe(i.skip(1),i.withLatestFrom(this.sortedList$),i.map((function(e){var i=r(e,2),n=i[0],o=i[1],s=o.list,c=o.sorting,a=0===t.config.pageSize?0:Math.ceil(s.length/t.config.pageSize),u=Math.max(0,Math.min(n,a-1)),l=0===a?s:s.slice(u*t.config.pageSize,u*t.config.pageSize+t.config.pageSize);return{list:l,sorting:c,pagination:{listSize:s.length,page:{current:u+1,size:l.length,total:Math.max(a,1)},pages:Array.from({length:Math.max(a,1)},(function(t,e){return e+1})),disabled:{prev:0===u,next:u===Math.max(a-1,0)}}}})))},t.prototype.goToPage=function(t){this.currentIndex$.next(t-1)},t.prototype.nextPage=function(){this.currentIndex$.next(this.currentIndex$.getValue()+1)},t.prototype.prevPage=function(){this.currentIndex$.next(this.currentIndex$.getValue()-1)},t}();o.decorators=[{type:n.Injectable}],o.ctorParameters=function(){return[]},t.ListService=o,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
***************************************************************************** */Object.create;function r(t,e){var i="function"==typeof Symbol&&t[Symbol.iterator];if(!i)return t;var n,r,o=i.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(n=o.next()).done;)s.push(n.value)}catch(t){r={error:t}}finally{try{n&&!n.done&&(i=o.return)&&i.call(o)}finally{if(r)throw r.error}}return s}Object.create;var o=function(){function t(){this.filterFunction$=new e.BehaviorSubject(null),this.sortOptions$=new e.BehaviorSubject(null),this.currentIndex$=new e.BehaviorSubject(0),this.originalList$=new e.Subject,this.config={sort:{key:null,order:"asc"},list:[],filterFunction:null,sortFunction:null,pageSize:0,resetToFirstPageOnUpdate:!0},this.createFilteredList$(),this.createSortedList$(),this.createList$()}return t.prototype.create=function(t){var i=this;this.config=Object.assign(Object.assign({},this.config),t),this.config.filterFunction&&this.filterFunction$.next(this.config.filterFunction),this.config.sort&&this.sortOptions$.next(this.config.sort),e.isObservable(this.config.list)?this.config.list.subscribe((function(t){return i.update(t)})):this.update(this.config.list)},t.prototype.update=function(t){this.originalList$.next(t.slice()),this.currentIndex$.next(0)},t.prototype.filter=function(t){this.filterFunction$.next(null!=t?t:this.config.filterFunction),this.currentIndex$.next(0)},t.prototype.sort=function(t){var e,i,n;n=t===(null===(e=this.sortOptions$.getValue())||void 0===e?void 0:e.key)&&"asc"===(null===(i=this.sortOptions$.getValue())||void 0===i?void 0:i.order)?"desc":"asc",this.sortOptions$.next({order:n,key:t}),this.currentIndex$.next(0)},t.prototype.createFilteredList$=function(){this.filteredList$=e.combineLatest([this.originalList$,this.filterFunction$]).pipe(i.map((function(t){var e=r(t,2),i=e[0],n=e[1];return n?i.filter(n):i})))},t.prototype.createSortedList$=function(){var t=this;this.sortedList$=e.combineLatest([this.filteredList$,this.sortOptions$.pipe(i.filter((function(t){return null!==t})))]).pipe(i.map((function(e){var i=r(e,2),n=i[0],o=i[1];return{list:o.key?n.sort((function(e,i){var n,r;return t.config.sortFunction?(n=t.config.sortFunction(e,o.key),r=t.config.sortFunction(i,o.key)):(n=e[o.key],r=i[o.key]),"asc"===o.order?n<r?-1:n>r?1:0:"desc"===o.order?r<n?-1:r>n?1:0:0})):n,sorting:o}})))},t.prototype.createList$=function(){var t=this;this.result$=this.currentIndex$.pipe(i.skip(1),i.withLatestFrom(this.sortedList$),i.map((function(e){var i=r(e,2),n=i[0],o=i[1],s=o.list,c=o.sorting,a=0===t.config.pageSize?0:Math.ceil(s.length/t.config.pageSize),u=Math.max(0,Math.min(n,a-1)),l=u*t.config.pageSize,f=0===a?s.slice():s.slice(l,l+t.config.pageSize);return{page:f,sorting:c,pagination:{listSize:s.length,page:{current:u+1,size:f.length,total:Math.max(a,1)},pages:Array.from({length:Math.max(a,1)},(function(t,e){return e+1})),disabled:{prev:0===u,next:u===Math.max(a-1,0)}}}})))},t.prototype.goToPage=function(t){this.currentIndex$.next(t-1)},t.prototype.nextPage=function(){this.currentIndex$.next(this.currentIndex$.getValue()+1)},t.prototype.prevPage=function(){this.currentIndex$.next(this.currentIndex$.getValue()-1)},t}();o.decorators=[{type:n.Injectable}],o.ctorParameters=function(){return[]},t.ListService=o,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=politie-ngx-list-service.umd.min.js.map |
export {}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saXN0LXNlcnZpY2Uvc3JjL2xpYi9tb2RlbHMvbGlzdC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG4vKipcbiAqIFNvcnRpbmcgcGF5bG9hZFxuICovXG5leHBvcnQgdHlwZSBMaXN0U29ydGluZzxUPiA9IHtcbiAgLyoqXG4gICAqIEtleSB0byBzb3J0IGJ5LCBhcyBrZXlvZiBvZiB0aGUgcHJvdmlkZWQgZ2VuZXJpYyB0eXBlIFRcbiAgICovXG4gIGtleTogKEV4dHJhY3Q8a2V5b2YgVCwgc3RyaW5nPikgfCBudWxsO1xuXG4gIC8qKlxuICAgKiBPcmRlciwgY2FuIGJlICdhc2MnIG9yICdkZXNjJ1xuICAgKi9cbiAgb3JkZXI6ICdhc2MnIHwgJ2Rlc2MnO1xufTtcblxuLyoqXG4gKiBMaXN0IHBhZ2luYXRpb24gcGF5bG9hZFxuICovXG5leHBvcnQgdHlwZSBMaXN0UGFnaW5hdGlvbiA9IHtcbiAgLyoqXG4gICAqIFNpemUgb2YgdGhlIGN1cnJlbnQgc29ydGVkIGxpc3RcbiAgICovXG4gIGxpc3RTaXplOiBudW1iZXI7XG5cbiAgcGFnZToge1xuICAgIC8qKlxuICAgICAqIFRoZSBjdXJyZW50IHBhZ2UgKDEtYmFzZWQpXG4gICAgICovXG4gICAgY3VycmVudDogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIEl0ZW1zIG9uIGN1cnJlbnQgcGFnZVxuICAgICAqL1xuICAgIHNpemU6IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIFRvdGFsIG51bWJlciBvZiBwYWdlc1xuICAgICAqL1xuICAgIHRvdGFsOiBudW1iZXI7XG4gIH07XG5cbiAgLyoqXG4gICAqIEFycmF5IHdpdGggcGFnZXNcbiAgICovXG4gIHBhZ2VzOiBudW1iZXJbXTtcblxuICBkaXNhYmxlZDoge1xuICAgIC8qKlxuICAgICAqIFNob3VsZCBhIHByZXYgYnV0dG9uIGJlIGRpc2FibGVkP1xuICAgICAqL1xuICAgIHByZXY6IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBTaG91bGQgYSBuZXh0IGJ1dHRvbiBiZSBkaXNhYmxlZD9cbiAgICAgKi9cbiAgICBuZXh0OiBib29sZWFuO1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgTGlzdFJlc3VsdDxUPiA9IHtcbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50IHNsaWNlIG9mIHRoZSBsaXN0XG4gICAqL1xuICBsaXN0OiBUW107XG5cbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50IHNvcnRpbmcgb3B0aW9uc1xuICAgKi9cbiAgc29ydGluZzogTGlzdFNvcnRpbmc8VD47XG5cbiAgLyoqXG4gICAqIE9iamVjdCB3aXRoIHBhZ2luYXRpb24gcHJvcGVydGllc1xuICAgKi9cbiAgcGFnaW5hdGlvbjogTGlzdFBhZ2luYXRpb25cbn07XG5cbmV4cG9ydCB0eXBlIExpc3RQYXlsb2FkPFQ+ID0ge1xuICAvKipcbiAgICogVGhlIGRhdGEgdGhhdCBzaG91bGQgYmUgaGFuZGxlZCBieSB0aGUgTGlzdFNlcnZpY2VcbiAgICovXG4gIGRhdGE6IFRbXSB8IE9ic2VydmFibGU8VFtdPjtcblxuICAvKipcbiAgICogU2V0IHRvIG51bWJlciBvZiBpdGVtcyBwZXIgcGFnZSAvIHNsaWNlXG4gICAqL1xuICBwYWdlU2l6ZT86IG51bWJlcjtcblxuICAvKipcbiAgICogU2hvdWxkIHRoZSBwYWdpbmF0aW9uIHJldHVybiB0byBwYWdlIDEgb24gdXBkYXRlP1xuICAgKlxuICAgKiBAZGVwcmVjYXRlZFxuICAgKi9cbiAgcmVzZXRUb0ZpcnN0UGFnZU9uVXBkYXRlPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogQ3VzdG9tIGZpbHRlciBmdW5jdGlvblxuICAgKi9cbiAgZmlsdGVyRnVuY3Rpb24/OiBudWxsIHwgKChpdGVtOiBUKSA9PiBib29sZWFuKTtcblxuICAvKipcbiAgICogQ3VzdG9tIHNvcnQgZnVuY3Rpb25cbiAgICovXG4gIHNvcnRGdW5jdGlvbj86IG51bGwgfCAoKGl0ZW06IFQsIHByb3BlcnR5OiBFeHRyYWN0PGtleW9mIFQsIHN0cmluZz4pID0+IGFueSk7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1saXN0LXNlcnZpY2Uvc3JjL2xpYi9tb2RlbHMvbGlzdC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG4vKipcbiAqIFNvcnRpbmcgcGF5bG9hZFxuICovXG5leHBvcnQgdHlwZSBMaXN0U29ydGluZzxUPiA9IHtcbiAgLyoqXG4gICAqIEtleSB0byBzb3J0IGJ5LCBhcyBrZXlvZiBvZiB0aGUgcHJvdmlkZWQgZ2VuZXJpYyB0eXBlIFRcbiAgICovXG4gIGtleTogKEV4dHJhY3Q8a2V5b2YgVCwgc3RyaW5nPikgfCBudWxsO1xuXG4gIC8qKlxuICAgKiBPcmRlciwgY2FuIGJlICdhc2MnIG9yICdkZXNjJ1xuICAgKi9cbiAgb3JkZXI6ICdhc2MnIHwgJ2Rlc2MnO1xufTtcblxuLyoqXG4gKiBMaXN0IHBhZ2luYXRpb24gcGF5bG9hZFxuICovXG5leHBvcnQgdHlwZSBMaXN0UGFnaW5hdGlvbiA9IHtcbiAgLyoqXG4gICAqIFNpemUgb2YgdGhlIGN1cnJlbnQgc29ydGVkIGxpc3RcbiAgICovXG4gIGxpc3RTaXplOiBudW1iZXI7XG5cbiAgcGFnZToge1xuICAgIC8qKlxuICAgICAqIFRoZSBjdXJyZW50IHBhZ2UgKDEtYmFzZWQpXG4gICAgICovXG4gICAgY3VycmVudDogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIEl0ZW1zIG9uIGN1cnJlbnQgcGFnZVxuICAgICAqL1xuICAgIHNpemU6IG51bWJlcjtcblxuICAgIC8qKlxuICAgICAqIFRvdGFsIG51bWJlciBvZiBwYWdlc1xuICAgICAqL1xuICAgIHRvdGFsOiBudW1iZXI7XG4gIH07XG5cbiAgLyoqXG4gICAqIEFycmF5IHdpdGggcGFnZXNcbiAgICovXG4gIHBhZ2VzOiBudW1iZXJbXTtcblxuICBkaXNhYmxlZDoge1xuICAgIC8qKlxuICAgICAqIFNob3VsZCBhIHByZXYgYnV0dG9uIGJlIGRpc2FibGVkP1xuICAgICAqL1xuICAgIHByZXY6IGJvb2xlYW47XG5cbiAgICAvKipcbiAgICAgKiBTaG91bGQgYSBuZXh0IGJ1dHRvbiBiZSBkaXNhYmxlZD9cbiAgICAgKi9cbiAgICBuZXh0OiBib29sZWFuO1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgTGlzdFJlc3VsdDxUPiA9IHtcbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50IHNsaWNlIG9mIHRoZSBsaXN0XG4gICAqL1xuICBwYWdlOiBUW107XG5cbiAgLyoqXG4gICAqIFRoZSBjdXJyZW50IHNvcnRpbmcgb3B0aW9uc1xuICAgKi9cbiAgc29ydGluZzogTGlzdFNvcnRpbmc8VD47XG5cbiAgLyoqXG4gICAqIE9iamVjdCB3aXRoIHBhZ2luYXRpb24gcHJvcGVydGllc1xuICAgKi9cbiAgcGFnaW5hdGlvbjogTGlzdFBhZ2luYXRpb25cbn07XG5cbmV4cG9ydCB0eXBlIExpc3RQYXlsb2FkPFQ+ID0ge1xuICAvKipcbiAgICogVGhlIGRhdGEgdGhhdCBzaG91bGQgYmUgaGFuZGxlZCBieSB0aGUgTGlzdFNlcnZpY2VcbiAgICovXG4gIGxpc3Q6IFRbXSB8IE9ic2VydmFibGU8VFtdPjtcblxuICAvKipcbiAgICogU2V0IHRvIG51bWJlciBvZiBpdGVtcyBwZXIgcGFnZSAvIHNsaWNlXG4gICAqL1xuICBwYWdlU2l6ZT86IG51bWJlcjtcblxuICAvKipcbiAgICogSW5pdGlhbCBzb3J0aW5nXG4gICAqL1xuICBzb3J0PzogTGlzdFNvcnRpbmc8VD47XG5cbiAgLyoqXG4gICAqIFNob3VsZCB0aGUgcGFnaW5hdGlvbiByZXR1cm4gdG8gcGFnZSAxIG9uIHVwZGF0ZT9cbiAgICpcbiAgICogQGRlcHJlY2F0ZWRcbiAgICovXG4gIHJlc2V0VG9GaXJzdFBhZ2VPblVwZGF0ZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEN1c3RvbSBmaWx0ZXIgZnVuY3Rpb25cbiAgICovXG4gIGZpbHRlckZ1bmN0aW9uPzogbnVsbCB8ICgoaXRlbTogVCkgPT4gYm9vbGVhbik7XG5cbiAgLyoqXG4gICAqIEN1c3RvbSBzb3J0IGZ1bmN0aW9uXG4gICAqL1xuICBzb3J0RnVuY3Rpb24/OiBudWxsIHwgKChpdGVtOiBULCBwcm9wZXJ0eTogRXh0cmFjdDxrZXlvZiBULCBzdHJpbmc+KSA9PiBhbnkpO1xufVxuIl19 |
import { BehaviorSubject, combineLatest, isObservable, Subject } from 'rxjs'; | ||
import { map, skip, withLatestFrom } from 'rxjs/operators'; | ||
import { filter, map, skip, withLatestFrom } from 'rxjs/operators'; | ||
import { Injectable } from '@angular/core'; | ||
@@ -7,7 +7,8 @@ export class ListService { | ||
this.filterFunction$ = new BehaviorSubject(null); | ||
this.sortOptions$ = new BehaviorSubject({ key: null, order: 'asc' }); | ||
this.sortOptions$ = new BehaviorSubject(null); | ||
this.currentIndex$ = new BehaviorSubject(0); | ||
this.originalList$ = new Subject(); | ||
this.config = { | ||
data: [], | ||
sort: { key: null, order: 'asc' }, | ||
list: [], | ||
filterFunction: null, | ||
@@ -38,7 +39,10 @@ sortFunction: null, | ||
} | ||
if (isObservable(this.config.data)) { | ||
this.config.data.subscribe(r => this.update(r)); | ||
if (this.config.sort) { | ||
this.sortOptions$.next(this.config.sort); | ||
} | ||
if (isObservable(this.config.list)) { | ||
this.config.list.subscribe(r => this.update(r)); | ||
} | ||
else { | ||
this.update(this.config.data); | ||
this.update(this.config.list); | ||
} | ||
@@ -72,5 +76,6 @@ } | ||
sort(key) { | ||
var _a, _b; | ||
let order; | ||
if (key === this.sortOptions$.getValue().key) { | ||
order = this.sortOptions$.getValue().order === 'asc' ? 'desc' : 'asc'; | ||
if (key === ((_a = this.sortOptions$.getValue()) === null || _a === void 0 ? void 0 : _a.key)) { | ||
order = ((_b = this.sortOptions$.getValue()) === null || _b === void 0 ? void 0 : _b.order) === 'asc' ? 'desc' : 'asc'; | ||
} | ||
@@ -107,3 +112,3 @@ else { | ||
this.filteredList$, | ||
this.sortOptions$ | ||
this.sortOptions$.pipe(filter((i) => i !== null)) | ||
]).pipe(map(([filteredList, sorting]) => { | ||
@@ -148,3 +153,3 @@ let list; | ||
createList$() { | ||
this.list$ = this.currentIndex$.pipe(skip(1), withLatestFrom(this.sortedList$), map(([requestedIndex, { list, sorting }]) => { | ||
this.result$ = this.currentIndex$.pipe(skip(1), withLatestFrom(this.sortedList$), map(([requestedIndex, { list, sorting }]) => { | ||
/** | ||
@@ -159,5 +164,6 @@ * Check the amount of pages that is needed for the given list | ||
/** | ||
* Create a slice based on the index and the pageSize | ||
* Create a page based on the index and the pageSize | ||
*/ | ||
const slice = totalPages === 0 ? list : list.slice((index * this.config.pageSize), ((index * this.config.pageSize) + this.config.pageSize)); | ||
const sliceStart = index * this.config.pageSize; | ||
const page = (totalPages === 0) ? list.slice() : list.slice(sliceStart, (sliceStart + this.config.pageSize)); | ||
/** | ||
@@ -167,3 +173,3 @@ * Return the payload to the view, with the list, sorting and pagination options | ||
return { | ||
list: slice, | ||
page, | ||
sorting, | ||
@@ -174,3 +180,3 @@ pagination: { | ||
current: index + 1, | ||
size: slice.length, | ||
size: page.length, | ||
total: Math.max(totalPages, 1) | ||
@@ -213,2 +219,2 @@ }, | ||
ListService.ctorParameters = () => []; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-list-service/src/lib/service/list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, combineLatest, isObservable, Observable, Subject } from 'rxjs';\nimport { map, skip, withLatestFrom } from 'rxjs/operators';\nimport { Injectable } from '@angular/core';\nimport { ListPayload, ListResult, ListSorting } from '../models/list.model';\n\n@Injectable()\nexport class ListService<T> {\n  list$!: Observable<ListResult<T>>;\n\n  private filterFunction$: BehaviorSubject<((item: T) => boolean) | null> = new BehaviorSubject<((item: T) => boolean) | null>(null);\n  private sortOptions$: BehaviorSubject<ListSorting<T>> = new BehaviorSubject<ListSorting<T>>({ key: null, order: 'asc' });\n  private currentIndex$ = new BehaviorSubject<number>(0);\n\n  private originalList$: Subject<T[]> = new Subject<T[]>();\n  private filteredList$!: Observable<T[]>;\n  private sortedList$!: Observable<{ list: T[], sorting: ListSorting<T>}>;\n\n  private config: Required<ListPayload<any>> = {\n    data: [],\n    filterFunction: null,\n    sortFunction: null,\n    pageSize: 0,\n    resetToFirstPageOnUpdate: true\n  }\n\n  constructor() {\n    /**\n     * Setup the observables\n     */\n    this.createFilteredList$();\n    this.createSortedList$();\n    this.createList$();\n  }\n\n  /**\n   * Creates a List instance and generate a list of data, filtered and sorted.\n   *\n   * @param payload the configuration for this List instance.\n   */\n  create(payload: ListPayload<any>): void {\n    this.config = {...this.config, ...payload} as Required<ListPayload<any>>;\n\n    /**\n     * Emit one time if a filterFunction has been found.\n     */\n    if (this.config.filterFunction) {\n      this.filterFunction$.next(this.config.filterFunction);\n    }\n\n    if (isObservable(this.config.data)) {\n      this.config.data.subscribe(r => this.update(r));\n    } else {\n      this.update(this.config.data);\n    }\n  }\n\n  /**\n   * Update the list with the provided data\n   *\n   * @param data Array with the new data\n   */\n  update(data: T[]) {\n    this.originalList$.next(data.slice());\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Filters the original list based on provided (or provided in the config) function\n   *\n   * @param filterFunction function to use when filtering the list\n   */\n  filter(filterFunction?: (item: T) => boolean) {\n    this.filterFunction$.next(filterFunction ?? this.config.filterFunction);\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Sort the list by provided key\n   * If the current sorting key matches the provided key\n   * the list is sorted in the opposite order.\n   *\n   * @param key the key in which the array of objects is sorted\n   */\n  sort(key: Extract<keyof T, string>) {\n    let order: 'asc' | 'desc';\n\n    if (key === this.sortOptions$.getValue().key) {\n      order = this.sortOptions$.getValue().order === 'asc' ? 'desc' : 'asc';\n    } else {\n      order = 'asc';\n    }\n\n    this.sortOptions$.next({ order, key });\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Create a observable that combines the original list + emits from the filterFunction$\n   * observable to return a filtered list.\n   */\n  createFilteredList$() {\n    this.filteredList$ = combineLatest([\n      this.originalList$,\n      this.filterFunction$\n    ]).pipe(\n      map(([list, filterFunction]) => {\n        if (filterFunction) {\n          return list.filter(filterFunction);\n        } else {\n          return list;\n        }\n      })\n    );\n  }\n\n  /**\n   * Create a observable that combines the filteredList$ and sortOptions$ observables and\n   * return a sorted list\n   */\n  createSortedList$() {\n    this.sortedList$ = combineLatest([\n      this.filteredList$,\n      this.sortOptions$\n    ]).pipe(\n      map(([filteredList, sorting]) => {\n        let list: T[];\n\n        if (sorting.key) {\n          list = filteredList.sort((a, b): number => {\n            let resultA: any;\n            let resultB: any;\n\n            if (this.config.sortFunction) {\n              resultA = this.config.sortFunction(a, sorting.key as string);\n              resultB = this.config.sortFunction(b, sorting.key as string);\n            } else {\n              resultA = a[(sorting.key as Extract<keyof T, string>)];\n              resultB = b[(sorting.key as Extract<keyof T, string>)];\n            }\n\n            if (sorting.order === 'asc') {\n              return resultA < resultB ? -1 : resultA > resultB ? 1 : 0;\n            } else if (sorting.order === 'desc') {\n              return resultB < resultA ? -1 : resultB > resultA ? 1 : 0;\n            } else {\n              return 0;\n            }\n          });\n        } else {\n          list = filteredList;\n        }\n\n        /**\n         * Return a object for the next consumer with the sorted list + sorting options in\n         */\n        return { list, sorting };\n      }\n    ));\n  }\n\n  /**\n   * Create a observable by watching the currentIndex$ observable and grab the latest value from the sortedList$\n   * observable and generate output (ListResult<T>) for the list$ consumers.\n   */\n  createList$() {\n    this.list$ = this.currentIndex$.pipe(\n      skip(1),\n      withLatestFrom(this.sortedList$),\n      map(([requestedIndex, { list, sorting }]) => {\n\n        /**\n         * Check the amount of pages that is needed for the given list\n         */\n        const totalPages = (this.config.pageSize === 0) ? 0 : Math.ceil(list.length / this.config.pageSize);\n\n        /**\n         * Check if the requested index is in bounds of the list size.\n         */\n        const index = Math.max(0, Math.min(requestedIndex, totalPages - 1));\n\n        /**\n         * Create a slice based on the index and the pageSize\n         */\n        const slice = totalPages === 0 ? list : list.slice((index * this.config.pageSize), ((index * this.config.pageSize) + this.config.pageSize));\n\n        /**\n         * Return the payload to the view, with the list, sorting and pagination options\n         */\n        return {\n          list: slice,\n          sorting,\n          pagination: {\n            listSize: list.length,\n            page: {\n              current: index + 1,\n              size: slice.length,\n              total: Math.max(totalPages, 1)\n            },\n            pages: Array.from({length: Math.max(totalPages, 1)}, (_, i) => i + 1),\n            disabled: {\n              prev: (index === 0),\n              next: (index === Math.max(totalPages - 1, 0))\n            }\n          }\n        };\n      })\n    );\n  }\n\n  /**\n   * Go to a specific page in the set\n   * This will be transformed to a zero based index\n   *\n   * @param page the page number to go to\n   */\n  goToPage(page: number) {\n    this.currentIndex$.next(page - 1);\n  }\n\n  /**\n   * Go to the next page\n   */\n  nextPage() {\n    this.currentIndex$.next(this.currentIndex$.getValue() + 1);\n  }\n\n  /**\n   * Go to the previous page\n   */\n  prevPage() {\n    this.currentIndex$.next(this.currentIndex$.getValue() - 1);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-list-service/src/lib/service/list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, combineLatest, isObservable, Observable, Subject } from 'rxjs';\nimport { filter, map, skip, withLatestFrom } from 'rxjs/operators';\nimport { Injectable } from '@angular/core';\nimport { ListPayload, ListResult, ListSorting } from '../models/list.model';\n\n@Injectable()\nexport class ListService<T> {\n  result$!: Observable<ListResult<T>>;\n\n  private filterFunction$: BehaviorSubject<((item: T) => boolean) | null> = new BehaviorSubject<((item: T) => boolean) | null>(null);\n  private sortOptions$: BehaviorSubject<ListSorting<T> | null> = new BehaviorSubject<ListSorting<T> | null>(null);\n  private currentIndex$ = new BehaviorSubject<number>(0);\n\n  private originalList$: Subject<T[]> = new Subject<T[]>();\n  private filteredList$!: Observable<T[]>;\n  private sortedList$!: Observable<{ list: T[], sorting: ListSorting<T>}>;\n\n  private config: Required<ListPayload<any>> = {\n    sort: { key: null, order: 'asc' },\n    list: [],\n    filterFunction: null,\n    sortFunction: null,\n    pageSize: 0,\n    resetToFirstPageOnUpdate: true\n  }\n\n  constructor() {\n    /**\n     * Setup the observables\n     */\n    this.createFilteredList$();\n    this.createSortedList$();\n    this.createList$();\n  }\n\n  /**\n   * Creates a List instance and generate a list of data, filtered and sorted.\n   *\n   * @param payload the configuration for this List instance.\n   */\n  create(payload: ListPayload<any>): void {\n    this.config = {...this.config, ...payload} as Required<ListPayload<any>>;\n\n    /**\n     * Emit one time if a filterFunction has been found.\n     */\n    if (this.config.filterFunction) {\n      this.filterFunction$.next(this.config.filterFunction);\n    }\n\n    if (this.config.sort) {\n      this.sortOptions$.next(this.config.sort);\n    }\n\n    if (isObservable(this.config.list)) {\n      this.config.list.subscribe(r => this.update(r));\n    } else {\n      this.update(this.config.list);\n    }\n  }\n\n  /**\n   * Update the list with the provided data\n   *\n   * @param data Array with the new data\n   */\n  update(data: T[]) {\n    this.originalList$.next(data.slice());\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Filters the original list based on provided (or provided in the config) function\n   *\n   * @param filterFunction function to use when filtering the list\n   */\n  filter(filterFunction?: (item: T) => boolean) {\n    this.filterFunction$.next(filterFunction ?? this.config.filterFunction);\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Sort the list by provided key\n   * If the current sorting key matches the provided key\n   * the list is sorted in the opposite order.\n   *\n   * @param key the key in which the array of objects is sorted\n   */\n  sort(key: Extract<keyof T, string>) {\n    let order: 'asc' | 'desc';\n\n    if (key === this.sortOptions$.getValue()?.key) {\n      order = this.sortOptions$.getValue()?.order === 'asc' ? 'desc' : 'asc';\n    } else {\n      order = 'asc';\n    }\n\n\n    this.sortOptions$.next({ order, key });\n    this.currentIndex$.next(0);\n  }\n\n  /**\n   * Create a observable that combines the original list + emits from the filterFunction$\n   * observable to return a filtered list.\n   */\n  createFilteredList$() {\n    this.filteredList$ = combineLatest([\n      this.originalList$,\n      this.filterFunction$\n    ]).pipe(\n      map(([list, filterFunction]) => {\n\n        if (filterFunction) {\n          return list.filter(filterFunction);\n        } else {\n          return list;\n        }\n      })\n    );\n  }\n\n  /**\n   * Create a observable that combines the filteredList$ and sortOptions$ observables and\n   * return a sorted list\n   */\n  createSortedList$() {\n    this.sortedList$ = combineLatest([\n      this.filteredList$,\n      this.sortOptions$.pipe(filter((i) => i !== null)) as Observable<ListSorting<T>>\n    ]).pipe(\n      map(([filteredList, sorting]) => {\n        let list: T[];\n\n        if (sorting.key) {\n          list = filteredList.sort((a, b): number => {\n            let resultA: any;\n            let resultB: any;\n\n            if (this.config.sortFunction) {\n              resultA = this.config.sortFunction(a, sorting.key as string);\n              resultB = this.config.sortFunction(b, sorting.key as string);\n            } else {\n              resultA = a[(sorting.key as Extract<keyof T, string>)];\n              resultB = b[(sorting.key as Extract<keyof T, string>)];\n            }\n\n            if (sorting.order === 'asc') {\n              return resultA < resultB ? -1 : resultA > resultB ? 1 : 0;\n            } else if (sorting.order === 'desc') {\n              return resultB < resultA ? -1 : resultB > resultA ? 1 : 0;\n            } else {\n              return 0;\n            }\n          });\n        } else {\n          list = filteredList;\n        }\n\n        /**\n         * Return a object for the next consumer with the sorted list + sorting options in\n         */\n        return { list, sorting };\n      }\n    ));\n  }\n\n  /**\n   * Create a observable by watching the currentIndex$ observable and grab the latest value from the sortedList$\n   * observable and generate output (ListResult<T>) for the list$ consumers.\n   */\n  createList$() {\n    this.result$ = this.currentIndex$.pipe(\n      skip(1),\n      withLatestFrom(this.sortedList$),\n      map(([requestedIndex, { list, sorting }]) => {\n        /**\n         * Check the amount of pages that is needed for the given list\n         */\n        const totalPages = (this.config.pageSize === 0) ? 0 : Math.ceil(list.length / this.config.pageSize);\n\n        /**\n         * Check if the requested index is in bounds of the list size.\n         */\n        const index = Math.max(0, Math.min(requestedIndex, totalPages - 1));\n\n        /**\n         * Create a page based on the index and the pageSize\n         */\n        const sliceStart = index * this.config.pageSize;\n        const page = (totalPages === 0) ? list.slice() : list.slice(sliceStart, (sliceStart + this.config.pageSize));\n\n        /**\n         * Return the payload to the view, with the list, sorting and pagination options\n         */\n        return {\n          page,\n          sorting,\n          pagination: {\n            listSize: list.length,\n            page: {\n              current: index + 1,\n              size: page.length,\n              total: Math.max(totalPages, 1)\n            },\n            pages: Array.from({length: Math.max(totalPages, 1)}, (_, i) => i + 1),\n            disabled: {\n              prev: (index === 0),\n              next: (index === Math.max(totalPages - 1, 0))\n            }\n          }\n        };\n      })\n    );\n  }\n\n  /**\n   * Go to a specific page in the set\n   * This will be transformed to a zero based index\n   *\n   * @param page the page number to go to\n   */\n  goToPage(page: number) {\n    this.currentIndex$.next(page - 1);\n  }\n\n  /**\n   * Go to the next page\n   */\n  nextPage() {\n    this.currentIndex$.next(this.currentIndex$.getValue() + 1);\n  }\n\n  /**\n   * Go to the previous page\n   */\n  prevPage() {\n    this.currentIndex$.next(this.currentIndex$.getValue() - 1);\n  }\n}\n"]} |
import { BehaviorSubject, Subject, isObservable, combineLatest } from 'rxjs'; | ||
import { map, skip, withLatestFrom } from 'rxjs/operators'; | ||
import { map, filter, skip, withLatestFrom } from 'rxjs/operators'; | ||
import { Injectable } from '@angular/core'; | ||
@@ -8,7 +8,8 @@ | ||
this.filterFunction$ = new BehaviorSubject(null); | ||
this.sortOptions$ = new BehaviorSubject({ key: null, order: 'asc' }); | ||
this.sortOptions$ = new BehaviorSubject(null); | ||
this.currentIndex$ = new BehaviorSubject(0); | ||
this.originalList$ = new Subject(); | ||
this.config = { | ||
data: [], | ||
sort: { key: null, order: 'asc' }, | ||
list: [], | ||
filterFunction: null, | ||
@@ -39,7 +40,10 @@ sortFunction: null, | ||
} | ||
if (isObservable(this.config.data)) { | ||
this.config.data.subscribe(r => this.update(r)); | ||
if (this.config.sort) { | ||
this.sortOptions$.next(this.config.sort); | ||
} | ||
if (isObservable(this.config.list)) { | ||
this.config.list.subscribe(r => this.update(r)); | ||
} | ||
else { | ||
this.update(this.config.data); | ||
this.update(this.config.list); | ||
} | ||
@@ -73,5 +77,6 @@ } | ||
sort(key) { | ||
var _a, _b; | ||
let order; | ||
if (key === this.sortOptions$.getValue().key) { | ||
order = this.sortOptions$.getValue().order === 'asc' ? 'desc' : 'asc'; | ||
if (key === ((_a = this.sortOptions$.getValue()) === null || _a === void 0 ? void 0 : _a.key)) { | ||
order = ((_b = this.sortOptions$.getValue()) === null || _b === void 0 ? void 0 : _b.order) === 'asc' ? 'desc' : 'asc'; | ||
} | ||
@@ -108,3 +113,3 @@ else { | ||
this.filteredList$, | ||
this.sortOptions$ | ||
this.sortOptions$.pipe(filter((i) => i !== null)) | ||
]).pipe(map(([filteredList, sorting]) => { | ||
@@ -149,3 +154,3 @@ let list; | ||
createList$() { | ||
this.list$ = this.currentIndex$.pipe(skip(1), withLatestFrom(this.sortedList$), map(([requestedIndex, { list, sorting }]) => { | ||
this.result$ = this.currentIndex$.pipe(skip(1), withLatestFrom(this.sortedList$), map(([requestedIndex, { list, sorting }]) => { | ||
/** | ||
@@ -160,5 +165,6 @@ * Check the amount of pages that is needed for the given list | ||
/** | ||
* Create a slice based on the index and the pageSize | ||
* Create a page based on the index and the pageSize | ||
*/ | ||
const slice = totalPages === 0 ? list : list.slice((index * this.config.pageSize), ((index * this.config.pageSize) + this.config.pageSize)); | ||
const sliceStart = index * this.config.pageSize; | ||
const page = (totalPages === 0) ? list.slice() : list.slice(sliceStart, (sliceStart + this.config.pageSize)); | ||
/** | ||
@@ -168,3 +174,3 @@ * Return the payload to the view, with the list, sorting and pagination options | ||
return { | ||
list: slice, | ||
page, | ||
sorting, | ||
@@ -175,3 +181,3 @@ pagination: { | ||
current: index + 1, | ||
size: slice.length, | ||
size: page.length, | ||
total: Math.max(totalPages, 1) | ||
@@ -178,0 +184,0 @@ }, |
@@ -56,3 +56,3 @@ import { Observable } from 'rxjs'; | ||
*/ | ||
list: T[]; | ||
page: T[]; | ||
/** | ||
@@ -71,3 +71,3 @@ * The current sorting options | ||
*/ | ||
data: T[] | Observable<T[]>; | ||
list: T[] | Observable<T[]>; | ||
/** | ||
@@ -78,2 +78,6 @@ * Set to number of items per page / slice | ||
/** | ||
* Initial sorting | ||
*/ | ||
sort?: ListSorting<T>; | ||
/** | ||
* Should the pagination return to page 1 on update? | ||
@@ -80,0 +84,0 @@ * |
import { Observable } from 'rxjs'; | ||
import { ListPayload, ListResult } from '../models/list.model'; | ||
export declare class ListService<T> { | ||
list$: Observable<ListResult<T>>; | ||
result$: Observable<ListResult<T>>; | ||
private filterFunction$; | ||
@@ -6,0 +6,0 @@ private sortOptions$; |
{ | ||
"name": "@politie/ngx-list-service", | ||
"license": "Apache-2.0", | ||
"version": "1.0.1", | ||
"version": "1.0.2", | ||
"peerDependencies": { | ||
@@ -23,2 +23,2 @@ "@angular/common": "^11.0.9", | ||
"sideEffects": false | ||
} | ||
} |
@@ -35,3 +35,3 @@ # ListService | ||
this.listService.create({ | ||
data: myData, | ||
list: myData, | ||
pageSize: 25 | ||
@@ -54,11 +54,11 @@ }); | ||
| --- | :--- | --- | --- | | ||
| data | `T[]` or `Observable<T[]>` | Array (or observable with array) of objects containing the data that should be displayed. | `[]` | | ||
| list | `T[]` or `Observable<T[]>` | Array (or observable with array) of objects containing the data that should be displayed. | `[]` | | ||
| pageSize | `number` | How many items should be returned per page? Set to `0` for no pages. | `0` | | ||
| sort | `{key: property: Extract<keyof T, string>, order: 'asc' / 'desc' `} | If you want to sort the list on initialzation, set the sort property to the key you want to sort the list to. | `{ key: null, order: 'asc' }` | | ||
| filterFunction | `(item: T) => boolean` | Define a custom filter function. See [Filtering the List](#filtering-the-list) for a example. | `null` | | ||
| sortFunction | `(item: T, property: Extract<keyof T, string>) => any)` | If you want to override the default sorting behaviour, you can do so by adding your own sortFunction. See [Sorting the List](#sorting-the-list) for a example. | `null` | | ||
### `update(payload: T[])` | ||
Update the data list with a new set. This will return a slice of the new data, based on the filtering and sorting options already set. | ||
Update the data list with a new set. This will return a chunk of the new data, based on the filtering and sorting options already set. | ||
@@ -79,7 +79,7 @@ ### `sort(key: Extract<keyof T, string>)` | ||
If pagination is active, grab the next `slice` of data and emit the result to the `result$` observable. | ||
If pagination is active, grab the next `chunk` of data and emit the result to the `result$` observable. | ||
### `prevPage()` | ||
If pagination is active, grab the previous `slice` of data and emit the result to the `result$` observable. | ||
If pagination is active, grab the previous `chunk` of data and emit the result to the `result$` observable. | ||
@@ -96,7 +96,7 @@ ### `goToPage(page: number)` | ||
The list$ observable will emit a new result whenever the ListService `update()`, `sort()` or `filter()` methods are called. The `result$` observable contains the current slice of items, the active sorting options and properties to create pagination. The object that is returned looks like this: | ||
The result$ observable will emit a new result whenever the ListService `update()`, `sort()` or `filter()` methods are called. The `result$` observable contains the current chunk of items, the active sorting options and properties to create pagination. The object that is returned from this observable looks like this: | ||
```typescript | ||
{ | ||
list: `T[]`, // The current list slice (based on pagination and pageSize) of the filtered and sorted list | ||
page: `T[]`, // The current page chunk (based on pagination and pageSize) of the filtered and sorted list | ||
sorting: { | ||
@@ -115,4 +115,4 @@ key: `Extract<keyof T, string>`, | ||
disabled: { | ||
prev: `boolean`, // Should a prev button be disabled (current slice is start of list) | ||
next: `boolean` // Should a next button be disabled (current slice is end of list) | ||
prev: `boolean`, // Should a prev button be disabled (current chunk is start of list) | ||
next: `boolean` // Should a next button be disabled (current chunk is end of list) | ||
} | ||
@@ -144,3 +144,3 @@ } | ||
const myData: User[] = [ | ||
const myList: User[] = [ | ||
{ | ||
@@ -159,3 +159,3 @@ id: 1, | ||
this.listService.create({ | ||
data: myData, | ||
list: myList, | ||
pageSize: 25, | ||
@@ -192,3 +192,3 @@ filterFunction: (item: User): boolean => { | ||
this.listService.create({ | ||
data: myData, | ||
list: myList, | ||
pageSize: 25, | ||
@@ -202,3 +202,3 @@ sortFunction: (item: User, key: string): any => { | ||
// By default, just return the value of the key to sort | ||
// By default, just return the value of the key to the sorting function inside the Service. | ||
return item[key]; | ||
@@ -205,0 +205,0 @@ } |
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
153507
1167