ionic-header-parallax
Advanced tools
Comparing version 2.1.0 to 2.1.1
@@ -214,2 +214,8 @@ (function (global, factory) { | ||
this.imageOverlay.append(this.barButtons); | ||
Array.from(this.barButtons.children).forEach(( /** | ||
* @param {?} btn | ||
* @return {?} | ||
*/function (btn) { | ||
_this.renderer.setStyle(btn, 'color', _this.titleColor); | ||
})); | ||
} | ||
@@ -216,0 +222,0 @@ else { |
@@ -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["ionic-header-parallax"]={},e.ng.core)}(this,function(e,t){"use strict";var r=(i.prototype.ngAfterViewInit=function(){var e=this;setTimeout(function(){e.initElements(),e.initStyles(),e.initEvents()})},i.prototype.initElements=function(){var t=this,e=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=e.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 e=t.overlayTitle.shadowRoot.querySelector(".toolbar-title");t.renderer.setStyle(e,"pointer-events","unset")})),this.overlayTitle&&this.imageOverlay.appendChild(this.overlayTitle),this.barButtons&&this.imageOverlay.appendChild(this.barButtons)},i.prototype.initStyles=function(){var t=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(e){t.renderer.setStyle(e,"color",t.titleColor)})),this.scrollContent&&(this.renderer.setAttribute(this.scrollContent,"parallax",""),this.renderer.setStyle(this.scrollContent,"padding-top",this.maximumHeight+this.scrollContentPaddingTop-this.headerMinHeight+"px")))},i.prototype.initEvents=function(){var t=this;window.addEventListener("resize",function(){t.headerHeight=t.scrollContent.clientHeight},!1),this.scrollContent&&this.scrollContent.addEventListener("scroll",function(e){t.ticking||window.requestAnimationFrame(function(){t.updateElasticHeader()}),t.ticking=!0})},i.prototype.updateElasticHeader=function(){var t=this;if(this.scrollContent&&toolbar){this.scrollTop=this.scrollContent.scrollTop,0<=this.scrollTop?(this.translateAmt=this.scrollTop/2,this.scaleAmt=1):(this.translateAmt=0,this.scaleAmt=-this.scrollTop/this.headerHeight+1),this.headerMinHeight=this.toolbar.offsetHeight;var e=(this.maximumHeight-this.scrollTop-this.headerMinHeight)/(this.maximumHeight-this.headerMinHeight);e=Math.max(e,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",""+e),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):(this.toolbar.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(e){t.renderer.setStyle(e,"color","unset")}))),this.ticking=!1}},i.decorators=[{type:t.Directive,args:[{selector:"ion-header[parallax]"}]}],i.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2}]},i.propDecorators={imageUrl:[{type:t.Input}],expandedColor:[{type:t.Input}],titleColor:[{type:t.Input}],maximumHeight:[{type:t.Input}]},i);function i(e,t){this.headerRef=e,this.renderer=t,this.maximumHeight=300}var o=(s.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],s);function s(){}e.IonicHeaderParallaxModule=o,e.ɵa=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["ionic-header-parallax"]={},e.ng.core)}(this,function(e,t){"use strict";var r=(i.prototype.ngAfterViewInit=function(){var e=this;setTimeout(function(){e.initElements(),e.initStyles(),e.initEvents()})},i.prototype.initElements=function(){var t=this,e=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=e.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 e=t.overlayTitle.shadowRoot.querySelector(".toolbar-title");t.renderer.setStyle(e,"pointer-events","unset")})),this.overlayTitle&&this.imageOverlay.appendChild(this.overlayTitle),this.barButtons&&this.imageOverlay.appendChild(this.barButtons)},i.prototype.initStyles=function(){var t=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(e){t.renderer.setStyle(e,"color",t.titleColor)})),this.scrollContent&&(this.renderer.setAttribute(this.scrollContent,"parallax",""),this.renderer.setStyle(this.scrollContent,"padding-top",this.maximumHeight+this.scrollContentPaddingTop-this.headerMinHeight+"px")))},i.prototype.initEvents=function(){var t=this;window.addEventListener("resize",function(){t.headerHeight=t.scrollContent.clientHeight},!1),this.scrollContent&&this.scrollContent.addEventListener("scroll",function(e){t.ticking||window.requestAnimationFrame(function(){t.updateElasticHeader()}),t.ticking=!0})},i.prototype.updateElasticHeader=function(){var t=this;if(this.scrollContent&&toolbar){this.scrollTop=this.scrollContent.scrollTop,0<=this.scrollTop?(this.translateAmt=this.scrollTop/2,this.scaleAmt=1):(this.translateAmt=0,this.scaleAmt=-this.scrollTop/this.headerHeight+1),this.headerMinHeight=this.toolbar.offsetHeight;var e=(this.maximumHeight-this.scrollTop-this.headerMinHeight)/(this.maximumHeight-this.headerMinHeight);e=Math.max(e,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",""+e),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(e){t.renderer.setStyle(e,"color",t.titleColor)})):(this.toolbar.append(this.barButtons),Array.from(this.barButtons.children).forEach(function(e){t.renderer.setStyle(e,"color","unset")}))),this.ticking=!1}},i.decorators=[{type:t.Directive,args:[{selector:"ion-header[parallax]"}]}],i.ctorParameters=function(){return[{type:t.ElementRef},{type:t.Renderer2}]},i.propDecorators={imageUrl:[{type:t.Input}],expandedColor:[{type:t.Input}],titleColor:[{type:t.Input}],maximumHeight:[{type:t.Input}]},i);function i(e,t){this.headerRef=e,this.renderer=t,this.maximumHeight=300}var o=(s.decorators=[{type:t.NgModule,args:[{declarations:[r],imports:[],exports:[r]}]}],s);function s(){}e.IonicHeaderParallaxModule=o,e.ɵa=r,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ionic-header-parallax.umd.min.js.map |
@@ -199,2 +199,9 @@ /** | ||
this.imageOverlay.append(this.barButtons); | ||
Array.from(this.barButtons.children).forEach((/** | ||
* @param {?} btn | ||
* @return {?} | ||
*/ | ||
btn => { | ||
this.renderer.setStyle(btn, 'color', this.titleColor); | ||
})); | ||
} | ||
@@ -283,2 +290,2 @@ else { | ||
} | ||
//# 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;AAKvF,MAAM,OAAO,iBAAiB;;;;;IA0B5B,YAAmB,SAAkC,EAAS,QAAmB;QAA9D,cAAS,GAAT,SAAS,CAAyB;QAAS,aAAQ,GAAR,QAAQ,CAAW;QAtBxE,kBAAa,GAAG,GAAG,CAAC;IAuB7B,CAAC;;;;IAED,eAAe;QACb,UAAU;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,YAAY;;cACJ,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;;cACtE,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,GAAG,EAAE;;sBACR,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC;gBACjF,IAAI,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,UAAU;QACR,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,EAAE,GAAG,IAAI,CAAC,aAAa,IAAI,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,EAAE,GAAG,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,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,OAAO,IAAI,CAAC,QAAQ,IAAI,EAAE,GAAG,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,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,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,EACtD,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,eAAe,IAAI,CAAC,CAAC;SACpF;IACH,CAAC;;;;IAED,UAAU;QACR,MAAM,CAAC,gBAAgB,CAAC,QAAQ;;;QAAE,GAAG,EAAE;YACrC,IAAI,CAAC,YAAY,GAAG,IAAI,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,CAAC,CAAC,EAAE,EAAE;gBAElD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;oBACjB,MAAM,CAAC,qBAAqB;;;oBAAC,GAAG,EAAE;wBAChC,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC7B,CAAC,EAAC,CAAC;iBACJ;gBACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACtB,CAAC,EAAC,CAAC;SACJ;IACH,CAAC;;;;IAED,mBAAmB;QACjB,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,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,GAAG,YAAY,IAAI,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;aAC3C;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,GAAG,CAAC,EAAE;oBACjD,IAAI,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;;;YAvMF,SAAS,SAAC;gBACT,QAAQ,EAAE,sBAAsB;aACjC;;;;YAJmB,UAAU;YAAS,SAAS;;;uBAM7C,KAAK;4BACL,KAAK;yBACL,KAAK;4BACL,KAAK;;;;IAHN,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    });\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      } 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    });\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"]} |
@@ -215,2 +215,9 @@ /** | ||
this.imageOverlay.append(this.barButtons); | ||
Array.from(this.barButtons.children).forEach((/** | ||
* @param {?} btn | ||
* @return {?} | ||
*/ | ||
function (btn) { | ||
_this.renderer.setStyle(btn, 'color', _this.titleColor); | ||
})); | ||
} | ||
@@ -301,2 +308,2 @@ else { | ||
} | ||
//# 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      } 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    });\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"]} |
@@ -200,2 +200,9 @@ import { Directive, ElementRef, Input, Renderer2, NgModule } from '@angular/core'; | ||
this.imageOverlay.append(this.barButtons); | ||
Array.from(this.barButtons.children).forEach((/** | ||
* @param {?} btn | ||
* @return {?} | ||
*/ | ||
btn => { | ||
this.renderer.setStyle(btn, 'color', this.titleColor); | ||
})); | ||
} | ||
@@ -202,0 +209,0 @@ else { |
@@ -216,2 +216,9 @@ import { Directive, ElementRef, Input, Renderer2, NgModule } from '@angular/core'; | ||
this.imageOverlay.append(this.barButtons); | ||
Array.from(this.barButtons.children).forEach((/** | ||
* @param {?} btn | ||
* @return {?} | ||
*/ | ||
function (btn) { | ||
_this.renderer.setStyle(btn, 'color', _this.titleColor); | ||
})); | ||
} | ||
@@ -218,0 +225,0 @@ else { |
{ | ||
"name": "ionic-header-parallax", | ||
"version": "2.1.0", | ||
"version": "2.1.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", |
# Parallax Header Directive for Ionic v4 # | ||
> For Ionic 3 use version [1.0.1](https://www.npmjs.com/package/ionic-header-parallax/v/1.0.1) of this package. | ||
> For Ionic 3 use version [1.0.1](https://www.npmjs.com/package/ionic-header-parallax/v/1.0.1) of this package: `$ npm ionic-header-parallax@1.0.1`. | ||
@@ -55,2 +55,5 @@ 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. | ||
## Modifying the Source Code ## | ||
In case you need to make your own modifications, the package is pritty simple, just 1 .ts file. You can clone the repo wherever in your ionic project (usually inside the `directives` folder): `$ git clone https://github.com/RaschidJFR/ionic-header-parallax.git`. Then edit the file `src/lib/parallax.directive.ts`. | ||
## Credits ## | ||
@@ -57,0 +60,0 @@ This is an implementation of this awesome tutorial on v2 by [Josh Morony](https://www.joshmorony.com/how-to-create-a-directive-in-ionic-2-parallax-header/). Thanks. |
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
194754
1587
64