New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.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 2.0.1 to 2.1.0

20

bundles/rfx-scroll-animation.umd.js

@@ -99,3 +99,3 @@ (function (global, factory) {

this.elementVisibleChange = new i0.EventEmitter();
this.currentTransition = 'translate3d(0, 0, 0) scale(1)';
this.currentTransition = 'translate(0, 0) scale(1)';
this.animationVisibility = AnimationVisibilityEnum.HIDDEN;

@@ -150,13 +150,13 @@ }

case AnimationTypeEnum.TOP:
return "translate3d(0, -" + animationDistancePx + "px, 0) scale(1)";
return "translate(0, -" + animationDistancePx + "px) scale(1)";
case AnimationTypeEnum.BOTTOM:
return "translate3d(0, " + animationDistancePx + "px, 0) scale(1)";
return "translate(0, " + animationDistancePx + "px) scale(1)";
case AnimationTypeEnum.LEFT:
return "translate3d(-" + animationDistancePx + "px, 0, 0) scale(1)";
return "translate(-" + animationDistancePx + "px, 0) scale(1)";
case AnimationTypeEnum.RIGHT:
return "translate3d(" + animationDistancePx + "px, 0, 0) scale(1)";
return "translate(" + animationDistancePx + "px, 0) scale(1)";
case AnimationTypeEnum.ZOOM:
return "translate3d(0, 0, 0) scale(" + scaleRatio + ")";
return "translate(0, 0) scale(" + scaleRatio + ")";
default:
return 'translate3d(0, 0, 0) scale(1)';
return 'translate(0, 0) scale(1)';
}

@@ -210,3 +210,3 @@ };

opacity: 1,
transform: 'translate3d(0, 0, 0)'
transform: 'translate(0, 0)'
})),

@@ -216,3 +216,3 @@ animations.state('hidden', animations.style({

transform: '{{ currentTransition }}'
}), { params: { currentTransition: 'translate3d(0, 0, 0) scale(1)' } }),
}), { params: { currentTransition: 'translate(0, 0) scale(1)' } }),
animations.transition('visible <=> hidden', [

@@ -223,3 +223,3 @@ animations.animate('{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}')

],
styles: [""]
styles: [":host{will-change:transform,opacity}"]
},] }

@@ -226,0 +226,0 @@ ];

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

