ionic-header-parallax
Advanced tools
Comparing version 2.2.0 to 2.2.1
@@ -32,3 +32,3 @@ (function (global, factory) { | ||
_this.initEvents(); | ||
})); | ||
}), 100); | ||
}; | ||
@@ -35,0 +35,0 @@ /** |
@@ -1,2 +0,2 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core")):"function"==typeof define&&define.amd?define("ionic-header-parallax",["exports","@angular/core"],t):t((e=e||self)["ionic-header-parallax"]={},e.ng.core)}(this,function(e,t){"use strict";var r=function(){function e(e,t){this.headerRef=e,this.renderer=t,this.maximumHeight=300}return e.prototype.ngAfterViewInit=function(){var e=this;setTimeout(function(){e.initElements(),e.initStyles(),e.initEvents()})},e.prototype.initElements=function(){var e=this,t=this.headerRef.nativeElement.parentElement;if(this.header=this.headerRef.nativeElement,this.toolbar=this.header.querySelector("ion-toolbar"),!this.toolbar)throw new Error("Parallax directive requires a toolbar or navbar element on the page to work.");this.ionTitle=this.toolbar.querySelector("ion-title"),this.toolbarBackground=this.toolbar.shadowRoot.querySelector(".toolbar-background"),this.barButtons=this.headerRef.nativeElement.querySelector("ion-buttons");var r=t.querySelector("ion-content");if(this.scrollContent=r.shadowRoot.querySelector(".inner-scroll"),!this.scrollContent)throw new Error("Parallax directive requires an <ion-content> element on the page to work.");this.imageOverlay=this.renderer.createElement("div"),this.renderer.addClass(this.imageOverlay,"image-overlay"),this.colorOverlay=this.renderer.createElement("div"),this.renderer.addClass(this.colorOverlay,"color-overlay"),this.colorOverlay.appendChild(this.imageOverlay),this.header.appendChild(this.colorOverlay),this.overlayTitle=this.ionTitle&&this.ionTitle.cloneNode(!0),this.overlayTitle&&(this.renderer.addClass(this.overlayTitle,"parallax-title"),setTimeout(function(){var t=e.overlayTitle.shadowRoot.querySelector(".toolbar-title");e.renderer.setStyle(t,"pointer-events","unset")})),this.overlayTitle&&this.imageOverlay.appendChild(this.overlayTitle),this.barButtons&&this.imageOverlay.appendChild(this.barButtons)},e.prototype.initStyles=function(){var e=this;this.headerHeight=this.scrollContent.clientHeight,this.ticking=!1,this.scrollContent&&toolbar&&(this.maximumHeight=parseFloat(this.maximumHeight.toString()),this.headerMinHeight=this.toolbar.offsetHeight,this.scrollContentPaddingTop=window.getComputedStyle(this.scrollContent,null).paddingTop.replace("px",""),this.scrollContentPaddingTop=parseFloat(this.scrollContentPaddingTop),this.originalToolbarBgColor=window.getComputedStyle(this.toolbarBackground,null).backgroundColor,this.renderer.setStyle(this.header,"position","relative"),this.overlayTitle&&(this.renderer.setStyle(this.overlayTitle,"color",this.titleColor),this.renderer.setStyle(this.overlayTitle,"position","absolute"),this.renderer.setStyle(this.overlayTitle,"width","100%"),this.renderer.setStyle(this.overlayTitle,"height","100%"),this.renderer.setStyle(this.overlayTitle,"text-align","center")),this.renderer.setStyle(this.colorOverlay,"background-color",this.originalToolbarBgColor),this.renderer.setStyle(this.colorOverlay,"height",this.maximumHeight+"px"),this.renderer.setStyle(this.colorOverlay,"position","absolute"),this.renderer.setStyle(this.colorOverlay,"top",0*-this.headerMinHeight+"px"),this.renderer.setStyle(this.colorOverlay,"left","0"),this.renderer.setStyle(this.colorOverlay,"width","100%"),this.renderer.setStyle(this.colorOverlay,"z-index","10"),this.renderer.setStyle(this.colorOverlay,"pointer-events","none"),this.renderer.setStyle(this.imageOverlay,"background-color",this.expandedColor),this.renderer.setStyle(this.imageOverlay,"background-image","url("+(this.imageUrl||"")+")"),this.renderer.setStyle(this.imageOverlay,"height","100%"),this.renderer.setStyle(this.imageOverlay,"width","100%"),this.renderer.setStyle(this.imageOverlay,"pointer-events","none"),this.renderer.setStyle(this.imageOverlay,"background-size","cover"),this.renderer.setStyle(this.imageOverlay,"background-position","center"),this.renderer.setStyle(this.toolbarBackground,"background-color",this.originalToolbarBgColor),this.barButtons&&(this.renderer.setStyle(this.barButtons,"pointer-events","all"),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color",e.titleColor)})),this.scrollContent&&(this.renderer.setAttribute(this.scrollContent,"parallax",""),this.renderer.setStyle(this.scrollContent,"padding-top",this.maximumHeight+this.scrollContentPaddingTop-this.headerMinHeight+"px")))},e.prototype.initEvents=function(){var e=this;window.addEventListener("resize",function(){e.headerHeight=e.scrollContent.clientHeight},!1),this.scrollContent&&this.scrollContent.addEventListener("scroll",function(t){e.ticking||window.requestAnimationFrame(function(){e.updateElasticHeader()}),e.ticking=!0})},e.prototype.updateElasticHeader=function(){var e=this;if(this.scrollContent&&toolbar){this.scrollTop=this.scrollContent.scrollTop,this.scrollTop>=0?(this.translateAmt=this.scrollTop/2,this.scaleAmt=1):(this.translateAmt=0,this.scaleAmt=-this.scrollTop/this.headerHeight+1),this.headerMinHeight=this.toolbar.offsetHeight;var t=(this.maximumHeight-this.scrollTop-this.headerMinHeight)/(this.maximumHeight-this.headerMinHeight);t=Math.max(t,0);var r=this.maximumHeight-this.scrollTop;r=Math.max(r,this.headerMinHeight),this.renderer.setStyle(this.imageOverlay,"height",r+"px"),this.renderer.setStyle(this.imageOverlay,"opacity",""+t),this.renderer.setStyle(this.colorOverlay,"height",r+"px"),this.renderer.setStyle(this.colorOverlay,"opacity",r>this.headerMinHeight?"1":"0"),this.renderer.setStyle(this.toolbarBackground,"background-color",r>this.headerMinHeight?"transparent":this.originalToolbarBgColor),this.barButtons&&(r>this.headerMinHeight?(this.imageOverlay.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color",e.titleColor)})):(this.toolbar.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color","unset")}))),this.ticking=!1}},e.decorators=[{type:t.Directive,args:[{selector:"ion-header[parallax]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2}]},e.propDecorators={imageUrl:[{type:t.Input}],expandedColor:[{type:t.Input}],titleColor:[{type:t.Input}],maximumHeight:[{type:t.Input}]},e}();var i=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],e}();e.IonicHeaderParallaxModule=i,e.ParallaxDirective=r,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core")):"function"==typeof define&&define.amd?define("ionic-header-parallax",["exports","@angular/core"],t):t((e=e||self)["ionic-header-parallax"]={},e.ng.core)}(this,function(e,t){"use strict";var r=function(){function e(e,t){this.headerRef=e,this.renderer=t,this.maximumHeight=300}return e.prototype.ngAfterViewInit=function(){var e=this;setTimeout(function(){e.initElements(),e.initStyles(),e.initEvents()},100)},e.prototype.initElements=function(){var e=this,t=this.headerRef.nativeElement.parentElement;if(this.header=this.headerRef.nativeElement,this.toolbar=this.header.querySelector("ion-toolbar"),!this.toolbar)throw new Error("Parallax directive requires a toolbar or navbar element on the page to work.");this.ionTitle=this.toolbar.querySelector("ion-title"),this.toolbarBackground=this.toolbar.shadowRoot.querySelector(".toolbar-background"),this.barButtons=this.headerRef.nativeElement.querySelector("ion-buttons");var r=t.querySelector("ion-content");if(this.scrollContent=r.shadowRoot.querySelector(".inner-scroll"),!this.scrollContent)throw new Error("Parallax directive requires an <ion-content> element on the page to work.");this.imageOverlay=this.renderer.createElement("div"),this.renderer.addClass(this.imageOverlay,"image-overlay"),this.colorOverlay=this.renderer.createElement("div"),this.renderer.addClass(this.colorOverlay,"color-overlay"),this.colorOverlay.appendChild(this.imageOverlay),this.header.appendChild(this.colorOverlay),this.overlayTitle=this.ionTitle&&this.ionTitle.cloneNode(!0),this.overlayTitle&&(this.renderer.addClass(this.overlayTitle,"parallax-title"),setTimeout(function(){var t=e.overlayTitle.shadowRoot.querySelector(".toolbar-title");e.renderer.setStyle(t,"pointer-events","unset")})),this.overlayTitle&&this.imageOverlay.appendChild(this.overlayTitle),this.barButtons&&this.imageOverlay.appendChild(this.barButtons)},e.prototype.initStyles=function(){var e=this;this.headerHeight=this.scrollContent.clientHeight,this.ticking=!1,this.scrollContent&&toolbar&&(this.maximumHeight=parseFloat(this.maximumHeight.toString()),this.headerMinHeight=this.toolbar.offsetHeight,this.scrollContentPaddingTop=window.getComputedStyle(this.scrollContent,null).paddingTop.replace("px",""),this.scrollContentPaddingTop=parseFloat(this.scrollContentPaddingTop),this.originalToolbarBgColor=window.getComputedStyle(this.toolbarBackground,null).backgroundColor,this.renderer.setStyle(this.header,"position","relative"),this.overlayTitle&&(this.renderer.setStyle(this.overlayTitle,"color",this.titleColor),this.renderer.setStyle(this.overlayTitle,"position","absolute"),this.renderer.setStyle(this.overlayTitle,"width","100%"),this.renderer.setStyle(this.overlayTitle,"height","100%"),this.renderer.setStyle(this.overlayTitle,"text-align","center")),this.renderer.setStyle(this.colorOverlay,"background-color",this.originalToolbarBgColor),this.renderer.setStyle(this.colorOverlay,"height",this.maximumHeight+"px"),this.renderer.setStyle(this.colorOverlay,"position","absolute"),this.renderer.setStyle(this.colorOverlay,"top",0*-this.headerMinHeight+"px"),this.renderer.setStyle(this.colorOverlay,"left","0"),this.renderer.setStyle(this.colorOverlay,"width","100%"),this.renderer.setStyle(this.colorOverlay,"z-index","10"),this.renderer.setStyle(this.colorOverlay,"pointer-events","none"),this.renderer.setStyle(this.imageOverlay,"background-color",this.expandedColor),this.renderer.setStyle(this.imageOverlay,"background-image","url("+(this.imageUrl||"")+")"),this.renderer.setStyle(this.imageOverlay,"height","100%"),this.renderer.setStyle(this.imageOverlay,"width","100%"),this.renderer.setStyle(this.imageOverlay,"pointer-events","none"),this.renderer.setStyle(this.imageOverlay,"background-size","cover"),this.renderer.setStyle(this.imageOverlay,"background-position","center"),this.renderer.setStyle(this.toolbarBackground,"background-color",this.originalToolbarBgColor),this.barButtons&&(this.renderer.setStyle(this.barButtons,"pointer-events","all"),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color",e.titleColor)})),this.scrollContent&&(this.renderer.setAttribute(this.scrollContent,"parallax",""),this.renderer.setStyle(this.scrollContent,"padding-top",this.maximumHeight+this.scrollContentPaddingTop-this.headerMinHeight+"px")))},e.prototype.initEvents=function(){var e=this;window.addEventListener("resize",function(){e.headerHeight=e.scrollContent.clientHeight},!1),this.scrollContent&&this.scrollContent.addEventListener("scroll",function(t){e.ticking||window.requestAnimationFrame(function(){e.updateElasticHeader()}),e.ticking=!0})},e.prototype.updateElasticHeader=function(){var e=this;if(this.scrollContent&&toolbar){this.scrollTop=this.scrollContent.scrollTop,this.scrollTop>=0?(this.translateAmt=this.scrollTop/2,this.scaleAmt=1):(this.translateAmt=0,this.scaleAmt=-this.scrollTop/this.headerHeight+1),this.headerMinHeight=this.toolbar.offsetHeight;var t=(this.maximumHeight-this.scrollTop-this.headerMinHeight)/(this.maximumHeight-this.headerMinHeight);t=Math.max(t,0);var r=this.maximumHeight-this.scrollTop;r=Math.max(r,this.headerMinHeight),this.renderer.setStyle(this.imageOverlay,"height",r+"px"),this.renderer.setStyle(this.imageOverlay,"opacity",""+t),this.renderer.setStyle(this.colorOverlay,"height",r+"px"),this.renderer.setStyle(this.colorOverlay,"opacity",r>this.headerMinHeight?"1":"0"),this.renderer.setStyle(this.toolbarBackground,"background-color",r>this.headerMinHeight?"transparent":this.originalToolbarBgColor),this.barButtons&&(r>this.headerMinHeight?(this.imageOverlay.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color",e.titleColor)})):(this.toolbar.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(t){e.renderer.setStyle(t,"color","unset")}))),this.ticking=!1}},e.decorators=[{type:t.Directive,args:[{selector:"ion-header[parallax]"}]}],e.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2}]},e.propDecorators={imageUrl:[{type:t.Input}],expandedColor:[{type:t.Input}],titleColor:[{type:t.Input}],maximumHeight:[{type:t.Input}]},e}();var i=function(){function e(){}return e.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],e}();e.IonicHeaderParallaxModule=i,e.ParallaxDirective=r,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ionic-header-parallax.umd.min.js.map |
@@ -27,3 +27,3 @@ /** | ||
this.initEvents(); | ||
})); | ||
}), 100); | ||
} | ||
@@ -290,2 +290,2 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallax.directive.js","sourceRoot":"ng://ionic-header-parallax/","sources":["lib/parallax.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, AfterViewInit } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: 'ion-header[parallax]'\r\n})\r\nexport class ParallaxDirective implements AfterViewInit {\r\n  @Input() imageUrl: string;\r\n  @Input() expandedColor: string;\r\n  @Input() titleColor: string;\r\n  @Input() maximumHeight = 300;\r\n\r\n  header: HTMLElement;\r\n  toolbar: HTMLElement;\r\n  toolbarBackground: HTMLElement;\r\n  imageOverlay: HTMLElement;\r\n  colorOverlay: HTMLElement;\r\n  barButtons: HTMLElement;\r\n  scrollContent: HTMLElement;\r\n  headerHeight: any;\r\n  headerMinHeight: number;\r\n  translateAmt: any;\r\n  scaleAmt: any;\r\n  scrollTop: any;\r\n  lastScrollTop: any;\r\n  ticking: any;\r\n  originalToolbarBgColor: string;\r\n  overlayTitle: HTMLElement;\r\n  ionTitle: HTMLElement;\r\n  overlayButtons: HTMLElement[];\r\n  scrollContentPaddingTop;\r\n\r\n  constructor(public headerRef: ElementRef<HTMLElement>, public renderer: Renderer2) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.initElements();\r\n      this.initStyles();\r\n      this.initEvents();\r\n    });\r\n  }\r\n\r\n  initElements() {\r\n    const parentElement = this.headerRef.nativeElement.parentElement;\r\n    this.header = this.headerRef.nativeElement;\r\n\r\n    this.toolbar = this.header.querySelector('ion-toolbar');\r\n    if (!this.toolbar) { throw new Error('Parallax directive requires a toolbar or navbar element on the page to work.'); }\r\n    this.ionTitle = this.toolbar.querySelector('ion-title');\r\n    this.toolbarBackground = this.toolbar.shadowRoot.querySelector('.toolbar-background');\r\n\r\n    this.barButtons = this.headerRef.nativeElement.querySelector('ion-buttons');\r\n    const ionContent = parentElement.querySelector('ion-content');\r\n    this.scrollContent = ionContent.shadowRoot.querySelector('.inner-scroll');\r\n    if (!this.scrollContent) { throw new Error('Parallax directive requires an <ion-content> element on the page to work.'); }\r\n\r\n    // Create image overlay\r\n    this.imageOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.imageOverlay, 'image-overlay');\r\n\r\n    this.colorOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.colorOverlay, 'color-overlay');\r\n\r\n    this.colorOverlay.appendChild(this.imageOverlay);\r\n    this.header.appendChild(this.colorOverlay);\r\n\r\n    // Copy title and buttons\r\n    this.overlayTitle = this.ionTitle && this.ionTitle.cloneNode(true) as HTMLElement;\r\n    if (this.overlayTitle) {\r\n      this.renderer.addClass(this.overlayTitle, 'parallax-title');\r\n      setTimeout(() => {\r\n        const toolbarTitle = this.overlayTitle.shadowRoot.querySelector('.toolbar-title');\r\n        this.renderer.setStyle(toolbarTitle, 'pointer-events', 'unset');\r\n      });\r\n    }\r\n\r\n    if (this.overlayTitle) { this.imageOverlay.appendChild(this.overlayTitle); }\r\n    if (this.barButtons) { this.imageOverlay.appendChild(this.barButtons); }\r\n  }\r\n\r\n  initStyles() {\r\n    this.headerHeight = this.scrollContent.clientHeight;\r\n    this.ticking = false;\r\n\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    // fetch styles\r\n    this.maximumHeight = parseFloat(this.maximumHeight.toString());\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    this.scrollContentPaddingTop = window.getComputedStyle(this.scrollContent, null).paddingTop.replace('px', '');\r\n    this.scrollContentPaddingTop = parseFloat(this.scrollContentPaddingTop);\r\n    this.originalToolbarBgColor = window.getComputedStyle(this.toolbarBackground, null).backgroundColor;\r\n\r\n    // header and title\r\n    this.renderer.setStyle(this.header, 'position', 'relative');\r\n    if (this.overlayTitle) {\r\n      this.renderer.setStyle(this.overlayTitle, 'color', this.titleColor);\r\n      this.renderer.setStyle(this.overlayTitle, 'position', 'absolute');\r\n      this.renderer.setStyle(this.overlayTitle, 'width', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'height', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'text-align', 'center');\r\n    }\r\n\r\n    // color overlay\r\n    this.renderer.setStyle(this.colorOverlay, 'background-color', this.originalToolbarBgColor);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${this.maximumHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'position', 'absolute');\r\n    this.renderer.setStyle(this.colorOverlay, 'top', `${-this.headerMinHeight * 0}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'left', '0');\r\n    this.renderer.setStyle(this.colorOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.colorOverlay, 'z-index', '10');\r\n    this.renderer.setStyle(this.colorOverlay, 'pointer-events', 'none');\r\n\r\n    // image overlay\r\n    this.renderer.setStyle(this.imageOverlay, 'background-color', this.expandedColor);\r\n    this.renderer.setStyle(this.imageOverlay, 'background-image', `url(${this.imageUrl || ''})`);\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `100%`);\r\n    this.renderer.setStyle(this.imageOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.imageOverlay, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-size', 'cover');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-position', 'center');\r\n\r\n    // .toolbar-background\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color', this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      this.renderer.setStyle(this.barButtons, 'pointer-events', 'all');\r\n      Array.from(this.barButtons.children).forEach(btn => {\r\n        this.renderer.setStyle(btn, 'color', this.titleColor);\r\n      });\r\n    }\r\n\r\n    // .scroll-content\r\n    if (this.scrollContent) {\r\n      this.renderer.setAttribute(this.scrollContent, 'parallax', '');\r\n      this.renderer.setStyle(this.scrollContent, 'padding-top',\r\n        `${this.maximumHeight + this.scrollContentPaddingTop - this.headerMinHeight}px`);\r\n    }\r\n  }\r\n\r\n  initEvents() {\r\n    window.addEventListener('resize', () => {\r\n      this.headerHeight = this.scrollContent.clientHeight;\r\n    }, false);\r\n\r\n    if (this.scrollContent) {\r\n      this.scrollContent.addEventListener('scroll', (e) => {\r\n\r\n        if (!this.ticking) {\r\n          window.requestAnimationFrame(() => {\r\n            this.updateElasticHeader();\r\n          });\r\n        }\r\n        this.ticking = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  updateElasticHeader() {\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    this.scrollTop = this.scrollContent.scrollTop;\r\n    if (this.scrollTop >= 0) {\r\n      this.translateAmt = this.scrollTop / 2;\r\n      this.scaleAmt = 1;\r\n    } else {\r\n      this.translateAmt = 0;\r\n      this.scaleAmt = -this.scrollTop / this.headerHeight + 1;\r\n    }\r\n\r\n    // Parallax total progress\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    let progress = (this.maximumHeight - this.scrollTop - this.headerMinHeight) / (this.maximumHeight - this.headerMinHeight);\r\n    progress = Math.max(progress, 0);\r\n\r\n    // ion-header: set height\r\n    let targetHeight = this.maximumHeight - this.scrollTop;\r\n    targetHeight = Math.max(targetHeight, this.headerMinHeight);\r\n\r\n    // .toolbar-background: change color\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.imageOverlay, 'opacity', `${progress}`);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'opacity', targetHeight > this.headerMinHeight ? '1' : '0');\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color',\r\n      targetHeight > this.headerMinHeight ? 'transparent' : this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      if (targetHeight > this.headerMinHeight) {\r\n        this.imageOverlay.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', this.titleColor);\r\n        });\r\n      } else {\r\n        this.toolbar.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', 'unset');\r\n        });\r\n      }\r\n    }\r\n\r\n    this.ticking = false;\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallax.directive.js","sourceRoot":"ng://ionic-header-parallax/","sources":["lib/parallax.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, AfterViewInit } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: 'ion-header[parallax]'\r\n})\r\nexport class ParallaxDirective implements AfterViewInit {\r\n  @Input() imageUrl: string;\r\n  @Input() expandedColor: string;\r\n  @Input() titleColor: string;\r\n  @Input() maximumHeight = 300;\r\n\r\n  header: HTMLElement;\r\n  toolbar: HTMLElement;\r\n  toolbarBackground: HTMLElement;\r\n  imageOverlay: HTMLElement;\r\n  colorOverlay: HTMLElement;\r\n  barButtons: HTMLElement;\r\n  scrollContent: HTMLElement;\r\n  headerHeight: any;\r\n  headerMinHeight: number;\r\n  translateAmt: any;\r\n  scaleAmt: any;\r\n  scrollTop: any;\r\n  lastScrollTop: any;\r\n  ticking: any;\r\n  originalToolbarBgColor: string;\r\n  overlayTitle: HTMLElement;\r\n  ionTitle: HTMLElement;\r\n  overlayButtons: HTMLElement[];\r\n  scrollContentPaddingTop;\r\n\r\n  constructor(public headerRef: ElementRef<HTMLElement>, public renderer: Renderer2) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.initElements();\r\n      this.initStyles();\r\n      this.initEvents();\r\n    }, 100);\r\n  }\r\n\r\n  initElements() {\r\n    const parentElement = this.headerRef.nativeElement.parentElement;\r\n    this.header = this.headerRef.nativeElement;\r\n\r\n    this.toolbar = this.header.querySelector('ion-toolbar');\r\n    if (!this.toolbar) { throw new Error('Parallax directive requires a toolbar or navbar element on the page to work.'); }\r\n    this.ionTitle = this.toolbar.querySelector('ion-title');\r\n    this.toolbarBackground = this.toolbar.shadowRoot.querySelector('.toolbar-background');\r\n\r\n    this.barButtons = this.headerRef.nativeElement.querySelector('ion-buttons');\r\n    const ionContent = parentElement.querySelector('ion-content');\r\n    this.scrollContent = ionContent.shadowRoot.querySelector('.inner-scroll');\r\n    if (!this.scrollContent) { throw new Error('Parallax directive requires an <ion-content> element on the page to work.'); }\r\n\r\n    // Create image overlay\r\n    this.imageOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.imageOverlay, 'image-overlay');\r\n\r\n    this.colorOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.colorOverlay, 'color-overlay');\r\n\r\n    this.colorOverlay.appendChild(this.imageOverlay);\r\n    this.header.appendChild(this.colorOverlay);\r\n\r\n    // Copy title and buttons\r\n    this.overlayTitle = this.ionTitle && this.ionTitle.cloneNode(true) as HTMLElement;\r\n    if (this.overlayTitle) {\r\n      this.renderer.addClass(this.overlayTitle, 'parallax-title');\r\n      setTimeout(() => {\r\n        const toolbarTitle = this.overlayTitle.shadowRoot.querySelector('.toolbar-title');\r\n        this.renderer.setStyle(toolbarTitle, 'pointer-events', 'unset');\r\n      });\r\n    }\r\n\r\n    if (this.overlayTitle) { this.imageOverlay.appendChild(this.overlayTitle); }\r\n    if (this.barButtons) { this.imageOverlay.appendChild(this.barButtons); }\r\n  }\r\n\r\n  initStyles() {\r\n    this.headerHeight = this.scrollContent.clientHeight;\r\n    this.ticking = false;\r\n\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    // fetch styles\r\n    this.maximumHeight = parseFloat(this.maximumHeight.toString());\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    this.scrollContentPaddingTop = window.getComputedStyle(this.scrollContent, null).paddingTop.replace('px', '');\r\n    this.scrollContentPaddingTop = parseFloat(this.scrollContentPaddingTop);\r\n    this.originalToolbarBgColor = window.getComputedStyle(this.toolbarBackground, null).backgroundColor;\r\n\r\n    // header and title\r\n    this.renderer.setStyle(this.header, 'position', 'relative');\r\n    if (this.overlayTitle) {\r\n      this.renderer.setStyle(this.overlayTitle, 'color', this.titleColor);\r\n      this.renderer.setStyle(this.overlayTitle, 'position', 'absolute');\r\n      this.renderer.setStyle(this.overlayTitle, 'width', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'height', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'text-align', 'center');\r\n    }\r\n\r\n    // color overlay\r\n    this.renderer.setStyle(this.colorOverlay, 'background-color', this.originalToolbarBgColor);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${this.maximumHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'position', 'absolute');\r\n    this.renderer.setStyle(this.colorOverlay, 'top', `${-this.headerMinHeight * 0}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'left', '0');\r\n    this.renderer.setStyle(this.colorOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.colorOverlay, 'z-index', '10');\r\n    this.renderer.setStyle(this.colorOverlay, 'pointer-events', 'none');\r\n\r\n    // image overlay\r\n    this.renderer.setStyle(this.imageOverlay, 'background-color', this.expandedColor);\r\n    this.renderer.setStyle(this.imageOverlay, 'background-image', `url(${this.imageUrl || ''})`);\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `100%`);\r\n    this.renderer.setStyle(this.imageOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.imageOverlay, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-size', 'cover');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-position', 'center');\r\n\r\n    // .toolbar-background\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color', this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      this.renderer.setStyle(this.barButtons, 'pointer-events', 'all');\r\n      Array.from(this.barButtons.children).forEach(btn => {\r\n        this.renderer.setStyle(btn, 'color', this.titleColor);\r\n      });\r\n    }\r\n\r\n    // .scroll-content\r\n    if (this.scrollContent) {\r\n      this.renderer.setAttribute(this.scrollContent, 'parallax', '');\r\n      this.renderer.setStyle(this.scrollContent, 'padding-top',\r\n        `${this.maximumHeight + this.scrollContentPaddingTop - this.headerMinHeight}px`);\r\n    }\r\n  }\r\n\r\n  initEvents() {\r\n    window.addEventListener('resize', () => {\r\n      this.headerHeight = this.scrollContent.clientHeight;\r\n    }, false);\r\n\r\n    if (this.scrollContent) {\r\n      this.scrollContent.addEventListener('scroll', (e) => {\r\n\r\n        if (!this.ticking) {\r\n          window.requestAnimationFrame(() => {\r\n            this.updateElasticHeader();\r\n          });\r\n        }\r\n        this.ticking = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  updateElasticHeader() {\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    this.scrollTop = this.scrollContent.scrollTop;\r\n    if (this.scrollTop >= 0) {\r\n      this.translateAmt = this.scrollTop / 2;\r\n      this.scaleAmt = 1;\r\n    } else {\r\n      this.translateAmt = 0;\r\n      this.scaleAmt = -this.scrollTop / this.headerHeight + 1;\r\n    }\r\n\r\n    // Parallax total progress\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    let progress = (this.maximumHeight - this.scrollTop - this.headerMinHeight) / (this.maximumHeight - this.headerMinHeight);\r\n    progress = Math.max(progress, 0);\r\n\r\n    // ion-header: set height\r\n    let targetHeight = this.maximumHeight - this.scrollTop;\r\n    targetHeight = Math.max(targetHeight, this.headerMinHeight);\r\n\r\n    // .toolbar-background: change color\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.imageOverlay, 'opacity', `${progress}`);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'opacity', targetHeight > this.headerMinHeight ? '1' : '0');\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color',\r\n      targetHeight > this.headerMinHeight ? 'transparent' : this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      if (targetHeight > this.headerMinHeight) {\r\n        this.imageOverlay.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', this.titleColor);\r\n        });\r\n      } else {\r\n        this.toolbar.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', 'unset');\r\n        });\r\n      }\r\n    }\r\n\r\n    this.ticking = false;\r\n  }\r\n}\r\n"]} |
@@ -27,3 +27,3 @@ /** | ||
_this.initEvents(); | ||
})); | ||
}), 100); | ||
}; | ||
@@ -308,2 +308,2 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallax.directive.js","sourceRoot":"ng://ionic-header-parallax/","sources":["lib/parallax.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, AfterViewInit } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: 'ion-header[parallax]'\r\n})\r\nexport class ParallaxDirective implements AfterViewInit {\r\n  @Input() imageUrl: string;\r\n  @Input() expandedColor: string;\r\n  @Input() titleColor: string;\r\n  @Input() maximumHeight = 300;\r\n\r\n  header: HTMLElement;\r\n  toolbar: HTMLElement;\r\n  toolbarBackground: HTMLElement;\r\n  imageOverlay: HTMLElement;\r\n  colorOverlay: HTMLElement;\r\n  barButtons: HTMLElement;\r\n  scrollContent: HTMLElement;\r\n  headerHeight: any;\r\n  headerMinHeight: number;\r\n  translateAmt: any;\r\n  scaleAmt: any;\r\n  scrollTop: any;\r\n  lastScrollTop: any;\r\n  ticking: any;\r\n  originalToolbarBgColor: string;\r\n  overlayTitle: HTMLElement;\r\n  ionTitle: HTMLElement;\r\n  overlayButtons: HTMLElement[];\r\n  scrollContentPaddingTop;\r\n\r\n  constructor(public headerRef: ElementRef<HTMLElement>, public renderer: Renderer2) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.initElements();\r\n      this.initStyles();\r\n      this.initEvents();\r\n    });\r\n  }\r\n\r\n  initElements() {\r\n    const parentElement = this.headerRef.nativeElement.parentElement;\r\n    this.header = this.headerRef.nativeElement;\r\n\r\n    this.toolbar = this.header.querySelector('ion-toolbar');\r\n    if (!this.toolbar) { throw new Error('Parallax directive requires a toolbar or navbar element on the page to work.'); }\r\n    this.ionTitle = this.toolbar.querySelector('ion-title');\r\n    this.toolbarBackground = this.toolbar.shadowRoot.querySelector('.toolbar-background');\r\n\r\n    this.barButtons = this.headerRef.nativeElement.querySelector('ion-buttons');\r\n    const ionContent = parentElement.querySelector('ion-content');\r\n    this.scrollContent = ionContent.shadowRoot.querySelector('.inner-scroll');\r\n    if (!this.scrollContent) { throw new Error('Parallax directive requires an <ion-content> element on the page to work.'); }\r\n\r\n    // Create image overlay\r\n    this.imageOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.imageOverlay, 'image-overlay');\r\n\r\n    this.colorOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.colorOverlay, 'color-overlay');\r\n\r\n    this.colorOverlay.appendChild(this.imageOverlay);\r\n    this.header.appendChild(this.colorOverlay);\r\n\r\n    // Copy title and buttons\r\n    this.overlayTitle = this.ionTitle && this.ionTitle.cloneNode(true) as HTMLElement;\r\n    if (this.overlayTitle) {\r\n      this.renderer.addClass(this.overlayTitle, 'parallax-title');\r\n      setTimeout(() => {\r\n        const toolbarTitle = this.overlayTitle.shadowRoot.querySelector('.toolbar-title');\r\n        this.renderer.setStyle(toolbarTitle, 'pointer-events', 'unset');\r\n      });\r\n    }\r\n\r\n    if (this.overlayTitle) { this.imageOverlay.appendChild(this.overlayTitle); }\r\n    if (this.barButtons) { this.imageOverlay.appendChild(this.barButtons); }\r\n  }\r\n\r\n  initStyles() {\r\n    this.headerHeight = this.scrollContent.clientHeight;\r\n    this.ticking = false;\r\n\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    // fetch styles\r\n    this.maximumHeight = parseFloat(this.maximumHeight.toString());\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    this.scrollContentPaddingTop = window.getComputedStyle(this.scrollContent, null).paddingTop.replace('px', '');\r\n    this.scrollContentPaddingTop = parseFloat(this.scrollContentPaddingTop);\r\n    this.originalToolbarBgColor = window.getComputedStyle(this.toolbarBackground, null).backgroundColor;\r\n\r\n    // header and title\r\n    this.renderer.setStyle(this.header, 'position', 'relative');\r\n    if (this.overlayTitle) {\r\n      this.renderer.setStyle(this.overlayTitle, 'color', this.titleColor);\r\n      this.renderer.setStyle(this.overlayTitle, 'position', 'absolute');\r\n      this.renderer.setStyle(this.overlayTitle, 'width', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'height', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'text-align', 'center');\r\n    }\r\n\r\n    // color overlay\r\n    this.renderer.setStyle(this.colorOverlay, 'background-color', this.originalToolbarBgColor);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${this.maximumHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'position', 'absolute');\r\n    this.renderer.setStyle(this.colorOverlay, 'top', `${-this.headerMinHeight * 0}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'left', '0');\r\n    this.renderer.setStyle(this.colorOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.colorOverlay, 'z-index', '10');\r\n    this.renderer.setStyle(this.colorOverlay, 'pointer-events', 'none');\r\n\r\n    // image overlay\r\n    this.renderer.setStyle(this.imageOverlay, 'background-color', this.expandedColor);\r\n    this.renderer.setStyle(this.imageOverlay, 'background-image', `url(${this.imageUrl || ''})`);\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `100%`);\r\n    this.renderer.setStyle(this.imageOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.imageOverlay, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-size', 'cover');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-position', 'center');\r\n\r\n    // .toolbar-background\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color', this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      this.renderer.setStyle(this.barButtons, 'pointer-events', 'all');\r\n      Array.from(this.barButtons.children).forEach(btn => {\r\n        this.renderer.setStyle(btn, 'color', this.titleColor);\r\n      });\r\n    }\r\n\r\n    // .scroll-content\r\n    if (this.scrollContent) {\r\n      this.renderer.setAttribute(this.scrollContent, 'parallax', '');\r\n      this.renderer.setStyle(this.scrollContent, 'padding-top',\r\n        `${this.maximumHeight + this.scrollContentPaddingTop - this.headerMinHeight}px`);\r\n    }\r\n  }\r\n\r\n  initEvents() {\r\n    window.addEventListener('resize', () => {\r\n      this.headerHeight = this.scrollContent.clientHeight;\r\n    }, false);\r\n\r\n    if (this.scrollContent) {\r\n      this.scrollContent.addEventListener('scroll', (e) => {\r\n\r\n        if (!this.ticking) {\r\n          window.requestAnimationFrame(() => {\r\n            this.updateElasticHeader();\r\n          });\r\n        }\r\n        this.ticking = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  updateElasticHeader() {\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    this.scrollTop = this.scrollContent.scrollTop;\r\n    if (this.scrollTop >= 0) {\r\n      this.translateAmt = this.scrollTop / 2;\r\n      this.scaleAmt = 1;\r\n    } else {\r\n      this.translateAmt = 0;\r\n      this.scaleAmt = -this.scrollTop / this.headerHeight + 1;\r\n    }\r\n\r\n    // Parallax total progress\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    let progress = (this.maximumHeight - this.scrollTop - this.headerMinHeight) / (this.maximumHeight - this.headerMinHeight);\r\n    progress = Math.max(progress, 0);\r\n\r\n    // ion-header: set height\r\n    let targetHeight = this.maximumHeight - this.scrollTop;\r\n    targetHeight = Math.max(targetHeight, this.headerMinHeight);\r\n\r\n    // .toolbar-background: change color\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.imageOverlay, 'opacity', `${progress}`);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'opacity', targetHeight > this.headerMinHeight ? '1' : '0');\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color',\r\n      targetHeight > this.headerMinHeight ? 'transparent' : this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      if (targetHeight > this.headerMinHeight) {\r\n        this.imageOverlay.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', this.titleColor);\r\n        });\r\n      } else {\r\n        this.toolbar.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', 'unset');\r\n        });\r\n      }\r\n    }\r\n\r\n    this.ticking = false;\r\n  }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallax.directive.js","sourceRoot":"ng://ionic-header-parallax/","sources":["lib/parallax.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAiB,MAAM,eAAe,CAAC;AAEvF;IA6BE,2BAAmB,SAAkC,EAAS,QAAmB;QAA9D,cAAS,GAAT,SAAS,CAAyB;QAAS,aAAQ,GAAR,QAAQ,CAAW;QAtBxE,kBAAa,GAAG,GAAG,CAAC;IAuB7B,CAAC;;;;IAED,2CAAe;;;IAAf;QAAA,iBAMC;QALC,UAAU;;;QAAC;YACT,KAAI,CAAC,YAAY,EAAE,CAAC;YACpB,KAAI,CAAC,UAAU,EAAE,CAAC;YAClB,KAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,GAAE,GAAG,CAAC,CAAC;IACV,CAAC;;;;IAED,wCAAY;;;IAAZ;QAAA,iBAoCC;;YAnCO,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,aAAa;QAChE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;QAE3C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACxD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;SAAE;QACvH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QACxD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC;QAEtF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;;YACtE,UAAU,GAAG,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC;QAC7D,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;QAC1E,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,2EAA2E,CAAC,CAAC;SAAE;QAE1H,uBAAuB;QACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;QAE3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;QAE3D,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACjD,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAE3C,yBAAyB;QACzB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,IAAI,mBAAA,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,EAAe,CAAC;QAClF,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;YAC5D,UAAU;;;YAAC;;oBACH,YAAY,GAAG,KAAI,CAAC,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC;gBACjF,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,YAAY,EAAE,gBAAgB,EAAE,OAAO,CAAC,CAAC;YAClE,CAAC,EAAC,CAAC;SACJ;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SAAE;QAC5E,IAAI,IAAI,CAAC,UAAU,EAAE;YAAE,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAAE;IAC1E,CAAC;;;;IAED,sCAAU;;;IAAV;QAAA,iBA2DC;QA1DC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;QACpD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,OAAO,EAAE;YAAE,OAAO;SAAE;QAEhD,eAAe;QACf,IAAI,CAAC,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC/D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;QACjD,IAAI,CAAC,uBAAuB,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QAC9G,IAAI,CAAC,uBAAuB,GAAG,UAAU,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QACxE,IAAI,CAAC,sBAAsB,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,CAAC,eAAe,CAAC;QAEpG,mBAAmB;QACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAC5D,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;YAClE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;YAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;SACnE;QAED,gBAAgB;QAChB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAC3F,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAK,IAAI,CAAC,aAAa,OAAI,CAAC,CAAC;QAC/E,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAClE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,EAAK,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,OAAI,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;QACvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;QAEpE,gBAAgB;QAChB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAClF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,kBAAkB,EAAE,UAAO,IAAI,CAAC,QAAQ,IAAI,EAAE,OAAG,CAAC,CAAC;QAC7F,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,iBAAiB,EAAE,OAAO,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,qBAAqB,EAAE,QAAQ,CAAC,CAAC;QAE3E,sBAAsB;QACtB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAEhG,eAAe;QACf,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,gBAAgB,EAAE,KAAK,CAAC,CAAC;YACjE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO;;;;YAAC,UAAA,GAAG;gBAC9C,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,KAAI,CAAC,UAAU,CAAC,CAAC;YACxD,CAAC,EAAC,CAAC;SACJ;QAED,kBAAkB;QAClB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,aAAa,EACnD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,eAAe,OAAI,CAAC,CAAC;SACpF;IACH,CAAC;;;;IAED,sCAAU;;;IAAV;QAAA,iBAgBC;QAfC,MAAM,CAAC,gBAAgB,CAAC,QAAQ;;;QAAE;YAChC,KAAI,CAAC,YAAY,GAAG,KAAI,CAAC,aAAa,CAAC,YAAY,CAAC;QACtD,CAAC,GAAE,KAAK,CAAC,CAAC;QAEV,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,QAAQ;;;;YAAE,UAAC,CAAC;gBAE9C,IAAI,CAAC,KAAI,CAAC,OAAO,EAAE;oBACjB,MAAM,CAAC,qBAAqB;;;oBAAC;wBAC3B,KAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC7B,CAAC,EAAC,CAAC;iBACJ;gBACD,KAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACtB,CAAC,EAAC,CAAC;SACJ;IACH,CAAC;;;;IAED,+CAAmB;;;IAAnB;QAAA,iBA6CC;QA5CC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,OAAO,EAAE;YAAE,OAAO;SAAE;QAEhD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;QAC9C,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE;YACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;SACnB;aAAM;YACL,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;SACzD;QAED,0BAA0B;QAC1B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;;YAC7C,QAAQ,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,eAAe,CAAC;QACzH,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;;;YAG7B,YAAY,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS;QACtD,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAE5D,oCAAoC;QACpC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAK,YAAY,OAAI,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,KAAG,QAAU,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAK,YAAY,OAAI,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACtG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,kBAAkB,EAC/D,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAErF,eAAe;QACf,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE;gBACvC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC1C,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO;;;;gBAAC,UAAA,GAAG;oBAC9C,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,KAAI,CAAC,UAAU,CAAC,CAAC;gBACxD,CAAC,EAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACrC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,OAAO;;;;gBAAC,UAAA,GAAG;oBAC9C,KAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;gBAChD,CAAC,EAAC,CAAC;aACJ;SACF;QAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;;gBA1MF,SAAS,SAAC;oBACT,QAAQ,EAAE,sBAAsB;iBACjC;;;;gBAJmB,UAAU;gBAAS,SAAS;;;2BAM7C,KAAK;gCACL,KAAK;6BACL,KAAK;gCACL,KAAK;;IAoMR,wBAAC;CAAA,AA3MD,IA2MC;SAxMY,iBAAiB;;;IAC5B,qCAA0B;;IAC1B,0CAA+B;;IAC/B,uCAA4B;;IAC5B,0CAA6B;;IAE7B,mCAAoB;;IACpB,oCAAqB;;IACrB,8CAA+B;;IAC/B,yCAA0B;;IAC1B,yCAA0B;;IAC1B,uCAAwB;;IACxB,0CAA2B;;IAC3B,yCAAkB;;IAClB,4CAAwB;;IACxB,yCAAkB;;IAClB,qCAAc;;IACd,sCAAe;;IACf,0CAAmB;;IACnB,oCAAa;;IACb,mDAA+B;;IAC/B,yCAA0B;;IAC1B,qCAAsB;;IACtB,2CAA8B;;IAC9B,oDAAwB;;IAEZ,sCAAyC;;IAAE,qCAA0B","sourcesContent":["import { Directive, ElementRef, Input, Renderer2, AfterViewInit } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: 'ion-header[parallax]'\r\n})\r\nexport class ParallaxDirective implements AfterViewInit {\r\n  @Input() imageUrl: string;\r\n  @Input() expandedColor: string;\r\n  @Input() titleColor: string;\r\n  @Input() maximumHeight = 300;\r\n\r\n  header: HTMLElement;\r\n  toolbar: HTMLElement;\r\n  toolbarBackground: HTMLElement;\r\n  imageOverlay: HTMLElement;\r\n  colorOverlay: HTMLElement;\r\n  barButtons: HTMLElement;\r\n  scrollContent: HTMLElement;\r\n  headerHeight: any;\r\n  headerMinHeight: number;\r\n  translateAmt: any;\r\n  scaleAmt: any;\r\n  scrollTop: any;\r\n  lastScrollTop: any;\r\n  ticking: any;\r\n  originalToolbarBgColor: string;\r\n  overlayTitle: HTMLElement;\r\n  ionTitle: HTMLElement;\r\n  overlayButtons: HTMLElement[];\r\n  scrollContentPaddingTop;\r\n\r\n  constructor(public headerRef: ElementRef<HTMLElement>, public renderer: Renderer2) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.initElements();\r\n      this.initStyles();\r\n      this.initEvents();\r\n    }, 100);\r\n  }\r\n\r\n  initElements() {\r\n    const parentElement = this.headerRef.nativeElement.parentElement;\r\n    this.header = this.headerRef.nativeElement;\r\n\r\n    this.toolbar = this.header.querySelector('ion-toolbar');\r\n    if (!this.toolbar) { throw new Error('Parallax directive requires a toolbar or navbar element on the page to work.'); }\r\n    this.ionTitle = this.toolbar.querySelector('ion-title');\r\n    this.toolbarBackground = this.toolbar.shadowRoot.querySelector('.toolbar-background');\r\n\r\n    this.barButtons = this.headerRef.nativeElement.querySelector('ion-buttons');\r\n    const ionContent = parentElement.querySelector('ion-content');\r\n    this.scrollContent = ionContent.shadowRoot.querySelector('.inner-scroll');\r\n    if (!this.scrollContent) { throw new Error('Parallax directive requires an <ion-content> element on the page to work.'); }\r\n\r\n    // Create image overlay\r\n    this.imageOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.imageOverlay, 'image-overlay');\r\n\r\n    this.colorOverlay = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.colorOverlay, 'color-overlay');\r\n\r\n    this.colorOverlay.appendChild(this.imageOverlay);\r\n    this.header.appendChild(this.colorOverlay);\r\n\r\n    // Copy title and buttons\r\n    this.overlayTitle = this.ionTitle && this.ionTitle.cloneNode(true) as HTMLElement;\r\n    if (this.overlayTitle) {\r\n      this.renderer.addClass(this.overlayTitle, 'parallax-title');\r\n      setTimeout(() => {\r\n        const toolbarTitle = this.overlayTitle.shadowRoot.querySelector('.toolbar-title');\r\n        this.renderer.setStyle(toolbarTitle, 'pointer-events', 'unset');\r\n      });\r\n    }\r\n\r\n    if (this.overlayTitle) { this.imageOverlay.appendChild(this.overlayTitle); }\r\n    if (this.barButtons) { this.imageOverlay.appendChild(this.barButtons); }\r\n  }\r\n\r\n  initStyles() {\r\n    this.headerHeight = this.scrollContent.clientHeight;\r\n    this.ticking = false;\r\n\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    // fetch styles\r\n    this.maximumHeight = parseFloat(this.maximumHeight.toString());\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    this.scrollContentPaddingTop = window.getComputedStyle(this.scrollContent, null).paddingTop.replace('px', '');\r\n    this.scrollContentPaddingTop = parseFloat(this.scrollContentPaddingTop);\r\n    this.originalToolbarBgColor = window.getComputedStyle(this.toolbarBackground, null).backgroundColor;\r\n\r\n    // header and title\r\n    this.renderer.setStyle(this.header, 'position', 'relative');\r\n    if (this.overlayTitle) {\r\n      this.renderer.setStyle(this.overlayTitle, 'color', this.titleColor);\r\n      this.renderer.setStyle(this.overlayTitle, 'position', 'absolute');\r\n      this.renderer.setStyle(this.overlayTitle, 'width', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'height', '100%');\r\n      this.renderer.setStyle(this.overlayTitle, 'text-align', 'center');\r\n    }\r\n\r\n    // color overlay\r\n    this.renderer.setStyle(this.colorOverlay, 'background-color', this.originalToolbarBgColor);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${this.maximumHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'position', 'absolute');\r\n    this.renderer.setStyle(this.colorOverlay, 'top', `${-this.headerMinHeight * 0}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'left', '0');\r\n    this.renderer.setStyle(this.colorOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.colorOverlay, 'z-index', '10');\r\n    this.renderer.setStyle(this.colorOverlay, 'pointer-events', 'none');\r\n\r\n    // image overlay\r\n    this.renderer.setStyle(this.imageOverlay, 'background-color', this.expandedColor);\r\n    this.renderer.setStyle(this.imageOverlay, 'background-image', `url(${this.imageUrl || ''})`);\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `100%`);\r\n    this.renderer.setStyle(this.imageOverlay, 'width', '100%');\r\n    this.renderer.setStyle(this.imageOverlay, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-size', 'cover');\r\n    this.renderer.setStyle(this.imageOverlay, 'background-position', 'center');\r\n\r\n    // .toolbar-background\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color', this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      this.renderer.setStyle(this.barButtons, 'pointer-events', 'all');\r\n      Array.from(this.barButtons.children).forEach(btn => {\r\n        this.renderer.setStyle(btn, 'color', this.titleColor);\r\n      });\r\n    }\r\n\r\n    // .scroll-content\r\n    if (this.scrollContent) {\r\n      this.renderer.setAttribute(this.scrollContent, 'parallax', '');\r\n      this.renderer.setStyle(this.scrollContent, 'padding-top',\r\n        `${this.maximumHeight + this.scrollContentPaddingTop - this.headerMinHeight}px`);\r\n    }\r\n  }\r\n\r\n  initEvents() {\r\n    window.addEventListener('resize', () => {\r\n      this.headerHeight = this.scrollContent.clientHeight;\r\n    }, false);\r\n\r\n    if (this.scrollContent) {\r\n      this.scrollContent.addEventListener('scroll', (e) => {\r\n\r\n        if (!this.ticking) {\r\n          window.requestAnimationFrame(() => {\r\n            this.updateElasticHeader();\r\n          });\r\n        }\r\n        this.ticking = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  updateElasticHeader() {\r\n    if (!this.scrollContent || !toolbar) { return; }\r\n\r\n    this.scrollTop = this.scrollContent.scrollTop;\r\n    if (this.scrollTop >= 0) {\r\n      this.translateAmt = this.scrollTop / 2;\r\n      this.scaleAmt = 1;\r\n    } else {\r\n      this.translateAmt = 0;\r\n      this.scaleAmt = -this.scrollTop / this.headerHeight + 1;\r\n    }\r\n\r\n    // Parallax total progress\r\n    this.headerMinHeight = this.toolbar.offsetHeight;\r\n    let progress = (this.maximumHeight - this.scrollTop - this.headerMinHeight) / (this.maximumHeight - this.headerMinHeight);\r\n    progress = Math.max(progress, 0);\r\n\r\n    // ion-header: set height\r\n    let targetHeight = this.maximumHeight - this.scrollTop;\r\n    targetHeight = Math.max(targetHeight, this.headerMinHeight);\r\n\r\n    // .toolbar-background: change color\r\n    this.renderer.setStyle(this.imageOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.imageOverlay, 'opacity', `${progress}`);\r\n    this.renderer.setStyle(this.colorOverlay, 'height', `${targetHeight}px`);\r\n    this.renderer.setStyle(this.colorOverlay, 'opacity', targetHeight > this.headerMinHeight ? '1' : '0');\r\n    this.renderer.setStyle(this.toolbarBackground, 'background-color',\r\n      targetHeight > this.headerMinHeight ? 'transparent' : this.originalToolbarBgColor);\r\n\r\n    // .bar-buttons\r\n    if (this.barButtons) {\r\n      if (targetHeight > this.headerMinHeight) {\r\n        this.imageOverlay.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', this.titleColor);\r\n        });\r\n      } else {\r\n        this.toolbar.append(this.barButtons);\r\n        Array.from(this.barButtons.children).forEach(btn => {\r\n          this.renderer.setStyle(btn, 'color', 'unset');\r\n        });\r\n      }\r\n    }\r\n\r\n    this.ticking = false;\r\n  }\r\n}\r\n"]} |
@@ -28,3 +28,3 @@ import { Directive, ElementRef, Renderer2, Input, NgModule } from '@angular/core'; | ||
this.initEvents(); | ||
})); | ||
}), 100); | ||
} | ||
@@ -31,0 +31,0 @@ /** |
@@ -28,3 +28,3 @@ import { Directive, ElementRef, Renderer2, Input, NgModule } from '@angular/core'; | ||
_this.initEvents(); | ||
})); | ||
}), 100); | ||
}; | ||
@@ -31,0 +31,0 @@ /** |
{ | ||
"name": "ionic-header-parallax", | ||
"version": "2.2.0", | ||
"version": "2.2.1", | ||
"description": "This directive enables parallax effect on `ion-header` elements to display a cover photo while on top of the page and transition it to the normal navbar when content is scrolled down.", | ||
@@ -5,0 +5,0 @@ "main": "bundles/ionic-header-parallax.umd.js", |
@@ -7,3 +7,4 @@ # Parallax Header Directive for Ionic v4 # | ||
[Live Demo](https://raschidjfr.github.io/ionic-header-parallax) | ||
* [Live Demo](https://raschidjfr.github.io/ionic-header-parallax) | ||
* [Code Playground](https://stackblitz.com/github/raschidjfr/ionic-header-parallax) | ||
@@ -10,0 +11,0 @@ ![alt text](https://raw.githubusercontent.com/raschidJFR/ionic-header-parallax/master/gif.gif) |
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
Sorry, the diff of this file is not supported yet
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
200063
71
0