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

rfx-scroll-animation

Package Overview
Dependencies
Maintainers
1
Versions
30
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

rfx-scroll-animation - npm Package Compare versions

Comparing version 1.1.1 to 1.1.2

37

bundles/rfx-scroll-animation.umd.js

@@ -7,2 +7,19 @@ (function (global, factory) {

var RendererStyleModel = /** @class */ (function () {
function RendererStyleModel(name, value) {
this.name = name;
this.value = value;
}
return RendererStyleModel;
}());
(function (AnimationTypeEnum) {
AnimationTypeEnum["NONE"] = "none";
AnimationTypeEnum["TOP"] = "top";
AnimationTypeEnum["BOTTOM"] = "bottom";
AnimationTypeEnum["RIGHT"] = "right";
AnimationTypeEnum["LEFT"] = "left";
AnimationTypeEnum["ZOOM"] = "zoom";
})(exports.AnimationTypeEnum || (exports.AnimationTypeEnum = {}));
var RfxScrollAnimationService = /** @class */ (function () {

@@ -64,19 +81,2 @@ function RfxScrollAnimationService(router) {

var RendererStyleModel = /** @class */ (function () {
function RendererStyleModel(name, value) {
this.name = name;
this.value = value;
}
return RendererStyleModel;
}());
(function (AnimationTypeEnum) {
AnimationTypeEnum["NONE"] = "none";
AnimationTypeEnum["TOP"] = "top";
AnimationTypeEnum["BOTTOM"] = "bottom";
AnimationTypeEnum["RIGHT"] = "right";
AnimationTypeEnum["LEFT"] = "left";
AnimationTypeEnum["ZOOM"] = "zoom";
})(exports.AnimationTypeEnum || (exports.AnimationTypeEnum = {}));
var RfxScrollAnimationDirective = /** @class */ (function () {

@@ -298,6 +298,5 @@ function RfxScrollAnimationDirective(htmlElement, renderer, changeDetectorRef, rfxScrollAnimationService) {

exports.RendererStyleModel = RendererStyleModel;
exports.RfxScrollAnimationDirective = RfxScrollAnimationDirective;
exports.RfxScrollAnimationModule = RfxScrollAnimationModule;
exports.RfxScrollAnimationService = RfxScrollAnimationService;
exports.ɵa = RfxScrollAnimationDirective;

@@ -304,0 +303,0 @@ Object.defineProperty(exports, '__esModule', { value: true });

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

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/router"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("rfx-scroll-animation",["exports","@angular/core","@angular/router","rxjs","rxjs/operators"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["rfx-scroll-animation"]={},t.ng.core,t.ng.router,t.rxjs,t.rxjs.operators)}(this,(function(t,e,n,i,o){"use strict";var r=function(){function t(t){this.router=t,this.subjectScroll=new i.BehaviorSubject(void 0),this.subjectNavigation=new i.BehaviorSubject(!1)}return t.prototype.ngOnDestroy=function(){document.removeEventListener("scroll",this.mouseScroll)},t.prototype.initListeners=function(){var t=this;this.mouseScroll=this.onMouseScroll.bind(this),document.addEventListener("scroll",this.mouseScroll,!1),this.router.events.pipe(o.filter((function(t){return t instanceof n.NavigationEnd}))).subscribe((function(){t.subjectNavigation.next(!0)}))},t.prototype.onMouseScroll=function(){this.subjectScroll.next(void 0)},t.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},t.prototype.getNavigationEndValue=function(){return this.subjectNavigation.value},t.prototype.getNavigationEnd=function(){return this.subjectNavigation.asObservable()},t}();r.ɵprov=e.ɵɵdefineInjectable({factory:function(){return new r(e.ɵɵinject(n.Router))},token:r,providedIn:"root"}),r.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],r.ctorParameters=function(){return[{type:n.Router}]};var s,a=function(t,e){this.name=t,this.value=e};(s=t.AnimationTypeEnum||(t.AnimationTypeEnum={})).NONE="none",s.TOP="top",s.BOTTOM="bottom",s.RIGHT="right",s.LEFT="left",s.ZOOM="zoom";var l=function(){function n(t,n,i,o){this.htmlElement=t,this.renderer=n,this.changeDetectorRef=i,this.rfxScrollAnimationService=o,this.elementVisibleChange=new e.EventEmitter,this.distanceFromPageBottomPercentage=20,this.animationDistancePx=25,this.transitionDurationMs=500,this.transitionTimingFunction="cubic-bezier(0.4, 0.0, 0.2, 1)",this.scaleRatio=1.5,this.isOnlyFirstTime=!0}return n.prototype.ngOnChanges=function(){this.animationType!==t.AnimationTypeEnum.NONE&&this.setInitialElementStyle()},n.prototype.ngOnInit=function(){var t=this;this.toggleElementInstantly(!1),this.rfxScrollAnimationService.getNavigationEnd().subscribe((function(e){e&&(t.initElement(),t.isOnlyFirstTime&&t.elementVisible||(t.onScrollListener=t.rfxScrollAnimationService.getMouseScroll().subscribe((function(){t.onMouseScroll()}))))}))},n.prototype.ngOnDestroy=function(){this.onScrollListener&&this.onScrollListener.unsubscribe()},n.prototype.initElement=function(){var t=this.isElementInView(),e=t||this.isElementVisible();e&&!t?this.toggleElementInstantly(!0):e&&t&&this.toggleElement(!0)},n.prototype.setInitialElementStyle=function(){this.setElementStyle(this.htmlElement.nativeElement,new a("transition-timing-function",this.transitionTimingFunction),new a("transition-duration",this.transitionDurationMs+"ms"),new a("transition-property","opacity, transform"))},n.prototype.isElementInView=function(){var t=this.htmlElement.nativeElement.getBoundingClientRect(),e=t.top+window.pageYOffset-document.documentElement.clientTop,n=window.innerHeight/100*this.distanceFromPageBottomPercentage;return window.pageYOffset+window.innerHeight-n>=e&&window.pageYOffset<e+t.height},n.prototype.isElementVisible=function(){var t=window.scrollY+window.innerHeight,e=window.innerHeight/100*this.distanceFromPageBottomPercentage;return t>=this.htmlElement.nativeElement.getBoundingClientRect().top+window.pageYOffset-document.documentElement.clientTop+e},n.prototype.setElementStyle=function(t){for(var e=this,n=[],i=1;i<arguments.length;i++)n[i-1]=arguments[i];n.forEach((function(n){e.renderer.setStyle(t,n.name,n.value)}))},n.prototype.removeElementStyle=function(t){for(var e=this,n=[],i=1;i<arguments.length;i++)n[i-1]=arguments[i];n.forEach((function(n){e.renderer.removeStyle(t,n.name)}))},n.prototype.toggleElement=function(t){this.elementVisible=t,this.elementVisibleChange.emit(t),this.setElementStyle(this.htmlElement.nativeElement,new a("opacity",String(+t)),new a("transform",this.getElementTransform(t,this.animationType)))},n.prototype.toggleElementInstantly=function(t){this.toggleTransition(!1),this.toggleElement(t),this.changeDetectorRef.detectChanges(),this.toggleTransition(!0)},n.prototype.getElementTransform=function(e,n){switch(n){case t.AnimationTypeEnum.TOP:return e?"translateY(0)":"translateY(-"+this.animationDistancePx+"px)";case t.AnimationTypeEnum.BOTTOM:return e?"translateY(0)":"translateY("+this.animationDistancePx+"px)";case t.AnimationTypeEnum.LEFT:return e?"translateX(0)":"translateX(-"+this.animationDistancePx+"px)";case t.AnimationTypeEnum.RIGHT:return e?"translateX(0)":"translateX("+this.animationDistancePx+"px)";case t.AnimationTypeEnum.ZOOM:return e?"scale(1)":"scale("+this.scaleRatio+")";default:return"none"}},n.prototype.toggleTransition=function(t){t?this.setElementStyle(this.htmlElement.nativeElement,new a("transition-duration",this.transitionDurationMs+"ms")):this.removeElementStyle(this.htmlElement.nativeElement,new a("transition-duration"))},n.prototype.onMouseScroll=function(){this.isOnlyFirstTime&&this.elementVisible&&this.onScrollListener.unsubscribe();var t=this.isElementInView();t&&!this.elementVisible?this.toggleElement(!0):t||this.elementVisible||this.toggleElement(!1)},n}();l.decorators=[{type:e.Directive,args:[{selector:"[libRfxScrollAnimation]"}]}],l.ctorParameters=function(){return[{type:e.ElementRef},{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:r}]},l.propDecorators={distanceFromPageBottomPercentage:[{type:e.Input}],animationType:[{type:e.Input}],animationDistancePx:[{type:e.Input}],transitionDurationMs:[{type:e.Input}],transitionTimingFunction:[{type:e.Input}],scaleRatio:[{type:e.Input}],elementVisibleChange:[{type:e.Output}]};var c=function(){};c.decorators=[{type:e.NgModule,args:[{declarations:[l],imports:[],exports:[l]}]}],t.RendererStyleModel=a,t.RfxScrollAnimationDirective=l,t.RfxScrollAnimationModule=c,t.RfxScrollAnimationService=r,Object.defineProperty(t,"__esModule",{value:!0})}));
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/router"),require("rxjs"),require("rxjs/operators")):"function"==typeof define&&define.amd?define("rfx-scroll-animation",["exports","@angular/core","@angular/router","rxjs","rxjs/operators"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self)["rfx-scroll-animation"]={},t.ng.core,t.ng.router,t.rxjs,t.rxjs.operators)}(this,(function(t,e,n,i,o){"use strict";var r,s=function(t,e){this.name=t,this.value=e};(r=t.AnimationTypeEnum||(t.AnimationTypeEnum={})).NONE="none",r.TOP="top",r.BOTTOM="bottom",r.RIGHT="right",r.LEFT="left",r.ZOOM="zoom";var a=function(){function t(t){this.router=t,this.subjectScroll=new i.BehaviorSubject(void 0),this.subjectNavigation=new i.BehaviorSubject(!1)}return t.prototype.ngOnDestroy=function(){document.removeEventListener("scroll",this.mouseScroll)},t.prototype.initListeners=function(){var t=this;this.mouseScroll=this.onMouseScroll.bind(this),document.addEventListener("scroll",this.mouseScroll,!1),this.router.events.pipe(o.filter((function(t){return t instanceof n.NavigationEnd}))).subscribe((function(){t.subjectNavigation.next(!0)}))},t.prototype.onMouseScroll=function(){this.subjectScroll.next(void 0)},t.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},t.prototype.getNavigationEndValue=function(){return this.subjectNavigation.value},t.prototype.getNavigationEnd=function(){return this.subjectNavigation.asObservable()},t}();a.ɵprov=e.ɵɵdefineInjectable({factory:function(){return new a(e.ɵɵinject(n.Router))},token:a,providedIn:"root"}),a.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],a.ctorParameters=function(){return[{type:n.Router}]};var l=function(){function n(t,n,i,o){this.htmlElement=t,this.renderer=n,this.changeDetectorRef=i,this.rfxScrollAnimationService=o,this.elementVisibleChange=new e.EventEmitter,this.distanceFromPageBottomPercentage=20,this.animationDistancePx=25,this.transitionDurationMs=500,this.transitionTimingFunction="cubic-bezier(0.4, 0.0, 0.2, 1)",this.scaleRatio=1.5,this.isOnlyFirstTime=!0}return n.prototype.ngOnChanges=function(){this.animationType!==t.AnimationTypeEnum.NONE&&this.setInitialElementStyle()},n.prototype.ngOnInit=function(){var t=this;this.toggleElementInstantly(!1),this.rfxScrollAnimationService.getNavigationEnd().subscribe((function(e){e&&(t.initElement(),t.isOnlyFirstTime&&t.elementVisible||(t.onScrollListener=t.rfxScrollAnimationService.getMouseScroll().subscribe((function(){t.onMouseScroll()}))))}))},n.prototype.ngOnDestroy=function(){this.onScrollListener&&this.onScrollListener.unsubscribe()},n.prototype.initElement=function(){var t=this.isElementInView(),e=t||this.isElementVisible();e&&!t?this.toggleElementInstantly(!0):e&&t&&this.toggleElement(!0)},n.prototype.setInitialElementStyle=function(){this.setElementStyle(this.htmlElement.nativeElement,new s("transition-timing-function",this.transitionTimingFunction),new s("transition-duration",this.transitionDurationMs+"ms"),new s("transition-property","opacity, transform"))},n.prototype.isElementInView=function(){var t=this.htmlElement.nativeElement.getBoundingClientRect(),e=t.top+window.pageYOffset-document.documentElement.clientTop,n=window.innerHeight/100*this.distanceFromPageBottomPercentage;return window.pageYOffset+window.innerHeight-n>=e&&window.pageYOffset<e+t.height},n.prototype.isElementVisible=function(){var t=window.scrollY+window.innerHeight,e=window.innerHeight/100*this.distanceFromPageBottomPercentage;return t>=this.htmlElement.nativeElement.getBoundingClientRect().top+window.pageYOffset-document.documentElement.clientTop+e},n.prototype.setElementStyle=function(t){for(var e=this,n=[],i=1;i<arguments.length;i++)n[i-1]=arguments[i];n.forEach((function(n){e.renderer.setStyle(t,n.name,n.value)}))},n.prototype.removeElementStyle=function(t){for(var e=this,n=[],i=1;i<arguments.length;i++)n[i-1]=arguments[i];n.forEach((function(n){e.renderer.removeStyle(t,n.name)}))},n.prototype.toggleElement=function(t){this.elementVisible=t,this.elementVisibleChange.emit(t),this.setElementStyle(this.htmlElement.nativeElement,new s("opacity",String(+t)),new s("transform",this.getElementTransform(t,this.animationType)))},n.prototype.toggleElementInstantly=function(t){this.toggleTransition(!1),this.toggleElement(t),this.changeDetectorRef.detectChanges(),this.toggleTransition(!0)},n.prototype.getElementTransform=function(e,n){switch(n){case t.AnimationTypeEnum.TOP:return e?"translateY(0)":"translateY(-"+this.animationDistancePx+"px)";case t.AnimationTypeEnum.BOTTOM:return e?"translateY(0)":"translateY("+this.animationDistancePx+"px)";case t.AnimationTypeEnum.LEFT:return e?"translateX(0)":"translateX(-"+this.animationDistancePx+"px)";case t.AnimationTypeEnum.RIGHT:return e?"translateX(0)":"translateX("+this.animationDistancePx+"px)";case t.AnimationTypeEnum.ZOOM:return e?"scale(1)":"scale("+this.scaleRatio+")";default:return"none"}},n.prototype.toggleTransition=function(t){t?this.setElementStyle(this.htmlElement.nativeElement,new s("transition-duration",this.transitionDurationMs+"ms")):this.removeElementStyle(this.htmlElement.nativeElement,new s("transition-duration"))},n.prototype.onMouseScroll=function(){this.isOnlyFirstTime&&this.elementVisible&&this.onScrollListener.unsubscribe();var t=this.isElementInView();t&&!this.elementVisible?this.toggleElement(!0):t||this.elementVisible||this.toggleElement(!1)},n}();l.decorators=[{type:e.Directive,args:[{selector:"[libRfxScrollAnimation]"}]}],l.ctorParameters=function(){return[{type:e.ElementRef},{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:a}]},l.propDecorators={distanceFromPageBottomPercentage:[{type:e.Input}],animationType:[{type:e.Input}],animationDistancePx:[{type:e.Input}],transitionDurationMs:[{type:e.Input}],transitionTimingFunction:[{type:e.Input}],scaleRatio:[{type:e.Input}],elementVisibleChange:[{type:e.Output}]};var c=function(){};c.decorators=[{type:e.NgModule,args:[{declarations:[l],imports:[],exports:[l]}]}],t.RfxScrollAnimationModule=c,t.RfxScrollAnimationService=a,t.ɵa=l,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=rfx-scroll-animation.umd.min.js.map

@@ -10,2 +10,2 @@ export var AnimationTypeEnum;

})(AnimationTypeEnum || (AnimationTypeEnum = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLXR5cGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiJEOi9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9fbW9kZWxzL2FuaW1hdGlvbi10eXBlLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksaUJBT1g7QUFQRCxXQUFZLGlCQUFpQjtJQUMzQixrQ0FBYSxDQUFBO0lBQ2IsZ0NBQVcsQ0FBQTtJQUNYLHNDQUFpQixDQUFBO0lBQ2pCLG9DQUFlLENBQUE7SUFDZixrQ0FBYSxDQUFBO0lBQ2Isa0NBQWEsQ0FBQTtBQUNmLENBQUMsRUFQVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBTzVCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gQW5pbWF0aW9uVHlwZUVudW0ge1xyXG4gIE5PTkUgPSAnbm9uZScsXHJcbiAgVE9QID0gJ3RvcCcsXHJcbiAgQk9UVE9NID0gJ2JvdHRvbScsXHJcbiAgUklHSFQgPSAncmlnaHQnLFxyXG4gIExFRlQgPSAnbGVmdCcsXHJcbiAgWk9PTSA9ICd6b29tJ1xyXG59XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9uLXR5cGUuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9yZngtc2Nyb2xsLWFuaW1hdGlvbi9zcmMvIiwic291cmNlcyI6WyJsaWIvX21vZGVscy9hbmltYXRpb24tdHlwZS5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGlCQU9YO0FBUEQsV0FBWSxpQkFBaUI7SUFDM0Isa0NBQWEsQ0FBQTtJQUNiLGdDQUFXLENBQUE7SUFDWCxzQ0FBaUIsQ0FBQTtJQUNqQixvQ0FBZSxDQUFBO0lBQ2Ysa0NBQWEsQ0FBQTtJQUNiLGtDQUFhLENBQUE7QUFDZixDQUFDLEVBUFcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQU81QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEFuaW1hdGlvblR5cGVFbnVtIHtcclxuICBOT05FID0gJ25vbmUnLFxyXG4gIFRPUCA9ICd0b3AnLFxyXG4gIEJPVFRPTSA9ICdib3R0b20nLFxyXG4gIFJJR0hUID0gJ3JpZ2h0JyxcclxuICBMRUZUID0gJ2xlZnQnLFxyXG4gIFpPT00gPSAnem9vbSdcclxufVxyXG4iXX0=
export * from './render-style.model';
export * from './animation-type.enum';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiRDovUmVwb3MvUkZYTGlicmFyeS9wcm9qZWN0cy9yZngtc2Nyb2xsLWFuaW1hdGlvbi9zcmMvIiwic291cmNlcyI6WyJsaWIvX21vZGVscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3JlbmRlci1zdHlsZS5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYW5pbWF0aW9uLXR5cGUuZW51bSc7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vcHJvamVjdHMvcmZ4LXNjcm9sbC1hbmltYXRpb24vc3JjLyIsInNvdXJjZXMiOlsibGliL19tb2RlbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9yZW5kZXItc3R5bGUubW9kZWwnO1xyXG5leHBvcnQgKiBmcm9tICcuL2FuaW1hdGlvbi10eXBlLmVudW0nO1xyXG4iXX0=

@@ -7,2 +7,2 @@ export class RendererStyleModel {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXN0eWxlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IkQ6L1JlcG9zL1JGWExpYnJhcnkvcHJvamVjdHMvcmZ4LXNjcm9sbC1hbmltYXRpb24vc3JjLyIsInNvdXJjZXMiOlsibGliL19tb2RlbHMvcmVuZGVyLXN0eWxlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxrQkFBa0I7SUFJN0IsWUFBWSxJQUFhLEVBQUUsS0FBYztRQUN2QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztJQUNyQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgUmVuZGVyZXJTdHlsZU1vZGVsIHtcclxuICBwdWJsaWMgbmFtZTogc3RyaW5nO1xyXG4gIHB1YmxpYyB2YWx1ZTogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3RvcihuYW1lPzogc3RyaW5nLCB2YWx1ZT86IHN0cmluZykge1xyXG4gICAgdGhpcy5uYW1lID0gbmFtZTtcclxuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcclxuICB9XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXN0eWxlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9fbW9kZWxzL3JlbmRlci1zdHlsZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sa0JBQWtCO0lBSTdCLFlBQVksSUFBYSxFQUFFLEtBQWM7UUFDdkMsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFJlbmRlcmVyU3R5bGVNb2RlbCB7XHJcbiAgcHVibGljIG5hbWU6IHN0cmluZztcclxuICBwdWJsaWMgdmFsdWU6IHN0cmluZztcclxuXHJcbiAgY29uc3RydWN0b3IobmFtZT86IHN0cmluZywgdmFsdWU/OiBzdHJpbmcpIHtcclxuICAgIHRoaXMubmFtZSA9IG5hbWU7XHJcbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XHJcbiAgfVxyXG59XHJcbiJdfQ==

@@ -186,2 +186,2 @@ import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Input, Output, Renderer2 } from '@angular/core';

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.directive.js","sourceRoot":"D:/Repos/RFXLibrary/projects/rfx-scroll-animation/src/","sources":["lib/rfx-scroll-animation.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, Renderer2 } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AnimationTypeEnum, RendererStyleModel } from './_models';\r\nimport { RfxScrollAnimationService } from './rfx-scroll-animation.service';\r\n\r\n@Directive({\r\n  selector: '[libRfxScrollAnimation]'\r\n})\r\nexport class RfxScrollAnimationDirective implements OnInit, OnDestroy, OnChanges {\r\n  @Input() public distanceFromPageBottomPercentage: number;\r\n  @Input() public animationType: AnimationTypeEnum;\r\n  @Input() public animationDistancePx: number;\r\n  @Input() public transitionDurationMs: number;\r\n  // @Input() public transitionDelayMs: number; // PERFORMANCE ISSUES\r\n  @Input() public transitionTimingFunction: string;\r\n  @Input() public scaleRatio: number;\r\n  public isOnlyFirstTime: boolean; // @Input() // NOT WORKING CORRECTLY\r\n  @Output() public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  private elementVisible: boolean;\r\n  private onScrollListener: Subscription;\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private rfxScrollAnimationService: RfxScrollAnimationService\r\n  ) {\r\n    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.animationDistancePx = 25;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionTimingFunction = 'cubic-bezier(0.4, 0.0, 0.2, 1)';\r\n    this.scaleRatio = 1.5;\r\n    this.isOnlyFirstTime = true;\r\n  }\r\n\r\n  public ngOnChanges(): void {\r\n    if (this.animationType !== AnimationTypeEnum.NONE) {\r\n      this.setInitialElementStyle();\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.toggleElementInstantly(false);\r\n\r\n    this.rfxScrollAnimationService.getNavigationEnd().subscribe((value: boolean) => {\r\n      if (value) {\r\n        this.initElement();\r\n\r\n        if (!this.isOnlyFirstTime || !this.elementVisible) {\r\n          this.onScrollListener = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => {\r\n            this.onMouseScroll();\r\n          });\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    if (this.onScrollListener) {\r\n      this.onScrollListener.unsubscribe();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set html element initial state\r\n   */\r\n  private initElement(): void {\r\n    const isElementInView = this.isElementInView();\r\n    const isElementVisible = isElementInView ? isElementInView : this.isElementVisible();\r\n\r\n    if (isElementVisible && !isElementInView) {\r\n      this.toggleElementInstantly(true);\r\n    } else if (isElementVisible && isElementInView) {\r\n      this.toggleElement(true);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set html element initial style\r\n   */\r\n  private setInitialElementStyle(): void {\r\n    this.setElementStyle(\r\n      this.htmlElement.nativeElement,\r\n      new RendererStyleModel('transition-timing-function', this.transitionTimingFunction),\r\n      new RendererStyleModel('transition-duration', `${this.transitionDurationMs}ms`),\r\n      new RendererStyleModel('transition-property', 'opacity, transform')\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Is element visible in the window\r\n   */\r\n  private isElementInView(): boolean {\r\n    const rect: DOMRect = this.htmlElement.nativeElement.getBoundingClientRect();\r\n    const offsetTop: number = rect.top + window.pageYOffset - document.documentElement.clientTop;\r\n    const distanceInPx: number = (window.innerHeight / 100) * this.distanceFromPageBottomPercentage;\r\n    const viewTop: number = window.pageYOffset + window.innerHeight - distanceInPx;\r\n    return viewTop >= offsetTop && window.pageYOffset < offsetTop + rect.height;\r\n  }\r\n\r\n  /**\r\n   * IS element visible in the document\r\n   */\r\n  private isElementVisible(): boolean {\r\n    const scrollBottom: number = window.scrollY + window.innerHeight;\r\n    const distanceInPx: number = (window.innerHeight / 100) * this.distanceFromPageBottomPercentage;\r\n    const rectTop: number = this.htmlElement.nativeElement.getBoundingClientRect().top;\r\n    const scrollBottomWithDistance: number = rectTop + window.pageYOffset - document.documentElement.clientTop + distanceInPx;\r\n    return scrollBottom >= scrollBottomWithDistance;\r\n  }\r\n\r\n  /**\r\n   * Set single or multiple element styles\r\n   * @param element html element\r\n   * @param styles single or multiple style models\r\n   */\r\n  private setElementStyle(element: Element, ...styles: RendererStyleModel[]): void {\r\n    styles.forEach((style) => {\r\n      this.renderer.setStyle(element, style.name, style.value);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Remove single or multiple element styles\r\n   * @param element html element\r\n   * @param styles single or multiple style models (only style name is required)\r\n   */\r\n  private removeElementStyle(element: Element, ...styles: RendererStyleModel[]): void {\r\n    styles.forEach((style) => {\r\n      this.renderer.removeStyle(element, style.name);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show / hide element from page\r\n   */\r\n  private toggleElement(visible: boolean): void {\r\n    this.elementVisible = visible;\r\n    this.elementVisibleChange.emit(visible);\r\n\r\n    this.setElementStyle(\r\n      this.htmlElement.nativeElement,\r\n      new RendererStyleModel('opacity', String(+visible)),\r\n      new RendererStyleModel('transform', this.getElementTransform(visible, this.animationType))\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Show / hide element instantly (without animation) from page\r\n   */\r\n  private toggleElementInstantly(visible: boolean): void {\r\n    this.toggleTransition(false);\r\n    this.toggleElement(visible);\r\n    this.changeDetectorRef.detectChanges();\r\n    this.toggleTransition(true);\r\n  }\r\n\r\n  /**\r\n   * Get animation transform by AnimationTypeEnum\r\n   * @param isElementVisible is element already visible\r\n   * @param animationType animation type\r\n   */\r\n  private getElementTransform(isElementVisible: boolean, animationType: AnimationTypeEnum): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return isElementVisible ? 'translateY(0)' : `translateY(-${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return isElementVisible ? 'translateY(0)' : `translateY(${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return isElementVisible ? 'translateX(0)' : `translateX(-${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return isElementVisible ? 'translateX(0)' : `translateX(${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return isElementVisible ? 'scale(1)' : `scale(${this.scaleRatio})`;\r\n      default:\r\n        return 'none';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Enable / disable element animation\r\n   * @param enabled enabled or disabled transition\r\n   */\r\n  private toggleTransition(enabled: boolean): void {\r\n    if (enabled) {\r\n      this.setElementStyle(this.htmlElement.nativeElement, new RendererStyleModel('transition-duration', `${this.transitionDurationMs}ms`));\r\n    } else {\r\n      this.removeElementStyle(this.htmlElement.nativeElement, new RendererStyleModel('transition-duration'));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * On mouse scroll event\r\n   */\r\n  private onMouseScroll(): void {\r\n    if (this.isOnlyFirstTime && this.elementVisible) {\r\n      this.onScrollListener.unsubscribe();\r\n    }\r\n\r\n    const isElementInView: boolean = this.isElementInView();\r\n\r\n    if (isElementInView && !this.elementVisible) {\r\n      this.toggleElement(true);\r\n    } else if (!isElementInView && !this.elementVisible) {\r\n      this.toggleElement(false);\r\n    }\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.directive.js","sourceRoot":"../../../projects/rfx-scroll-animation/src/","sources":["lib/rfx-scroll-animation.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, Renderer2 } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AnimationTypeEnum, RendererStyleModel } from './_models';\r\nimport { RfxScrollAnimationService } from './rfx-scroll-animation.service';\r\n\r\n@Directive({\r\n  selector: '[libRfxScrollAnimation]'\r\n})\r\nexport class RfxScrollAnimationDirective implements OnInit, OnDestroy, OnChanges {\r\n  @Input() public distanceFromPageBottomPercentage: number;\r\n  @Input() public animationType: AnimationTypeEnum;\r\n  @Input() public animationDistancePx: number;\r\n  @Input() public transitionDurationMs: number;\r\n  // @Input() public transitionDelayMs: number; // PERFORMANCE ISSUES\r\n  @Input() public transitionTimingFunction: string;\r\n  @Input() public scaleRatio: number;\r\n  public isOnlyFirstTime: boolean; // @Input() // NOT WORKING CORRECTLY\r\n  @Output() public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  private elementVisible: boolean;\r\n  private onScrollListener: Subscription;\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private rfxScrollAnimationService: RfxScrollAnimationService\r\n  ) {\r\n    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.animationDistancePx = 25;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionTimingFunction = 'cubic-bezier(0.4, 0.0, 0.2, 1)';\r\n    this.scaleRatio = 1.5;\r\n    this.isOnlyFirstTime = true;\r\n  }\r\n\r\n  public ngOnChanges(): void {\r\n    if (this.animationType !== AnimationTypeEnum.NONE) {\r\n      this.setInitialElementStyle();\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.toggleElementInstantly(false);\r\n\r\n    this.rfxScrollAnimationService.getNavigationEnd().subscribe((value: boolean) => {\r\n      if (value) {\r\n        this.initElement();\r\n\r\n        if (!this.isOnlyFirstTime || !this.elementVisible) {\r\n          this.onScrollListener = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => {\r\n            this.onMouseScroll();\r\n          });\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    if (this.onScrollListener) {\r\n      this.onScrollListener.unsubscribe();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set html element initial state\r\n   */\r\n  private initElement(): void {\r\n    const isElementInView = this.isElementInView();\r\n    const isElementVisible = isElementInView ? isElementInView : this.isElementVisible();\r\n\r\n    if (isElementVisible && !isElementInView) {\r\n      this.toggleElementInstantly(true);\r\n    } else if (isElementVisible && isElementInView) {\r\n      this.toggleElement(true);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set html element initial style\r\n   */\r\n  private setInitialElementStyle(): void {\r\n    this.setElementStyle(\r\n      this.htmlElement.nativeElement,\r\n      new RendererStyleModel('transition-timing-function', this.transitionTimingFunction),\r\n      new RendererStyleModel('transition-duration', `${this.transitionDurationMs}ms`),\r\n      new RendererStyleModel('transition-property', 'opacity, transform')\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Is element visible in the window\r\n   */\r\n  private isElementInView(): boolean {\r\n    const rect: DOMRect = this.htmlElement.nativeElement.getBoundingClientRect();\r\n    const offsetTop: number = rect.top + window.pageYOffset - document.documentElement.clientTop;\r\n    const distanceInPx: number = (window.innerHeight / 100) * this.distanceFromPageBottomPercentage;\r\n    const viewTop: number = window.pageYOffset + window.innerHeight - distanceInPx;\r\n    return viewTop >= offsetTop && window.pageYOffset < offsetTop + rect.height;\r\n  }\r\n\r\n  /**\r\n   * IS element visible in the document\r\n   */\r\n  private isElementVisible(): boolean {\r\n    const scrollBottom: number = window.scrollY + window.innerHeight;\r\n    const distanceInPx: number = (window.innerHeight / 100) * this.distanceFromPageBottomPercentage;\r\n    const rectTop: number = this.htmlElement.nativeElement.getBoundingClientRect().top;\r\n    const scrollBottomWithDistance: number = rectTop + window.pageYOffset - document.documentElement.clientTop + distanceInPx;\r\n    return scrollBottom >= scrollBottomWithDistance;\r\n  }\r\n\r\n  /**\r\n   * Set single or multiple element styles\r\n   * @param element html element\r\n   * @param styles single or multiple style models\r\n   */\r\n  private setElementStyle(element: Element, ...styles: RendererStyleModel[]): void {\r\n    styles.forEach((style) => {\r\n      this.renderer.setStyle(element, style.name, style.value);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Remove single or multiple element styles\r\n   * @param element html element\r\n   * @param styles single or multiple style models (only style name is required)\r\n   */\r\n  private removeElementStyle(element: Element, ...styles: RendererStyleModel[]): void {\r\n    styles.forEach((style) => {\r\n      this.renderer.removeStyle(element, style.name);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show / hide element from page\r\n   */\r\n  private toggleElement(visible: boolean): void {\r\n    this.elementVisible = visible;\r\n    this.elementVisibleChange.emit(visible);\r\n\r\n    this.setElementStyle(\r\n      this.htmlElement.nativeElement,\r\n      new RendererStyleModel('opacity', String(+visible)),\r\n      new RendererStyleModel('transform', this.getElementTransform(visible, this.animationType))\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Show / hide element instantly (without animation) from page\r\n   */\r\n  private toggleElementInstantly(visible: boolean): void {\r\n    this.toggleTransition(false);\r\n    this.toggleElement(visible);\r\n    this.changeDetectorRef.detectChanges();\r\n    this.toggleTransition(true);\r\n  }\r\n\r\n  /**\r\n   * Get animation transform by AnimationTypeEnum\r\n   * @param isElementVisible is element already visible\r\n   * @param animationType animation type\r\n   */\r\n  private getElementTransform(isElementVisible: boolean, animationType: AnimationTypeEnum): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return isElementVisible ? 'translateY(0)' : `translateY(-${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return isElementVisible ? 'translateY(0)' : `translateY(${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return isElementVisible ? 'translateX(0)' : `translateX(-${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return isElementVisible ? 'translateX(0)' : `translateX(${this.animationDistancePx}px)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return isElementVisible ? 'scale(1)' : `scale(${this.scaleRatio})`;\r\n      default:\r\n        return 'none';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Enable / disable element animation\r\n   * @param enabled enabled or disabled transition\r\n   */\r\n  private toggleTransition(enabled: boolean): void {\r\n    if (enabled) {\r\n      this.setElementStyle(this.htmlElement.nativeElement, new RendererStyleModel('transition-duration', `${this.transitionDurationMs}ms`));\r\n    } else {\r\n      this.removeElementStyle(this.htmlElement.nativeElement, new RendererStyleModel('transition-duration'));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * On mouse scroll event\r\n   */\r\n  private onMouseScroll(): void {\r\n    if (this.isOnlyFirstTime && this.elementVisible) {\r\n      this.onScrollListener.unsubscribe();\r\n    }\r\n\r\n    const isElementInView: boolean = this.isElementInView();\r\n\r\n    if (isElementInView && !this.elementVisible) {\r\n      this.toggleElement(true);\r\n    } else if (!isElementInView && !this.elementVisible) {\r\n      this.toggleElement(false);\r\n    }\r\n  }\r\n}\r\n"]}

@@ -12,2 +12,2 @@ import { NgModule } from '@angular/core';

];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IkQ6L1JlcG9zL1JGWExpYnJhcnkvcHJvamVjdHMvcmZ4LXNjcm9sbC1hbmltYXRpb24vc3JjLyIsInNvdXJjZXMiOlsibGliL3JmeC1zY3JvbGwtYW5pbWF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBUS9FLE1BQU0sT0FBTyx3QkFBd0I7OztZQU5wQyxRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFLENBQUMsMkJBQTJCLENBQUM7Z0JBQzNDLE9BQU8sRUFBRSxFQUNSO2dCQUNELE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO2FBQ3ZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUmZ4U2Nyb2xsQW5pbWF0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9yZngtc2Nyb2xsLWFuaW1hdGlvbi5kaXJlY3RpdmUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtSZnhTY3JvbGxBbmltYXRpb25EaXJlY3RpdmVdLFxyXG4gIGltcG9ydHM6IFtcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtSZnhTY3JvbGxBbmltYXRpb25EaXJlY3RpdmVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZnhTY3JvbGxBbmltYXRpb25Nb2R1bGUgeyB9XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uLy4uL3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9yZngtc2Nyb2xsLWFuaW1hdGlvbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQVEvRSxNQUFNLE9BQU8sd0JBQXdCOzs7WUFOcEMsUUFBUSxTQUFDO2dCQUNSLFlBQVksRUFBRSxDQUFDLDJCQUEyQixDQUFDO2dCQUMzQyxPQUFPLEVBQUUsRUFDUjtnQkFDRCxPQUFPLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQzthQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJmeFNjcm9sbEFuaW1hdGlvbkRpcmVjdGl2ZSB9IGZyb20gJy4vcmZ4LXNjcm9sbC1hbmltYXRpb24uZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbUmZ4U2Nyb2xsQW5pbWF0aW9uRGlyZWN0aXZlXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgXSxcclxuICBleHBvcnRzOiBbUmZ4U2Nyb2xsQW5pbWF0aW9uRGlyZWN0aXZlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmZ4U2Nyb2xsQW5pbWF0aW9uTW9kdWxlIHsgfVxyXG4iXX0=

@@ -60,2 +60,2 @@ import { Injectable } from '@angular/core';

];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJEOi9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9yZngtc2Nyb2xsLWFuaW1hdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDdEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBS3hDLE1BQU0sT0FBTyx5QkFBeUI7SUFLcEMsWUFDVSxNQUFjO1FBQWQsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUV0QixJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksZUFBZSxDQUFZLFNBQVMsQ0FBQyxDQUFDO1FBQy9ELElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU0sV0FBVztRQUNoQixRQUFRLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakQsUUFBUSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRTdELElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDckIsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxZQUFZLGFBQWEsQ0FBQyxDQUNoRCxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZixJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0ssYUFBYTtRQUNuQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxjQUFjO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMzQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxxQkFBcUI7UUFDMUIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDO0lBQ3RDLENBQUM7SUFFRDs7T0FFRztJQUNJLGdCQUFnQjtRQUNyQixPQUFPLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMvQyxDQUFDOzs7O1lBM0RGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBTnVCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTmF2aWdhdGlvbkVuZCwgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IGZpbHRlciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJmeFNjcm9sbEFuaW1hdGlvblNlcnZpY2UgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xyXG4gIHByaXZhdGUgbW91c2VTY3JvbGw6IGFueTtcclxuICBwcml2YXRlIHN1YmplY3RTY3JvbGw6IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+O1xyXG4gIHByaXZhdGUgc3ViamVjdE5hdmlnYXRpb246IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyXHJcbiAgKSB7XHJcbiAgICB0aGlzLnN1YmplY3RTY3JvbGwgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcclxuICAgIHRoaXMuc3ViamVjdE5hdmlnYXRpb24gPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIHRoaXMubW91c2VTY3JvbGwpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogSW5pdCBsaXN0ZW5lcnNcclxuICAgKi9cclxuICBwdWJsaWMgaW5pdExpc3RlbmVycygpOiB2b2lkIHtcclxuICAgIHRoaXMubW91c2VTY3JvbGwgPSB0aGlzLm9uTW91c2VTY3JvbGwuYmluZCh0aGlzKTtcclxuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIHRoaXMubW91c2VTY3JvbGwsIGZhbHNlKTtcclxuXHJcbiAgICB0aGlzLnJvdXRlci5ldmVudHMucGlwZShcclxuICAgICAgZmlsdGVyKGV2ZW50ID0+IGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvbkVuZClcclxuICAgICkuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgdGhpcy5zdWJqZWN0TmF2aWdhdGlvbi5uZXh0KHRydWUpO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBNb3VzZSBzY3JvbGwgZXZlbnRcclxuICAgKi9cclxuICBwcml2YXRlIG9uTW91c2VTY3JvbGwoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1YmplY3RTY3JvbGwubmV4dCh1bmRlZmluZWQpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTW91c2Ugc2Nyb2xsIGV2ZW50IG9ic2VydmFibGVcclxuICAgKi9cclxuICBwdWJsaWMgZ2V0TW91c2VTY3JvbGwoKTogT2JzZXJ2YWJsZTx1bmRlZmluZWQ+IHtcclxuICAgIHJldHVybiB0aGlzLnN1YmplY3RTY3JvbGwuYXNPYnNlcnZhYmxlKCk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBOYXZpZ2F0aW9uRW5kIGV2ZW50XHJcbiAgICovXHJcbiAgcHVibGljIGdldE5hdmlnYXRpb25FbmRWYWx1ZSgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLnN1YmplY3ROYXZpZ2F0aW9uLnZhbHVlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTmF2aWdhdGlvbkVuZCBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldE5hdmlnYXRpb25FbmQoKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWJqZWN0TmF2aWdhdGlvbi5hc09ic2VydmFibGUoKTtcclxuICB9XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9yZngtc2Nyb2xsLWFuaW1hdGlvbi9zcmMvIiwic291cmNlcyI6WyJsaWIvcmZ4LXNjcm9sbC1hbmltYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3RELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUt4QyxNQUFNLE9BQU8seUJBQXlCO0lBS3BDLFlBQ1UsTUFBYztRQUFkLFdBQU0sR0FBTixNQUFNLENBQVE7UUFFdEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBWSxTQUFTLENBQUMsQ0FBQztRQUMvRCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVNLFdBQVc7UUFDaEIsUUFBUSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVEOztPQUVHO0lBQ0ksYUFBYTtRQUNsQixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2pELFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUU3RCxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ3JCLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FDaEQsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2YsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRDs7T0FFRztJQUNLLGFBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDM0MsQ0FBQztJQUVEOztPQUVHO0lBQ0kscUJBQXFCO1FBQzFCLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQztJQUN0QyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxnQkFBZ0I7UUFDckIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDL0MsQ0FBQzs7OztZQTNERixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQU51QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5hdmlnYXRpb25FbmQsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBmaWx0ZXIgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZnhTY3JvbGxBbmltYXRpb25TZXJ2aWNlIGltcGxlbWVudHMgT25EZXN0cm95IHtcclxuICBwcml2YXRlIG1vdXNlU2Nyb2xsOiBhbnk7XHJcbiAgcHJpdmF0ZSBzdWJqZWN0U2Nyb2xsOiBCZWhhdmlvclN1YmplY3Q8dW5kZWZpbmVkPjtcclxuICBwcml2YXRlIHN1YmplY3ROYXZpZ2F0aW9uOiBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj47XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxyXG4gICkge1xyXG4gICAgdGhpcy5zdWJqZWN0U2Nyb2xsID0gbmV3IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XHJcbiAgICB0aGlzLnN1YmplY3ROYXZpZ2F0aW9uID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLm1vdXNlU2Nyb2xsKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEluaXQgbGlzdGVuZXJzXHJcbiAgICovXHJcbiAgcHVibGljIGluaXRMaXN0ZW5lcnMoKTogdm9pZCB7XHJcbiAgICB0aGlzLm1vdXNlU2Nyb2xsID0gdGhpcy5vbk1vdXNlU2Nyb2xsLmJpbmQodGhpcyk7XHJcbiAgICBkb2N1bWVudC5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLm1vdXNlU2Nyb2xsLCBmYWxzZSk7XHJcblxyXG4gICAgdGhpcy5yb3V0ZXIuZXZlbnRzLnBpcGUoXHJcbiAgICAgIGZpbHRlcihldmVudCA9PiBldmVudCBpbnN0YW5jZW9mIE5hdmlnYXRpb25FbmQpXHJcbiAgICApLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgIHRoaXMuc3ViamVjdE5hdmlnYXRpb24ubmV4dCh0cnVlKTtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTW91c2Ugc2Nyb2xsIGV2ZW50XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBvbk1vdXNlU2Nyb2xsKCk6IHZvaWQge1xyXG4gICAgdGhpcy5zdWJqZWN0U2Nyb2xsLm5leHQodW5kZWZpbmVkKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1vdXNlIHNjcm9sbCBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldE1vdXNlU2Nyb2xsKCk6IE9ic2VydmFibGU8dW5kZWZpbmVkPiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWJqZWN0U2Nyb2xsLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTmF2aWdhdGlvbkVuZCBldmVudFxyXG4gICAqL1xyXG4gIHB1YmxpYyBnZXROYXZpZ2F0aW9uRW5kVmFsdWUoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWJqZWN0TmF2aWdhdGlvbi52YWx1ZTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE5hdmlnYXRpb25FbmQgZXZlbnQgb2JzZXJ2YWJsZVxyXG4gICAqL1xyXG4gIHB1YmxpYyBnZXROYXZpZ2F0aW9uRW5kKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc3ViamVjdE5hdmlnYXRpb24uYXNPYnNlcnZhYmxlKCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
/*
* Public API Surface of rfx-scroll-animation
*/
export * from './lib';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJEOi9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1zY3JvbGwtYW5pbWF0aW9uL3NyYy8iLCJzb3VyY2VzIjpbInB1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiByZngtc2Nyb2xsLWFuaW1hdGlvblxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliJztcclxuIl19
export * from './lib/rfx-scroll-animation.module';
export * from './lib/rfx-scroll-animation.service';
export * from './lib/_models/animation-type.enum';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLi9wcm9qZWN0cy9yZngtc2Nyb2xsLWFuaW1hdGlvbi9zcmMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgcmZ4LXNjcm9sbC1hbmltYXRpb25cclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZngtc2Nyb2xsLWFuaW1hdGlvbi5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZngtc2Nyb2xsLWFuaW1hdGlvbi5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvX21vZGVscy9hbmltYXRpb24tdHlwZS5lbnVtJztcclxuIl19

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

export * from './public-api';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uanMiLCJzb3VyY2VSb290IjoiRDovUmVwb3MvUkZYTGlicmFyeS9wcm9qZWN0cy9yZngtc2Nyb2xsLWFuaW1hdGlvbi9zcmMvIiwic291cmNlcyI6WyJyZngtc2Nyb2xsLWFuaW1hdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
export { RfxScrollAnimationDirective as ɵa } from './lib/rfx-scroll-animation.directive';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXNjcm9sbC1hbmltYXRpb24uanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4vcHJvamVjdHMvcmZ4LXNjcm9sbC1hbmltYXRpb24vc3JjLyIsInNvdXJjZXMiOlsicmZ4LXNjcm9sbC1hbmltYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQztBQUU3QixPQUFPLEVBQUMsMkJBQTJCLElBQUksRUFBRSxFQUFDLE1BQU0sc0NBQXNDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG5cbmV4cG9ydCB7UmZ4U2Nyb2xsQW5pbWF0aW9uRGlyZWN0aXZlIGFzIMm1YX0gZnJvbSAnLi9saWIvcmZ4LXNjcm9sbC1hbmltYXRpb24uZGlyZWN0aXZlJzsiXX0=

@@ -6,2 +6,19 @@ import { ɵɵdefineInjectable, ɵɵinject, Injectable, EventEmitter, Directive, ElementRef, Renderer2, ChangeDetectorRef, Input, Output, NgModule } from '@angular/core';

class RendererStyleModel {
constructor(name, value) {
this.name = name;
this.value = value;
}
}
var AnimationTypeEnum;
(function (AnimationTypeEnum) {
AnimationTypeEnum["NONE"] = "none";
AnimationTypeEnum["TOP"] = "top";
AnimationTypeEnum["BOTTOM"] = "bottom";
AnimationTypeEnum["RIGHT"] = "right";
AnimationTypeEnum["LEFT"] = "left";
AnimationTypeEnum["ZOOM"] = "zoom";
})(AnimationTypeEnum || (AnimationTypeEnum = {}));
class RfxScrollAnimationService {

@@ -61,19 +78,2 @@ constructor(router) {

class RendererStyleModel {
constructor(name, value) {
this.name = name;
this.value = value;
}
}
var AnimationTypeEnum;
(function (AnimationTypeEnum) {
AnimationTypeEnum["NONE"] = "none";
AnimationTypeEnum["TOP"] = "top";
AnimationTypeEnum["BOTTOM"] = "bottom";
AnimationTypeEnum["RIGHT"] = "right";
AnimationTypeEnum["LEFT"] = "left";
AnimationTypeEnum["ZOOM"] = "zoom";
})(AnimationTypeEnum || (AnimationTypeEnum = {}));
class RfxScrollAnimationDirective {

@@ -280,3 +280,3 @@ constructor(htmlElement, renderer, changeDetectorRef, rfxScrollAnimationService) {

export { AnimationTypeEnum, RendererStyleModel, RfxScrollAnimationDirective, RfxScrollAnimationModule, RfxScrollAnimationService };
export { AnimationTypeEnum, RfxScrollAnimationModule, RfxScrollAnimationService, RfxScrollAnimationDirective as ɵa };
//# sourceMappingURL=rfx-scroll-animation.js.map
{
"name": "rfx-scroll-animation",
"version": "1.1.1",
"version": "1.1.2",
"description": "RfxScrollAnimation - animate your page elements on scroll",
"author": "RedFoxxo",
"author": {
"name": "RedFoxxo",
"url": "https://github.com/RedFoxxo"
},
"repository": {

@@ -25,3 +28,4 @@ "type": "git",

"@angular/common": ">=8.0.0",
"@angular/core": ">=8.0.0"
"@angular/core": ">=8.0.0",
"rxjs": ">=6.0.0"
},

@@ -28,0 +32,0 @@ "dependencies": {

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

export * from './lib';
export * from './lib/rfx-scroll-animation.module';
export * from './lib/rfx-scroll-animation.service';
export * from './lib/_models/animation-type.enum';

@@ -5,1 +5,2 @@ /**

export * from './public-api';
export { RfxScrollAnimationDirective as ɵa } from './lib/rfx-scroll-animation.directive';

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

{"__symbolic":"module","version":4,"exports":[{"from":"./rfx-scroll-animation.service"},{"from":"./rfx-scroll-animation.module"},{"from":"./rfx-scroll-animation.directive"},{"from":"./_models"}],"metadata":{},"origins":{},"importAs":"rfx-scroll-animation"}
{"__symbolic":"module","version":4,"metadata":{"RfxScrollAnimationModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":3,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"ɵa"}],"imports":[],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"RfxScrollAnimationService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":5,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/router","name":"Router","line":14,"character":20}]}],"ngOnDestroy":[{"__symbolic":"method"}],"initListeners":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"getMouseScroll":[{"__symbolic":"method"}],"getNavigationEndValue":[{"__symbolic":"method"}],"getNavigationEnd":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"AnimationTypeEnum":{"NONE":"none","TOP":"top","BOTTOM":"bottom","RIGHT":"right","LEFT":"left","ZOOM":"zoom"},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":5,"character":1},"arguments":[{"selector":"[libRfxScrollAnimation]"}]}],"members":{"distanceFromPageBottomPercentage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"animationType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"animationDistancePx":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"transitionDurationMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"transitionTimingFunction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"scaleRatio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"elementVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":17,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":23,"character":25},{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":24,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":25,"character":31},{"__symbolic":"reference","name":"RfxScrollAnimationService"}]}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"initElement":[{"__symbolic":"method"}],"setInitialElementStyle":[{"__symbolic":"method"}],"isElementInView":[{"__symbolic":"method"}],"isElementVisible":[{"__symbolic":"method"}],"setElementStyle":[{"__symbolic":"method"}],"removeElementStyle":[{"__symbolic":"method"}],"toggleElement":[{"__symbolic":"method"}],"toggleElementInstantly":[{"__symbolic":"method"}],"getElementTransform":[{"__symbolic":"method"}],"toggleTransition":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}]}}},"origins":{"RfxScrollAnimationModule":"./lib/rfx-scroll-animation.module","RfxScrollAnimationService":"./lib/rfx-scroll-animation.service","AnimationTypeEnum":"./lib/_models/animation-type.enum","ɵa":"./lib/rfx-scroll-animation.directive"},"importAs":"rfx-scroll-animation"}

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