!function(t,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports,require("@angular/core"),require("@angular/platform-browser"),require("@angular/platform-browser/animations"),require("@angular/animations"),require("@angular/router"),require("rxjs")):"function"==typeof define&&define.amd?define("rfx-scroll-animation",["exports","@angular/core","@angular/platform-browser","@angular/platform-browser/animations","@angular/animations","@angular/router","rxjs"],i):i((t="undefined"!=typeof globalThis?globalThis:t||self)["rfx-scroll-animation"]={},t.ng.core,t.ng.platformBrowser,t.ng.platformBrowser.animations,t.ng.animations,t.ng.router,t.rxjs)}(this,(function(t,i,n,e,r,o,s){"use strict";var a,u;!function(t){t.NONE="none",t.TOP="top",t.BOTTOM="bottom",t.RIGHT="right",t.LEFT="left",t.ZOOM="zoom"}(a||(a={})),function(t){t.VISIBLE="visible",t.HIDDEN="hidden"}(u||(u={}));var l=function(){function t(t,i){this.rendererFactory=t,this.router=i,this.subjectScroll=new s.Subject,this.subjectNavigation=new s.BehaviorSubject(!1),this.renderer=this.rendererFactory.createRenderer(null,null)}return t.prototype.ngOnDestroy=function(){this.destroyListeners()},t.prototype.destroyListeners=function(){var t;this.mouseScrollEvent&&this.mouseScrollEvent(),null===(t=this.routerNavEvent)||void 0===t||t.unsubscribe()},t.prototype.initListeners=function(t){var i=this;this.destroyListeners(),this.mouseScrollEvent=this.renderer.listen(null!=t?t:document,"scroll",(function(){return i.onMouseScroll()})),this.initRouterEventListener()},t.prototype.initRouterEventListener=function(){var t=this;this.routerNavEvent=this.router.events.subscribe((function(i){i instanceof o.NavigationEnd&&t.onRouterEvent(!0),i instanceof o.NavigationStart&&t.onRouterEvent(!1)}))},t.prototype.onRouterEvent=function(t){this.subjectNavigation.next(t)},t.prototype.onMouseScroll=function(){this.subjectScroll.next()},t.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},t.prototype.getRouterEvent=function(){return this.subjectNavigation.asObservable()},t.prototype.getRouterEventValue=function(){return this.subjectNavigation.value},t}();l.ɵprov=i.ɵɵdefineInjectable({factory:function(){return new l(i.ɵɵinject(i.RendererFactory2),i.ɵɵinject(o.Router))},token:l,providedIn:"root"}),l.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],l.ctorParameters=function(){return[{type:i.RendererFactory2},{type:o.Router}]};var c=function(){function t(t,n){this.htmlElement=t,this.rfxScrollAnimationService=n,this.animationType=a.NONE,this.animationDistancePx=25,this.distanceFromPageBottomPercentage=20,this.transitionDurationMs=500,this.transitionDelayMs=0,this.transitionTimingFunction="cubic-bezier(0.4, 0.0, 0.2, 1)",this.scaleRatio=1.5,this.isOnlyFirstTime=!0,this.elementVisibleChange=new i.EventEmitter,this.currentTransition="translate3d(0, 0, 0) scale(1)",this.animationVisibility=u.HIDDEN}return Object.defineProperty(t.prototype,"visibility",{get:function(){return this.animationType===a.NONE?null:{value:this.animationVisibility,params:{currentTransition:this.currentTransition,transitionTimingFunction:this.transitionTimingFunction,transitionDurationMs:this.transitionDurationMs,transitionDelayMs:this.transitionDelayMs,scaleRatio:this.scaleRatio}}},enumerable:!1,configurable:!0}),t.prototype.ngOnInit=function(){this.onRouterEvent(this.rfxScrollAnimationService.getRouterEventValue()),this.subscribeToScrollEvent(),this.subscribeToRouterEvent()},t.prototype.ngOnDestroy=function(){var t,i;null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe(),null===(i=this.routerListenerSubscription)||void 0===i||i.unsubscribe()},t.prototype.ngOnChanges=function(t){var i,n,e;void 0===(null===(i=null==t?void 0:t.animationType)||void 0===i?void 0:i.currentValue)&&void 0===(null===(n=null==t?void 0:t.animationDistancePx)||void 0===n?void 0:n.currentValue)&&void 0===(null===(e=null==t?void 0:t.scaleRatio)||void 0===e?void 0:e.currentValue)||(this.currentTransition=this.getCurrentTransition(this.animationType,this.animationDistancePx,this.scaleRatio))},t.prototype.subscribeToScrollEvent=function(){var t=this;this.scrollListenerSubscription=this.rfxScrollAnimationService.getMouseScroll().subscribe((function(){return t.onMouseScroll()}))},t.prototype.subscribeToRouterEvent=function(){var t=this;this.routerListenerSubscription=this.rfxScrollAnimationService.getRouterEvent().subscribe((function(i){return t.onRouterEvent(i)}))},t.prototype.getCurrentTransition=function(t,i,n){switch(void 0===i&&(i=0),void 0===n&&(n=1),t){case a.TOP:return"translate3d(0, -"+i+"px, 0) scale(1)";case a.BOTTOM:return"translate3d(0, "+i+"px, 0) scale(1)";case a.LEFT:return"translate3d(-"+i+"px, 0, 0) scale(1)";case a.RIGHT:return"translate3d("+i+"px, 0, 0) scale(1)";case a.ZOOM:return"translate3d(0, 0, 0) scale("+n+")";default:return"translate3d(0, 0, 0) scale(1)"}},t.prototype.isElementInVisibleArea=function(t,i){var n=window.scrollY+window.innerHeight,e=window.innerHeight/100*i;return n>=t.getBoundingClientRect().top+window.pageYOffset-document.documentElement.clientTop+e},t.prototype.onRouterEvent=function(t){var i=this;t&&setTimeout((function(){i.onMouseScroll()}))},t.prototype.onMouseScroll=function(){var t,i=this.isElementInVisibleArea(this.htmlElement.nativeElement,this.distanceFromPageBottomPercentage);this.isOnlyFirstTime&&this.animationVisibility===u.VISIBLE&&(null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe()),i&&this.animationVisibility===u.HIDDEN?this.setVisibility(u.VISIBLE):i||this.animationVisibility!==u.VISIBLE||this.setVisibility(u.HIDDEN)},t.prototype.setVisibility=function(t){this.animationVisibility=t,this.elementVisibleChange.emit(t===u.VISIBLE)},t.prototype.hideElement=function(){var t;null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe(),this.subscribeToScrollEvent(),this.setVisibility(u.HIDDEN)},t}();c.decorators=[{type:i.Component,args:[{selector:"[libRfxScrollAnimation]",template:"<ng-content></ng-content>\r\n",animations:[r.trigger("visibility",[r.state("visible",r.style({opacity:1,transform:"translate3d(0, 0, 0)"})),r.state("hidden",r.style({opacity:0,transform:"{{ currentTransition }}"}),{params:{currentTransition:"translate3d(0, 0, 0) scale(1)"}}),r.transition("visible <=> hidden",[r.animate("{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}")],{params:{transitionDurationMs:0,transitionDelayMs:0,transitionTimingFunction:"ease"}})])],styles:[""]}]}],c.ctorParameters=function(){return[{type:i.ElementRef},{type:l}]},c.propDecorators={animationType:[{type:i.Input}],animationDistancePx:[{type:i.Input}],distanceFromPageBottomPercentage:[{type:i.Input}],transitionDurationMs:[{type:i.Input}],transitionDelayMs:[{type:i.Input}],transitionTimingFunction:[{type:i.Input}],scaleRatio:[{type:i.Input}],isOnlyFirstTime:[{type:i.Input}],elementVisibleChange:[{type:i.Output}],visibility:[{type:i.HostBinding,args:["@visibility"]}]};var p=function(){};p.decorators=[{type:i.NgModule,args:[{declarations:[c],imports:[n.BrowserModule,e.BrowserAnimationsModule],exports:[c]}]}],t.RfxScrollAnimationComponent=c,t.RfxScrollAnimationModule=p,t.RfxScrollAnimationService=l,Object.defineProperty(t,"__esModule",{value:!0})}));
!function(t,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports,require("@angular/core"),require("@angular/platform-browser"),require("@angular/platform-browser/animations"),require("@angular/animations"),require("@angular/router"),require("rxjs")):"function"==typeof define&&define.amd?define("rfx-scroll-animation",["exports","@angular/core","@angular/platform-browser","@angular/platform-browser/animations","@angular/animations","@angular/router","rxjs"],i):i((t="undefined"!=typeof globalThis?globalThis:t||self)["rfx-scroll-animation"]={},t.ng.core,t.ng.platformBrowser,t.ng.platformBrowser.animations,t.ng.animations,t.ng.router,t.rxjs)}(this,(function(t,i,n,e,r,o,s){"use strict";var a,l;!function(t){t.NONE="none",t.TOP="top",t.BOTTOM="bottom",t.RIGHT="right",t.LEFT="left",t.ZOOM="zoom"}(a||(a={})),function(t){t.VISIBLE="visible",t.HIDDEN="hidden"}(l||(l={}));var u=function(){function t(t,i){this.rendererFactory=t,this.router=i,this.subjectScroll=new s.Subject,this.subjectNavigation=new s.BehaviorSubject(!1),this.renderer=this.rendererFactory.createRenderer(null,null)}return t.prototype.ngOnDestroy=function(){this.destroyListeners()},t.prototype.destroyListeners=function(){var t;this.mouseScrollEvent&&this.mouseScrollEvent(),null===(t=this.routerNavEvent)||void 0===t||t.unsubscribe()},t.prototype.initListeners=function(t){var i=this;this.destroyListeners(),this.mouseScrollEvent=this.renderer.listen(null!=t?t:document,"scroll",(function(){return i.onMouseScroll()})),this.initRouterEventListener()},t.prototype.initRouterEventListener=function(){var t=this;this.routerNavEvent=this.router.events.subscribe((function(i){i instanceof o.NavigationEnd&&t.onRouterEvent(!0),i instanceof o.NavigationStart&&t.onRouterEvent(!1)}))},t.prototype.onRouterEvent=function(t){this.subjectNavigation.next(t)},t.prototype.onMouseScroll=function(){this.subjectScroll.next()},t.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},t.prototype.getRouterEvent=function(){return this.subjectNavigation.asObservable()},t.prototype.getRouterEventValue=function(){return this.subjectNavigation.value},t}();u.ɵprov=i.ɵɵdefineInjectable({factory:function(){return new u(i.ɵɵinject(i.RendererFactory2),i.ɵɵinject(o.Router))},token:u,providedIn:"root"}),u.decorators=[{type:i.Injectable,args:[{providedIn:"root"}]}],u.ctorParameters=function(){return[{type:i.RendererFactory2},{type:o.Router}]};var c=function(){function t(t,n){this.htmlElement=t,this.rfxScrollAnimationService=n,this.animationType=a.NONE,this.animationDistancePx=25,this.distanceFromPageBottomPercentage=20,this.transitionDurationMs=500,this.transitionDelayMs=0,this.transitionTimingFunction="cubic-bezier(0.4, 0.0, 0.2, 1)",this.scaleRatio=1.5,this.isOnlyFirstTime=!0,this.elementVisibleChange=new i.EventEmitter,this.currentTransition="translate(0, 0) scale(1)",this.animationVisibility=l.HIDDEN}return Object.defineProperty(t.prototype,"visibility",{get:function(){return this.animationType===a.NONE?null:{value:this.animationVisibility,params:{currentTransition:this.currentTransition,transitionTimingFunction:this.transitionTimingFunction,transitionDurationMs:this.transitionDurationMs,transitionDelayMs:this.transitionDelayMs,scaleRatio:this.scaleRatio}}},enumerable:!1,configurable:!0}),t.prototype.ngOnInit=function(){this.onRouterEvent(this.rfxScrollAnimationService.getRouterEventValue()),this.subscribeToScrollEvent(),this.subscribeToRouterEvent()},t.prototype.ngOnDestroy=function(){var t,i;null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe(),null===(i=this.routerListenerSubscription)||void 0===i||i.unsubscribe()},t.prototype.ngOnChanges=function(t){var i,n,e;void 0===(null===(i=null==t?void 0:t.animationType)||void 0===i?void 0:i.currentValue)&&void 0===(null===(n=null==t?void 0:t.animationDistancePx)||void 0===n?void 0:n.currentValue)&&void 0===(null===(e=null==t?void 0:t.scaleRatio)||void 0===e?void 0:e.currentValue)||(this.currentTransition=this.getCurrentTransition(this.animationType,this.animationDistancePx,this.scaleRatio))},t.prototype.subscribeToScrollEvent=function(){var t=this;this.scrollListenerSubscription=this.rfxScrollAnimationService.getMouseScroll().subscribe((function(){return t.onMouseScroll()}))},t.prototype.subscribeToRouterEvent=function(){var t=this;this.routerListenerSubscription=this.rfxScrollAnimationService.getRouterEvent().subscribe((function(i){return t.onRouterEvent(i)}))},t.prototype.getCurrentTransition=function(t,i,n){switch(void 0===i&&(i=0),void 0===n&&(n=1),t){case a.TOP:return"translate(0, -"+i+"px) scale(1)";case a.BOTTOM:return"translate(0, "+i+"px) scale(1)";case a.LEFT:return"translate(-"+i+"px, 0) scale(1)";case a.RIGHT:return"translate("+i+"px, 0) scale(1)";case a.ZOOM:return"translate(0, 0) scale("+n+")";default:return"translate(0, 0) scale(1)"}},t.prototype.isElementInVisibleArea=function(t,i){var n=window.scrollY+window.innerHeight,e=window.innerHeight/100*i;return n>=t.getBoundingClientRect().top+window.pageYOffset-document.documentElement.clientTop+e},t.prototype.onRouterEvent=function(t){var i=this;t&&setTimeout((function(){i.onMouseScroll()}))},t.prototype.onMouseScroll=function(){var t,i=this.isElementInVisibleArea(this.htmlElement.nativeElement,this.distanceFromPageBottomPercentage);this.isOnlyFirstTime&&this.animationVisibility===l.VISIBLE&&(null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe()),i&&this.animationVisibility===l.HIDDEN?this.setVisibility(l.VISIBLE):i||this.animationVisibility!==l.VISIBLE||this.setVisibility(l.HIDDEN)},t.prototype.setVisibility=function(t){this.animationVisibility=t,this.elementVisibleChange.emit(t===l.VISIBLE)},t.prototype.hideElement=function(){var t;null===(t=this.scrollListenerSubscription)||void 0===t||t.unsubscribe(),this.subscribeToScrollEvent(),this.setVisibility(l.HIDDEN)},t}();c.decorators=[{type:i.Component,args:[{selector:"[libRfxScrollAnimation]",template:"<ng-content></ng-content>\r\n",animations:[r.trigger("visibility",[r.state("visible",r.style({opacity:1,transform:"translate(0, 0)"})),r.state("hidden",r.style({opacity:0,transform:"{{ currentTransition }}"}),{params:{currentTransition:"translate(0, 0) scale(1)"}}),r.transition("visible <=> hidden",[r.animate("{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}")],{params:{transitionDurationMs:0,transitionDelayMs:0,transitionTimingFunction:"ease"}})])],styles:[":host{will-change:transform,opacity}"]}]}],c.ctorParameters=function(){return[{type:i.ElementRef},{type:u}]},c.propDecorators={animationType:[{type:i.Input}],animationDistancePx:[{type:i.Input}],distanceFromPageBottomPercentage:[{type:i.Input}],transitionDurationMs:[{type:i.Input}],transitionDelayMs:[{type:i.Input}],transitionTimingFunction:[{type:i.Input}],scaleRatio:[{type:i.Input}],isOnlyFirstTime:[{type:i.Input}],elementVisibleChange:[{type:i.Output}],visibility:[{type:i.HostBinding,args:["@visibility"]}]};var p=function(){};p.decorators=[{type:i.NgModule,args:[{declarations:[c],imports:[n.BrowserModule,e.BrowserAnimationsModule],exports:[c]}]}],t.RfxScrollAnimationComponent=c,t.RfxScrollAnimationModule=p,t.RfxScrollAnimationService=u,Object.defineProperty(t,"__esModule",{value:!0})}));
//# sourceMappingURL=rfx-scroll-animation.umd.min.js.map

