rfx-parallax
Advanced tools
Comparing version 1.2.1 to 1.2.2
@@ -97,6 +97,10 @@ (function (global, factory) { | ||
_this.imageTop = _this.getImageTop(window.scrollY); | ||
_this.setImageTransform(_this.imageLeft, _this.imageTop); | ||
if (_this.image) { | ||
_this.setImageTransform(_this.imageLeft, _this.imageTop); | ||
} | ||
}); | ||
this.onResizeListener = this.rfxParallaxService.getWindowResize().subscribe(function () { | ||
_this.setParallaxProperties(); | ||
if (_this.image) { | ||
_this.setParallaxProperties(); | ||
} | ||
}); | ||
@@ -103,0 +107,0 @@ }; |
@@ -1,2 +0,2 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs")):"function"==typeof define&&define.amd?define("rfx-parallax",["exports","@angular/core","rxjs"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["rfx-parallax"]={},e.ng.core,e.rxjs)}(this,(function(e,t,i){"use strict";var s=function(){function e(){this.subjectScroll=new i.BehaviorSubject(void 0),this.subjectResize=new i.BehaviorSubject(void 0)}return e.prototype.ngOnDestroy=function(){document.removeEventListener("scroll",this.mouseScroll),document.removeEventListener("resize",this.windowResize)},e.prototype.initListeners=function(){this.mouseScroll=this.onMouseScroll.bind(this),this.windowResize=this.onWindowResize.bind(this),document.addEventListener("scroll",this.mouseScroll,!1),window.addEventListener("resize",this.windowResize,!1)},e.prototype.onMouseScroll=function(){this.subjectScroll.next(void 0)},e.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},e.prototype.onWindowResize=function(){this.subjectResize.next(void 0)},e.prototype.getWindowResize=function(){return this.subjectResize.asObservable()},e}();s.ɵprov=t.ɵɵdefineInjectable({factory:function(){return new s},token:s,providedIn:"root"}),s.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],s.ctorParameters=function(){return[]};var r=function(){function e(e,t,i){this.htmlElement=e,this.renderer=t,this.rfxParallaxService=i,this.parallaxPercentage=20,this.positionPercentage=50,this.imageZIndex=-1,this.isDisabled=!1,this.visibleOverflow=!1}return e.prototype.ngOnInit=function(){this.setListeners()},e.prototype.ngOnDestroy=function(){this.onScrollListener&&this.onScrollListener.unsubscribe(),this.onResizeListener&&this.onResizeListener.unsubscribe()},e.prototype.ngOnChanges=function(e){var t;(null===(t=e.imageUrl)||void 0===t?void 0:t.currentValue)?this.loadImage(e.imageUrl.currentValue):this.image&&this.setParallaxProperties()},e.prototype.setListeners=function(){var e=this;this.onScrollListener=this.rfxParallaxService.getMouseScroll().subscribe((function(){e.imageTop=e.getImageTop(window.scrollY),e.setImageTransform(e.imageLeft,e.imageTop)})),this.onResizeListener=this.rfxParallaxService.getWindowResize().subscribe((function(){e.setParallaxProperties()}))},e.prototype.loadImage=function(e){var t=this;this.image=new Image,this.image.src=e,this.renderer.setStyle(this.image,"visilibity","hidden"),this.renderer.addClass(this.image,"parallax-image"),this.htmlElement.nativeElement.appendChild(this.image),this.image.onload=function(){t.setParallaxProperties(),t.renderer.setStyle(t.image,"visibility","visible")}},e.prototype.setParallaxProperties=function(){this.setStaticProperties(),this.setImageSize(),this.setParallaxValues(window.scrollY),this.imageLeft=this.getImageLeft(this.htmlElement.nativeElement.clientWidth),this.imageTop=this.getImageTop(window.scrollY),this.setImageTransform(this.imageLeft,this.imageTop)},e.prototype.setStaticProperties=function(){this.isAlreadyPositionAbsRel(this.htmlElement.nativeElement)||this.renderer.setStyle(this.htmlElement.nativeElement,"position","relative"),this.renderer.setStyle(this.htmlElement.nativeElement,"overflow",this.visibleOverflow?"visible":"hidden"),this.renderer.setStyle(this.image,"z-index",this.imageZIndex),this.renderer.setStyle(this.image,"position","absolute"),this.renderer.setStyle(this.image,"left","0"),this.renderer.setStyle(this.image,"top","0")},e.prototype.isAlreadyPositionAbsRel=function(e){return["absolute","relative"].includes(window.getComputedStyle(e).position)},e.prototype.setImageSize=function(){var e=this.htmlElement.nativeElement.clientHeight,t=this.htmlElement.nativeElement.clientWidth,i=e*(100+this.parallaxPercentage)/100;this.image.naturalHeight/this.image.naturalWidth>i/t?(this.renderer.setStyle(this.image,"width",t+"px"),this.renderer.setStyle(this.image,"height","auto")):(this.renderer.setStyle(this.image,"height",i+"px"),this.renderer.setStyle(this.image,"width","auto"))},e.prototype.setParallaxValues=function(e){var t=this.htmlElement.nativeElement.getBoundingClientRect();this.availablePixels=this.image.height-t.height,this.startPoint=t.top+e-window.innerHeight,this.endPoint=t.top+e+t.height},e.prototype.setImageTransform=function(e,t){this.renderer.setStyle(this.image,"transform","translate("+e+"px, "+t+"px)")},e.prototype.getImageLeft=function(e){return-(this.image.width-e)/100*this.positionPercentage},e.prototype.getImageTop=function(e){if(this.isDisabled)return-this.availablePixels/2;var t=Math.min(this.endPoint-this.startPoint,Math.max(0,e-this.startPoint));return-(this.availablePixels/100*(100-100*t/(this.endPoint-this.startPoint)))},e}();r.decorators=[{type:t.Directive,args:[{selector:"[libRfxParallax]"}]}],r.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:s}]},r.propDecorators={parallaxPercentage:[{type:t.Input}],positionPercentage:[{type:t.Input}],imageUrl:[{type:t.Input}],imageZIndex:[{type:t.Input}],visibleOverflow:[{type:t.Input}],isDisabled:[{type:t.Input}]};var n=function(){};n.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],e.RfxParallaxModule=n,e.RfxParallaxService=s,e.ɵa=r,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs")):"function"==typeof define&&define.amd?define("rfx-parallax",["exports","@angular/core","rxjs"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["rfx-parallax"]={},e.ng.core,e.rxjs)}(this,(function(e,t,i){"use strict";var s=function(){function e(){this.subjectScroll=new i.BehaviorSubject(void 0),this.subjectResize=new i.BehaviorSubject(void 0)}return e.prototype.ngOnDestroy=function(){document.removeEventListener("scroll",this.mouseScroll),document.removeEventListener("resize",this.windowResize)},e.prototype.initListeners=function(){this.mouseScroll=this.onMouseScroll.bind(this),this.windowResize=this.onWindowResize.bind(this),document.addEventListener("scroll",this.mouseScroll,!1),window.addEventListener("resize",this.windowResize,!1)},e.prototype.onMouseScroll=function(){this.subjectScroll.next(void 0)},e.prototype.getMouseScroll=function(){return this.subjectScroll.asObservable()},e.prototype.onWindowResize=function(){this.subjectResize.next(void 0)},e.prototype.getWindowResize=function(){return this.subjectResize.asObservable()},e}();s.ɵprov=t.ɵɵdefineInjectable({factory:function(){return new s},token:s,providedIn:"root"}),s.decorators=[{type:t.Injectable,args:[{providedIn:"root"}]}],s.ctorParameters=function(){return[]};var r=function(){function e(e,t,i){this.htmlElement=e,this.renderer=t,this.rfxParallaxService=i,this.parallaxPercentage=20,this.positionPercentage=50,this.imageZIndex=-1,this.isDisabled=!1,this.visibleOverflow=!1}return e.prototype.ngOnInit=function(){this.setListeners()},e.prototype.ngOnDestroy=function(){this.onScrollListener&&this.onScrollListener.unsubscribe(),this.onResizeListener&&this.onResizeListener.unsubscribe()},e.prototype.ngOnChanges=function(e){var t;(null===(t=e.imageUrl)||void 0===t?void 0:t.currentValue)?this.loadImage(e.imageUrl.currentValue):this.image&&this.setParallaxProperties()},e.prototype.setListeners=function(){var e=this;this.onScrollListener=this.rfxParallaxService.getMouseScroll().subscribe((function(){e.imageTop=e.getImageTop(window.scrollY),e.image&&e.setImageTransform(e.imageLeft,e.imageTop)})),this.onResizeListener=this.rfxParallaxService.getWindowResize().subscribe((function(){e.image&&e.setParallaxProperties()}))},e.prototype.loadImage=function(e){var t=this;this.image=new Image,this.image.src=e,this.renderer.setStyle(this.image,"visilibity","hidden"),this.renderer.addClass(this.image,"parallax-image"),this.htmlElement.nativeElement.appendChild(this.image),this.image.onload=function(){t.setParallaxProperties(),t.renderer.setStyle(t.image,"visibility","visible")}},e.prototype.setParallaxProperties=function(){this.setStaticProperties(),this.setImageSize(),this.setParallaxValues(window.scrollY),this.imageLeft=this.getImageLeft(this.htmlElement.nativeElement.clientWidth),this.imageTop=this.getImageTop(window.scrollY),this.setImageTransform(this.imageLeft,this.imageTop)},e.prototype.setStaticProperties=function(){this.isAlreadyPositionAbsRel(this.htmlElement.nativeElement)||this.renderer.setStyle(this.htmlElement.nativeElement,"position","relative"),this.renderer.setStyle(this.htmlElement.nativeElement,"overflow",this.visibleOverflow?"visible":"hidden"),this.renderer.setStyle(this.image,"z-index",this.imageZIndex),this.renderer.setStyle(this.image,"position","absolute"),this.renderer.setStyle(this.image,"left","0"),this.renderer.setStyle(this.image,"top","0")},e.prototype.isAlreadyPositionAbsRel=function(e){return["absolute","relative"].includes(window.getComputedStyle(e).position)},e.prototype.setImageSize=function(){var e=this.htmlElement.nativeElement.clientHeight,t=this.htmlElement.nativeElement.clientWidth,i=e*(100+this.parallaxPercentage)/100;this.image.naturalHeight/this.image.naturalWidth>i/t?(this.renderer.setStyle(this.image,"width",t+"px"),this.renderer.setStyle(this.image,"height","auto")):(this.renderer.setStyle(this.image,"height",i+"px"),this.renderer.setStyle(this.image,"width","auto"))},e.prototype.setParallaxValues=function(e){var t=this.htmlElement.nativeElement.getBoundingClientRect();this.availablePixels=this.image.height-t.height,this.startPoint=t.top+e-window.innerHeight,this.endPoint=t.top+e+t.height},e.prototype.setImageTransform=function(e,t){this.renderer.setStyle(this.image,"transform","translate("+e+"px, "+t+"px)")},e.prototype.getImageLeft=function(e){return-(this.image.width-e)/100*this.positionPercentage},e.prototype.getImageTop=function(e){if(this.isDisabled)return-this.availablePixels/2;var t=Math.min(this.endPoint-this.startPoint,Math.max(0,e-this.startPoint));return-(this.availablePixels/100*(100-100*t/(this.endPoint-this.startPoint)))},e}();r.decorators=[{type:t.Directive,args:[{selector:"[libRfxParallax]"}]}],r.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2},{type:s}]},r.propDecorators={parallaxPercentage:[{type:t.Input}],positionPercentage:[{type:t.Input}],imageUrl:[{type:t.Input}],imageZIndex:[{type:t.Input}],visibleOverflow:[{type:t.Input}],isDisabled:[{type:t.Input}]};var n=function(){};n.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],e.RfxParallaxModule=n,e.RfxParallaxService=s,e.ɵa=r,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=rfx-parallax.umd.min.js.map |
@@ -40,6 +40,10 @@ import { Directive, ElementRef, Input, Renderer2 } from '@angular/core'; | ||
this.imageTop = this.getImageTop(window.scrollY); | ||
this.setImageTransform(this.imageLeft, this.imageTop); | ||
if (this.image) { | ||
this.setImageTransform(this.imageLeft, this.imageTop); | ||
} | ||
}); | ||
this.onResizeListener = this.rfxParallaxService.getWindowResize().subscribe(() => { | ||
this.setParallaxProperties(); | ||
if (this.image) { | ||
this.setParallaxProperties(); | ||
} | ||
}); | ||
@@ -167,2 +171,2 @@ } | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-parallax.directive.js","sourceRoot":"E:/Sviluppo_lbielski/Repos/RFXLibrary/projects/rfx-parallax/src/","sources":["lib/rfx-parallax.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { RfxParallaxService } from './rfx-parallax.service';\r\n\r\n@Directive({\r\n  selector: '[libRfxParallax]'\r\n})\r\nexport class RfxParallaxDirective implements OnInit, OnDestroy, OnChanges {\r\n  @Input() public parallaxPercentage: number;\r\n  @Input() public positionPercentage: number;\r\n  @Input() public imageUrl: string;\r\n  @Input() public imageZIndex: number;\r\n  @Input() public visibleOverflow: boolean;\r\n  @Input() public isDisabled: boolean;\r\n\r\n  private image: HTMLImageElement;\r\n  private availablePixels: number;\r\n  private startPoint: number;\r\n  private endPoint: number;\r\n  private imageLeft: number;\r\n  private imageTop: number;\r\n\r\n  private onScrollListener: Subscription;\r\n  private onResizeListener: Subscription;\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private rfxParallaxService: RfxParallaxService\r\n  ) {\r\n    this.parallaxPercentage = 20;\r\n    this.positionPercentage = 50;\r\n    this.imageZIndex = -1;\r\n    this.isDisabled = false;\r\n    this.visibleOverflow = false;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setListeners();\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    if (this.onResizeListener) {\r\n      this.onResizeListener.unsubscribe();\r\n    }\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.imageUrl?.currentValue) {\r\n      this.loadImage(changes.imageUrl.currentValue);\r\n    } else if (this.image) {\r\n      this.setParallaxProperties();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Subscribe to scroll and resize listeners\r\n   */\r\n  private setListeners(): void {\r\n    this.onScrollListener = this.rfxParallaxService.getMouseScroll().subscribe(() => {\r\n      this.imageTop = this.getImageTop(window.scrollY);\r\n      this.setImageTransform(this.imageLeft, this.imageTop);\r\n    });\r\n\r\n    this.onResizeListener = this.rfxParallaxService.getWindowResize().subscribe(() => {\r\n      this.setParallaxProperties();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Load parallax image from imageUrl\r\n   * @param imageUrl image url\r\n   */\r\n  private loadImage(imageUrl: string): void {\r\n    this.image = new Image();\r\n    this.image.src = imageUrl;\r\n    this.renderer.setStyle(this.image, 'visilibity', 'hidden');\r\n    this.renderer.addClass(this.image, 'parallax-image');\r\n    this.htmlElement.nativeElement.appendChild(this.image);\r\n\r\n    this.image.onload = () => {\r\n      this.setParallaxProperties();\r\n      this.renderer.setStyle(this.image, 'visibility', 'visible');\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Set parallax properties and position\r\n   */\r\n  private setParallaxProperties(): void {\r\n    this.setStaticProperties();\r\n    this.setImageSize();\r\n    this.setParallaxValues(window.scrollY);\r\n    this.imageLeft = this.getImageLeft(this.htmlElement.nativeElement.clientWidth);\r\n    this.imageTop = this.getImageTop(window.scrollY);\r\n    this.setImageTransform(this.imageLeft, this.imageTop);\r\n  }\r\n\r\n  /**\r\n   * Set default properties for container and image\r\n   */\r\n  private setStaticProperties(): void {\r\n    if (!this.isAlreadyPositionAbsRel(this.htmlElement.nativeElement)) {\r\n      this.renderer.setStyle(this.htmlElement.nativeElement, 'position', 'relative');\r\n    }\r\n\r\n    this.renderer.setStyle(this.htmlElement.nativeElement, 'overflow', this.visibleOverflow ? 'visible' : 'hidden');\r\n    this.renderer.setStyle(this.image, 'z-index', this.imageZIndex);\r\n    this.renderer.setStyle(this.image, 'position', 'absolute');\r\n    this.renderer.setStyle(this.image, 'left', '0');\r\n    this.renderer.setStyle(this.image, 'top', '0');\r\n  }\r\n\r\n  /**\r\n   * Check if element has position absolute or relative\r\n   * @param element html element\r\n   */\r\n  private isAlreadyPositionAbsRel(element: Element): boolean {\r\n    return ['absolute', 'relative'].includes(window.getComputedStyle(element).position);\r\n  }\r\n\r\n  /**\r\n   * Set default image size that match properties\r\n   */\r\n  private setImageSize(): void {\r\n    const boxHeight = this.htmlElement.nativeElement.clientHeight;\r\n    const boxWidth = this.htmlElement.nativeElement.clientWidth;\r\n    const minHeight = (boxHeight * (100 + this.parallaxPercentage)) / 100;\r\n    const ratio = this.image.naturalHeight / this.image.naturalWidth;\r\n    const minRatio = minHeight / boxWidth;\r\n\r\n    if (ratio > minRatio) {\r\n      this.renderer.setStyle(this.image, 'width', `${boxWidth}px`);\r\n      this.renderer.setStyle(this.image, 'height', 'auto');\r\n    } else {\r\n      this.renderer.setStyle(this.image, 'height', `${minHeight}px`);\r\n      this.renderer.setStyle(this.image, 'width', 'auto');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set available pixels and start & stop parallax points for better cpu usage\r\n   * @param scrollTop pixels from the top of the page to the current view\r\n   */\r\n  private setParallaxValues(scrollTop: number): void {\r\n    const elementPosition = this.htmlElement.nativeElement.getBoundingClientRect();\r\n    this.availablePixels = this.image.height - elementPosition.height;\r\n    this.startPoint = elementPosition.top + scrollTop - window.innerHeight;\r\n    this.endPoint = elementPosition.top + scrollTop + elementPosition.height;\r\n  }\r\n\r\n  /**\r\n   * Set image transform property\r\n   * @param imageLeft image left shift in pixels\r\n   * @param imageTop imagetop shift in pixels\r\n   */\r\n  private setImageTransform(imageLeft: number, imageTop: number): void {\r\n    this.renderer.setStyle(this.image, 'transform', `translate(${imageLeft}px, ${imageTop}px)`);\r\n  }\r\n\r\n  /**\r\n   * Get image left shift in pixels\r\n   * @param containerWidth container width in pixels\r\n   */\r\n  private getImageLeft(containerWidth: number): number {\r\n    return -((this.image.width - containerWidth) / 100 * this.positionPercentage);\r\n  }\r\n\r\n  /**\r\n   * Get image top shift in pixels\r\n   * @param scrollTop pixels from the top of the page to the current view\r\n   */\r\n  private getImageTop(scrollTop: number): number {\r\n    if (this.isDisabled) {\r\n      return -this.availablePixels / 2;\r\n    }\r\n\r\n    const parallaxPositionPixels = Math.min(this.endPoint - this.startPoint, Math.max(0, scrollTop - this.startPoint));\r\n    const imageTop = (this.availablePixels / 100) * (100 - (100 * parallaxPositionPixels) / (this.endPoint - this.startPoint));\r\n    return -imageTop;\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-parallax.directive.js","sourceRoot":"E:/Sviluppo_lbielski/Repos/RFXLibrary/projects/rfx-parallax/src/","sources":["lib/rfx-parallax.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\nimport { RfxParallaxService } from './rfx-parallax.service';\r\n\r\n@Directive({\r\n  selector: '[libRfxParallax]'\r\n})\r\nexport class RfxParallaxDirective implements OnInit, OnDestroy, OnChanges {\r\n  @Input() public parallaxPercentage: number;\r\n  @Input() public positionPercentage: number;\r\n  @Input() public imageUrl: string;\r\n  @Input() public imageZIndex: number;\r\n  @Input() public visibleOverflow: boolean;\r\n  @Input() public isDisabled: boolean;\r\n\r\n  private image: HTMLImageElement;\r\n  private availablePixels: number;\r\n  private startPoint: number;\r\n  private endPoint: number;\r\n  private imageLeft: number;\r\n  private imageTop: number;\r\n\r\n  private onScrollListener: Subscription;\r\n  private onResizeListener: Subscription;\r\n\r\n  constructor(\r\n    private htmlElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private rfxParallaxService: RfxParallaxService\r\n  ) {\r\n    this.parallaxPercentage = 20;\r\n    this.positionPercentage = 50;\r\n    this.imageZIndex = -1;\r\n    this.isDisabled = false;\r\n    this.visibleOverflow = false;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.setListeners();\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    if (this.onResizeListener) {\r\n      this.onResizeListener.unsubscribe();\r\n    }\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.imageUrl?.currentValue) {\r\n      this.loadImage(changes.imageUrl.currentValue);\r\n    } else if (this.image) {\r\n      this.setParallaxProperties();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Subscribe to scroll and resize listeners\r\n   */\r\n  private setListeners(): void {\r\n    this.onScrollListener = this.rfxParallaxService.getMouseScroll().subscribe(() => {\r\n      this.imageTop = this.getImageTop(window.scrollY);\r\n      if (this.image) {\r\n        this.setImageTransform(this.imageLeft, this.imageTop);\r\n      }\r\n    });\r\n\r\n    this.onResizeListener = this.rfxParallaxService.getWindowResize().subscribe(() => {\r\n      if (this.image) {\r\n        this.setParallaxProperties();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Load parallax image from imageUrl\r\n   * @param imageUrl image url\r\n   */\r\n  private loadImage(imageUrl: string): void {\r\n    this.image = new Image();\r\n    this.image.src = imageUrl;\r\n    this.renderer.setStyle(this.image, 'visilibity', 'hidden');\r\n    this.renderer.addClass(this.image, 'parallax-image');\r\n    this.htmlElement.nativeElement.appendChild(this.image);\r\n\r\n    this.image.onload = () => {\r\n      this.setParallaxProperties();\r\n      this.renderer.setStyle(this.image, 'visibility', 'visible');\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Set parallax properties and position\r\n   */\r\n  private setParallaxProperties(): void {\r\n    this.setStaticProperties();\r\n    this.setImageSize();\r\n    this.setParallaxValues(window.scrollY);\r\n    this.imageLeft = this.getImageLeft(this.htmlElement.nativeElement.clientWidth);\r\n    this.imageTop = this.getImageTop(window.scrollY);\r\n    this.setImageTransform(this.imageLeft, this.imageTop);\r\n  }\r\n\r\n  /**\r\n   * Set default properties for container and image\r\n   */\r\n  private setStaticProperties(): void {\r\n    if (!this.isAlreadyPositionAbsRel(this.htmlElement.nativeElement)) {\r\n      this.renderer.setStyle(this.htmlElement.nativeElement, 'position', 'relative');\r\n    }\r\n\r\n    this.renderer.setStyle(this.htmlElement.nativeElement, 'overflow', this.visibleOverflow ? 'visible' : 'hidden');\r\n    this.renderer.setStyle(this.image, 'z-index', this.imageZIndex);\r\n    this.renderer.setStyle(this.image, 'position', 'absolute');\r\n    this.renderer.setStyle(this.image, 'left', '0');\r\n    this.renderer.setStyle(this.image, 'top', '0');\r\n  }\r\n\r\n  /**\r\n   * Check if element has position absolute or relative\r\n   * @param element html element\r\n   */\r\n  private isAlreadyPositionAbsRel(element: Element): boolean {\r\n    return ['absolute', 'relative'].includes(window.getComputedStyle(element).position);\r\n  }\r\n\r\n  /**\r\n   * Set default image size that match properties\r\n   */\r\n  private setImageSize(): void {\r\n    const boxHeight = this.htmlElement.nativeElement.clientHeight;\r\n    const boxWidth = this.htmlElement.nativeElement.clientWidth;\r\n    const minHeight = (boxHeight * (100 + this.parallaxPercentage)) / 100;\r\n    const ratio = this.image.naturalHeight / this.image.naturalWidth;\r\n    const minRatio = minHeight / boxWidth;\r\n\r\n    if (ratio > minRatio) {\r\n      this.renderer.setStyle(this.image, 'width', `${boxWidth}px`);\r\n      this.renderer.setStyle(this.image, 'height', 'auto');\r\n    } else {\r\n      this.renderer.setStyle(this.image, 'height', `${minHeight}px`);\r\n      this.renderer.setStyle(this.image, 'width', 'auto');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Set available pixels and start & stop parallax points for better cpu usage\r\n   * @param scrollTop pixels from the top of the page to the current view\r\n   */\r\n  private setParallaxValues(scrollTop: number): void {\r\n    const elementPosition = this.htmlElement.nativeElement.getBoundingClientRect();\r\n    this.availablePixels = this.image.height - elementPosition.height;\r\n    this.startPoint = elementPosition.top + scrollTop - window.innerHeight;\r\n    this.endPoint = elementPosition.top + scrollTop + elementPosition.height;\r\n  }\r\n\r\n  /**\r\n   * Set image transform property\r\n   * @param imageLeft image left shift in pixels\r\n   * @param imageTop imagetop shift in pixels\r\n   */\r\n  private setImageTransform(imageLeft: number, imageTop: number): void {\r\n    this.renderer.setStyle(this.image, 'transform', `translate(${imageLeft}px, ${imageTop}px)`);\r\n  }\r\n\r\n  /**\r\n   * Get image left shift in pixels\r\n   * @param containerWidth container width in pixels\r\n   */\r\n  private getImageLeft(containerWidth: number): number {\r\n    return -((this.image.width - containerWidth) / 100 * this.positionPercentage);\r\n  }\r\n\r\n  /**\r\n   * Get image top shift in pixels\r\n   * @param scrollTop pixels from the top of the page to the current view\r\n   */\r\n  private getImageTop(scrollTop: number): number {\r\n    if (this.isDisabled) {\r\n      return -this.availablePixels / 2;\r\n    }\r\n\r\n    const parallaxPositionPixels = Math.min(this.endPoint - this.startPoint, Math.max(0, scrollTop - this.startPoint));\r\n    const imageTop = (this.availablePixels / 100) * (100 - (100 * parallaxPositionPixels) / (this.endPoint - this.startPoint));\r\n    return -imageTop;\r\n  }\r\n}\r\n"]} |
@@ -92,6 +92,10 @@ import { ɵɵdefineInjectable, Injectable, Directive, ElementRef, Renderer2, Input, NgModule } from '@angular/core'; | ||
this.imageTop = this.getImageTop(window.scrollY); | ||
this.setImageTransform(this.imageLeft, this.imageTop); | ||
if (this.image) { | ||
this.setImageTransform(this.imageLeft, this.imageTop); | ||
} | ||
}); | ||
this.onResizeListener = this.rfxParallaxService.getWindowResize().subscribe(() => { | ||
this.setParallaxProperties(); | ||
if (this.image) { | ||
this.setParallaxProperties(); | ||
} | ||
}); | ||
@@ -98,0 +102,0 @@ } |
{ | ||
"name": "rfx-parallax", | ||
"version": "1.2.1", | ||
"version": "1.2.2", | ||
"description": "RfxParallax - parallax made easy", | ||
@@ -5,0 +5,0 @@ "author": "RedFoxxo", |
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
112023
873