rfx-parallax
Advanced tools
Comparing version 1.1.0 to 1.1.1
@@ -139,2 +139,4 @@ (function (global, factory) { | ||
this.renderer.setStyle(this.image, 'position', 'absolute'); | ||
this.renderer.setStyle(this.image, 'left', '0'); | ||
this.renderer.setStyle(this.image, 'top', '0'); | ||
}; | ||
@@ -141,0 +143,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.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.setParallaxProperties()},e.prototype.setListeners=function(){var e=this;this.onScrollListener=this.rfxParallaxService.getMouseScroll().subscribe((function(){e.imageTop=e.isDisabled?-e.availablePixels/2: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.isDisabled?-this.availablePixels/2: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")},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)/2},e.prototype.getImageTop=function(e){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}],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.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.setParallaxProperties()},e.prototype.setListeners=function(){var e=this;this.onScrollListener=this.rfxParallaxService.getMouseScroll().subscribe((function(){e.imageTop=e.isDisabled?-e.availablePixels/2: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.isDisabled?-this.availablePixels/2: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)/2},e.prototype.getImageTop=function(e){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}],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 |
@@ -81,2 +81,4 @@ import { Directive, ElementRef, Input, Renderer2 } from '@angular/core'; | ||
this.renderer.setStyle(this.image, 'position', 'absolute'); | ||
this.renderer.setStyle(this.image, 'left', '0'); | ||
this.renderer.setStyle(this.image, 'top', '0'); | ||
} | ||
@@ -160,2 +162,2 @@ /** | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rfx-parallax.directive.js","sourceRoot":"D:/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 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.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 {\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.isDisabled ? (-this.availablePixels / 2) : 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.isDisabled ? (-this.availablePixels / 2) : 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  }\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) / 2;\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    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 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.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 {\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.isDisabled ? (-this.availablePixels / 2) : 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.isDisabled ? (-this.availablePixels / 2) : 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) / 2;\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    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"]} |
@@ -16,2 +16,2 @@ import { NgModule } from '@angular/core'; | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJEOi9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1wYXJhbGxheC9zcmMvIiwic291cmNlcyI6WyJsaWIvcmZ4LXBhcmFsbGF4Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBV2hFLE1BQU0sT0FBTyxpQkFBaUI7OztZQVQ3QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLG9CQUFvQjtpQkFDckI7Z0JBQ0QsT0FBTyxFQUFFLEVBQUU7Z0JBQ1gsT0FBTyxFQUFFO29CQUNQLG9CQUFvQjtpQkFDckI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJmeFBhcmFsbGF4RGlyZWN0aXZlIH0gZnJvbSAnLi9yZngtcGFyYWxsYXguZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZnhQYXJhbGxheERpcmVjdGl2ZVxyXG4gIF0sXHJcbiAgaW1wb3J0czogW10sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgUmZ4UGFyYWxsYXhEaXJlY3RpdmVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZnhQYXJhbGxheE1vZHVsZSB7IH1cclxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJFOi9TdmlsdXBwb19sYmllbHNraS9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1wYXJhbGxheC9zcmMvIiwic291cmNlcyI6WyJsaWIvcmZ4LXBhcmFsbGF4Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBV2hFLE1BQU0sT0FBTyxpQkFBaUI7OztZQVQ3QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLG9CQUFvQjtpQkFDckI7Z0JBQ0QsT0FBTyxFQUFFLEVBQUU7Z0JBQ1gsT0FBTyxFQUFFO29CQUNQLG9CQUFvQjtpQkFDckI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJmeFBhcmFsbGF4RGlyZWN0aXZlIH0gZnJvbSAnLi9yZngtcGFyYWxsYXguZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZnhQYXJhbGxheERpcmVjdGl2ZVxyXG4gIF0sXHJcbiAgaW1wb3J0czogW10sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgUmZ4UGFyYWxsYXhEaXJlY3RpdmVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZnhQYXJhbGxheE1vZHVsZSB7IH1cclxuIl19 |
@@ -54,2 +54,2 @@ import { Injectable } from '@angular/core'; | ||
RfxParallaxService.ctorParameters = () => []; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiRDovUmVwb3MvUkZYTGlicmFyeS9wcm9qZWN0cy9yZngtcGFyYWxsYXgvc3JjLyIsInNvdXJjZXMiOlsibGliL3JmeC1wYXJhbGxheC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQzs7QUFLbkQsTUFBTSxPQUFPLGtCQUFrQjtJQU03QjtRQUNFLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFlLENBQVksU0FBUyxDQUFDLENBQUM7UUFDL0QsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBWSxTQUFTLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRU0sV0FBVztRQUNoQixRQUFRLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN6RCxRQUFRLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNuRCxRQUFRLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDN0QsTUFBTSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRDs7T0FFRztJQUNLLGFBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDM0MsQ0FBQztJQUVEOztPQUVHO0lBQ0ssY0FBYztRQUNwQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxlQUFlO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMzQyxDQUFDOzs7O1lBdkRGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJmeFBhcmFsbGF4U2VydmljZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSBtb3VzZVNjcm9sbDogYW55O1xyXG4gIHByaXZhdGUgd2luZG93UmVzaXplOiBhbnk7XHJcbiAgcHJpdmF0ZSBzdWJqZWN0U2Nyb2xsOiBCZWhhdmlvclN1YmplY3Q8dW5kZWZpbmVkPjtcclxuICBwcml2YXRlIHN1YmplY3RSZXNpemU6IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMuc3ViamVjdFNjcm9sbCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8dW5kZWZpbmVkPih1bmRlZmluZWQpO1xyXG4gICAgdGhpcy5zdWJqZWN0UmVzaXplID0gbmV3IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLm1vdXNlU2Nyb2xsKTtcclxuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Jlc2l6ZScsIHRoaXMud2luZG93UmVzaXplKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEluaXQgbGlzdGVuZXJzXHJcbiAgICovXHJcbiAgcHVibGljIGluaXRMaXN0ZW5lcnMoKTogdm9pZCB7XHJcbiAgICB0aGlzLm1vdXNlU2Nyb2xsID0gdGhpcy5vbk1vdXNlU2Nyb2xsLmJpbmQodGhpcyk7XHJcbiAgICB0aGlzLndpbmRvd1Jlc2l6ZSA9IHRoaXMub25XaW5kb3dSZXNpemUuYmluZCh0aGlzKTtcclxuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIHRoaXMubW91c2VTY3JvbGwsIGZhbHNlKTtcclxuICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdyZXNpemUnLCB0aGlzLndpbmRvd1Jlc2l6ZSwgZmFsc2UpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTW91c2Ugc2Nyb2xsIGV2ZW50XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBvbk1vdXNlU2Nyb2xsKCk6IHZvaWQge1xyXG4gICAgdGhpcy5zdWJqZWN0U2Nyb2xsLm5leHQodW5kZWZpbmVkKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1vdXNlIHNjcm9sbCBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldE1vdXNlU2Nyb2xsKCk6IE9ic2VydmFibGU8dW5kZWZpbmVkPiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWJqZWN0U2Nyb2xsLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogV2luZG93IHJlc2l6ZSBldmVudFxyXG4gICAqL1xyXG4gIHByaXZhdGUgb25XaW5kb3dSZXNpemUoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1YmplY3RSZXNpemUubmV4dCh1bmRlZmluZWQpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogV2luZG93IHJlc2l6ZSBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldFdpbmRvd1Jlc2l6ZSgpOiBPYnNlcnZhYmxlPHVuZGVmaW5lZD4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc3ViamVjdFJlc2l6ZS5hc09ic2VydmFibGUoKTtcclxuICB9XHJcbn1cclxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiRTovU3ZpbHVwcG9fbGJpZWxza2kvUmVwb3MvUkZYTGlicmFyeS9wcm9qZWN0cy9yZngtcGFyYWxsYXgvc3JjLyIsInNvdXJjZXMiOlsibGliL3JmeC1wYXJhbGxheC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBYyxNQUFNLE1BQU0sQ0FBQzs7QUFLbkQsTUFBTSxPQUFPLGtCQUFrQjtJQU03QjtRQUNFLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxlQUFlLENBQVksU0FBUyxDQUFDLENBQUM7UUFDL0QsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLGVBQWUsQ0FBWSxTQUFTLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRU0sV0FBVztRQUNoQixRQUFRLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN6RCxRQUFRLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxhQUFhO1FBQ2xCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDakQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNuRCxRQUFRLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDN0QsTUFBTSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsWUFBWSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRDs7T0FFRztJQUNLLGFBQWE7UUFDbkIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksY0FBYztRQUNuQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDM0MsQ0FBQztJQUVEOztPQUVHO0lBQ0ssY0FBYztRQUNwQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxlQUFlO1FBQ3BCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUMzQyxDQUFDOzs7O1lBdkRGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIFJmeFBhcmFsbGF4U2VydmljZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSBtb3VzZVNjcm9sbDogYW55O1xyXG4gIHByaXZhdGUgd2luZG93UmVzaXplOiBhbnk7XHJcbiAgcHJpdmF0ZSBzdWJqZWN0U2Nyb2xsOiBCZWhhdmlvclN1YmplY3Q8dW5kZWZpbmVkPjtcclxuICBwcml2YXRlIHN1YmplY3RSZXNpemU6IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIHRoaXMuc3ViamVjdFNjcm9sbCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8dW5kZWZpbmVkPih1bmRlZmluZWQpO1xyXG4gICAgdGhpcy5zdWJqZWN0UmVzaXplID0gbmV3IEJlaGF2aW9yU3ViamVjdDx1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICBkb2N1bWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLm1vdXNlU2Nyb2xsKTtcclxuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Jlc2l6ZScsIHRoaXMud2luZG93UmVzaXplKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEluaXQgbGlzdGVuZXJzXHJcbiAgICovXHJcbiAgcHVibGljIGluaXRMaXN0ZW5lcnMoKTogdm9pZCB7XHJcbiAgICB0aGlzLm1vdXNlU2Nyb2xsID0gdGhpcy5vbk1vdXNlU2Nyb2xsLmJpbmQodGhpcyk7XHJcbiAgICB0aGlzLndpbmRvd1Jlc2l6ZSA9IHRoaXMub25XaW5kb3dSZXNpemUuYmluZCh0aGlzKTtcclxuICAgIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIHRoaXMubW91c2VTY3JvbGwsIGZhbHNlKTtcclxuICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdyZXNpemUnLCB0aGlzLndpbmRvd1Jlc2l6ZSwgZmFsc2UpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTW91c2Ugc2Nyb2xsIGV2ZW50XHJcbiAgICovXHJcbiAgcHJpdmF0ZSBvbk1vdXNlU2Nyb2xsKCk6IHZvaWQge1xyXG4gICAgdGhpcy5zdWJqZWN0U2Nyb2xsLm5leHQodW5kZWZpbmVkKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1vdXNlIHNjcm9sbCBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldE1vdXNlU2Nyb2xsKCk6IE9ic2VydmFibGU8dW5kZWZpbmVkPiB7XHJcbiAgICByZXR1cm4gdGhpcy5zdWJqZWN0U2Nyb2xsLmFzT2JzZXJ2YWJsZSgpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogV2luZG93IHJlc2l6ZSBldmVudFxyXG4gICAqL1xyXG4gIHByaXZhdGUgb25XaW5kb3dSZXNpemUoKTogdm9pZCB7XHJcbiAgICB0aGlzLnN1YmplY3RSZXNpemUubmV4dCh1bmRlZmluZWQpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogV2luZG93IHJlc2l6ZSBldmVudCBvYnNlcnZhYmxlXHJcbiAgICovXHJcbiAgcHVibGljIGdldFdpbmRvd1Jlc2l6ZSgpOiBPYnNlcnZhYmxlPHVuZGVmaW5lZD4ge1xyXG4gICAgcmV0dXJuIHRoaXMuc3ViamVjdFJlc2l6ZS5hc09ic2VydmFibGUoKTtcclxuICB9XHJcbn1cclxuIl19 |
@@ -6,2 +6,2 @@ /* | ||
export * from './lib/rfx-parallax.module'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJEOi9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1wYXJhbGxheC9zcmMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHJmeC1wYXJhbGxheFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JmeC1wYXJhbGxheC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcmZ4LXBhcmFsbGF4Lm1vZHVsZSc7XHJcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJFOi9TdmlsdXBwb19sYmllbHNraS9SZXBvcy9SRlhMaWJyYXJ5L3Byb2plY3RzL3JmeC1wYXJhbGxheC9zcmMvIiwic291cmNlcyI6WyJwdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHJmeC1wYXJhbGxheFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JmeC1wYXJhbGxheC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcmZ4LXBhcmFsbGF4Lm1vZHVsZSc7XHJcbiJdfQ== |
@@ -6,2 +6,2 @@ /** | ||
export { RfxParallaxDirective as ɵa } from './lib/rfx-parallax.directive'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4LmpzIiwic291cmNlUm9vdCI6IkQ6L1JlcG9zL1JGWExpYnJhcnkvcHJvamVjdHMvcmZ4LXBhcmFsbGF4L3NyYy8iLCJzb3VyY2VzIjpbInJmeC1wYXJhbGxheC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtSZnhQYXJhbGxheERpcmVjdGl2ZSBhcyDJtWF9IGZyb20gJy4vbGliL3JmeC1wYXJhbGxheC5kaXJlY3RpdmUnOyJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmZ4LXBhcmFsbGF4LmpzIiwic291cmNlUm9vdCI6IkU6L1N2aWx1cHBvX2xiaWVsc2tpL1JlcG9zL1JGWExpYnJhcnkvcHJvamVjdHMvcmZ4LXBhcmFsbGF4L3NyYy8iLCJzb3VyY2VzIjpbInJmeC1wYXJhbGxheC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQyxvQkFBb0IsSUFBSSxFQUFFLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcblxuZXhwb3J0IHtSZnhQYXJhbGxheERpcmVjdGl2ZSBhcyDJtWF9IGZyb20gJy4vbGliL3JmeC1wYXJhbGxheC5kaXJlY3RpdmUnOyJdfQ== |
@@ -133,2 +133,4 @@ import { ɵɵdefineInjectable, Injectable, Directive, ElementRef, Renderer2, Input, NgModule } from '@angular/core'; | ||
this.renderer.setStyle(this.image, 'position', 'absolute'); | ||
this.renderer.setStyle(this.image, 'left', '0'); | ||
this.renderer.setStyle(this.image, 'top', '0'); | ||
} | ||
@@ -135,0 +137,0 @@ /** |
{ | ||
"name": "rfx-parallax", | ||
"version": "1.1.0", | ||
"version": "1.1.1", | ||
"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
109452
845