@@ -19,3 +19,3 @@ import { animate, state, style, transition, trigger } from '@angular/animations';

this.elementVisibleChange = new EventEmitter();
this.currentTransition = 'translate3d(0, 0, 0) scale(1)';
this.currentTransition = 'translate(0, 0) scale(1)';
this.animationVisibility = AnimationVisibilityEnum.HIDDEN;

@@ -62,13 +62,13 @@ }

case AnimationTypeEnum.TOP:
return `translate3d(0, -${animationDistancePx}px, 0) scale(1)`;
return `translate(0, -${animationDistancePx}px) scale(1)`;
case AnimationTypeEnum.BOTTOM:
return `translate3d(0, ${animationDistancePx}px, 0) scale(1)`;
return `translate(0, ${animationDistancePx}px) scale(1)`;
case AnimationTypeEnum.LEFT:
return `translate3d(-${animationDistancePx}px, 0, 0) scale(1)`;
return `translate(-${animationDistancePx}px, 0) scale(1)`;
case AnimationTypeEnum.RIGHT:
return `translate3d(${animationDistancePx}px, 0, 0) scale(1)`;
return `translate(${animationDistancePx}px, 0) scale(1)`;
case AnimationTypeEnum.ZOOM:
return `translate3d(0, 0, 0) scale(${scaleRatio})`;
return `translate(0, 0) scale(${scaleRatio})`;
default:
return 'translate3d(0, 0, 0) scale(1)';
return 'translate(0, 0) scale(1)';
}

