rfx-scroll-animation
Advanced tools
Comparing version 1.1.6 to 1.1.7
@@ -188,7 +188,8 @@ (function (global, factory) { | ||
*/ | ||
RfxScrollAnimationDirective.prototype.toggleElement = function (visible) { | ||
RfxScrollAnimationDirective.prototype.toggleElement = function (visible, restoreListener) { | ||
if (restoreListener === void 0) { restoreListener = false; } | ||
this.elementVisible = visible; | ||
this.elementVisibleChange.emit(visible); | ||
this.setElementStyle(this.htmlElement.nativeElement, { name: 'opacity', value: String(+visible) }, { name: 'transform', value: this.getElementTransform(visible, this.animationType) }); | ||
if (this.isOnlyFirstTime && !visible) { | ||
if (restoreListener) { | ||
this.subscribeToMouseScroll(); | ||
@@ -195,0 +196,0 @@ } |
@@ -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;(r=t.AnimationTypeEnum||(t.AnimationTypeEnum={})).NONE="none",r.TOP="top",r.BOTTOM="bottom",r.RIGHT="right",r.LEFT="left",r.ZOOM="zoom";var s=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}();s.ɵprov=e.ɵɵdefineInjectable({factory:function(){return new s(e.ɵɵinject(n.Router))},token:s,providedIn:"root"}),s.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],s.ctorParameters=function(){return[{type:n.Router}]};var a=function(){function n(n,i,o,r){this.htmlElement=n,this.renderer=i,this.changeDetectorRef=o,this.rfxScrollAnimationService=r,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,this.elementVisible=!1,this.animationType=t.AnimationTypeEnum.NONE}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.subscribeToMouseScroll())}))},n.prototype.subscribeToMouseScroll=function(){var t=this;this.onScrollListener=this.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,{name:"transition-timing-function",value:this.transitionTimingFunction},{name:"transition-duration",value:this.transitionDurationMs+"ms"},{name:"transition-property",value:"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,{name:"opacity",value:String(+t)},{name:"transform",value:this.getElementTransform(t,this.animationType)}),this.isOnlyFirstTime&&!t&&this.subscribeToMouseScroll()},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,{name:"transition-duration",value:this.transitionDurationMs+"ms"}):this.removeElementStyle(this.htmlElement.nativeElement,{name:"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}();a.decorators=[{type:e.Directive,args:[{selector:"[libRfxScrollAnimation]"}]}],a.ctorParameters=function(){return[{type:e.ElementRef},{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:s}]},a.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 l=function(){};l.decorators=[{type:e.NgModule,args:[{declarations:[a],imports:[],exports:[a]}]}],t.RfxScrollAnimationDirective=a,t.RfxScrollAnimationModule=l,t.RfxScrollAnimationService=s,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;(r=t.AnimationTypeEnum||(t.AnimationTypeEnum={})).NONE="none",r.TOP="top",r.BOTTOM="bottom",r.RIGHT="right",r.LEFT="left",r.ZOOM="zoom";var s=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}();s.ɵprov=e.ɵɵdefineInjectable({factory:function(){return new s(e.ɵɵinject(n.Router))},token:s,providedIn:"root"}),s.decorators=[{type:e.Injectable,args:[{providedIn:"root"}]}],s.ctorParameters=function(){return[{type:n.Router}]};var a=function(){function n(n,i,o,r){this.htmlElement=n,this.renderer=i,this.changeDetectorRef=o,this.rfxScrollAnimationService=r,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,this.elementVisible=!1,this.animationType=t.AnimationTypeEnum.NONE}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.subscribeToMouseScroll())}))},n.prototype.subscribeToMouseScroll=function(){var t=this;this.onScrollListener=this.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,{name:"transition-timing-function",value:this.transitionTimingFunction},{name:"transition-duration",value:this.transitionDurationMs+"ms"},{name:"transition-property",value:"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,e){void 0===e&&(e=!1),this.elementVisible=t,this.elementVisibleChange.emit(t),this.setElementStyle(this.htmlElement.nativeElement,{name:"opacity",value:String(+t)},{name:"transform",value:this.getElementTransform(t,this.animationType)}),e&&this.subscribeToMouseScroll()},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,{name:"transition-duration",value:this.transitionDurationMs+"ms"}):this.removeElementStyle(this.htmlElement.nativeElement,{name:"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}();a.decorators=[{type:e.Directive,args:[{selector:"[libRfxScrollAnimation]"}]}],a.ctorParameters=function(){return[{type:e.ElementRef},{type:e.Renderer2},{type:e.ChangeDetectorRef},{type:s}]},a.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 l=function(){};l.decorators=[{type:e.NgModule,args:[{declarations:[a],imports:[],exports:[a]}]}],t.RfxScrollAnimationDirective=a,t.RfxScrollAnimationModule=l,t.RfxScrollAnimationService=s,Object.defineProperty(t,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=rfx-scroll-animation.umd.min.js.map |
@@ -108,7 +108,7 @@ import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Input, Output, Renderer2 } from '@angular/core'; | ||
*/ | ||
toggleElement(visible) { | ||
toggleElement(visible, restoreListener = false) { | ||
this.elementVisible = visible; | ||
this.elementVisibleChange.emit(visible); | ||
this.setElementStyle(this.htmlElement.nativeElement, { name: 'opacity', value: String(+visible) }, { name: 'transform', value: this.getElementTransform(visible, this.animationType) }); | ||
if (this.isOnlyFirstTime && !visible) { | ||
if (restoreListener) { | ||
this.subscribeToMouseScroll(); | ||
@@ -195,2 +195,2 @@ } | ||
}; | ||
//# 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 } from './animation-type.enum';\r\nimport { IRendererStyle } from './render-style.interface';\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    this.elementVisible = false;\r\n    this.animationType = AnimationTypeEnum.NONE;\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.subscribeToMouseScroll();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private subscribeToMouseScroll(): void {\r\n    this.onScrollListener = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => {\r\n      this.onMouseScroll();\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      { name: 'transition-timing-function', value: this.transitionTimingFunction },\r\n      { name: 'transition-duration', value: `${this.transitionDurationMs}ms` },\r\n      { name: 'transition-property', value: '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: IRendererStyle[]): 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: IRendererStyle[]): 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  public 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      { name: 'opacity', value: String(+visible) },\r\n      { name: 'transform', value: this.getElementTransform(visible, this.animationType) }\r\n    );\r\n\r\n    if (this.isOnlyFirstTime && !visible) {\r\n      this.subscribeToMouseScroll();\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(\r\n        this.htmlElement.nativeElement,\r\n        { name: 'transition-duration', value: `${this.transitionDurationMs}ms` }\r\n      );\r\n    } else {\r\n      this.removeElementStyle(\r\n        this.htmlElement.nativeElement,\r\n        { name: 'transition-duration' }\r\n      );\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 } from './animation-type.enum';\r\nimport { IRendererStyle } from './render-style.interface';\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    this.elementVisible = false;\r\n    this.animationType = AnimationTypeEnum.NONE;\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.subscribeToMouseScroll();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private subscribeToMouseScroll(): void {\r\n    this.onScrollListener = this.rfxScrollAnimationService.getMouseScroll().subscribe(() => {\r\n      this.onMouseScroll();\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      { name: 'transition-timing-function', value: this.transitionTimingFunction },\r\n      { name: 'transition-duration', value: `${this.transitionDurationMs}ms` },\r\n      { name: 'transition-property', value: '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: IRendererStyle[]): 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: IRendererStyle[]): 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  public toggleElement(visible: boolean, restoreListener: boolean = false): 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      { name: 'opacity', value: String(+visible) },\r\n      { name: 'transform', value: this.getElementTransform(visible, this.animationType) }\r\n    );\r\n\r\n    if (restoreListener) {\r\n      this.subscribeToMouseScroll();\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(\r\n        this.htmlElement.nativeElement,\r\n        { name: 'transition-duration', value: `${this.transitionDurationMs}ms` }\r\n      );\r\n    } else {\r\n      this.removeElementStyle(\r\n        this.htmlElement.nativeElement,\r\n        { name: 'transition-duration' }\r\n      );\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"]} |
@@ -174,7 +174,7 @@ import { ɵɵdefineInjectable, ɵɵinject, Injectable, EventEmitter, Directive, ElementRef, Renderer2, ChangeDetectorRef, Input, Output, NgModule } from '@angular/core'; | ||
*/ | ||
toggleElement(visible) { | ||
toggleElement(visible, restoreListener = false) { | ||
this.elementVisible = visible; | ||
this.elementVisibleChange.emit(visible); | ||
this.setElementStyle(this.htmlElement.nativeElement, { name: 'opacity', value: String(+visible) }, { name: 'transform', value: this.getElementTransform(visible, this.animationType) }); | ||
if (this.isOnlyFirstTime && !visible) { | ||
if (restoreListener) { | ||
this.subscribeToMouseScroll(); | ||
@@ -181,0 +181,0 @@ } |
@@ -55,3 +55,3 @@ import { ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, OnDestroy, OnInit, Renderer2 } from '@angular/core'; | ||
*/ | ||
toggleElement(visible: boolean): void; | ||
toggleElement(visible: boolean, restoreListener?: boolean): void; | ||
/** | ||
@@ -58,0 +58,0 @@ * Show / hide element instantly (without animation) from page |
{ | ||
"name": "rfx-scroll-animation", | ||
"version": "1.1.6", | ||
"version": "1.1.7", | ||
"description": "RfxScrollAnimation - animate your page elements on scroll", | ||
@@ -5,0 +5,0 @@ "author": { |
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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
133646
1006