Commit 7147c4bc by Emile TAVERNE

Modification composant in viewport

parent 17282a9f
......@@ -10,19 +10,24 @@
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var InViewportComponent = /** @class */ (function () {
function InViewportComponent() {
function InViewportComponent(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
}
/**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
InViewportComponent.prototype.onViewportChange = /**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
function (event) {
console.log(event);
function (intersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
};
InViewportComponent.decorators = [
{
......@@ -32,6 +37,12 @@
}]
}
];
/** @nocollapse */
InViewportComponent.ctorParameters = function () {
return [
{type: core.ChangeDetectorRef}
];
};
return InViewportComponent;
}());
......
......@@ -9,7 +9,7 @@
"ng://aitp-utils/lib/aitp-utils.module.ts"
],
"sourcesContent": [
"import {Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n\r\n onViewportChange(event) {\r\n console.log(event);\r\n }\r\n}\r\n",
"import {ChangeDetectorRef, Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n constructor(private changeDetectorRef: ChangeDetectorRef) {\r\n }\r\n\r\n\r\n onViewportChange(intersectionObserverEntry: IntersectionObserverEntry) {\r\n if (intersectionObserverEntry.isIntersecting) {\r\n this.changeDetectorRef.reattach();\r\n } else {\r\n this.changeDetectorRef.detach();\r\n }\r\n }\r\n}\r\n",
"import {Injectable} from '@angular/core';\r\nimport {Observable, Subject} from 'rxjs';\r\nimport {filter, finalize} from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class ViewportService {\r\n private readonly options: IntersectionObserverInit = {\r\n rootMargin: '0px 0px 0px 0px',\r\n threshold: [0.5],\r\n };\r\n private observer: IntersectionObserver;\r\n private callback$: Subject<IntersectionObserverEntry> = new Subject();\r\n\r\n constructor() {\r\n this.observer = new IntersectionObserver(this.handler.bind(this), this.options);\r\n }\r\n\r\n observe(element: Element): Observable<IntersectionObserverEntry> {\r\n this.observer.observe(element);\r\n\r\n return this.callback$.asObservable().pipe(\r\n filter((entry: IntersectionObserverEntry) => entry.target === element),\r\n finalize(() => this.observer.unobserve(element)),\r\n );\r\n }\r\n\r\n private handler(entries: Array<IntersectionObserverEntry>): void {\r\n entries.forEach(entry => this.callback$.next(entry));\r\n }\r\n}\r\n",
"import {MonoTypeOperatorFunction, Observable} from 'rxjs';\r\nimport {takeUntil} from 'rxjs/operators';\r\n\r\n// create a symbol identify the observable I add to\r\n// the component so it doesn't conflict with anything.\r\n// I need this so I'm able to add the desired behaviour to the component.\r\nexport const destroy$ = Symbol('destroy$');\r\n\r\n/**\r\n * An operator that takes until destroy it takes a components this a parameter\r\n * returns a pipeable RxJS operator.\r\n */\r\nexport const untilDestroy = <T>(component: any): MonoTypeOperatorFunction<T> => {\r\n if (component[destroy$] === undefined) {\r\n // only hookup each component once.\r\n addDestroyObservableToComponent(component);\r\n }\r\n\r\n // pipe in the takeUntil destroy$ and return the source unaltered\r\n return takeUntil<T>(component[destroy$]);\r\n};\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function addDestroyObservableToComponent(component: any) {\r\n component[destroy$] = new Observable<void>(observer => {\r\n // keep track of the original destroy function,\r\n // the user might do something in there\r\n const orignalDestroy = component.ngOnDestroy;\r\n if (orignalDestroy == null) {\r\n // Angular does not support dynamic added destroy methods\r\n // so make sure there is one.\r\n throw new Error('untilDestroy operator needs the component to have an ngOnDestroy method');\r\n }\r\n // replace the ngOndestroy\r\n component.ngOnDestroy = () => {\r\n // fire off the destroy observable\r\n observer.next();\r\n // complete the observable\r\n observer.complete();\r\n // and at last, call the original destroy\r\n orignalDestroy.call(component);\r\n };\r\n // return cleanup function.\r\n return (_: any) => (component[destroy$] = undefined);\r\n });\r\n}\r\n",
"import {Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, OnInit, Output, PLATFORM_ID,} from '@angular/core';\r\nimport {isPlatformBrowser} from '@angular/common';\r\nimport {filter, take} from 'rxjs/operators';\r\nimport {ViewportService} from '../services';\r\nimport {untilDestroy} from '../operators';\r\n\r\n@Directive({\r\n selector: '[aiutInViewport]',\r\n})\r\nexport class InViewportDirective implements OnInit, OnDestroy {\r\n @Input() public preRender = true;\r\n @Input() public oneTime = false;\r\n @Output() readonly inViewport = new EventEmitter<Partial<IntersectionObserverEntry>>();\r\n\r\n constructor(\r\n private readonly elementRef: ElementRef,\r\n private viewportService: ViewportService,\r\n @Inject(PLATFORM_ID) private platformId: Object,\r\n ) {\r\n }\r\n\r\n public ngOnInit() {\r\n if (isPlatformBrowser(this.platformId)) {\r\n if (this.oneTime) {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(\r\n untilDestroy(this),\r\n filter(entry => entry.intersectionRatio >= 0.5),\r\n take(1),\r\n )\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n } else {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(untilDestroy(this))\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n }\r\n } else {\r\n if (this.preRender) {\r\n this.inViewport.emit({isIntersecting: true, intersectionRatio: 1});\r\n }\r\n }\r\n }\r\n\r\n ngOnDestroy() {\r\n }\r\n}\r\n",
......@@ -17,6 +17,7 @@
],
"names": [
"Component",
"ChangeDetectorRef",
"Subject",
"filter",
"finalize",
......@@ -38,5 +39,5 @@
"Components.InViewportComponent",
"Services.ViewportService"
],
"mappings": "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"
"mappings": "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"
}
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/common"),require("@angular/core"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("aitp-utils",["exports","@angular/common","@angular/core","rxjs","rxjs/operators"],t):t(e["aitp-utils"]={},e.ng.common,e.ng.core,e.rxjs,e.rxjs.operators)}(this,function(e,n,r,t,o){"use strict";var i=function(){function e(){}return e.prototype.onViewportChange=function(e){console.log(e)},e.decorators=[{type:r.Component,args:[{selector:"aiut-in-viewport",template:'<div (inViewport)="onViewportChange($event)" aiutInViewport>\r\n <ng-content></ng-content>\r\n</div>\r\n'}]}],e}(),s=function(){function e(){this.options={rootMargin:"0px 0px 0px 0px",threshold:[.5]},this.callback$=new t.Subject,this.observer=new IntersectionObserver(this.handler.bind(this),this.options)}return e.prototype.observe=function(t){var e=this;return this.observer.observe(t),this.callback$.asObservable().pipe(o.filter(function(e){return e.target===t}),o.finalize(function(){return e.observer.unobserve(t)}))},e.prototype.handler=function(e){var t=this;e.forEach(function(e){return t.callback$.next(e)})},e.decorators=[{type:r.Injectable}],e.ctorParameters=function(){return[]},e}(),p=Symbol("destroy$"),c=function(e){return e[p]===undefined&&u(e),o.takeUntil(e[p])};function u(n){n[p]=new t.Observable(function(e){var t=n.ngOnDestroy;if(null==t)throw new Error("untilDestroy operator needs the component to have an ngOnDestroy method");return n.ngOnDestroy=function(){e.next(),e.complete(),t.call(n)},function(e){return n[p]=undefined}})}var a=function(){function e(e,t,n){this.elementRef=e,this.viewportService=t,this.platformId=n,this.preRender=!0,this.oneTime=!1,this.inViewport=new r.EventEmitter}return e.prototype.ngOnInit=function(){var t=this;n.isPlatformBrowser(this.platformId)?this.oneTime?this.viewportService.observe(this.elementRef.nativeElement).pipe(c(this),o.filter(function(e){return.5<=e.intersectionRatio}),o.take(1)).subscribe(function(e){t.inViewport.emit(e)}):this.viewportService.observe(this.elementRef.nativeElement).pipe(c(this)).subscribe(function(e){t.inViewport.emit(e)}):this.preRender&&this.inViewport.emit({isIntersecting:!0,intersectionRatio:1})},e.prototype.ngOnDestroy=function(){},e.decorators=[{type:r.Directive,args:[{selector:"[aiutInViewport]"}]}],e.ctorParameters=function(){return[{type:r.ElementRef},{type:s},{type:Object,decorators:[{type:r.Inject,args:[r.PLATFORM_ID]}]}]},e.propDecorators={preRender:[{type:r.Input}],oneTime:[{type:r.Input}],inViewport:[{type:r.Output}]},e}(),l=function(){function e(){}return e.decorators=[{type:r.NgModule,args:[{imports:[n.CommonModule],declarations:[a,i],providers:[s],exports:[a,i]}]}],e}();e.AitpUtilsModule=l,e.InViewportComponent=i,e.InViewportDirective=a,e.addDestroyObservableToComponent=u,e.destroy$=p,e.untilDestroy=c,e.ViewportService=s,e.ɵb=i,e.ɵa=a,e.ɵc=s,Object.defineProperty(e,"__esModule",{value:!0})});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/common"),require("@angular/core"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("aitp-utils",["exports","@angular/common","@angular/core","rxjs","rxjs/operators"],t):t(e["aitp-utils"]={},e.ng.common,e.ng.core,e.rxjs,e.rxjs.operators)}(this,function(e,r,n,t,o){"use strict";var i=function(){function e(e){this.changeDetectorRef=e}return e.prototype.onViewportChange=function(e){e.isIntersecting?this.changeDetectorRef.reattach():this.changeDetectorRef.detach()},e.decorators=[{type:n.Component,args:[{selector:"aiut-in-viewport",template:'<div (inViewport)="onViewportChange($event)" aiutInViewport>\r\n <ng-content></ng-content>\r\n</div>\r\n'}]}],e.ctorParameters=function(){return[{type:n.ChangeDetectorRef}]},e}(),s=function(){function e(){this.options={rootMargin:"0px 0px 0px 0px",threshold:[.5]},this.callback$=new t.Subject,this.observer=new IntersectionObserver(this.handler.bind(this),this.options)}return e.prototype.observe=function(t){var e=this;return this.observer.observe(t),this.callback$.asObservable().pipe(o.filter(function(e){return e.target===t}),o.finalize(function(){return e.observer.unobserve(t)}))},e.prototype.handler=function(e){var t=this;e.forEach(function(e){return t.callback$.next(e)})},e.decorators=[{type:n.Injectable}],e.ctorParameters=function(){return[]},e}(),c=Symbol("destroy$"),a=function(e){return e[c]===undefined&&p(e),o.takeUntil(e[c])};function p(r){r[c]=new t.Observable(function(e){var t=r.ngOnDestroy;if(null==t)throw new Error("untilDestroy operator needs the component to have an ngOnDestroy method");return r.ngOnDestroy=function(){e.next(),e.complete(),t.call(r)},function(e){return r[c]=undefined}})}var u=function(){function e(e,t,r){this.elementRef=e,this.viewportService=t,this.platformId=r,this.preRender=!0,this.oneTime=!1,this.inViewport=new n.EventEmitter}return e.prototype.ngOnInit=function(){var t=this;r.isPlatformBrowser(this.platformId)?this.oneTime?this.viewportService.observe(this.elementRef.nativeElement).pipe(a(this),o.filter(function(e){return.5<=e.intersectionRatio}),o.take(1)).subscribe(function(e){t.inViewport.emit(e)}):this.viewportService.observe(this.elementRef.nativeElement).pipe(a(this)).subscribe(function(e){t.inViewport.emit(e)}):this.preRender&&this.inViewport.emit({isIntersecting:!0,intersectionRatio:1})},e.prototype.ngOnDestroy=function(){},e.decorators=[{type:n.Directive,args:[{selector:"[aiutInViewport]"}]}],e.ctorParameters=function(){return[{type:n.ElementRef},{type:s},{type:Object,decorators:[{type:n.Inject,args:[n.PLATFORM_ID]}]}]},e.propDecorators={preRender:[{type:n.Input}],oneTime:[{type:n.Input}],inViewport:[{type:n.Output}]},e}(),f=function(){function e(){}return e.decorators=[{type:n.NgModule,args:[{imports:[r.CommonModule],declarations:[u,i],providers:[s],exports:[u,i]}]}],e}();e.AitpUtilsModule=f,e.InViewportComponent=i,e.InViewportDirective=u,e.addDestroyObservableToComponent=p,e.destroy$=c,e.untilDestroy=a,e.ViewportService=s,e.ɵb=i,e.ɵa=u,e.ɵc=s,Object.defineProperty(e,"__esModule",{value:!0})});
//# sourceMappingURL=aitp-utils.umd.min.js.map
\ No newline at end of file
......@@ -9,17 +9,20 @@
],
"names": [
"InViewportComponent",
"changeDetectorRef",
"this",
"prototype",
"onViewportChange",
"event",
"console",
"log",
"intersectionObserverEntry",
"isIntersecting",
"reattach",
"detach",
"Component",
"args",
"selector",
"template",
"ChangeDetectorRef",
"ViewportService",
"this",
"options",
"rootMargin",
"threshold",
......@@ -72,7 +75,6 @@
"take",
"subscribe",
"emit",
"isIntersecting",
"Directive",
"ElementRef",
"Object",
......@@ -93,9 +95,9 @@
"Services.ViewportService",
"exports"
],
"mappings": "2ZAAA,IAAAA,EAAA,WAEA,SAAAA,KASA,OAHEA,EAAAC,UAAAC,iBAAA,SAAiBC,GACfC,QAAQC,IAAIF,wBAPfG,EAAAA,UAASC,KAAA,CAAC,CACTC,SAAU,mBACVC,SAAA,gHAOFT,EAXA,GCAAU,EAAA,WAaE,SAAAA,IAPiBC,KAAAC,QAAoC,CACnDC,WAAY,kBACZC,UAAW,CAAC,KAGNH,KAAAI,UAAgD,IAAIC,EAAAA,QAG1DL,KAAKM,SAAW,IAAIC,qBAAqBP,KAAKQ,QAAQC,KAAKT,MAAOA,KAAKC,SAe3E,OAZEF,EAAAT,UAAAoB,QAAA,SAAQC,GAAR,IAAAC,EAAAZ,KAGE,OAFAA,KAAKM,SAASI,QAAQC,GAEfX,KAAKI,UAAUS,eAAeC,KACnCC,EAAAA,OAAM,SAAEC,GAAqC,OAAAA,EAAMC,SAAWN,IAC9DO,EAAAA,SAAQ,WAAO,OAAAN,EAAKN,SAASa,UAAUR,OAInCZ,EAAAT,UAAAkB,QAAR,SAAgBY,GAAhB,IAAAR,EAAAZ,KACEoB,EAAQC,QAAO,SAACL,GAAS,OAAAJ,EAAKR,UAAUkB,KAAKN,0BAvBhDO,EAAAA,mDAyBDxB,EA7BA,GCMayB,EAAWC,OAAO,YAMlBC,EAAY,SAAOC,GAO9B,OANIA,EAAUH,KAAcI,WAE1BC,EAAgCF,GAI3BG,EAAAA,UAAaH,EAAUH,KAMhC,SAAgBK,EAAgCF,GAC9CA,EAAUH,GAAY,IAAIO,EAAAA,WAAU,SAAOzB,OAGnC0B,EAAiBL,EAAUM,YACjC,GAAsB,MAAlBD,EAGF,MAAM,IAAIE,MAAM,2EAYlB,OATAP,EAAUM,YAAW,WAEnB3B,EAASgB,OAEThB,EAAS6B,WAETH,EAAeI,KAAKT,IAGtB,SAAQU,GAAW,OAACV,EAAUH,GAAYI,aC7C9C,IAAAU,EAAA,WAcE,SAAAA,EACmBC,EACTC,EACqBC,GAFZzC,KAAAuC,WAAAA,EACTvC,KAAAwC,gBAAAA,EACqBxC,KAAAyC,WAAAA,EAPfzC,KAAA0C,WAAY,EACZ1C,KAAA2C,SAAU,EACP3C,KAAA4C,WAAa,IAAIC,EAAAA,aAuCtC,OA9BSP,EAAAhD,UAAAwD,SAAP,WAAA,IAAAlC,EAAAZ,KACM+C,EAAAA,kBAAkB/C,KAAKyC,YACrBzC,KAAK2C,QACP3C,KAAKwC,gBACF9B,QAAQV,KAAKuC,WAAWS,eACxBlC,KACCY,EAAa1B,MACbe,EAAAA,OAAM,SAACC,GAAS,MAA2B,IAA3BA,EAAMiC,oBACtBC,EAAAA,KAAK,IAENC,UAAS,SAAEnC,GACVJ,EAAKgC,WAAWQ,KAAKpC,KAGzBhB,KAAKwC,gBACF9B,QAAQV,KAAKuC,WAAWS,eACxBlC,KAAKY,EAAa1B,OAClBmD,UAAS,SAAEnC,GACVJ,EAAKgC,WAAWQ,KAAKpC,KAIvBhB,KAAK0C,WACP1C,KAAK4C,WAAWQ,KAAK,CAACC,gBAAgB,EAAMJ,kBAAmB,KAKrEX,EAAAhD,UAAA2C,YAAA,iCA3CDqB,EAAAA,UAAS1D,KAAA,CAAC,CACTC,SAAU,gEAPO0D,EAAAA,kBAGXxD,SAcqCyD,OAAMC,WAAA,CAAA,CAAAC,KAA9CC,EAAAA,OAAM/D,KAAA,CAACgE,EAAAA,qDAPTC,EAAAA,uBACAA,EAAAA,0BACAC,EAAAA,UAuCHxB,EAnDA,GCAAyB,EAAA,WAOA,SAAAA,KAM+B,2BAN9BC,EAAAA,SAAQpE,KAAA,CAAC,CACRqE,QAAS,CAACC,EAAAA,cACVC,aAAc,CAACC,EAAgCC,GAC/CC,UAAW,CAACC,GACZC,QAAS,CAACJ,EAAgCC,OAEbN,EAb/B",
"mappings": "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",
"sourcesContent": [
"import {Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n\r\n onViewportChange(event) {\r\n console.log(event);\r\n }\r\n}\r\n",
"import {ChangeDetectorRef, Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n constructor(private changeDetectorRef: ChangeDetectorRef) {\r\n }\r\n\r\n\r\n onViewportChange(intersectionObserverEntry: IntersectionObserverEntry) {\r\n if (intersectionObserverEntry.isIntersecting) {\r\n this.changeDetectorRef.reattach();\r\n } else {\r\n this.changeDetectorRef.detach();\r\n }\r\n }\r\n}\r\n",
"import {Injectable} from '@angular/core';\r\nimport {Observable, Subject} from 'rxjs';\r\nimport {filter, finalize} from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class ViewportService {\r\n private readonly options: IntersectionObserverInit = {\r\n rootMargin: '0px 0px 0px 0px',\r\n threshold: [0.5],\r\n };\r\n private observer: IntersectionObserver;\r\n private callback$: Subject<IntersectionObserverEntry> = new Subject();\r\n\r\n constructor() {\r\n this.observer = new IntersectionObserver(this.handler.bind(this), this.options);\r\n }\r\n\r\n observe(element: Element): Observable<IntersectionObserverEntry> {\r\n this.observer.observe(element);\r\n\r\n return this.callback$.asObservable().pipe(\r\n filter((entry: IntersectionObserverEntry) => entry.target === element),\r\n finalize(() => this.observer.unobserve(element)),\r\n );\r\n }\r\n\r\n private handler(entries: Array<IntersectionObserverEntry>): void {\r\n entries.forEach(entry => this.callback$.next(entry));\r\n }\r\n}\r\n",
"import {MonoTypeOperatorFunction, Observable} from 'rxjs';\r\nimport {takeUntil} from 'rxjs/operators';\r\n\r\n// create a symbol identify the observable I add to\r\n// the component so it doesn't conflict with anything.\r\n// I need this so I'm able to add the desired behaviour to the component.\r\nexport const destroy$ = Symbol('destroy$');\r\n\r\n/**\r\n * An operator that takes until destroy it takes a components this a parameter\r\n * returns a pipeable RxJS operator.\r\n */\r\nexport const untilDestroy = <T>(component: any): MonoTypeOperatorFunction<T> => {\r\n if (component[destroy$] === undefined) {\r\n // only hookup each component once.\r\n addDestroyObservableToComponent(component);\r\n }\r\n\r\n // pipe in the takeUntil destroy$ and return the source unaltered\r\n return takeUntil<T>(component[destroy$]);\r\n};\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function addDestroyObservableToComponent(component: any) {\r\n component[destroy$] = new Observable<void>(observer => {\r\n // keep track of the original destroy function,\r\n // the user might do something in there\r\n const orignalDestroy = component.ngOnDestroy;\r\n if (orignalDestroy == null) {\r\n // Angular does not support dynamic added destroy methods\r\n // so make sure there is one.\r\n throw new Error('untilDestroy operator needs the component to have an ngOnDestroy method');\r\n }\r\n // replace the ngOndestroy\r\n component.ngOnDestroy = () => {\r\n // fire off the destroy observable\r\n observer.next();\r\n // complete the observable\r\n observer.complete();\r\n // and at last, call the original destroy\r\n orignalDestroy.call(component);\r\n };\r\n // return cleanup function.\r\n return (_: any) => (component[destroy$] = undefined);\r\n });\r\n}\r\n",
"import {Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, OnInit, Output, PLATFORM_ID,} from '@angular/core';\r\nimport {isPlatformBrowser} from '@angular/common';\r\nimport {filter, take} from 'rxjs/operators';\r\nimport {ViewportService} from '../services';\r\nimport {untilDestroy} from '../operators';\r\n\r\n@Directive({\r\n selector: '[aiutInViewport]',\r\n})\r\nexport class InViewportDirective implements OnInit, OnDestroy {\r\n @Input() public preRender = true;\r\n @Input() public oneTime = false;\r\n @Output() readonly inViewport = new EventEmitter<Partial<IntersectionObserverEntry>>();\r\n\r\n constructor(\r\n private readonly elementRef: ElementRef,\r\n private viewportService: ViewportService,\r\n @Inject(PLATFORM_ID) private platformId: Object,\r\n ) {\r\n }\r\n\r\n public ngOnInit() {\r\n if (isPlatformBrowser(this.platformId)) {\r\n if (this.oneTime) {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(\r\n untilDestroy(this),\r\n filter(entry => entry.intersectionRatio >= 0.5),\r\n take(1),\r\n )\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n } else {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(untilDestroy(this))\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n }\r\n } else {\r\n if (this.preRender) {\r\n this.inViewport.emit({isIntersecting: true, intersectionRatio: 1});\r\n }\r\n }\r\n }\r\n\r\n ngOnDestroy() {\r\n }\r\n}\r\n",
......
......@@ -2,15 +2,26 @@
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import {Component} from '@angular/core';
import {ChangeDetectorRef, Component} from '@angular/core';
export class InViewportComponent {
/**
* @param {?} event
* @param {?} changeDetectorRef
*/
constructor(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
}
/**
* @param {?} intersectionObserverEntry
* @return {?}
*/
onViewportChange(event) {
console.log(event);
onViewportChange(intersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
}
}
InViewportComponent.decorators = [
......@@ -21,4 +32,15 @@ InViewportComponent.decorators = [
}]
}
];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tdmlld3BvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWl0cC11dGlscy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2luLXZpZXdwb3J0L2luLXZpZXdwb3J0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQU14QyxNQUFNLE9BQU8sbUJBQW1COzs7OztJQUU5QixnQkFBZ0IsQ0FBQyxLQUFLO1FBQ3BCLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckIsQ0FBQzs7O1lBUkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLHVIQUEyQzthQUM1QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYWl1dC1pbi12aWV3cG9ydCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2luLXZpZXdwb3J0LmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5WaWV3cG9ydENvbXBvbmVudCB7XHJcblxyXG4gIG9uVmlld3BvcnRDaGFuZ2UoZXZlbnQpIHtcclxuICAgIGNvbnNvbGUubG9nKGV2ZW50KTtcclxuICB9XHJcbn1cclxuIl19
/** @nocollapse */
InViewportComponent.ctorParameters = () => [
{type: ChangeDetectorRef}
];
if (false) {
/**
* @type {?}
* @private
*/
InViewportComponent.prototype.changeDetectorRef;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tdmlld3BvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWl0cC11dGlscy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2luLXZpZXdwb3J0L2luLXZpZXdwb3J0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFDLGlCQUFpQixFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQU0zRCxNQUFNLE9BQU8sbUJBQW1COzs7O0lBQzlCLFlBQW9CLGlCQUFvQztRQUFwQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO0lBQ3hELENBQUM7Ozs7O0lBR0QsZ0JBQWdCLENBQUMseUJBQW9EO1FBQ25FLElBQUkseUJBQXlCLENBQUMsY0FBYyxFQUFFO1lBQzVDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUNuQzthQUFNO1lBQ0wsSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sRUFBRSxDQUFDO1NBQ2pDO0lBQ0gsQ0FBQzs7O1lBZkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLHVIQUEyQzthQUM1Qzs7OztZQUxPLGlCQUFpQjs7Ozs7OztJQU9YLGdEQUE0QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FpdXQtaW4tdmlld3BvcnQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9pbi12aWV3cG9ydC5jb21wb25lbnQuaHRtbCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEluVmlld3BvcnRDb21wb25lbnQge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2hhbmdlRGV0ZWN0b3JSZWY6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgfVxyXG5cclxuXHJcbiAgb25WaWV3cG9ydENoYW5nZShpbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5OiBJbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5KSB7XHJcbiAgICBpZiAoaW50ZXJzZWN0aW9uT2JzZXJ2ZXJFbnRyeS5pc0ludGVyc2VjdGluZykge1xyXG4gICAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLnJlYXR0YWNoKCk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGFjaCgpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
......@@ -2,22 +2,27 @@
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import {Component} from '@angular/core';
import {ChangeDetectorRef, Component} from '@angular/core';
var InViewportComponent = /** @class */ (function () {
function InViewportComponent() {
function InViewportComponent(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
}
/**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
InViewportComponent.prototype.onViewportChange = /**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
function (event) {
console.log(event);
function (intersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
};
InViewportComponent.decorators = [
{
......@@ -27,7 +32,20 @@ var InViewportComponent = /** @class */ (function () {
}]
}
];
/** @nocollapse */
InViewportComponent.ctorParameters = function () {
return [
{type: ChangeDetectorRef}
];
};
return InViewportComponent;
}());
export {InViewportComponent};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tdmlld3BvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWl0cC11dGlscy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2luLXZpZXdwb3J0L2luLXZpZXdwb3J0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV4QztJQUFBO0lBU0EsQ0FBQzs7Ozs7SUFIQyw4Q0FBZ0I7Ozs7SUFBaEIsVUFBaUIsS0FBSztRQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLENBQUM7O2dCQVJGLFNBQVMsU0FBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1Qix1SEFBMkM7aUJBQzVDOztJQU1ELDBCQUFDO0NBQUEsQUFURCxJQVNDO1NBTFksbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhaXV0LWluLXZpZXdwb3J0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vaW4tdmlld3BvcnQuY29tcG9uZW50Lmh0bWwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJblZpZXdwb3J0Q29tcG9uZW50IHtcclxuXHJcbiAgb25WaWV3cG9ydENoYW5nZShldmVudCkge1xyXG4gICAgY29uc29sZS5sb2coZXZlbnQpO1xyXG4gIH1cclxufVxyXG4iXX0=
if (false) {
/**
* @type {?}
* @private
*/
InViewportComponent.prototype.changeDetectorRef;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW4tdmlld3BvcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vYWl0cC11dGlscy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL2luLXZpZXdwb3J0L2luLXZpZXdwb3J0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBQUEsT0FBTyxFQUFDLGlCQUFpQixFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUzRDtJQUtFLDZCQUFvQixpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUN4RCxDQUFDOzs7OztJQUdELDhDQUFnQjs7OztJQUFoQixVQUFpQix5QkFBb0Q7UUFDbkUsSUFBSSx5QkFBeUIsQ0FBQyxjQUFjLEVBQUU7WUFDNUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFFBQVEsRUFBRSxDQUFDO1NBQ25DO2FBQU07WUFDTCxJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxFQUFFLENBQUM7U0FDakM7SUFDSCxDQUFDOztnQkFmRixTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsdUhBQTJDO2lCQUM1Qzs7OztnQkFMTyxpQkFBaUI7O0lBa0J6QiwwQkFBQztDQUFBLEFBaEJELElBZ0JDO1NBWlksbUJBQW1COzs7Ozs7SUFDbEIsZ0RBQTRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYWl1dC1pbi12aWV3cG9ydCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2luLXZpZXdwb3J0LmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5WaWV3cG9ydENvbXBvbmVudCB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICB9XHJcblxyXG5cclxuICBvblZpZXdwb3J0Q2hhbmdlKGludGVyc2VjdGlvbk9ic2VydmVyRW50cnk6IEludGVyc2VjdGlvbk9ic2VydmVyRW50cnkpIHtcclxuICAgIGlmIChpbnRlcnNlY3Rpb25PYnNlcnZlckVudHJ5LmlzSW50ZXJzZWN0aW5nKSB7XHJcbiAgICAgIHRoaXMuY2hhbmdlRGV0ZWN0b3JSZWYucmVhdHRhY2goKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuY2hhbmdlRGV0ZWN0b3JSZWYuZGV0YWNoKCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
import {CommonModule, isPlatformBrowser} from '@angular/common';
import {
ChangeDetectorRef,
Component,
Directive,
ElementRef,
......@@ -20,11 +21,22 @@ import {filter, finalize, take, takeUntil} from 'rxjs/operators';
*/
class InViewportComponent {
/**
* @param {?} event
* @param {?} changeDetectorRef
*/
constructor(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
}
/**
* @param {?} intersectionObserverEntry
* @return {?}
*/
onViewportChange(event) {
console.log(event);
onViewportChange(intersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
}
}
InViewportComponent.decorators = [
......@@ -35,6 +47,10 @@ InViewportComponent.decorators = [
}]
}
];
/** @nocollapse */
InViewportComponent.ctorParameters = () => [
{type: ChangeDetectorRef}
];
/**
* @fileoverview added by tsickle
......
......@@ -9,7 +9,7 @@
"ng://aitp-utils/lib/aitp-utils.module.ts"
],
"sourcesContent": [
"import {Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n\r\n onViewportChange(event) {\r\n console.log(event);\r\n }\r\n}\r\n",
"import {ChangeDetectorRef, Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n constructor(private changeDetectorRef: ChangeDetectorRef) {\r\n }\r\n\r\n\r\n onViewportChange(intersectionObserverEntry: IntersectionObserverEntry) {\r\n if (intersectionObserverEntry.isIntersecting) {\r\n this.changeDetectorRef.reattach();\r\n } else {\r\n this.changeDetectorRef.detach();\r\n }\r\n }\r\n}\r\n",
"import {Injectable} from '@angular/core';\r\nimport {Observable, Subject} from 'rxjs';\r\nimport {filter, finalize} from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class ViewportService {\r\n private readonly options: IntersectionObserverInit = {\r\n rootMargin: '0px 0px 0px 0px',\r\n threshold: [0.5],\r\n };\r\n private observer: IntersectionObserver;\r\n private callback$: Subject<IntersectionObserverEntry> = new Subject();\r\n\r\n constructor() {\r\n this.observer = new IntersectionObserver(this.handler.bind(this), this.options);\r\n }\r\n\r\n observe(element: Element): Observable<IntersectionObserverEntry> {\r\n this.observer.observe(element);\r\n\r\n return this.callback$.asObservable().pipe(\r\n filter((entry: IntersectionObserverEntry) => entry.target === element),\r\n finalize(() => this.observer.unobserve(element)),\r\n );\r\n }\r\n\r\n private handler(entries: Array<IntersectionObserverEntry>): void {\r\n entries.forEach(entry => this.callback$.next(entry));\r\n }\r\n}\r\n",
"import {MonoTypeOperatorFunction, Observable} from 'rxjs';\r\nimport {takeUntil} from 'rxjs/operators';\r\n\r\n// create a symbol identify the observable I add to\r\n// the component so it doesn't conflict with anything.\r\n// I need this so I'm able to add the desired behaviour to the component.\r\nexport const destroy$ = Symbol('destroy$');\r\n\r\n/**\r\n * An operator that takes until destroy it takes a components this a parameter\r\n * returns a pipeable RxJS operator.\r\n */\r\nexport const untilDestroy = <T>(component: any): MonoTypeOperatorFunction<T> => {\r\n if (component[destroy$] === undefined) {\r\n // only hookup each component once.\r\n addDestroyObservableToComponent(component);\r\n }\r\n\r\n // pipe in the takeUntil destroy$ and return the source unaltered\r\n return takeUntil<T>(component[destroy$]);\r\n};\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function addDestroyObservableToComponent(component: any) {\r\n component[destroy$] = new Observable<void>(observer => {\r\n // keep track of the original destroy function,\r\n // the user might do something in there\r\n const orignalDestroy = component.ngOnDestroy;\r\n if (orignalDestroy == null) {\r\n // Angular does not support dynamic added destroy methods\r\n // so make sure there is one.\r\n throw new Error('untilDestroy operator needs the component to have an ngOnDestroy method');\r\n }\r\n // replace the ngOndestroy\r\n component.ngOnDestroy = () => {\r\n // fire off the destroy observable\r\n observer.next();\r\n // complete the observable\r\n observer.complete();\r\n // and at last, call the original destroy\r\n orignalDestroy.call(component);\r\n };\r\n // return cleanup function.\r\n return (_: any) => (component[destroy$] = undefined);\r\n });\r\n}\r\n",
"import {Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, OnInit, Output, PLATFORM_ID,} from '@angular/core';\r\nimport {isPlatformBrowser} from '@angular/common';\r\nimport {filter, take} from 'rxjs/operators';\r\nimport {ViewportService} from '../services';\r\nimport {untilDestroy} from '../operators';\r\n\r\n@Directive({\r\n selector: '[aiutInViewport]',\r\n})\r\nexport class InViewportDirective implements OnInit, OnDestroy {\r\n @Input() public preRender = true;\r\n @Input() public oneTime = false;\r\n @Output() readonly inViewport = new EventEmitter<Partial<IntersectionObserverEntry>>();\r\n\r\n constructor(\r\n private readonly elementRef: ElementRef,\r\n private viewportService: ViewportService,\r\n @Inject(PLATFORM_ID) private platformId: Object,\r\n ) {\r\n }\r\n\r\n public ngOnInit() {\r\n if (isPlatformBrowser(this.platformId)) {\r\n if (this.oneTime) {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(\r\n untilDestroy(this),\r\n filter(entry => entry.intersectionRatio >= 0.5),\r\n take(1),\r\n )\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n } else {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(untilDestroy(this))\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n }\r\n } else {\r\n if (this.preRender) {\r\n this.inViewport.emit({isIntersecting: true, intersectionRatio: 1});\r\n }\r\n }\r\n }\r\n\r\n ngOnDestroy() {\r\n }\r\n}\r\n",
......@@ -20,5 +20,5 @@
"Components.InViewportComponent",
"Services.ViewportService"
],
"mappings": "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"
"mappings": "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"
}
import {CommonModule, isPlatformBrowser} from '@angular/common';
import {
ChangeDetectorRef,
Component,
Directive,
ElementRef,
......@@ -19,19 +20,24 @@ import {filter, finalize, take, takeUntil} from 'rxjs/operators';
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
var InViewportComponent = /** @class */ (function () {
function InViewportComponent() {
function InViewportComponent(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
}
/**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
InViewportComponent.prototype.onViewportChange = /**
* @param {?} event
* @param {?} intersectionObserverEntry
* @return {?}
*/
function (event) {
console.log(event);
function (intersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
};
InViewportComponent.decorators = [
{
......@@ -41,6 +47,12 @@ var InViewportComponent = /** @class */ (function () {
}]
}
];
/** @nocollapse */
InViewportComponent.ctorParameters = function () {
return [
{type: ChangeDetectorRef}
];
};
return InViewportComponent;
}());
......
......@@ -9,7 +9,7 @@
"ng://aitp-utils/lib/aitp-utils.module.ts"
],
"sourcesContent": [
"import {Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n\r\n onViewportChange(event) {\r\n console.log(event);\r\n }\r\n}\r\n",
"import {ChangeDetectorRef, Component} from '@angular/core';\r\n\r\n@Component({\r\n selector: 'aiut-in-viewport',\r\n templateUrl: './in-viewport.component.html'\r\n})\r\nexport class InViewportComponent {\r\n constructor(private changeDetectorRef: ChangeDetectorRef) {\r\n }\r\n\r\n\r\n onViewportChange(intersectionObserverEntry: IntersectionObserverEntry) {\r\n if (intersectionObserverEntry.isIntersecting) {\r\n this.changeDetectorRef.reattach();\r\n } else {\r\n this.changeDetectorRef.detach();\r\n }\r\n }\r\n}\r\n",
"import {Injectable} from '@angular/core';\r\nimport {Observable, Subject} from 'rxjs';\r\nimport {filter, finalize} from 'rxjs/operators';\r\n\r\n@Injectable()\r\nexport class ViewportService {\r\n private readonly options: IntersectionObserverInit = {\r\n rootMargin: '0px 0px 0px 0px',\r\n threshold: [0.5],\r\n };\r\n private observer: IntersectionObserver;\r\n private callback$: Subject<IntersectionObserverEntry> = new Subject();\r\n\r\n constructor() {\r\n this.observer = new IntersectionObserver(this.handler.bind(this), this.options);\r\n }\r\n\r\n observe(element: Element): Observable<IntersectionObserverEntry> {\r\n this.observer.observe(element);\r\n\r\n return this.callback$.asObservable().pipe(\r\n filter((entry: IntersectionObserverEntry) => entry.target === element),\r\n finalize(() => this.observer.unobserve(element)),\r\n );\r\n }\r\n\r\n private handler(entries: Array<IntersectionObserverEntry>): void {\r\n entries.forEach(entry => this.callback$.next(entry));\r\n }\r\n}\r\n",
"import {MonoTypeOperatorFunction, Observable} from 'rxjs';\r\nimport {takeUntil} from 'rxjs/operators';\r\n\r\n// create a symbol identify the observable I add to\r\n// the component so it doesn't conflict with anything.\r\n// I need this so I'm able to add the desired behaviour to the component.\r\nexport const destroy$ = Symbol('destroy$');\r\n\r\n/**\r\n * An operator that takes until destroy it takes a components this a parameter\r\n * returns a pipeable RxJS operator.\r\n */\r\nexport const untilDestroy = <T>(component: any): MonoTypeOperatorFunction<T> => {\r\n if (component[destroy$] === undefined) {\r\n // only hookup each component once.\r\n addDestroyObservableToComponent(component);\r\n }\r\n\r\n // pipe in the takeUntil destroy$ and return the source unaltered\r\n return takeUntil<T>(component[destroy$]);\r\n};\r\n\r\n/**\r\n * @internal\r\n */\r\nexport function addDestroyObservableToComponent(component: any) {\r\n component[destroy$] = new Observable<void>(observer => {\r\n // keep track of the original destroy function,\r\n // the user might do something in there\r\n const orignalDestroy = component.ngOnDestroy;\r\n if (orignalDestroy == null) {\r\n // Angular does not support dynamic added destroy methods\r\n // so make sure there is one.\r\n throw new Error('untilDestroy operator needs the component to have an ngOnDestroy method');\r\n }\r\n // replace the ngOndestroy\r\n component.ngOnDestroy = () => {\r\n // fire off the destroy observable\r\n observer.next();\r\n // complete the observable\r\n observer.complete();\r\n // and at last, call the original destroy\r\n orignalDestroy.call(component);\r\n };\r\n // return cleanup function.\r\n return (_: any) => (component[destroy$] = undefined);\r\n });\r\n}\r\n",
"import {Directive, ElementRef, EventEmitter, Inject, Input, OnDestroy, OnInit, Output, PLATFORM_ID,} from '@angular/core';\r\nimport {isPlatformBrowser} from '@angular/common';\r\nimport {filter, take} from 'rxjs/operators';\r\nimport {ViewportService} from '../services';\r\nimport {untilDestroy} from '../operators';\r\n\r\n@Directive({\r\n selector: '[aiutInViewport]',\r\n})\r\nexport class InViewportDirective implements OnInit, OnDestroy {\r\n @Input() public preRender = true;\r\n @Input() public oneTime = false;\r\n @Output() readonly inViewport = new EventEmitter<Partial<IntersectionObserverEntry>>();\r\n\r\n constructor(\r\n private readonly elementRef: ElementRef,\r\n private viewportService: ViewportService,\r\n @Inject(PLATFORM_ID) private platformId: Object,\r\n ) {\r\n }\r\n\r\n public ngOnInit() {\r\n if (isPlatformBrowser(this.platformId)) {\r\n if (this.oneTime) {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(\r\n untilDestroy(this),\r\n filter(entry => entry.intersectionRatio >= 0.5),\r\n take(1),\r\n )\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n } else {\r\n this.viewportService\r\n .observe(this.elementRef.nativeElement)\r\n .pipe(untilDestroy(this))\r\n .subscribe((entry: IntersectionObserverEntry) => {\r\n this.inViewport.emit(entry);\r\n });\r\n }\r\n } else {\r\n if (this.preRender) {\r\n this.inViewport.emit({isIntersecting: true, intersectionRatio: 1});\r\n }\r\n }\r\n }\r\n\r\n ngOnDestroy() {\r\n }\r\n}\r\n",
......@@ -20,5 +20,5 @@
"Components.InViewportComponent",
"Services.ViewportService"
],
"mappings": "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"
"mappings": "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"
}
import {ChangeDetectorRef} from '@angular/core';
export declare class InViewportComponent {
onViewportChange(event: any): void;
private changeDetectorRef;
constructor(changeDetectorRef: ChangeDetectorRef);
onViewportChange(intersectionObserverEntry: IntersectionObserverEntry): void;
}
import {Component} from '@angular/core';
import {ChangeDetectorRef, Component} from '@angular/core';
@Component({
selector: 'aiut-in-viewport',
templateUrl: './in-viewport.component.html'
})
export class InViewportComponent {
constructor(private changeDetectorRef: ChangeDetectorRef) {
}
onViewportChange(event) {
console.log(event);
onViewportChange(intersectionObserverEntry: IntersectionObserverEntry) {
if (intersectionObserverEntry.isIntersecting) {
this.changeDetectorRef.reattach();
} else {
this.changeDetectorRef.detach();
}
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment