New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

ngx-suspense

Package Overview
Dependencies
Maintainers
1
Versions
4
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ngx-suspense - npm Package Compare versions

Comparing version 0.0.3 to 0.0.4

20

bundles/ngx-suspense.umd.js

@@ -428,4 +428,13 @@ (function (global, factory) {

this.allListeners = [];
this.hasParentControlSubject = new rxjs.BehaviorSubject(undefined);
this.parentControl$ = this.hasParentControlSubject.asObservable();
}
NgxSuspenseListComponent.prototype.ngOnInit = function () { };
NgxSuspenseListComponent_1 = NgxSuspenseListComponent;
NgxSuspenseListComponent.prototype.ngOnInit = function () {
this.parentControl$
.pipe(operators.tap(function (val) {
console.log("release", val);
}))
.subscribe();
};
NgxSuspenseListComponent.prototype.ngAfterContentInit = function () {

@@ -451,2 +460,4 @@ var _this = this;

};
NgxSuspenseListComponent.prototype.show = function () { };
NgxSuspenseListComponent.prototype.hide = function () { };
NgxSuspenseListComponent.prototype.revealOrderOperator = function (order) {

@@ -570,2 +581,3 @@ if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {

};
var NgxSuspenseListComponent_1;
__decorate([

@@ -577,3 +589,6 @@ core.Input()

], NgxSuspenseListComponent.prototype, "skeletons", void 0);
NgxSuspenseListComponent = __decorate([
__decorate([
core.ContentChildren(NgxSuspenseListComponent_1)
], NgxSuspenseListComponent.prototype, "list", void 0);
NgxSuspenseListComponent = NgxSuspenseListComponent_1 = __decorate([
core.Component({

@@ -615,2 +630,3 @@ selector: "SuspenseList",

],
schemas: [core.CUSTOM_ELEMENTS_SCHEMA],
exports: [NgxSuspenseComponent, NgxSuspenseListComponent],

@@ -617,0 +633,0 @@ })

2

bundles/ngx-suspense.umd.min.js

@@ -15,3 +15,3 @@ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("rxjs"),require("rxjs/operators"),require("@angular/animations"),require("@angular/platform-browser/animations"),require("@angular/common")):"function"==typeof define&&define.amd?define("ngx-suspense",["exports","@angular/core","rxjs","rxjs/operators","@angular/animations","@angular/platform-browser/animations","@angular/common"],e):e((t=t||self)["ngx-suspense"]={},t.ng.core,t.rxjs,t.rxjs.operators,t.ng.animations,t.ng.platformBrowser.animations,t.ng.common)}(this,(function(t,e,n,r,i,o,s){"use strict";

and limitations under the License.
***************************************************************************** */var a=function(){return(a=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var i in e=arguments[n])Object.prototype.hasOwnProperty.call(e,i)&&(t[i]=e[i]);return t}).apply(this,arguments)};function u(t,e,n,r){var i,o=arguments.length,s=o<3?e:null===r?r=Object.getOwnPropertyDescriptor(e,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(t,e,n,r);else for(var a=t.length-1;a>=0;a--)(i=t[a])&&(s=(o<3?i(s):o>3?i(e,n,s):i(e,n))||s);return o>3&&s&&Object.defineProperty(e,n,s),s}function l(t,e){return function(n,r){e(n,r,t)}}function c(t){var e="function"==typeof Symbol&&Symbol.iterator,n=e&&t[e],r=0;if(n)return n.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function p(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,i,o=n.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(r=o.next()).done;)s.push(r.value)}catch(t){i={error:t}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(i)throw i.error}}return s}function f(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(p(arguments[e]));return t}var h={busyMinDurationMs:0,busyDelayMs:0},b=new e.InjectionToken("LOADING_CONFIG_TOKEN"),d=function(){function t(t){void 0===t&&(t=h),this.userConfig=t,this.loadingSubject=new n.BehaviorSubject(!1),this.loading$=this.loadingSubject.asObservable(),this.taskStartSubject=new n.Subject,this.taskStart$=this.taskStartSubject.asObservable(),this.taskEndSubject=new n.Subject,this.taskEnd$=this.taskEndSubject.asObservable()}return t.prototype.ngOnDestroy=function(){this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe()},Object.defineProperty(t.prototype,"busyTimer",{set:function(t){var e=t.busyDelayMs,n=t.busyMinDurationMs;"number"==typeof e&&(this.userConfig.busyDelayMs=e),"number"==typeof n&&(this.userConfig.busyMinDurationMs=n)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"config",{get:function(){return this.userConfig},enumerable:!0,configurable:!0}),t.prototype.show=function(){this.loadingSubject.next(!0)},t.prototype.hide=function(){this.loadingSubject.next(!1)},t.prototype.controller=function(){var t=this;this.busyMinDurationTimer=n.timer(this.config.busyMinDurationMs+this.config.busyDelayMs),this.busyDelayTimer=n.timer(this.config.busyDelayMs);var e=this.taskStart$.pipe(r.switchMap((function(){return t.busyDelayTimer}))).pipe(r.takeUntil(this.taskEnd$)),i=this.taskEnd$.pipe(r.mapTo(1)),o=e.pipe(r.mapTo(-1)),s=this.busyMinDurationTimer.pipe(r.mapTo(-1)),a=n.combineLatest([i.pipe(r.startWith(null)),o.pipe(r.startWith(null))]).pipe(r.skip(1)),u=a.pipe(r.filter((function(t){var e=p(t,2),n=e[0],r=e[1];return 1===n&&null===r}))).pipe(r.mapTo(!1)),l=a.pipe(r.filter((function(t){var e=p(t,2),n=e[0],r=e[1];return null===n&&-1===r}))).pipe(r.mapTo(!0)).pipe(r.tap((function(){t.show()}))),c=n.combineLatest([i.pipe(r.startWith(null)),s.pipe(r.startWith(null))]).pipe(r.skip(1)),f=c.pipe(r.filter((function(t){var e=p(t,2),n=e[0],r=e[1];return 1===n&&null===r}))),h=c.pipe(r.filter((function(t){var e=p(t,2),n=e[0],r=e[1];return 1===n&&-1===r}))),b=n.merge(u,n.combineLatest([f,s]),h).pipe(r.tap((function(){t.hide()})));return l.pipe(r.takeUntil(b))},t.prototype.showLoadingStatus=function(){var t=this;return this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe(),this.sub=this.controller().subscribe(),function(e){return new n.Observable((function(i){var o=e.pipe(r.tap((function(){t.taskEndSubject.next()}))),s=n.of(null).pipe(r.tap((function(){t.taskStartSubject.next()})),r.concatMap((function(){return o})),r.shareReplay(1)).subscribe(i);return function(){s.unsubscribe()}}))}},t.prototype.showingFor=function(t){var e=this;this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe(),this.sub=this.controller().subscribe();var i=t.pipe(r.tap((function(){e.taskEndSubject.next()})));return n.of(null).pipe(r.tap((function(){e.taskStartSubject.next()})),r.concatMap((function(){return i})),r.shareReplay(1))},t.ctorParameters=function(){return[{type:void 0,decorators:[{type:e.Optional},{type:e.Inject,args:[b]}]}]},t=u([e.Injectable(),l(0,e.Optional()),l(0,e.Inject(b))],t)}(),y=function(){function t(t){this.loadingService=t,this.ariaLabel="Loading...",this.isVisible=!1}return t.prototype.ngOnInit=function(){this.service=this.getService(),this.loading$=this.service.loading$},t.prototype.getService=function(){return this.bind||this.loadingService},t.prototype.show=function(){this.service.show(),this.isVisible=!0},t.prototype.hide=function(){this.service.hide(),this.isVisible=!1},t.ctorParameters=function(){return[{type:d}]},u([e.Input()],t.prototype,"fallback",void 0),u([e.Input()],t.prototype,"ariaLabel",void 0),u([e.Input()],t.prototype,"bind",void 0),u([e.Input()],t.prototype,"isVisible",void 0),t=u([e.Component({selector:"Suspense",template:'<ng-template #content>\n \x3c!-- animation doesn\'t work with ng-template, ng-content or ng-container, have to add extra div for workaround--\x3e\n <div [@fadeIn]>\n <ng-content></ng-content>\n </div>\n</ng-template>\n\n<div\n *ngIf="(loading$ | async) || isVisible; else content"\n role="alert"\n aria-busy="true"\n aria-hidden="false"\n [attr.aria-label]="ariaLabel"\n>\n <ng-container *ngTemplateOutlet="fallback"></ng-container>\n</div>\n',animations:[i.trigger("fadeIn",[i.transition(":enter",[i.style({opacity:0}),i.animate("300ms ease-in",i.style({opacity:1}))])])],styles:["\n :host {\n display: block;\n }\n "]})],t)}(),g=function(){function t(){this.revealOrder="*",this.subs=[],this.allBroadcasters=[],this.allListeners=[]}return t.prototype.ngOnInit=function(){},t.prototype.ngAfterContentInit=function(){var t=this;this.allBroadcasters=this.skeletons.map((function(t){return t.loading$})),this.allListeners=this.skeletons.map((function(e){return t.hideSkeletonListener(e)})),this.revealOrderOperator(this.revealOrder)},t.prototype.ngOnChanges=function(t){t.revealOrder&&this.revealOrderOperator(t.revealOrder.currentValue)},t.prototype.ngOnDestroy=function(){this.subs.length&&(this.subs.forEach((function(t){return t.unsubscribe()})),this.subs.length=0)},t.prototype.reload=function(t){this.revealOrderOperator(t||this.revealOrder)},t.prototype.revealOrderOperator=function(t){if(0!==this.allBroadcasters.length&&0!==this.allListeners.length)switch(this.subs.length&&(this.subs.forEach((function(t){return t.unsubscribe()})),this.subs.length=0),t){case"together":var e=this.togetherOperator(this.allBroadcasters)(this.allListeners);this.subs.push(e);break;case"forwards":var n=this.domOrderOperator(this.allBroadcasters)(this.allListeners);this.subs=n;break;case"backwards":var r=f(this.allBroadcasters).reverse(),i=f(this.allListeners).reverse();n=this.domOrderOperator(r)(i);this.subs=n}},t.prototype.hideSkeletonListener=function(t){return function(){t.hide()}},t.prototype.showSkeletonListener=function(t){return function(){t.show()}},t.prototype.togetherOperator=function(t){var e=this;return this.skeletons.forEach((function(t){return e.showSkeletonListener(t)()})),function(e){return n.combineLatest(f(t)).pipe(r.skip(1),r.pairwise(),r.filter((function(t){var e=p(t,2),n=e[0],r=e[1],i=n.some((function(t){return t})),o=!r.some((function(t){return t}));return i&&o}))).subscribe((function(){e.forEach((function(t){return t()}))}))}},t.prototype.domOrderOperator=function(t){var e=this;return this.skeletons.forEach((function(t){return e.showSkeletonListener(t)()})),function(n){var i=[],o=f(new Array(t.length)).fill(null);return t.forEach((function(t,s){i.push(t.pipe(r.skip(1),r.pairwise(),r.filter((function(t){var e=p(t,2),n=e[0],r=e[1];return n&&!r}))).subscribe((function(){var t,r;o[s]=!0;var i=e.getFlushIndexes(o);try{for(var a=c(i),u=a.next();!u.done;u=a.next()){var l=u.value;n[l]()}}catch(e){t={error:e}}finally{try{u&&!u.done&&(r=a.return)&&r.call(a)}finally{if(t)throw t.error}}})))})),i}},t.prototype.getFlushIndexes=function(t){for(var e=[],n=0;n<t.length;n++)if(!(e.indexOf(n)>-1)){if(null===t[n])break;e.push(n)}return e},u([e.Input()],t.prototype,"revealOrder",void 0),u([e.ContentChildren(y)],t.prototype,"skeletons",void 0),t=u([e.Component({selector:"SuspenseList",template:"<ng-content></ng-content>\n",exportAs:"list"})],t)}(),v=h,m=function(){function t(){}var n;return n=t,t.forRoot=function(t){return{ngModule:n,providers:[{provide:b,useValue:a(a({},h),t)}]}},t=n=u([e.NgModule({declarations:[g,y],imports:[o.BrowserAnimationsModule,s.CommonModule],providers:[{provide:b,useValue:v}],exports:[y,g]})],t)}();t.LOADING_CONFIG_TOKEN=b,t.LOADING_DEFUALT_CONFIG=h,t.NgxSuspenseComponent=y,t.NgxSuspenseListComponent=g,t.NgxSuspenseModule=m,t.NgxSuspenseService=d,t.ɵ0=v,Object.defineProperty(t,"__esModule",{value:!0})}));
***************************************************************************** */var a=function(){return(a=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var i in e=arguments[n])Object.prototype.hasOwnProperty.call(e,i)&&(t[i]=e[i]);return t}).apply(this,arguments)};function u(t,e,n,r){var i,o=arguments.length,s=o<3?e:null===r?r=Object.getOwnPropertyDescriptor(e,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(t,e,n,r);else for(var a=t.length-1;a>=0;a--)(i=t[a])&&(s=(o<3?i(s):o>3?i(e,n,s):i(e,n))||s);return o>3&&s&&Object.defineProperty(e,n,s),s}function l(t,e){return function(n,r){e(n,r,t)}}function p(t){var e="function"==typeof Symbol&&Symbol.iterator,n=e&&t[e],r=0;if(n)return n.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function c(t,e){var n="function"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,i,o=n.call(t),s=[];try{for(;(void 0===e||e-- >0)&&!(r=o.next()).done;)s.push(r.value)}catch(t){i={error:t}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(i)throw i.error}}return s}function f(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(c(arguments[e]));return t}var h={busyMinDurationMs:0,busyDelayMs:0},b=new e.InjectionToken("LOADING_CONFIG_TOKEN"),d=function(){function t(t){void 0===t&&(t=h),this.userConfig=t,this.loadingSubject=new n.BehaviorSubject(!1),this.loading$=this.loadingSubject.asObservable(),this.taskStartSubject=new n.Subject,this.taskStart$=this.taskStartSubject.asObservable(),this.taskEndSubject=new n.Subject,this.taskEnd$=this.taskEndSubject.asObservable()}return t.prototype.ngOnDestroy=function(){this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe()},Object.defineProperty(t.prototype,"busyTimer",{set:function(t){var e=t.busyDelayMs,n=t.busyMinDurationMs;"number"==typeof e&&(this.userConfig.busyDelayMs=e),"number"==typeof n&&(this.userConfig.busyMinDurationMs=n)},enumerable:!0,configurable:!0}),Object.defineProperty(t.prototype,"config",{get:function(){return this.userConfig},enumerable:!0,configurable:!0}),t.prototype.show=function(){this.loadingSubject.next(!0)},t.prototype.hide=function(){this.loadingSubject.next(!1)},t.prototype.controller=function(){var t=this;this.busyMinDurationTimer=n.timer(this.config.busyMinDurationMs+this.config.busyDelayMs),this.busyDelayTimer=n.timer(this.config.busyDelayMs);var e=this.taskStart$.pipe(r.switchMap((function(){return t.busyDelayTimer}))).pipe(r.takeUntil(this.taskEnd$)),i=this.taskEnd$.pipe(r.mapTo(1)),o=e.pipe(r.mapTo(-1)),s=this.busyMinDurationTimer.pipe(r.mapTo(-1)),a=n.combineLatest([i.pipe(r.startWith(null)),o.pipe(r.startWith(null))]).pipe(r.skip(1)),u=a.pipe(r.filter((function(t){var e=c(t,2),n=e[0],r=e[1];return 1===n&&null===r}))).pipe(r.mapTo(!1)),l=a.pipe(r.filter((function(t){var e=c(t,2),n=e[0],r=e[1];return null===n&&-1===r}))).pipe(r.mapTo(!0)).pipe(r.tap((function(){t.show()}))),p=n.combineLatest([i.pipe(r.startWith(null)),s.pipe(r.startWith(null))]).pipe(r.skip(1)),f=p.pipe(r.filter((function(t){var e=c(t,2),n=e[0],r=e[1];return 1===n&&null===r}))),h=p.pipe(r.filter((function(t){var e=c(t,2),n=e[0],r=e[1];return 1===n&&-1===r}))),b=n.merge(u,n.combineLatest([f,s]),h).pipe(r.tap((function(){t.hide()})));return l.pipe(r.takeUntil(b))},t.prototype.showLoadingStatus=function(){var t=this;return this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe(),this.sub=this.controller().subscribe(),function(e){return new n.Observable((function(i){var o=e.pipe(r.tap((function(){t.taskEndSubject.next()}))),s=n.of(null).pipe(r.tap((function(){t.taskStartSubject.next()})),r.concatMap((function(){return o})),r.shareReplay(1)).subscribe(i);return function(){s.unsubscribe()}}))}},t.prototype.showingFor=function(t){var e=this;this.sub&&"function"==typeof this.sub.unsubscribe&&this.sub.unsubscribe(),this.sub=this.controller().subscribe();var i=t.pipe(r.tap((function(){e.taskEndSubject.next()})));return n.of(null).pipe(r.tap((function(){e.taskStartSubject.next()})),r.concatMap((function(){return i})),r.shareReplay(1))},t.ctorParameters=function(){return[{type:void 0,decorators:[{type:e.Optional},{type:e.Inject,args:[b]}]}]},t=u([e.Injectable(),l(0,e.Optional()),l(0,e.Inject(b))],t)}(),y=function(){function t(t){this.loadingService=t,this.ariaLabel="Loading...",this.isVisible=!1}return t.prototype.ngOnInit=function(){this.service=this.getService(),this.loading$=this.service.loading$},t.prototype.getService=function(){return this.bind||this.loadingService},t.prototype.show=function(){this.service.show(),this.isVisible=!0},t.prototype.hide=function(){this.service.hide(),this.isVisible=!1},t.ctorParameters=function(){return[{type:d}]},u([e.Input()],t.prototype,"fallback",void 0),u([e.Input()],t.prototype,"ariaLabel",void 0),u([e.Input()],t.prototype,"bind",void 0),u([e.Input()],t.prototype,"isVisible",void 0),t=u([e.Component({selector:"Suspense",template:'<ng-template #content>\n \x3c!-- animation doesn\'t work with ng-template, ng-content or ng-container, have to add extra div for workaround--\x3e\n <div [@fadeIn]>\n <ng-content></ng-content>\n </div>\n</ng-template>\n\n<div\n *ngIf="(loading$ | async) || isVisible; else content"\n role="alert"\n aria-busy="true"\n aria-hidden="false"\n [attr.aria-label]="ariaLabel"\n>\n <ng-container *ngTemplateOutlet="fallback"></ng-container>\n</div>\n',animations:[i.trigger("fadeIn",[i.transition(":enter",[i.style({opacity:0}),i.animate("300ms ease-in",i.style({opacity:1}))])])],styles:["\n :host {\n display: block;\n }\n "]})],t)}(),g=function(){function t(){this.revealOrder="*",this.subs=[],this.allBroadcasters=[],this.allListeners=[],this.hasParentControlSubject=new n.BehaviorSubject(void 0),this.parentControl$=this.hasParentControlSubject.asObservable()}var i;return i=t,t.prototype.ngOnInit=function(){this.parentControl$.pipe(r.tap((function(t){console.log("release",t)}))).subscribe()},t.prototype.ngAfterContentInit=function(){var t=this;this.allBroadcasters=this.skeletons.map((function(t){return t.loading$})),this.allListeners=this.skeletons.map((function(e){return t.hideSkeletonListener(e)})),this.revealOrderOperator(this.revealOrder)},t.prototype.ngOnChanges=function(t){t.revealOrder&&this.revealOrderOperator(t.revealOrder.currentValue)},t.prototype.ngOnDestroy=function(){this.subs.length&&(this.subs.forEach((function(t){return t.unsubscribe()})),this.subs.length=0)},t.prototype.reload=function(t){this.revealOrderOperator(t||this.revealOrder)},t.prototype.show=function(){},t.prototype.hide=function(){},t.prototype.revealOrderOperator=function(t){if(0!==this.allBroadcasters.length&&0!==this.allListeners.length)switch(this.subs.length&&(this.subs.forEach((function(t){return t.unsubscribe()})),this.subs.length=0),t){case"together":var e=this.togetherOperator(this.allBroadcasters)(this.allListeners);this.subs.push(e);break;case"forwards":var n=this.domOrderOperator(this.allBroadcasters)(this.allListeners);this.subs=n;break;case"backwards":var r=f(this.allBroadcasters).reverse(),i=f(this.allListeners).reverse();n=this.domOrderOperator(r)(i);this.subs=n}},t.prototype.hideSkeletonListener=function(t){return function(){t.hide()}},t.prototype.showSkeletonListener=function(t){return function(){t.show()}},t.prototype.togetherOperator=function(t){var e=this;return this.skeletons.forEach((function(t){return e.showSkeletonListener(t)()})),function(e){return n.combineLatest(f(t)).pipe(r.skip(1),r.pairwise(),r.filter((function(t){var e=c(t,2),n=e[0],r=e[1],i=n.some((function(t){return t})),o=!r.some((function(t){return t}));return i&&o}))).subscribe((function(){e.forEach((function(t){return t()}))}))}},t.prototype.domOrderOperator=function(t){var e=this;return this.skeletons.forEach((function(t){return e.showSkeletonListener(t)()})),function(n){var i=[],o=f(new Array(t.length)).fill(null);return t.forEach((function(t,s){i.push(t.pipe(r.skip(1),r.pairwise(),r.filter((function(t){var e=c(t,2),n=e[0],r=e[1];return n&&!r}))).subscribe((function(){var t,r;o[s]=!0;var i=e.getFlushIndexes(o);try{for(var a=p(i),u=a.next();!u.done;u=a.next()){var l=u.value;n[l]()}}catch(e){t={error:e}}finally{try{u&&!u.done&&(r=a.return)&&r.call(a)}finally{if(t)throw t.error}}})))})),i}},t.prototype.getFlushIndexes=function(t){for(var e=[],n=0;n<t.length;n++)if(!(e.indexOf(n)>-1)){if(null===t[n])break;e.push(n)}return e},u([e.Input()],t.prototype,"revealOrder",void 0),u([e.ContentChildren(y)],t.prototype,"skeletons",void 0),u([e.ContentChildren(i)],t.prototype,"list",void 0),t=i=u([e.Component({selector:"SuspenseList",template:"<ng-content></ng-content>\n",exportAs:"list"})],t)}(),v=h,m=function(){function t(){}var n;return n=t,t.forRoot=function(t){return{ngModule:n,providers:[{provide:b,useValue:a(a({},h),t)}]}},t=n=u([e.NgModule({declarations:[g,y],imports:[o.BrowserAnimationsModule,s.CommonModule],providers:[{provide:b,useValue:v}],schemas:[e.CUSTOM_ELEMENTS_SCHEMA],exports:[y,g]})],t)}();t.LOADING_CONFIG_TOKEN=b,t.LOADING_DEFUALT_CONFIG=h,t.NgxSuspenseComponent=y,t.NgxSuspenseListComponent=g,t.NgxSuspenseModule=m,t.NgxSuspenseService=d,t.ɵ0=v,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=ngx-suspense.umd.min.js.map

@@ -0,7 +1,8 @@

var NgxSuspenseListComponent_1;
import { __decorate } from "tslib";
import { Component, Input, ContentChildren, } from "@angular/core";
import { NgxSuspenseComponent } from "./ngx-suspense.component";
import { combineLatest } from "rxjs";
import { filter, skip, pairwise } from "rxjs/operators";
let NgxSuspenseListComponent = class NgxSuspenseListComponent {
import { combineLatest, BehaviorSubject, } from "rxjs";
import { filter, skip, pairwise, tap } from "rxjs/operators";
let NgxSuspenseListComponent = NgxSuspenseListComponent_1 = class NgxSuspenseListComponent {
constructor() {

@@ -12,4 +13,12 @@ this.revealOrder = "*";

this.allListeners = [];
this.hasParentControlSubject = new BehaviorSubject(undefined);
this.parentControl$ = this.hasParentControlSubject.asObservable();
}
ngOnInit() { }
ngOnInit() {
this.parentControl$
.pipe(tap((val) => {
console.log("release", val);
}))
.subscribe();
}
ngAfterContentInit() {

@@ -34,2 +43,4 @@ this.allBroadcasters = this.skeletons.map((s) => s.loading$);

}
show() { }
hide() { }
revealOrderOperator(order) {

@@ -145,3 +156,6 @@ if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {

], NgxSuspenseListComponent.prototype, "skeletons", void 0);
NgxSuspenseListComponent = __decorate([
__decorate([
ContentChildren(NgxSuspenseListComponent_1)
], NgxSuspenseListComponent.prototype, "list", void 0);
NgxSuspenseListComponent = NgxSuspenseListComponent_1 = __decorate([
Component({

@@ -154,2 +168,2 @@ selector: "SuspenseList",

export { NgxSuspenseListComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-suspense-list.component.js","sourceRoot":"ng://ngx-suspense/","sources":["lib/ngx-suspense-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterContentInit,\n  ContentChildren,\n  QueryList,\n  SimpleChanges,\n  OnDestroy,\n} from \"@angular/core\";\nimport { NgxSuspenseComponent } from \"./ngx-suspense.component\";\nimport { combineLatest, Subscription } from \"rxjs\";\nimport { filter, skip, pairwise } from \"rxjs/operators\";\n\ntype ORDERS = \"*\" | \"together\" | \"forwards\" | \"backwards\";\n\n@Component({\n  selector: \"SuspenseList\",\n  templateUrl: \"./ngx-suspense-list.component.html\",\n  exportAs: \"list\",\n})\nexport class NgxSuspenseListComponent implements AfterContentInit, OnDestroy {\n  @Input() revealOrder: ORDERS = \"*\";\n  @ContentChildren(NgxSuspenseComponent) skeletons: QueryList<\n    NgxSuspenseComponent\n  >;\n  subs: Array<Subscription> = [];\n  allBroadcasters = [];\n  allListeners = [];\n\n  ngOnInit() {}\n\n  ngAfterContentInit() {\n    this.allBroadcasters = this.skeletons.map((s) => s.loading$);\n    this.allListeners = this.skeletons.map((s) => this.hideSkeletonListener(s));\n    this.revealOrderOperator(this.revealOrder);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.revealOrder) {\n      this.revealOrderOperator(changes.revealOrder.currentValue);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n  }\n\n  reload(order) {\n    this.revealOrderOperator(order || this.revealOrder);\n  }\n\n  private revealOrderOperator(order: ORDERS) {\n    if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {\n      return;\n    }\n\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n    switch (order) {\n      case \"together\": {\n        const sub = this.togetherOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs.push(sub);\n        break;\n      }\n      case \"forwards\": {\n        const subs = this.domOrderOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs = subs;\n        break;\n      }\n      case \"backwards\": {\n        const broadcasters = [...this.allBroadcasters].reverse();\n        const listeners = [...this.allListeners].reverse();\n        const subs = this.domOrderOperator(broadcasters)(listeners);\n        this.subs = subs;\n        break;\n      }\n      default:\n\n      // nothing should happen\n    }\n  }\n\n  private hideSkeletonListener(skeleton: NgxSuspenseComponent) {\n    return () => {\n      skeleton.hide();\n    };\n  }\n\n  private showSkeletonListener(skeleton: NgxSuspenseComponent) {\n    return () => {\n      skeleton.show();\n    };\n  }\n\n  private togetherOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      return combineLatest([...broadcasters])\n        .pipe(\n          // skip default\n          skip(1),\n          // keep tracking previous value\n          pairwise(),\n          filter(([ary1, ary2]) => {\n            // any loading state is ture\n            const cond1 = ary1.some((b) => b);\n            // all loading state is false\n            const cond2 = !ary2.some((b) => b);\n            // pass only when prev loading state is ture, current is false\n            return cond1 && cond2;\n          })\n        )\n        .subscribe(() => {\n          listeners.forEach((hide: any) => hide());\n        });\n    };\n  }\n\n  private domOrderOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      let subs = [];\n      let checks = [...new Array(broadcasters.length)].fill(null);\n      broadcasters.forEach((boradcaster, index) => {\n        subs.push(\n          boradcaster\n            .pipe(\n              // skip default\n              skip(1),\n              // keep tracking previous value\n              pairwise(),\n              filter(([b1, b2]) => {\n                // pass only when prev loading state is ture, current is false\n                return b1 && !b2;\n              })\n            )\n            .subscribe(() => {\n              checks[index] = true;\n              const indexesToFlush = this.getFlushIndexes(checks);\n              for (let i of indexesToFlush) {\n                listeners[i]();\n              }\n            })\n        );\n      });\n      return subs;\n    };\n  }\n\n  private getFlushIndexes(checks) {\n    const indexesToFlush = [];\n    for (let i = 0; i < checks.length; i++) {\n      if (indexesToFlush.indexOf(i) > -1) {\n        continue;\n      }\n      const check = checks[i];\n      if (check !== null) {\n        indexesToFlush.push(i);\n      } else {\n        break;\n      }\n    }\n\n    return indexesToFlush;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-suspense-list.component.js","sourceRoot":"ng://ngx-suspense/","sources":["lib/ngx-suspense-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterContentInit,\n  ContentChildren,\n  QueryList,\n  SimpleChanges,\n  OnDestroy,\n} from \"@angular/core\";\nimport { NgxSuspenseComponent } from \"./ngx-suspense.component\";\nimport {\n  combineLatest,\n  Subscription,\n  Subject,\n  BehaviorSubject,\n  Observable,\n} from \"rxjs\";\nimport { filter, skip, pairwise, tap, startWith } from \"rxjs/operators\";\n\ntype ORDERS = \"*\" | \"together\" | \"forwards\" | \"backwards\";\n\n@Component({\n  selector: \"SuspenseList\",\n  templateUrl: \"./ngx-suspense-list.component.html\",\n  exportAs: \"list\",\n})\nexport class NgxSuspenseListComponent implements AfterContentInit, OnDestroy {\n  @Input() revealOrder: ORDERS = \"*\";\n  @ContentChildren(NgxSuspenseComponent) skeletons: QueryList<\n    NgxSuspenseComponent\n  >;\n  @ContentChildren(NgxSuspenseListComponent) list: QueryList<\n    NgxSuspenseListComponent\n  >;\n  loading$: Observable<boolean>;\n  subs: Array<Subscription> = [];\n  allBroadcasters = [];\n  allListeners = [];\n\n  private hasParentControlSubject = new BehaviorSubject(undefined);\n  private parentControl$ = this.hasParentControlSubject.asObservable();\n\n  ngOnInit() {\n    this.parentControl$\n      .pipe(\n        tap((val) => {\n          console.log(\"release\", val);\n        })\n      )\n      .subscribe();\n  }\n\n  ngAfterContentInit() {\n    this.allBroadcasters = this.skeletons.map((s) => s.loading$);\n    this.allListeners = this.skeletons.map((s) => this.hideSkeletonListener(s));\n    this.revealOrderOperator(this.revealOrder);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.revealOrder) {\n      this.revealOrderOperator(changes.revealOrder.currentValue);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n  }\n\n  reload(order) {\n    this.revealOrderOperator(order || this.revealOrder);\n  }\n\n  show() {}\n\n  hide() {}\n\n  private revealOrderOperator(order: ORDERS) {\n    if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {\n      return;\n    }\n\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n    switch (order) {\n      case \"together\": {\n        const sub = this.togetherOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs.push(sub);\n        break;\n      }\n      case \"forwards\": {\n        const subs = this.domOrderOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs = subs;\n        break;\n      }\n      case \"backwards\": {\n        const broadcasters = [...this.allBroadcasters].reverse();\n        const listeners = [...this.allListeners].reverse();\n        const subs = this.domOrderOperator(broadcasters)(listeners);\n        this.subs = subs;\n        break;\n      }\n      default:\n\n      // nothing should happen\n    }\n  }\n\n  private hideSkeletonListener(\n    skeleton: NgxSuspenseComponent | NgxSuspenseListComponent\n  ) {\n    return () => {\n      skeleton.hide();\n    };\n  }\n\n  private showSkeletonListener(\n    skeleton: NgxSuspenseComponent | NgxSuspenseListComponent\n  ) {\n    return () => {\n      skeleton.show();\n    };\n  }\n\n  private togetherOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      return combineLatest([...broadcasters])\n        .pipe(\n          // skip default\n          skip(1),\n          // keep tracking previous value\n          pairwise(),\n          filter(([ary1, ary2]) => {\n            // any loading state is ture\n            const cond1 = ary1.some((b) => b);\n            // all loading state is false\n            const cond2 = !ary2.some((b) => b);\n            // pass only when prev loading state is ture, current is false\n            return cond1 && cond2;\n          })\n        )\n        .subscribe(() => {\n          listeners.forEach((hide: any) => hide());\n        });\n    };\n  }\n\n  private domOrderOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      let subs = [];\n      let checks = [...new Array(broadcasters.length)].fill(null);\n      broadcasters.forEach((boradcaster, index) => {\n        subs.push(\n          boradcaster\n            .pipe(\n              // skip default\n              skip(1),\n              // keep tracking previous value\n              pairwise(),\n              filter(([b1, b2]) => {\n                // pass only when prev loading state is ture, current is false\n                return b1 && !b2;\n              })\n            )\n            .subscribe(() => {\n              checks[index] = true;\n              const indexesToFlush = this.getFlushIndexes(checks);\n              for (let i of indexesToFlush) {\n                listeners[i]();\n              }\n            })\n        );\n      });\n      return subs;\n    };\n  }\n\n  private getFlushIndexes(checks) {\n    const indexesToFlush = [];\n    for (let i = 0; i < checks.length; i++) {\n      if (indexesToFlush.indexOf(i) > -1) {\n        continue;\n      }\n      const check = checks[i];\n      if (check !== null) {\n        indexesToFlush.push(i);\n      } else {\n        break;\n      }\n    }\n\n    return indexesToFlush;\n  }\n}\n"]}
var NgxSuspenseModule_1;
import { __decorate } from "tslib";
import { NgModule } from "@angular/core";
import { NgModule, CUSTOM_ELEMENTS_SCHEMA, } from "@angular/core";
import { NgxSuspenseComponent } from "./ngx-suspense.component";

@@ -33,2 +33,3 @@ import { LOADING_CONFIG_TOKEN, LOADING_DEFUALT_CONFIG, } from "./ngx-suspense.config";

],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
exports: [NgxSuspenseComponent, NgxSuspenseListComponent],

@@ -39,2 +40,2 @@ })

export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXN1c3BlbnNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1zdXNwZW5zZS8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtc3VzcGVuc2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUNMLG9CQUFvQixFQUNwQixzQkFBc0IsR0FFdkIsTUFBTSx1QkFBdUIsQ0FBQztBQUMvQixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7V0FRekQsc0JBQXNCO0FBS3RDLElBQWEsaUJBQWlCLHlCQUE5QixNQUFhLGlCQUFpQjtJQUM1QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXNCO1FBQ25DLE9BQU87WUFDTCxRQUFRLEVBQUUsbUJBQWlCO1lBQzNCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsb0JBQW9CO29CQUM3QixRQUFRLGtDQUNILHNCQUFzQixHQUN0QixNQUFNLENBQ1Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0YsQ0FBQTtBQWZZLGlCQUFpQjtJQVg3QixRQUFRLENBQUM7UUFDUixZQUFZLEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSxvQkFBb0IsQ0FBQztRQUM5RCxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxZQUFZLENBQUM7UUFDaEQsU0FBUyxFQUFFO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLG9CQUFvQjtnQkFDN0IsUUFBUSxJQUF3QjthQUNqQztTQUNGO1FBQ0QsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsd0JBQXdCLENBQUM7S0FDMUQsQ0FBQztHQUNXLGlCQUFpQixDQWU3QjtTQWZZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE5neFN1c3BlbnNlQ29tcG9uZW50IH0gZnJvbSBcIi4vbmd4LXN1c3BlbnNlLmNvbXBvbmVudFwiO1xuaW1wb3J0IHtcbiAgTE9BRElOR19DT05GSUdfVE9LRU4sXG4gIExPQURJTkdfREVGVUFMVF9DT05GSUcsXG4gIElMb2FkaW5nQ29uZmlnLFxufSBmcm9tIFwiLi9uZ3gtc3VzcGVuc2UuY29uZmlnXCI7XG5pbXBvcnQgeyBCcm93c2VyQW5pbWF0aW9uc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyL2FuaW1hdGlvbnNcIjtcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5neFN1c3BlbnNlTGlzdENvbXBvbmVudCB9IGZyb20gXCIuL25neC1zdXNwZW5zZS1saXN0LmNvbXBvbmVudFwiO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtOZ3hTdXNwZW5zZUxpc3RDb21wb25lbnQsIE5neFN1c3BlbnNlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0Jyb3dzZXJBbmltYXRpb25zTW9kdWxlLCBDb21tb25Nb2R1bGVdLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBMT0FESU5HX0NPTkZJR19UT0tFTixcbiAgICAgIHVzZVZhbHVlOiBMT0FESU5HX0RFRlVBTFRfQ09ORklHLFxuICAgIH0sXG4gIF0sXG4gIGV4cG9ydHM6IFtOZ3hTdXNwZW5zZUNvbXBvbmVudCwgTmd4U3VzcGVuc2VMaXN0Q29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmd4U3VzcGVuc2VNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChjb25maWc6IElMb2FkaW5nQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBOZ3hTdXNwZW5zZU1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogTE9BRElOR19DT05GSUdfVE9LRU4sXG4gICAgICAgICAgdXNlVmFsdWU6IHtcbiAgICAgICAgICAgIC4uLkxPQURJTkdfREVGVUFMVF9DT05GSUcsXG4gICAgICAgICAgICAuLi5jb25maWcsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXN1c3BlbnNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1zdXNwZW5zZS8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtc3VzcGVuc2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUNMLFFBQVEsRUFFUixzQkFBc0IsR0FDdkIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUNMLG9CQUFvQixFQUNwQixzQkFBc0IsR0FFdkIsTUFBTSx1QkFBdUIsQ0FBQztBQUMvQixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7V0FRekQsc0JBQXNCO0FBTXRDLElBQWEsaUJBQWlCLHlCQUE5QixNQUFhLGlCQUFpQjtJQUM1QixNQUFNLENBQUMsT0FBTyxDQUFDLE1BQXNCO1FBQ25DLE9BQU87WUFDTCxRQUFRLEVBQUUsbUJBQWlCO1lBQzNCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsb0JBQW9CO29CQUM3QixRQUFRLGtDQUNILHNCQUFzQixHQUN0QixNQUFNLENBQ1Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0YsQ0FBQTtBQWZZLGlCQUFpQjtJQVo3QixRQUFRLENBQUM7UUFDUixZQUFZLEVBQUUsQ0FBQyx3QkFBd0IsRUFBRSxvQkFBb0IsQ0FBQztRQUM5RCxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxZQUFZLENBQUM7UUFDaEQsU0FBUyxFQUFFO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLG9CQUFvQjtnQkFDN0IsUUFBUSxJQUF3QjthQUNqQztTQUNGO1FBQ0QsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7UUFDakMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsd0JBQXdCLENBQUM7S0FDMUQsQ0FBQztHQUNXLGlCQUFpQixDQWU3QjtTQWZZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE5nTW9kdWxlLFxuICBNb2R1bGVXaXRoUHJvdmlkZXJzLFxuICBDVVNUT01fRUxFTUVOVFNfU0NIRU1BLFxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTmd4U3VzcGVuc2VDb21wb25lbnQgfSBmcm9tIFwiLi9uZ3gtc3VzcGVuc2UuY29tcG9uZW50XCI7XG5pbXBvcnQge1xuICBMT0FESU5HX0NPTkZJR19UT0tFTixcbiAgTE9BRElOR19ERUZVQUxUX0NPTkZJRyxcbiAgSUxvYWRpbmdDb25maWcsXG59IGZyb20gXCIuL25neC1zdXNwZW5zZS5jb25maWdcIjtcbmltcG9ydCB7IEJyb3dzZXJBbmltYXRpb25zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9uc1wiO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHsgTmd4U3VzcGVuc2VMaXN0Q29tcG9uZW50IH0gZnJvbSBcIi4vbmd4LXN1c3BlbnNlLWxpc3QuY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW05neFN1c3BlbnNlTGlzdENvbXBvbmVudCwgTmd4U3VzcGVuc2VDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQnJvd3NlckFuaW1hdGlvbnNNb2R1bGUsIENvbW1vbk1vZHVsZV0sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IExPQURJTkdfQ09ORklHX1RPS0VOLFxuICAgICAgdXNlVmFsdWU6IExPQURJTkdfREVGVUFMVF9DT05GSUcsXG4gICAgfSxcbiAgXSxcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxuICBleHBvcnRzOiBbTmd4U3VzcGVuc2VDb21wb25lbnQsIE5neFN1c3BlbnNlTGlzdENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE5neFN1c3BlbnNlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3QoY29uZmlnOiBJTG9hZGluZ0NvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogTmd4U3VzcGVuc2VNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IExPQURJTkdfQ09ORklHX1RPS0VOLFxuICAgICAgICAgIHVzZVZhbHVlOiB7XG4gICAgICAgICAgICAuLi5MT0FESU5HX0RFRlVBTFRfQ09ORklHLFxuICAgICAgICAgICAgLi4uY29uZmlnLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
import { __decorate, __read, __spread, __values } from "tslib";
import { Component, Input, ContentChildren, } from "@angular/core";
import { NgxSuspenseComponent } from "./ngx-suspense.component";
import { combineLatest } from "rxjs";
import { filter, skip, pairwise } from "rxjs/operators";
import { combineLatest, BehaviorSubject, } from "rxjs";
import { filter, skip, pairwise, tap } from "rxjs/operators";
var NgxSuspenseListComponent = /** @class */ (function () {

@@ -12,4 +12,13 @@ function NgxSuspenseListComponent() {

this.allListeners = [];
this.hasParentControlSubject = new BehaviorSubject(undefined);
this.parentControl$ = this.hasParentControlSubject.asObservable();
}
NgxSuspenseListComponent.prototype.ngOnInit = function () { };
NgxSuspenseListComponent_1 = NgxSuspenseListComponent;
NgxSuspenseListComponent.prototype.ngOnInit = function () {
this.parentControl$
.pipe(tap(function (val) {
console.log("release", val);
}))
.subscribe();
};
NgxSuspenseListComponent.prototype.ngAfterContentInit = function () {

@@ -35,2 +44,4 @@ var _this = this;

};
NgxSuspenseListComponent.prototype.show = function () { };
NgxSuspenseListComponent.prototype.hide = function () { };
NgxSuspenseListComponent.prototype.revealOrderOperator = function (order) {

@@ -154,2 +165,3 @@ if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {

};
var NgxSuspenseListComponent_1;
__decorate([

@@ -161,3 +173,6 @@ Input()

], NgxSuspenseListComponent.prototype, "skeletons", void 0);
NgxSuspenseListComponent = __decorate([
__decorate([
ContentChildren(NgxSuspenseListComponent_1)
], NgxSuspenseListComponent.prototype, "list", void 0);
NgxSuspenseListComponent = NgxSuspenseListComponent_1 = __decorate([
Component({

@@ -172,2 +187,2 @@ selector: "SuspenseList",

export { NgxSuspenseListComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-suspense-list.component.js","sourceRoot":"ng://ngx-suspense/","sources":["lib/ngx-suspense-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterContentInit,\n  ContentChildren,\n  QueryList,\n  SimpleChanges,\n  OnDestroy,\n} from \"@angular/core\";\nimport { NgxSuspenseComponent } from \"./ngx-suspense.component\";\nimport { combineLatest, Subscription } from \"rxjs\";\nimport { filter, skip, pairwise } from \"rxjs/operators\";\n\ntype ORDERS = \"*\" | \"together\" | \"forwards\" | \"backwards\";\n\n@Component({\n  selector: \"SuspenseList\",\n  templateUrl: \"./ngx-suspense-list.component.html\",\n  exportAs: \"list\",\n})\nexport class NgxSuspenseListComponent implements AfterContentInit, OnDestroy {\n  @Input() revealOrder: ORDERS = \"*\";\n  @ContentChildren(NgxSuspenseComponent) skeletons: QueryList<\n    NgxSuspenseComponent\n  >;\n  subs: Array<Subscription> = [];\n  allBroadcasters = [];\n  allListeners = [];\n\n  ngOnInit() {}\n\n  ngAfterContentInit() {\n    this.allBroadcasters = this.skeletons.map((s) => s.loading$);\n    this.allListeners = this.skeletons.map((s) => this.hideSkeletonListener(s));\n    this.revealOrderOperator(this.revealOrder);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.revealOrder) {\n      this.revealOrderOperator(changes.revealOrder.currentValue);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n  }\n\n  reload(order) {\n    this.revealOrderOperator(order || this.revealOrder);\n  }\n\n  private revealOrderOperator(order: ORDERS) {\n    if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {\n      return;\n    }\n\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n    switch (order) {\n      case \"together\": {\n        const sub = this.togetherOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs.push(sub);\n        break;\n      }\n      case \"forwards\": {\n        const subs = this.domOrderOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs = subs;\n        break;\n      }\n      case \"backwards\": {\n        const broadcasters = [...this.allBroadcasters].reverse();\n        const listeners = [...this.allListeners].reverse();\n        const subs = this.domOrderOperator(broadcasters)(listeners);\n        this.subs = subs;\n        break;\n      }\n      default:\n\n      // nothing should happen\n    }\n  }\n\n  private hideSkeletonListener(skeleton: NgxSuspenseComponent) {\n    return () => {\n      skeleton.hide();\n    };\n  }\n\n  private showSkeletonListener(skeleton: NgxSuspenseComponent) {\n    return () => {\n      skeleton.show();\n    };\n  }\n\n  private togetherOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      return combineLatest([...broadcasters])\n        .pipe(\n          // skip default\n          skip(1),\n          // keep tracking previous value\n          pairwise(),\n          filter(([ary1, ary2]) => {\n            // any loading state is ture\n            const cond1 = ary1.some((b) => b);\n            // all loading state is false\n            const cond2 = !ary2.some((b) => b);\n            // pass only when prev loading state is ture, current is false\n            return cond1 && cond2;\n          })\n        )\n        .subscribe(() => {\n          listeners.forEach((hide: any) => hide());\n        });\n    };\n  }\n\n  private domOrderOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      let subs = [];\n      let checks = [...new Array(broadcasters.length)].fill(null);\n      broadcasters.forEach((boradcaster, index) => {\n        subs.push(\n          boradcaster\n            .pipe(\n              // skip default\n              skip(1),\n              // keep tracking previous value\n              pairwise(),\n              filter(([b1, b2]) => {\n                // pass only when prev loading state is ture, current is false\n                return b1 && !b2;\n              })\n            )\n            .subscribe(() => {\n              checks[index] = true;\n              const indexesToFlush = this.getFlushIndexes(checks);\n              for (let i of indexesToFlush) {\n                listeners[i]();\n              }\n            })\n        );\n      });\n      return subs;\n    };\n  }\n\n  private getFlushIndexes(checks) {\n    const indexesToFlush = [];\n    for (let i = 0; i < checks.length; i++) {\n      if (indexesToFlush.indexOf(i) > -1) {\n        continue;\n      }\n      const check = checks[i];\n      if (check !== null) {\n        indexesToFlush.push(i);\n      } else {\n        break;\n      }\n    }\n\n    return indexesToFlush;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-suspense-list.component.js","sourceRoot":"ng://ngx-suspense/","sources":["lib/ngx-suspense-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterContentInit,\n  ContentChildren,\n  QueryList,\n  SimpleChanges,\n  OnDestroy,\n} from \"@angular/core\";\nimport { NgxSuspenseComponent } from \"./ngx-suspense.component\";\nimport {\n  combineLatest,\n  Subscription,\n  Subject,\n  BehaviorSubject,\n  Observable,\n} from \"rxjs\";\nimport { filter, skip, pairwise, tap, startWith } from \"rxjs/operators\";\n\ntype ORDERS = \"*\" | \"together\" | \"forwards\" | \"backwards\";\n\n@Component({\n  selector: \"SuspenseList\",\n  templateUrl: \"./ngx-suspense-list.component.html\",\n  exportAs: \"list\",\n})\nexport class NgxSuspenseListComponent implements AfterContentInit, OnDestroy {\n  @Input() revealOrder: ORDERS = \"*\";\n  @ContentChildren(NgxSuspenseComponent) skeletons: QueryList<\n    NgxSuspenseComponent\n  >;\n  @ContentChildren(NgxSuspenseListComponent) list: QueryList<\n    NgxSuspenseListComponent\n  >;\n  loading$: Observable<boolean>;\n  subs: Array<Subscription> = [];\n  allBroadcasters = [];\n  allListeners = [];\n\n  private hasParentControlSubject = new BehaviorSubject(undefined);\n  private parentControl$ = this.hasParentControlSubject.asObservable();\n\n  ngOnInit() {\n    this.parentControl$\n      .pipe(\n        tap((val) => {\n          console.log(\"release\", val);\n        })\n      )\n      .subscribe();\n  }\n\n  ngAfterContentInit() {\n    this.allBroadcasters = this.skeletons.map((s) => s.loading$);\n    this.allListeners = this.skeletons.map((s) => this.hideSkeletonListener(s));\n    this.revealOrderOperator(this.revealOrder);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.revealOrder) {\n      this.revealOrderOperator(changes.revealOrder.currentValue);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n  }\n\n  reload(order) {\n    this.revealOrderOperator(order || this.revealOrder);\n  }\n\n  show() {}\n\n  hide() {}\n\n  private revealOrderOperator(order: ORDERS) {\n    if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {\n      return;\n    }\n\n    if (this.subs.length) {\n      this.subs.forEach((sub) => sub.unsubscribe());\n      this.subs.length = 0;\n    }\n    switch (order) {\n      case \"together\": {\n        const sub = this.togetherOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs.push(sub);\n        break;\n      }\n      case \"forwards\": {\n        const subs = this.domOrderOperator(this.allBroadcasters)(\n          this.allListeners\n        );\n        this.subs = subs;\n        break;\n      }\n      case \"backwards\": {\n        const broadcasters = [...this.allBroadcasters].reverse();\n        const listeners = [...this.allListeners].reverse();\n        const subs = this.domOrderOperator(broadcasters)(listeners);\n        this.subs = subs;\n        break;\n      }\n      default:\n\n      // nothing should happen\n    }\n  }\n\n  private hideSkeletonListener(\n    skeleton: NgxSuspenseComponent | NgxSuspenseListComponent\n  ) {\n    return () => {\n      skeleton.hide();\n    };\n  }\n\n  private showSkeletonListener(\n    skeleton: NgxSuspenseComponent | NgxSuspenseListComponent\n  ) {\n    return () => {\n      skeleton.show();\n    };\n  }\n\n  private togetherOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      return combineLatest([...broadcasters])\n        .pipe(\n          // skip default\n          skip(1),\n          // keep tracking previous value\n          pairwise(),\n          filter(([ary1, ary2]) => {\n            // any loading state is ture\n            const cond1 = ary1.some((b) => b);\n            // all loading state is false\n            const cond2 = !ary2.some((b) => b);\n            // pass only when prev loading state is ture, current is false\n            return cond1 && cond2;\n          })\n        )\n        .subscribe(() => {\n          listeners.forEach((hide: any) => hide());\n        });\n    };\n  }\n\n  private domOrderOperator(broadcasters) {\n    this.skeletons.forEach((s) => this.showSkeletonListener(s)());\n    return (listeners) => {\n      let subs = [];\n      let checks = [...new Array(broadcasters.length)].fill(null);\n      broadcasters.forEach((boradcaster, index) => {\n        subs.push(\n          boradcaster\n            .pipe(\n              // skip default\n              skip(1),\n              // keep tracking previous value\n              pairwise(),\n              filter(([b1, b2]) => {\n                // pass only when prev loading state is ture, current is false\n                return b1 && !b2;\n              })\n            )\n            .subscribe(() => {\n              checks[index] = true;\n              const indexesToFlush = this.getFlushIndexes(checks);\n              for (let i of indexesToFlush) {\n                listeners[i]();\n              }\n            })\n        );\n      });\n      return subs;\n    };\n  }\n\n  private getFlushIndexes(checks) {\n    const indexesToFlush = [];\n    for (let i = 0; i < checks.length; i++) {\n      if (indexesToFlush.indexOf(i) > -1) {\n        continue;\n      }\n      const check = checks[i];\n      if (check !== null) {\n        indexesToFlush.push(i);\n      } else {\n        break;\n      }\n    }\n\n    return indexesToFlush;\n  }\n}\n"]}
import { __assign, __decorate } from "tslib";
import { NgModule } from "@angular/core";
import { NgModule, CUSTOM_ELEMENTS_SCHEMA, } from "@angular/core";
import { NgxSuspenseComponent } from "./ngx-suspense.component";

@@ -35,2 +35,3 @@ import { LOADING_CONFIG_TOKEN, LOADING_DEFUALT_CONFIG, } from "./ngx-suspense.config";

],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
exports: [NgxSuspenseComponent, NgxSuspenseListComponent],

@@ -43,2 +44,2 @@ })

export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXN1c3BlbnNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1zdXNwZW5zZS8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtc3VzcGVuc2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQ0wsb0JBQW9CLEVBQ3BCLHNCQUFzQixHQUV2QixNQUFNLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztTQVF6RCxzQkFBc0I7QUFLdEM7SUFBQTtJQWVBLENBQUM7MEJBZlksaUJBQWlCO0lBQ3JCLHlCQUFPLEdBQWQsVUFBZSxNQUFzQjtRQUNuQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLG1CQUFpQjtZQUMzQixTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLG9CQUFvQjtvQkFDN0IsUUFBUSx3QkFDSCxzQkFBc0IsR0FDdEIsTUFBTSxDQUNWO2lCQUNGO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7SUFkVSxpQkFBaUI7UUFYN0IsUUFBUSxDQUFDO1lBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLEVBQUUsb0JBQW9CLENBQUM7WUFDOUQsT0FBTyxFQUFFLENBQUMsdUJBQXVCLEVBQUUsWUFBWSxDQUFDO1lBQ2hELFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsb0JBQW9CO29CQUM3QixRQUFRLElBQXdCO2lCQUNqQzthQUNGO1lBQ0QsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsd0JBQXdCLENBQUM7U0FDMUQsQ0FBQztPQUNXLGlCQUFpQixDQWU3QjtJQUFELHdCQUFDO0NBQUEsQUFmRCxJQWVDO1NBZlksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTmd4U3VzcGVuc2VDb21wb25lbnQgfSBmcm9tIFwiLi9uZ3gtc3VzcGVuc2UuY29tcG9uZW50XCI7XG5pbXBvcnQge1xuICBMT0FESU5HX0NPTkZJR19UT0tFTixcbiAgTE9BRElOR19ERUZVQUxUX0NPTkZJRyxcbiAgSUxvYWRpbmdDb25maWcsXG59IGZyb20gXCIuL25neC1zdXNwZW5zZS5jb25maWdcIjtcbmltcG9ydCB7IEJyb3dzZXJBbmltYXRpb25zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXIvYW5pbWF0aW9uc1wiO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHsgTmd4U3VzcGVuc2VMaXN0Q29tcG9uZW50IH0gZnJvbSBcIi4vbmd4LXN1c3BlbnNlLWxpc3QuY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW05neFN1c3BlbnNlTGlzdENvbXBvbmVudCwgTmd4U3VzcGVuc2VDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQnJvd3NlckFuaW1hdGlvbnNNb2R1bGUsIENvbW1vbk1vZHVsZV0sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IExPQURJTkdfQ09ORklHX1RPS0VOLFxuICAgICAgdXNlVmFsdWU6IExPQURJTkdfREVGVUFMVF9DT05GSUcsXG4gICAgfSxcbiAgXSxcbiAgZXhwb3J0czogW05neFN1c3BlbnNlQ29tcG9uZW50LCBOZ3hTdXNwZW5zZUxpc3RDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3hTdXNwZW5zZU1vZHVsZSB7XG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogSUxvYWRpbmdDb25maWcpOiBNb2R1bGVXaXRoUHJvdmlkZXJzIHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IE5neFN1c3BlbnNlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBMT0FESU5HX0NPTkZJR19UT0tFTixcbiAgICAgICAgICB1c2VWYWx1ZToge1xuICAgICAgICAgICAgLi4uTE9BRElOR19ERUZVQUxUX0NPTkZJRyxcbiAgICAgICAgICAgIC4uLmNvbmZpZyxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9O1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXN1c3BlbnNlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL25neC1zdXNwZW5zZS8iLCJzb3VyY2VzIjpbImxpYi9uZ3gtc3VzcGVuc2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0wsUUFBUSxFQUVSLHNCQUFzQixHQUN2QixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQ0wsb0JBQW9CLEVBQ3BCLHNCQUFzQixHQUV2QixNQUFNLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztTQVF6RCxzQkFBc0I7QUFNdEM7SUFBQTtJQWVBLENBQUM7MEJBZlksaUJBQWlCO0lBQ3JCLHlCQUFPLEdBQWQsVUFBZSxNQUFzQjtRQUNuQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLG1CQUFpQjtZQUMzQixTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLG9CQUFvQjtvQkFDN0IsUUFBUSx3QkFDSCxzQkFBc0IsR0FDdEIsTUFBTSxDQUNWO2lCQUNGO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7SUFkVSxpQkFBaUI7UUFaN0IsUUFBUSxDQUFDO1lBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLEVBQUUsb0JBQW9CLENBQUM7WUFDOUQsT0FBTyxFQUFFLENBQUMsdUJBQXVCLEVBQUUsWUFBWSxDQUFDO1lBQ2hELFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsb0JBQW9CO29CQUM3QixRQUFRLElBQXdCO2lCQUNqQzthQUNGO1lBQ0QsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7WUFDakMsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUsd0JBQXdCLENBQUM7U0FDMUQsQ0FBQztPQUNXLGlCQUFpQixDQWU3QjtJQUFELHdCQUFDO0NBQUEsQUFmRCxJQWVDO1NBZlksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgTmdNb2R1bGUsXG4gIE1vZHVsZVdpdGhQcm92aWRlcnMsXG4gIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBOZ3hTdXNwZW5zZUNvbXBvbmVudCB9IGZyb20gXCIuL25neC1zdXNwZW5zZS5jb21wb25lbnRcIjtcbmltcG9ydCB7XG4gIExPQURJTkdfQ09ORklHX1RPS0VOLFxuICBMT0FESU5HX0RFRlVBTFRfQ09ORklHLFxuICBJTG9hZGluZ0NvbmZpZyxcbn0gZnJvbSBcIi4vbmd4LXN1c3BlbnNlLmNvbmZpZ1wiO1xuaW1wb3J0IHsgQnJvd3NlckFuaW1hdGlvbnNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlci9hbmltYXRpb25zXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ3hTdXNwZW5zZUxpc3RDb21wb25lbnQgfSBmcm9tIFwiLi9uZ3gtc3VzcGVuc2UtbGlzdC5jb21wb25lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTmd4U3VzcGVuc2VMaXN0Q29tcG9uZW50LCBOZ3hTdXNwZW5zZUNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtCcm93c2VyQW5pbWF0aW9uc01vZHVsZSwgQ29tbW9uTW9kdWxlXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTE9BRElOR19DT05GSUdfVE9LRU4sXG4gICAgICB1c2VWYWx1ZTogTE9BRElOR19ERUZVQUxUX0NPTkZJRyxcbiAgICB9LFxuICBdLFxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV0sXG4gIGV4cG9ydHM6IFtOZ3hTdXNwZW5zZUNvbXBvbmVudCwgTmd4U3VzcGVuc2VMaXN0Q29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmd4U3VzcGVuc2VNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChjb25maWc6IElMb2FkaW5nQ29uZmlnKTogTW9kdWxlV2l0aFByb3ZpZGVycyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBOZ3hTdXNwZW5zZU1vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogTE9BRElOR19DT05GSUdfVE9LRU4sXG4gICAgICAgICAgdXNlVmFsdWU6IHtcbiAgICAgICAgICAgIC4uLkxPQURJTkdfREVGVUFMVF9DT05GSUcsXG4gICAgICAgICAgICAuLi5jb25maWcsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxufVxuIl19
import { __decorate, __param } from 'tslib';
import { InjectionToken, Optional, Inject, Injectable, Input, Component, ContentChildren, NgModule } from '@angular/core';
import { InjectionToken, Optional, Inject, Injectable, Input, Component, ContentChildren, NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { BehaviorSubject, Subject, timer, combineLatest, merge, Observable, of } from 'rxjs';

@@ -195,3 +195,4 @@ import { switchMap, takeUntil, mapTo, startWith, skip, filter, tap, concatMap, shareReplay, pairwise } from 'rxjs/operators';

let NgxSuspenseListComponent = class NgxSuspenseListComponent {
var NgxSuspenseListComponent_1;
let NgxSuspenseListComponent = NgxSuspenseListComponent_1 = class NgxSuspenseListComponent {
constructor() {

@@ -202,4 +203,12 @@ this.revealOrder = "*";

this.allListeners = [];
this.hasParentControlSubject = new BehaviorSubject(undefined);
this.parentControl$ = this.hasParentControlSubject.asObservable();
}
ngOnInit() { }
ngOnInit() {
this.parentControl$
.pipe(tap((val) => {
console.log("release", val);
}))
.subscribe();
}
ngAfterContentInit() {

@@ -224,2 +233,4 @@ this.allBroadcasters = this.skeletons.map((s) => s.loading$);

}
show() { }
hide() { }
revealOrderOperator(order) {

@@ -335,3 +346,6 @@ if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {

], NgxSuspenseListComponent.prototype, "skeletons", void 0);
NgxSuspenseListComponent = __decorate([
__decorate([
ContentChildren(NgxSuspenseListComponent_1)
], NgxSuspenseListComponent.prototype, "list", void 0);
NgxSuspenseListComponent = NgxSuspenseListComponent_1 = __decorate([
Component({

@@ -369,2 +383,3 @@ selector: "SuspenseList",

],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
exports: [NgxSuspenseComponent, NgxSuspenseListComponent],

@@ -371,0 +386,0 @@ })

import { __read, __decorate, __param, __spread, __values, __assign } from 'tslib';
import { InjectionToken, Optional, Inject, Injectable, Input, Component, ContentChildren, NgModule } from '@angular/core';
import { InjectionToken, Optional, Inject, Injectable, Input, Component, ContentChildren, NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
import { BehaviorSubject, Subject, timer, combineLatest, merge, Observable, of } from 'rxjs';

@@ -216,4 +216,13 @@ import { switchMap, takeUntil, mapTo, startWith, skip, filter, tap, concatMap, shareReplay, pairwise } from 'rxjs/operators';

this.allListeners = [];
this.hasParentControlSubject = new BehaviorSubject(undefined);
this.parentControl$ = this.hasParentControlSubject.asObservable();
}
NgxSuspenseListComponent.prototype.ngOnInit = function () { };
NgxSuspenseListComponent_1 = NgxSuspenseListComponent;
NgxSuspenseListComponent.prototype.ngOnInit = function () {
this.parentControl$
.pipe(tap(function (val) {
console.log("release", val);
}))
.subscribe();
};
NgxSuspenseListComponent.prototype.ngAfterContentInit = function () {

@@ -239,2 +248,4 @@ var _this = this;

};
NgxSuspenseListComponent.prototype.show = function () { };
NgxSuspenseListComponent.prototype.hide = function () { };
NgxSuspenseListComponent.prototype.revealOrderOperator = function (order) {

@@ -358,2 +369,3 @@ if (this.allBroadcasters.length === 0 || this.allListeners.length === 0) {

};
var NgxSuspenseListComponent_1;
__decorate([

@@ -365,3 +377,6 @@ Input()

], NgxSuspenseListComponent.prototype, "skeletons", void 0);
NgxSuspenseListComponent = __decorate([
__decorate([
ContentChildren(NgxSuspenseListComponent_1)
], NgxSuspenseListComponent.prototype, "list", void 0);
NgxSuspenseListComponent = NgxSuspenseListComponent_1 = __decorate([
Component({

@@ -403,2 +418,3 @@ selector: "SuspenseList",

],
schemas: [CUSTOM_ELEMENTS_SCHEMA],
exports: [NgxSuspenseComponent, NgxSuspenseListComponent],

@@ -405,0 +421,0 @@ })

import { AfterContentInit, QueryList, SimpleChanges, OnDestroy } from "@angular/core";
import { NgxSuspenseComponent } from "./ngx-suspense.component";
import { Subscription } from "rxjs";
import { Subscription, Observable } from "rxjs";
declare type ORDERS = "*" | "together" | "forwards" | "backwards";

@@ -8,5 +8,9 @@ export declare class NgxSuspenseListComponent implements AfterContentInit, OnDestroy {

skeletons: QueryList<NgxSuspenseComponent>;
list: QueryList<NgxSuspenseListComponent>;
loading$: Observable<boolean>;
subs: Array<Subscription>;
allBroadcasters: any[];
allListeners: any[];
private hasParentControlSubject;
private parentControl$;
ngOnInit(): void;

@@ -17,2 +21,4 @@ ngAfterContentInit(): void;

reload(order: any): void;
show(): void;
hide(): void;
private revealOrderOperator;

@@ -19,0 +25,0 @@ private hideSkeletonListener;

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

{"__symbolic":"module","version":4,"metadata":{"NgxSuspenseService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":29,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":49,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":50,"character":5},"arguments":[{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"}]}]],"parameters":[{"__symbolic":"reference","name":"ILoadingConfig"}]}],"ngOnDestroy":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"controller":[{"__symbolic":"method"}],"showLoadingStatus":[{"__symbolic":"method"}],"showingFor":[{"__symbolic":"method"}]}},"ILoadingConfig":{"__symbolic":"interface"},"LOADING_DEFUALT_CONFIG":{"busyMinDurationMs":0,"busyDelayMs":0},"LOADING_CONFIG_TOKEN":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":11,"character":40},"arguments":["LOADING_CONFIG_TOKEN"]},"NgxSuspenseComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":5,"character":1},"arguments":[{"selector":"Suspense","styles":["\n :host {\n display: block;\n }\n "],"animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":16,"character":4},"arguments":["fadeIn",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":17,"character":6},"arguments":[":enter",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":18,"character":8},"arguments":[{"opacity":0}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":19,"character":8},"arguments":["300ms ease-in",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":21,"character":10},"arguments":[{"opacity":1}]}]}]]}]]}],"template":"<ng-template #content>\n <!-- animation doesn't work with ng-template, ng-content or ng-container, have to add extra div for workaround-->\n <div [@fadeIn]>\n <ng-content></ng-content>\n </div>\n</ng-template>\n\n<div\n *ngIf=\"(loading$ | async) || isVisible; else content\"\n role=\"alert\"\n aria-busy=\"true\"\n aria-hidden=\"false\"\n [attr.aria-label]=\"ariaLabel\"\n>\n <ng-container *ngTemplateOutlet=\"fallback\"></ng-container>\n</div>\n"}]}],"members":{"fallback":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"ariaLabel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"bind":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"isVisible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"NgxSuspenseService"}]}],"ngOnInit":[{"__symbolic":"method"}],"getService":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}]}},"NgxSuspenseListComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":15,"character":1},"arguments":[{"selector":"SuspenseList","exportAs":"list","template":"<ng-content></ng-content>\n"}]}],"members":{"revealOrder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"skeletons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":22,"character":3},"arguments":[{"__symbolic":"reference","name":"NgxSuspenseComponent"}]}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterContentInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"reload":[{"__symbolic":"method"}],"revealOrderOperator":[{"__symbolic":"method"}],"hideSkeletonListener":[{"__symbolic":"method"}],"showSkeletonListener":[{"__symbolic":"method"}],"togetherOperator":[{"__symbolic":"method"}],"domOrderOperator":[{"__symbolic":"method"}],"getFlushIndexes":[{"__symbolic":"method"}]}},"NgxSuspenseModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NgxSuspenseListComponent"},{"__symbolic":"reference","name":"NgxSuspenseComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":13,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":13,"character":37}],"providers":[{"provide":{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"},"useValue":{"__symbolic":"reference","name":"LOADING_DEFUALT_CONFIG"}}],"exports":[{"__symbolic":"reference","name":"NgxSuspenseComponent"},{"__symbolic":"reference","name":"NgxSuspenseListComponent"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"NgxSuspenseModule"},"providers":[{"provide":{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"},"useValue":{}}]}}}}},"origins":{"NgxSuspenseService":"./lib/ngx-suspense.service","ILoadingConfig":"./lib/ngx-suspense.config","LOADING_DEFUALT_CONFIG":"./lib/ngx-suspense.config","LOADING_CONFIG_TOKEN":"./lib/ngx-suspense.config","NgxSuspenseComponent":"./lib/ngx-suspense.component","NgxSuspenseListComponent":"./lib/ngx-suspense-list.component","NgxSuspenseModule":"./lib/ngx-suspense.module"},"importAs":"ngx-suspense"}
{"__symbolic":"module","version":4,"metadata":{"NgxSuspenseService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":29,"character":1}}],"members":{"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":49,"character":5}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":50,"character":5},"arguments":[{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"}]}]],"parameters":[{"__symbolic":"reference","name":"ILoadingConfig"}]}],"ngOnDestroy":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"controller":[{"__symbolic":"method"}],"showLoadingStatus":[{"__symbolic":"method"}],"showingFor":[{"__symbolic":"method"}]}},"ILoadingConfig":{"__symbolic":"interface"},"LOADING_DEFUALT_CONFIG":{"busyMinDurationMs":0,"busyDelayMs":0},"LOADING_CONFIG_TOKEN":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":11,"character":40},"arguments":["LOADING_CONFIG_TOKEN"]},"NgxSuspenseComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":5,"character":1},"arguments":[{"selector":"Suspense","styles":["\n :host {\n display: block;\n }\n "],"animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":16,"character":4},"arguments":["fadeIn",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":17,"character":6},"arguments":[":enter",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":18,"character":8},"arguments":[{"opacity":0}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":19,"character":8},"arguments":["300ms ease-in",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":21,"character":10},"arguments":[{"opacity":1}]}]}]]}]]}],"template":"<ng-template #content>\n <!-- animation doesn't work with ng-template, ng-content or ng-container, have to add extra div for workaround-->\n <div [@fadeIn]>\n <ng-content></ng-content>\n </div>\n</ng-template>\n\n<div\n *ngIf=\"(loading$ | async) || isVisible; else content\"\n role=\"alert\"\n aria-busy=\"true\"\n aria-hidden=\"false\"\n [attr.aria-label]=\"ariaLabel\"\n>\n <ng-container *ngTemplateOutlet=\"fallback\"></ng-container>\n</div>\n"}]}],"members":{"fallback":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"ariaLabel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"bind":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"isVisible":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"NgxSuspenseService"}]}],"ngOnInit":[{"__symbolic":"method"}],"getService":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}]}},"NgxSuspenseListComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":21,"character":1},"arguments":[{"selector":"SuspenseList","exportAs":"list","template":"<ng-content></ng-content>\n"}]}],"members":{"revealOrder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":27,"character":3}}]}],"skeletons":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":28,"character":3},"arguments":[{"__symbolic":"reference","name":"NgxSuspenseComponent"}]}]}],"list":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":31,"character":3},"arguments":[{"__symbolic":"reference","name":"NgxSuspenseListComponent"}]}]}],"ngOnInit":[{"__symbolic":"method"}],"ngAfterContentInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"reload":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"revealOrderOperator":[{"__symbolic":"method"}],"hideSkeletonListener":[{"__symbolic":"method"}],"showSkeletonListener":[{"__symbolic":"method"}],"togetherOperator":[{"__symbolic":"method"}],"domOrderOperator":[{"__symbolic":"method"}],"getFlushIndexes":[{"__symbolic":"method"}]}},"NgxSuspenseModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":15,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"NgxSuspenseListComponent"},{"__symbolic":"reference","name":"NgxSuspenseComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":17,"character":12},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":17,"character":37}],"providers":[{"provide":{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"},"useValue":{"__symbolic":"reference","name":"LOADING_DEFUALT_CONFIG"}}],"schemas":[{"__symbolic":"reference","module":"@angular/core","name":"CUSTOM_ELEMENTS_SCHEMA","line":24,"character":12}],"exports":[{"__symbolic":"reference","name":"NgxSuspenseComponent"},{"__symbolic":"reference","name":"NgxSuspenseListComponent"}]}]}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["config"],"value":{"ngModule":{"__symbolic":"reference","name":"NgxSuspenseModule"},"providers":[{"provide":{"__symbolic":"reference","name":"LOADING_CONFIG_TOKEN"},"useValue":{}}]}}}}},"origins":{"NgxSuspenseService":"./lib/ngx-suspense.service","ILoadingConfig":"./lib/ngx-suspense.config","LOADING_DEFUALT_CONFIG":"./lib/ngx-suspense.config","LOADING_CONFIG_TOKEN":"./lib/ngx-suspense.config","NgxSuspenseComponent":"./lib/ngx-suspense.component","NgxSuspenseListComponent":"./lib/ngx-suspense-list.component","NgxSuspenseModule":"./lib/ngx-suspense.module"},"importAs":"ngx-suspense"}
{
"name": "ngx-suspense",
"version": "0.0.3",
"version": "0.0.4",
"author": {

@@ -15,3 +15,3 @@ "name": "Zhentian Wan",

"description": "This library is an experimetnal implementation of React Suspense for Angular.",
"homepage": "https://github.com/zhentian-wan/ngx-loading-skeleton/blob/master/projects/ngx-suspense/README.md",
"homepage": "https://github.com/zhentian-wan/angular-suspense/blob/master/projects/ngx-suspense/README.md",
"peerDependencies": {

@@ -18,0 +18,0 @@ "@angular/common": "^9.1.0",

# NgxSuspense
This library is an experimetnal implementation of React Suspense for Angular.
This library is an experimental implementation of React Suspense for Angular.

@@ -88,2 +88,4 @@ ## [DEMO](https://codesandbox.io/s/ngx-suspense-dgjhh)

In the example uses [`ngx-loading-skeleton`](../loading-skeleton/README.md) for showing loading shimmer
#### `@Input() ariaLabel: string`

@@ -195,6 +197,6 @@

NgxSuspenseModule.forRoot({
busyDelayMs: 300, // within 300ms, don't show the loading skeleton
busyMinDurationMs: 700, // showing loading skeleton for at least 700ms
busyDelayMs: 300, // within 300ms, don't show the loading skeleton; default value: 0
busyMinDurationMs: 700, // showing loading skeleton for at least 700ms; default value: 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

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