@@ -120,3 +120,3 @@ }

opacity: 1,
transform: 'translate3d(0, 0, 0)'
transform: 'translate(0, 0)'
})),

@@ -126,3 +126,3 @@ state('hidden', style({

transform: '{{ currentTransition }}'
}), { params: { currentTransition: 'translate3d(0, 0, 0) scale(1)' } }),
}), { params: { currentTransition: 'translate(0, 0) scale(1)' } }),
transition('visible <=> hidden', [

@@ -133,3 +133,3 @@ animate('{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}')

],
styles: [""]
styles: [":host{will-change:transform,opacity}"]
},] }

@@ -153,2 +153,2 @@ ];

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.component.js","sourceRoot":"","sources":["../../../../../projects/rfx-scroll-animation/src/lib/rfx-scroll-animation/rfx-scroll-animation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { Component, ElementRef, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AnimationExpInterface } from '../animation/animation-exp.interface';\r\nimport { AnimationTypeEnum } from '../animation/animation-type.enum';\r\nimport { AnimationVisibilityEnum } from '../animation/animation-visiblity.enum';\r\nimport { RfxScrollAnimationService } from '../rfx-scroll-animation.service';\r\n\r\n@Component({\r\n  selector: '[libRfxScrollAnimation]',\r\n  templateUrl: './rfx-scroll-animation.component.html',\r\n  styleUrls: ['./rfx-scroll-animation.component.less'],\r\n  animations: [\r\n    trigger('visibility', [\r\n      state('visible', style({\r\n        opacity: 1,\r\n        transform: 'translate3d(0, 0, 0)'\r\n      })),\r\n      state('hidden', style({\r\n        opacity: 0,\r\n        transform: '{{ currentTransition }}'\r\n      }), { params: { currentTransition: 'translate3d(0, 0, 0) scale(1)' }}),\r\n      transition('visible <=> hidden', [\r\n        animate('{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}')\r\n      ], { params: { transitionDurationMs: 0, transitionDelayMs: 0, transitionTimingFunction: 'ease' }})\r\n    ])\r\n  ]\r\n})\r\nexport class RfxScrollAnimationComponent implements OnChanges, OnInit, OnDestroy {\r\n  @Input() public animationType: AnimationTypeEnum;\r\n  @Input() public animationDistancePx: number;\r\n  @Input() public distanceFromPageBottomPercentage: number;\r\n  @Input() public transitionDurationMs: number;\r\n  @Input() public transitionDelayMs: number;\r\n  @Input() public transitionTimingFunction: string;\r\n  @Input() public scaleRatio: number;\r\n  @Input() public isOnlyFirstTime: boolean;\r\n  @Output() public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  private scrollListenerSubscription!: Subscription;\r\n  private routerListenerSubscription!: Subscription;\r\n\r\n  public animationVisibility: AnimationVisibilityEnum;\r\n  public currentTransition: string;\r\n\r\n  @HostBinding('@visibility')\r\n  get visibility(): AnimationExpInterface | null {\r\n    return this.animationType === AnimationTypeEnum.NONE ? null : {\r\n      value: this.animationVisibility,\r\n      params: {\r\n        currentTransition: this.currentTransition,\r\n        transitionTimingFunction: this.transitionTimingFunction,\r\n        transitionDurationMs: this.transitionDurationMs,\r\n        transitionDelayMs: this.transitionDelayMs,\r\n        scaleRatio: this.scaleRatio\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private rfxScrollAnimationService: RfxScrollAnimationService\r\n  ) {\r\n    this.animationType = AnimationTypeEnum.NONE;\r\n    this.animationDistancePx = 25;\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionDelayMs = 0;\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    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.currentTransition = 'translate3d(0, 0, 0) scale(1)';\r\n    this.animationVisibility = AnimationVisibilityEnum.HIDDEN;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.onRouterEvent(this.rfxScrollAnimationService.getRouterEventValue());\r\n    this.subscribeToScrollEvent();\r\n    this.subscribeToRouterEvent();\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.routerListenerSubscription?.unsubscribe();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      changes?.animationType?.currentValue !== undefined ||\r\n      changes?.animationDistancePx?.currentValue !== undefined ||\r\n      changes?.scaleRatio?.currentValue !== undefined\r\n    ) {\r\n      this.currentTransition = this.getCurrentTransition(\r\n        this.animationType,\r\n        this.animationDistancePx,\r\n        this.scaleRatio\r\n      );\r\n    }\r\n  }\r\n\r\n  private subscribeToScrollEvent(): void {\r\n    this.scrollListenerSubscription = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => this.onMouseScroll());\r\n  }\r\n\r\n  private subscribeToRouterEvent(): void {\r\n    this.routerListenerSubscription = this.rfxScrollAnimationService.getRouterEvent().subscribe((isReady: boolean) => this.onRouterEvent(isReady));\r\n  }\r\n\r\n  private getCurrentTransition(animationType: AnimationTypeEnum, animationDistancePx: number = 0, scaleRatio: number = 1): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return `translate3d(0, -${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return `translate3d(0, ${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return `translate3d(-${animationDistancePx}px, 0, 0) scale(1)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return `translate3d(${animationDistancePx}px, 0, 0) scale(1)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return `translate3d(0, 0, 0) scale(${scaleRatio})`;\r\n      default:\r\n        return 'translate3d(0, 0, 0) scale(1)';\r\n    }\r\n  }\r\n\r\n  private isElementInVisibleArea(element: HTMLElement, distanceFromPageBottomPercentage: number): boolean {\r\n    const scrollBottom: number = window.scrollY + window.innerHeight;\r\n    const distanceInPx: number = (window.innerHeight / 100) * distanceFromPageBottomPercentage;\r\n    const rect: DOMRect = element.getBoundingClientRect();\r\n    const scrollBottomWithDistance: number = rect.top + window.pageYOffset - document.documentElement.clientTop + distanceInPx;\r\n    return scrollBottom >= scrollBottomWithDistance;\r\n  }\r\n\r\n  private onRouterEvent(isReady: boolean): void {\r\n    if (isReady) {\r\n      setTimeout(() => { this.onMouseScroll() })\r\n    }\r\n  }\r\n\r\n  private onMouseScroll(): void {\r\n    const isElementInVisibleArea: boolean = this.isElementInVisibleArea(this.htmlElement.nativeElement, this.distanceFromPageBottomPercentage);\r\n\r\n    if (this.isOnlyFirstTime && this.animationVisibility === AnimationVisibilityEnum.VISIBLE) {\r\n      this.scrollListenerSubscription?.unsubscribe();\r\n    }\r\n\r\n    if (isElementInVisibleArea && this.animationVisibility === AnimationVisibilityEnum.HIDDEN) {\r\n      this.setVisibility(AnimationVisibilityEnum.VISIBLE);\r\n    } else if (!isElementInVisibleArea && this.animationVisibility === AnimationVisibilityEnum.VISIBLE) {\r\n      this.setVisibility(AnimationVisibilityEnum.HIDDEN);\r\n    }\r\n  }\r\n\r\n  private setVisibility(visible: AnimationVisibilityEnum): void {\r\n    this.animationVisibility = visible;\r\n    this.elementVisibleChange.emit(visible === AnimationVisibilityEnum.VISIBLE);\r\n  }\r\n\r\n  public hideElement(): void {\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.subscribeToScrollEvent();\r\n    this.setVisibility(AnimationVisibilityEnum.HIDDEN);\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-scroll-animation.component.js","sourceRoot":"","sources":["../../../../../projects/rfx-scroll-animation/src/lib/rfx-scroll-animation/rfx-scroll-animation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { Component, ElementRef, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { AnimationExpInterface } from '../animation/animation-exp.interface';\r\nimport { AnimationTypeEnum } from '../animation/animation-type.enum';\r\nimport { AnimationVisibilityEnum } from '../animation/animation-visiblity.enum';\r\nimport { RfxScrollAnimationService } from '../rfx-scroll-animation.service';\r\n\r\n@Component({\r\n  selector: '[libRfxScrollAnimation]',\r\n  templateUrl: './rfx-scroll-animation.component.html',\r\n  styleUrls: ['./rfx-scroll-animation.component.less'],\r\n  animations: [\r\n    trigger('visibility', [\r\n      state('visible', style({\r\n        opacity: 1,\r\n        transform: 'translate(0, 0)'\r\n      })),\r\n      state('hidden', style({\r\n        opacity: 0,\r\n        transform: '{{ currentTransition }}'\r\n      }), { params: { currentTransition: 'translate(0, 0) scale(1)' }}),\r\n      transition('visible <=> hidden', [\r\n        animate('{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}')\r\n      ], { params: { transitionDurationMs: 0, transitionDelayMs: 0, transitionTimingFunction: 'ease' }})\r\n    ])\r\n  ]\r\n})\r\nexport class RfxScrollAnimationComponent implements OnChanges, OnInit, OnDestroy {\r\n  @Input() public animationType: AnimationTypeEnum;\r\n  @Input() public animationDistancePx: number;\r\n  @Input() public distanceFromPageBottomPercentage: number;\r\n  @Input() public transitionDurationMs: number;\r\n  @Input() public transitionDelayMs: number;\r\n  @Input() public transitionTimingFunction: string;\r\n  @Input() public scaleRatio: number;\r\n  @Input() public isOnlyFirstTime: boolean;\r\n  @Output() public elementVisibleChange: EventEmitter<boolean>;\r\n\r\n  private scrollListenerSubscription!: Subscription;\r\n  private routerListenerSubscription!: Subscription;\r\n\r\n  public animationVisibility: AnimationVisibilityEnum;\r\n  public currentTransition: string;\r\n\r\n  @HostBinding('@visibility')\r\n  get visibility(): AnimationExpInterface | null {\r\n    return this.animationType === AnimationTypeEnum.NONE ? null : {\r\n      value: this.animationVisibility,\r\n      params: {\r\n        currentTransition: this.currentTransition,\r\n        transitionTimingFunction: this.transitionTimingFunction,\r\n        transitionDurationMs: this.transitionDurationMs,\r\n        transitionDelayMs: this.transitionDelayMs,\r\n        scaleRatio: this.scaleRatio\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private rfxScrollAnimationService: RfxScrollAnimationService\r\n  ) {\r\n    this.animationType = AnimationTypeEnum.NONE;\r\n    this.animationDistancePx = 25;\r\n    this.distanceFromPageBottomPercentage = 20;\r\n    this.transitionDurationMs = 500;\r\n    this.transitionDelayMs = 0;\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    this.elementVisibleChange = new EventEmitter<boolean>();\r\n    this.currentTransition = 'translate(0, 0) scale(1)';\r\n    this.animationVisibility = AnimationVisibilityEnum.HIDDEN;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.onRouterEvent(this.rfxScrollAnimationService.getRouterEventValue());\r\n    this.subscribeToScrollEvent();\r\n    this.subscribeToRouterEvent();\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.routerListenerSubscription?.unsubscribe();\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (\r\n      changes?.animationType?.currentValue !== undefined ||\r\n      changes?.animationDistancePx?.currentValue !== undefined ||\r\n      changes?.scaleRatio?.currentValue !== undefined\r\n    ) {\r\n      this.currentTransition = this.getCurrentTransition(\r\n        this.animationType,\r\n        this.animationDistancePx,\r\n        this.scaleRatio\r\n      );\r\n    }\r\n  }\r\n\r\n  private subscribeToScrollEvent(): void {\r\n    this.scrollListenerSubscription = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => this.onMouseScroll());\r\n  }\r\n\r\n  private subscribeToRouterEvent(): void {\r\n    this.routerListenerSubscription = this.rfxScrollAnimationService.getRouterEvent().subscribe((isReady: boolean) => this.onRouterEvent(isReady));\r\n  }\r\n\r\n  private getCurrentTransition(animationType: AnimationTypeEnum, animationDistancePx: number = 0, scaleRatio: number = 1): string {\r\n    switch (animationType) {\r\n      case AnimationTypeEnum.TOP:\r\n        return `translate(0, -${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.BOTTOM:\r\n        return `translate(0, ${animationDistancePx}px) scale(1)`;\r\n      case AnimationTypeEnum.LEFT:\r\n        return `translate(-${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.RIGHT:\r\n        return `translate(${animationDistancePx}px, 0) scale(1)`;\r\n      case AnimationTypeEnum.ZOOM:\r\n        return `translate(0, 0) scale(${scaleRatio})`;\r\n      default:\r\n        return 'translate(0, 0) scale(1)';\r\n    }\r\n  }\r\n\r\n  private isElementInVisibleArea(element: HTMLElement, distanceFromPageBottomPercentage: number): boolean {\r\n    const scrollBottom: number = window.scrollY + window.innerHeight;\r\n    const distanceInPx: number = (window.innerHeight / 100) * distanceFromPageBottomPercentage;\r\n    const rect: DOMRect = element.getBoundingClientRect();\r\n    const scrollBottomWithDistance: number = rect.top + window.pageYOffset - document.documentElement.clientTop + distanceInPx;\r\n    return scrollBottom >= scrollBottomWithDistance;\r\n  }\r\n\r\n  private onRouterEvent(isReady: boolean): void {\r\n    if (isReady) {\r\n      setTimeout(() => { this.onMouseScroll() })\r\n    }\r\n  }\r\n\r\n  private onMouseScroll(): void {\r\n    const isElementInVisibleArea: boolean = this.isElementInVisibleArea(this.htmlElement.nativeElement, this.distanceFromPageBottomPercentage);\r\n\r\n    if (this.isOnlyFirstTime && this.animationVisibility === AnimationVisibilityEnum.VISIBLE) {\r\n      this.scrollListenerSubscription?.unsubscribe();\r\n    }\r\n\r\n    if (isElementInVisibleArea && this.animationVisibility === AnimationVisibilityEnum.HIDDEN) {\r\n      this.setVisibility(AnimationVisibilityEnum.VISIBLE);\r\n    } else if (!isElementInVisibleArea && this.animationVisibility === AnimationVisibilityEnum.VISIBLE) {\r\n      this.setVisibility(AnimationVisibilityEnum.HIDDEN);\r\n    }\r\n  }\r\n\r\n  private setVisibility(visible: AnimationVisibilityEnum): void {\r\n    this.animationVisibility = visible;\r\n    this.elementVisibleChange.emit(visible === AnimationVisibilityEnum.VISIBLE);\r\n  }\r\n\r\n  public hideElement(): void {\r\n    this.scrollListenerSubscription?.unsubscribe();\r\n    this.subscribeToScrollEvent();\r\n    this.setVisibility(AnimationVisibilityEnum.HIDDEN);\r\n  }\r\n}\r\n"]}

@@ -97,3 +97,3 @@ import { ɵɵdefineInjectable, ɵɵinject, RendererFactory2, Injectable, EventEmitter, Component, ElementRef, Input, Output, HostBinding, NgModule } from '@angular/core';

this.elementVisibleChange = new EventEmitter();
this.currentTransition = 'translate3d(0, 0, 0) scale(1)';
this.currentTransition = 'translate(0, 0) scale(1)';
this.animationVisibility = AnimationVisibilityEnum.HIDDEN;

@@ -140,13 +140,13 @@ }

case AnimationTypeEnum.TOP:
return `translate3d(0, -${animationDistancePx}px, 0) scale(1)`;
return `translate(0, -${animationDistancePx}px) scale(1)`;
case AnimationTypeEnum.BOTTOM:
return `translate3d(0, ${animationDistancePx}px, 0) scale(1)`;
return `translate(0, ${animationDistancePx}px) scale(1)`;
case AnimationTypeEnum.LEFT:
return `translate3d(-${animationDistancePx}px, 0, 0) scale(1)`;
return `translate(-${animationDistancePx}px, 0) scale(1)`;
case AnimationTypeEnum.RIGHT:
return `translate3d(${animationDistancePx}px, 0, 0) scale(1)`;
return `translate(${animationDistancePx}px, 0) scale(1)`;
case AnimationTypeEnum.ZOOM:
return `translate3d(0, 0, 0) scale(${scaleRatio})`;
return `translate(0, 0) scale(${scaleRatio})`;
default:
return 'translate3d(0, 0, 0) scale(1)';
return 'translate(0, 0) scale(1)';
}

@@ -198,3 +198,3 @@ }

opacity: 1,
transform: 'translate3d(0, 0, 0)'
transform: 'translate(0, 0)'
})),

@@ -204,3 +204,3 @@ state('hidden', style({

transform: '{{ currentTransition }}'
}), { params: { currentTransition: 'translate3d(0, 0, 0) scale(1)' } }),
}), { params: { currentTransition: 'translate(0, 0) scale(1)' } }),
transition('visible <=> hidden', [

@@ -211,3 +211,3 @@ animate('{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}')

],
styles: [""]
styles: [":host{will-change:transform,opacity}"]
},] }

@@ -214,0 +214,0 @@ ];

{
"name": "rfx-scroll-animation",
"version": "2.0.1",
"version": "2.1.0",
"description": "RfxScrollAnimation - animate your page elements on scroll",

@@ -5,0 +5,0 @@ "author": {

@@ -10,3 +10,3 @@ # RfxScrollAnimation

- Add your own custom animation
- Best performance with `translate3d`
- Best performance with `will-change`

@@ -13,0 +13,0 @@ ## Installation

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

{"__symbolic":"module","version":4,"metadata":{"RfxScrollAnimationModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":10,"character":4},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":11,"character":4}],"exports":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}]}]}],"members":{}},"RfxScrollAnimationService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"RendererFactory2","line":16,"character":29},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":17,"character":20}]}],"ngOnDestroy":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"initListeners":[{"__symbolic":"method"}],"initRouterEventListener":[{"__symbolic":"method"}],"onRouterEvent":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"getMouseScroll":[{"__symbolic":"method"}],"getRouterEvent":[{"__symbolic":"method"}],"getRouterEventValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"RfxScrollAnimationComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"[libRfxScrollAnimation]","animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":13,"character":4},"arguments":["visibility",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"state","line":14,"character":6},"arguments":["visible",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":14,"character":23},"arguments":[{"opacity":1,"transform":"translate3d(0, 0, 0)"}]}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"state","line":18,"character":6},"arguments":["hidden",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":18,"character":22},"arguments":[{"opacity":0,"transform":"{{ currentTransition }}"}]},{"params":{"currentTransition":"translate3d(0, 0, 0) scale(1)"}}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":22,"character":6},"arguments":["visible <=> hidden",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":23,"character":8},"arguments":["{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}"]}],{"params":{"transitionDurationMs":0,"transitionDelayMs":0,"transitionTimingFunction":"ease"}}]}]]}],"template":"<ng-content></ng-content>\r\n","styles":[""]}]}],"members":{"animationType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"animationDistancePx":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"distanceFromPageBottomPercentage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"transitionDurationMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"transitionDelayMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"transitionTimingFunction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"scaleRatio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"isOnlyFirstTime":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"elementVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":37,"character":3}}]}],"visibility":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":45,"character":3},"arguments":["@visibility"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":60,"character":25},{"__symbolic":"reference","name":"RfxScrollAnimationService"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"subscribeToScrollEvent":[{"__symbolic":"method"}],"subscribeToRouterEvent":[{"__symbolic":"method"}],"getCurrentTransition":[{"__symbolic":"method"}],"isElementInVisibleArea":[{"__symbolic":"method"}],"onRouterEvent":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"setVisibility":[{"__symbolic":"method"}],"hideElement":[{"__symbolic":"method"}]}}},"origins":{"RfxScrollAnimationModule":"./lib/rfx-scroll-animation.module","RfxScrollAnimationService":"./lib/rfx-scroll-animation.service","RfxScrollAnimationComponent":"./lib/rfx-scroll-animation/rfx-scroll-animation.component"},"importAs":"rfx-scroll-animation"}
{"__symbolic":"module","version":4,"metadata":{"RfxScrollAnimationModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}],"imports":[{"__symbolic":"reference","module":"@angular/platform-browser","name":"BrowserModule","line":10,"character":4},{"__symbolic":"reference","module":"@angular/platform-browser/animations","name":"BrowserAnimationsModule","line":11,"character":4}],"exports":[{"__symbolic":"reference","name":"RfxScrollAnimationComponent"}]}]}],"members":{}},"RfxScrollAnimationService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":4,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"RendererFactory2","line":16,"character":29},{"__symbolic":"reference","module":"@angular/router","name":"Router","line":17,"character":20}]}],"ngOnDestroy":[{"__symbolic":"method"}],"destroyListeners":[{"__symbolic":"method"}],"initListeners":[{"__symbolic":"method"}],"initRouterEventListener":[{"__symbolic":"method"}],"onRouterEvent":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"getMouseScroll":[{"__symbolic":"method"}],"getRouterEvent":[{"__symbolic":"method"}],"getRouterEventValue":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}},"RfxScrollAnimationComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":8,"character":1},"arguments":[{"selector":"[libRfxScrollAnimation]","animations":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"trigger","line":13,"character":4},"arguments":["visibility",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"state","line":14,"character":6},"arguments":["visible",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":14,"character":23},"arguments":[{"opacity":1,"transform":"translate(0, 0)"}]}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"state","line":18,"character":6},"arguments":["hidden",{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"style","line":18,"character":22},"arguments":[{"opacity":0,"transform":"{{ currentTransition }}"}]},{"params":{"currentTransition":"translate(0, 0) scale(1)"}}]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"transition","line":22,"character":6},"arguments":["visible <=> hidden",[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/animations","name":"animate","line":23,"character":8},"arguments":["{{ transitionDurationMs }}ms {{ transitionDelayMs }}ms {{ transitionTimingFunction }}"]}],{"params":{"transitionDurationMs":0,"transitionDelayMs":0,"transitionTimingFunction":"ease"}}]}]]}],"template":"<ng-content></ng-content>\r\n","styles":[":host{will-change:transform,opacity}"]}]}],"members":{"animationType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":29,"character":3}}]}],"animationDistancePx":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":30,"character":3}}]}],"distanceFromPageBottomPercentage":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":31,"character":3}}]}],"transitionDurationMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":32,"character":3}}]}],"transitionDelayMs":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":33,"character":3}}]}],"transitionTimingFunction":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":34,"character":3}}]}],"scaleRatio":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":35,"character":3}}]}],"isOnlyFirstTime":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":36,"character":3}}]}],"elementVisibleChange":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":37,"character":3}}]}],"visibility":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":45,"character":3},"arguments":["@visibility"]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":60,"character":25},{"__symbolic":"reference","name":"RfxScrollAnimationService"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"subscribeToScrollEvent":[{"__symbolic":"method"}],"subscribeToRouterEvent":[{"__symbolic":"method"}],"getCurrentTransition":[{"__symbolic":"method"}],"isElementInVisibleArea":[{"__symbolic":"method"}],"onRouterEvent":[{"__symbolic":"method"}],"onMouseScroll":[{"__symbolic":"method"}],"setVisibility":[{"__symbolic":"method"}],"hideElement":[{"__symbolic":"method"}]}}},"origins":{"RfxScrollAnimationModule":"./lib/rfx-scroll-animation.module","RfxScrollAnimationService":"./lib/rfx-scroll-animation.service","RfxScrollAnimationComponent":"./lib/rfx-scroll-animation/rfx-scroll-animation.component"},"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