ion-universal-navbar
Advanced tools
Comparing version 0.9.8-rc1 to 0.9.8-rc2
@@ -107,3 +107,3 @@ (function (global, factory) { | ||
stylesElement.id = 'ion-universal-navbar-colors'; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n a.tab-button [aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n a.tab-button[aria-selected=true] .tab-button-icon,\n a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
if (!document.querySelector('#ion-universal-navbar-colors')) | ||
@@ -110,0 +110,0 @@ document.head.appendChild(stylesElement); |
@@ -1,2 +0,2 @@ | ||
!function(t,a){"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("color"),require("@angular/core"),require("@angular/common"),require("ionic-angular")):"function"==typeof define&&define.amd?define("ion-universal-navbar",["exports","color","@angular/core","@angular/common","ionic-angular"],a):a(t["ion-universal-navbar"]={},t._color,t.ng.core,t.ng.common,t.ionicAngular)}(this,function(t,a,n,o,i){"use strict";var e=a,r=function(){function t(t){this.app=t,this.options={color:"#00FF00",pages:[],hide:!1,sidemenu:{heading:""},tabs:{layout:"icon-top",placement:"bottom",selectedIndex:0}},this.isFirstTabSelect=!0,this.appendStyles()}return t.prototype.ngOnInit=function(){this.hideModalOnBack()},t.prototype.hideModalOnBack=function(){var a=this;this.app.viewWillEnter.subscribe(function(t){a.lastView&&a.lastView.isOverlay&&a.lastView.dismiss(),a.lastView=t})},t.prototype.fixTabSelect=function(){var o=this;this.tabs.ionChange.subscribe(function(){if(o.isFirstTabSelect){o.isFirstTabSelect=!1;var t=o.tabs.getSelected();if(t&&t._views&&0<t._views.length){var a=t._views&&!(1<t._views.length),n=t.root!==t._views[0].id;a&&n&&t.setRoot(t.root)}}})},t.prototype.isDesktop=function(){return 768<window.innerWidth},t.prototype.toggleDrawer=function(){this.scrollLeft=!this.scrollLeft},t.prototype.appendStyles=function(){var t=document.createElement("style");t.id="ion-universal-navbar-colors",t.innerHTML="ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n "+this.getLinearGradient(this.options.color)+"\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid "+this.options.color+";\n }\n a.tab-button [aria-selected=true] {\n "+this.getLinearGradient(this.options.color)+"\n }\n }\n \n @media(max-width: 768px) {\n a.tab-button[aria-selected=true] .tab-button-icon,\n a.tab-button[aria-selected=true] .tab-button-text {\n color: "+this.options.color+";\n }\n }",document.querySelector("#ion-universal-navbar-colors")||document.head.appendChild(t)},t.prototype.getLinearGradient=function(t){var a=e(t).rotate(10).hex();return"background: "+t+";\n /* Old browsers */\n background: -moz-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* FF3.6+ */\n background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, "+t+"), color-stop(100%, "+a+"));\n /* Chrome,Safari4+ */\n background: -webkit-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* Chrome10+,Safari5.1+ */\n background: -o-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* Opera 11.10+ */\n background: -ms-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* IE10+ */\n background: linear-gradient(to bottom, "+t+" 0%, "+a+" 100%);\n /* W3C */\n filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='"+t+"', endColorstr='"+a+"', GradientType=0);\n /* IE6-9 */"},t.decorators=[{type:n.Component,args:[{selector:"ion-universal-navbar",template:'<nav [ngClass]="{ \'drawer\': isDesktop(), \'scroll-left\': scrollLeft}">\n <section (click)="toggleDrawer()" header text-center *ngIf="isDesktop()">\n <span title> {{options.sidemenu.heading}} </span>\n </section>\n <ion-tabs name="ion-universal-tabs" id="ion-universal-tabs" tabsHighlight="tabsHighlight" [tabsLayout]="options.tabs.layout"\n [tabsPlacement]="options.tabs.placement" [selectedIndex]="options.tabs.selectedIndex" #tabs [attr.hide]="options.hide">\n <ion-tab *ngFor="let tab of options.pages" [root]="tab.getRoot()" [rootParams]="tab.getRootParams()" [tabTitle]="tab.getTitle()"\n [tabUrlPath]="tab.getUrlPath()" [tabIcon]="tab.getIcon()" [tabBadge]="tab.getBadge()" [show]="tab.canShow()">\n </ion-tab>\n </ion-tabs>\n</nav>',encapsulation:n.ViewEncapsulation.None,styles:["ion-universal-navbar{height:auto;display:block;z-index:100}ion-universal-navbar .disable-navigation .tabbar *{pointer-events:none;opacity:.5}ion-universal-navbar .drawer{width:100vw;height:100vw}ion-universal-navbar .drawer [header]{height:calc(56px - 0px);width:calc(280px);font-size:16px;font-weight:400;color:#fff;padding-top:16px;border:none;cursor:pointer;position:absolute;z-index:999999;margin-bottom:-2px;margin-right:-2px;box-shadow:1px 1px 5px rgba(0,0,0,.2)}ion-universal-navbar .drawer [header] ion-icon{vertical-align:middle;font-size:20px;margin-left:5px}ion-universal-navbar .drawer [footer]{position:fixed;bottom:20px;max-width:280px}ion-universal-navbar .drawer [footer] [footer-text]{color:#efefef;width:280px;text-align:center}@media (min-width:768px){ion-universal-navbar ion-tabs.tabs ion-tab{left:calc(0px + 280px);max-width:calc(100vw - 280px);background-color:#fff}ion-universal-navbar ion-tabs.tabs ion-tab .scroll-content{margin-bottom:0}ion-universal-navbar ion-tabs.tabs ion-tab ion-title{text-align:center}ion-universal-navbar ion-tabs.tabs .tabbar.show-tabbar{display:block;max-width:280px;position:relative;top:56px;box-shadow:1px 2px 4px rgba(0,0,0,.4);height:100vh;background-color:#fff;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:10px}ion-universal-navbar ion-tabs.tabs .tabbar.show-tabbar *{transition-property:all;transition-duration:.25s}ion-universal-navbar ion-tabs.tabs a.tab-button{text-align:left;display:block;padding:5px 10px 10px;max-width:999px;border-radius:30px;background:#fff;margin-bottom:10px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-icon,ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-text{vertical-align:middle;color:#888;display:inline-block;margin-left:10px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-icon:before{font-size:27px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-text{padding:10px 10px 10px 0}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-badge{left:32px;top:12px;padding-top:2px}ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true]{padding:5px 10px 10px;font-weight:700;box-shadow:0 0 4px rgba(0,0,0,.4)}ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] ion-icon.tab-button-icon,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] span.tab-button-text{-webkit-transform:none;transform:none;color:#fff}ion-universal-navbar ion-tabs.tabs a.tab-button:hover,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true]{padding-left:75px;opacity:1}ion-universal-navbar ion-tabs.tabs a.tab-button:hover .tab-badge,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] .tab-badge{margin-left:66px}ion-universal-navbar ion-tabs.tabs a.tab-button.tab-hidden{display:none}}@media (max-width:768px){ion-universal-navbar ion-tabs .tabbar{transition-property:all;transition-duration:.35s}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-text{display:none}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-icon{color:rgba(0,0,0,.4)}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-icon:before{font-size:30px}ion-universal-navbar ion-tabs .tabbar .tab-badge{padding-top:3px;margin-top:16px;margin-right:16px}ion-universal-navbar ion-tabs[hide=true] .tabbar{margin-bottom:-100%}ion-universal-navbar ion-tabs[hide=true] ion-tab .fixed-content,ion-universal-navbar ion-tabs[hide=true] ion-tab .scroll-content{margin-bottom:0}}"]}]},{type:n.Injectable}],t.ctorParameters=function(){return[{type:i.App}]},t.propDecorators={options:[{type:n.Input,args:["options"]}],tabs:[{type:n.ViewChild,args:["tabs"]}]},t}(),b=function(){function t(){}return t.decorators=[{type:n.NgModule,args:[{imports:[o.CommonModule,i.IonicModule],declarations:[r],exports:[r]}]}],t}();t.IonUniversalNavbar=r,t.IonUniversalNavbarModule=b,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,a){"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("color"),require("@angular/core"),require("@angular/common"),require("ionic-angular")):"function"==typeof define&&define.amd?define("ion-universal-navbar",["exports","color","@angular/core","@angular/common","ionic-angular"],a):a(t["ion-universal-navbar"]={},t._color,t.ng.core,t.ng.common,t.ionicAngular)}(this,function(t,a,n,o,i){"use strict";var e=a,r=function(){function t(t){this.app=t,this.options={color:"#00FF00",pages:[],hide:!1,sidemenu:{heading:""},tabs:{layout:"icon-top",placement:"bottom",selectedIndex:0}},this.isFirstTabSelect=!0,this.appendStyles()}return t.prototype.ngOnInit=function(){this.hideModalOnBack()},t.prototype.hideModalOnBack=function(){var a=this;this.app.viewWillEnter.subscribe(function(t){a.lastView&&a.lastView.isOverlay&&a.lastView.dismiss(),a.lastView=t})},t.prototype.fixTabSelect=function(){var o=this;this.tabs.ionChange.subscribe(function(){if(o.isFirstTabSelect){o.isFirstTabSelect=!1;var t=o.tabs.getSelected();if(t&&t._views&&0<t._views.length){var a=t._views&&!(1<t._views.length),n=t.root!==t._views[0].id;a&&n&&t.setRoot(t.root)}}})},t.prototype.isDesktop=function(){return 768<window.innerWidth},t.prototype.toggleDrawer=function(){this.scrollLeft=!this.scrollLeft},t.prototype.appendStyles=function(){var t=document.createElement("style");t.id="ion-universal-navbar-colors",t.innerHTML="ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n "+this.getLinearGradient(this.options.color)+"\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid "+this.options.color+";\n }\n\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n "+this.getLinearGradient(this.options.color)+"\n }\n }\n \n @media(max-width: 768px) {\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n color: "+this.options.color+";\n }\n }",document.querySelector("#ion-universal-navbar-colors")||document.head.appendChild(t)},t.prototype.getLinearGradient=function(t){var a=e(t).rotate(10).hex();return"background: "+t+";\n /* Old browsers */\n background: -moz-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* FF3.6+ */\n background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, "+t+"), color-stop(100%, "+a+"));\n /* Chrome,Safari4+ */\n background: -webkit-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* Chrome10+,Safari5.1+ */\n background: -o-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* Opera 11.10+ */\n background: -ms-linear-gradient(top, "+t+" 0%, "+a+" 100%);\n /* IE10+ */\n background: linear-gradient(to bottom, "+t+" 0%, "+a+" 100%);\n /* W3C */\n filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='"+t+"', endColorstr='"+a+"', GradientType=0);\n /* IE6-9 */"},t.decorators=[{type:n.Component,args:[{selector:"ion-universal-navbar",template:'<nav [ngClass]="{ \'drawer\': isDesktop(), \'scroll-left\': scrollLeft}">\n <section (click)="toggleDrawer()" header text-center *ngIf="isDesktop()">\n <span title> {{options.sidemenu.heading}} </span>\n </section>\n <ion-tabs name="ion-universal-tabs" id="ion-universal-tabs" tabsHighlight="tabsHighlight" [tabsLayout]="options.tabs.layout"\n [tabsPlacement]="options.tabs.placement" [selectedIndex]="options.tabs.selectedIndex" #tabs [attr.hide]="options.hide">\n <ion-tab *ngFor="let tab of options.pages" [root]="tab.getRoot()" [rootParams]="tab.getRootParams()" [tabTitle]="tab.getTitle()"\n [tabUrlPath]="tab.getUrlPath()" [tabIcon]="tab.getIcon()" [tabBadge]="tab.getBadge()" [show]="tab.canShow()">\n </ion-tab>\n </ion-tabs>\n</nav>',encapsulation:n.ViewEncapsulation.None,styles:["ion-universal-navbar{height:auto;display:block;z-index:100}ion-universal-navbar .disable-navigation .tabbar *{pointer-events:none;opacity:.5}ion-universal-navbar .drawer{width:100vw;height:100vw}ion-universal-navbar .drawer [header]{height:calc(56px - 0px);width:calc(280px);font-size:16px;font-weight:400;color:#fff;padding-top:16px;border:none;cursor:pointer;position:absolute;z-index:999999;margin-bottom:-2px;margin-right:-2px;box-shadow:1px 1px 5px rgba(0,0,0,.2)}ion-universal-navbar .drawer [header] ion-icon{vertical-align:middle;font-size:20px;margin-left:5px}ion-universal-navbar .drawer [footer]{position:fixed;bottom:20px;max-width:280px}ion-universal-navbar .drawer [footer] [footer-text]{color:#efefef;width:280px;text-align:center}@media (min-width:768px){ion-universal-navbar ion-tabs.tabs ion-tab{left:calc(0px + 280px);max-width:calc(100vw - 280px);background-color:#fff}ion-universal-navbar ion-tabs.tabs ion-tab .scroll-content{margin-bottom:0}ion-universal-navbar ion-tabs.tabs ion-tab ion-title{text-align:center}ion-universal-navbar ion-tabs.tabs .tabbar.show-tabbar{display:block;max-width:280px;position:relative;top:56px;box-shadow:1px 2px 4px rgba(0,0,0,.4);height:100vh;background-color:#fff;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:10px}ion-universal-navbar ion-tabs.tabs .tabbar.show-tabbar *{transition-property:all;transition-duration:.25s}ion-universal-navbar ion-tabs.tabs a.tab-button{text-align:left;display:block;padding:5px 10px 10px;max-width:999px;border-radius:30px;background:#fff;margin-bottom:10px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-icon,ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-text{vertical-align:middle;color:#888;display:inline-block;margin-left:10px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-icon:before{font-size:27px}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-button-text{padding:10px 10px 10px 0}ion-universal-navbar ion-tabs.tabs a.tab-button .tab-badge{left:32px;top:12px;padding-top:2px}ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true]{padding:5px 10px 10px;font-weight:700;box-shadow:0 0 4px rgba(0,0,0,.4)}ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] ion-icon.tab-button-icon,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] span.tab-button-text{-webkit-transform:none;transform:none;color:#fff}ion-universal-navbar ion-tabs.tabs a.tab-button:hover,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true]{padding-left:75px;opacity:1}ion-universal-navbar ion-tabs.tabs a.tab-button:hover .tab-badge,ion-universal-navbar ion-tabs.tabs a.tab-button[aria-selected=true] .tab-badge{margin-left:66px}ion-universal-navbar ion-tabs.tabs a.tab-button.tab-hidden{display:none}}@media (max-width:768px){ion-universal-navbar ion-tabs .tabbar{transition-property:all;transition-duration:.35s}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-text{display:none}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-icon{color:rgba(0,0,0,.4)}ion-universal-navbar ion-tabs .tabbar .tab-button .tab-button-icon:before{font-size:30px}ion-universal-navbar ion-tabs .tabbar .tab-badge{padding-top:3px;margin-top:16px;margin-right:16px}ion-universal-navbar ion-tabs[hide=true] .tabbar{margin-bottom:-100%}ion-universal-navbar ion-tabs[hide=true] ion-tab .fixed-content,ion-universal-navbar ion-tabs[hide=true] ion-tab .scroll-content{margin-bottom:0}}"]}]},{type:n.Injectable}],t.ctorParameters=function(){return[{type:i.App}]},t.propDecorators={options:[{type:n.Input,args:["options"]}],tabs:[{type:n.ViewChild,args:["tabs"]}]},t}(),b=function(){function t(){}return t.decorators=[{type:n.NgModule,args:[{imports:[o.CommonModule,i.IonicModule],declarations:[r],exports:[r]}]}],t}();t.IonUniversalNavbar=r,t.IonUniversalNavbarModule=b,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ion-universal-navbar.umd.min.js.map |
@@ -105,3 +105,4 @@ /** | ||
} | ||
a.tab-button [aria-selected=true] { | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] { | ||
${this.getLinearGradient(this.options.color)} | ||
@@ -112,4 +113,4 @@ } | ||
@media(max-width: 768px) { | ||
a.tab-button[aria-selected=true] .tab-button-icon, | ||
a.tab-button[aria-selected=true] .tab-button-text { | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon, | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text { | ||
color: ${this.options.color}; | ||
@@ -180,2 +181,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ion-universal-navbar.component.js","sourceRoot":"ng://ion-universal-navbar/","sources":["lib/ion-universal-navbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license MIT\n * @version 1.1.0\n * @author Leonardo Quevedo\n * @description universal navbar component.\n */\n\n\nimport { Component, Input, ViewEncapsulation } from '@angular/core'\nimport { Injectable } from '@angular/core'\nimport { ViewChild } from '@angular/core'\n\nimport { App } from 'ionic-angular'\n\nimport * as _color from 'color'\n\nconst Color = _color\n\n@Component({\n    selector: 'ion-universal-navbar',\n    templateUrl: 'ion-universal-navbar.component.html',\n    styleUrls: ['ion-universal-navbar.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\n\n@Injectable()\nexport class IonUniversalNavbar {\n\n    @Input('options') options: any = {\n        color: '#00FF00',\n        pages: [],\n        hide: false,\n        sidemenu: { heading: '' },\n        tabs: {\n            layout: 'icon-top',\n            placement: 'bottom',\n            selectedIndex: 0\n        }\n    }\n\n    @ViewChild('tabs') tabs: any\n\n    isFirstTabSelect: boolean = true\n    scrollLeft: boolean\n    lastView: any\n\n    constructor(private app: App) {\n        this.appendStyles()\n     }\n\n    ngOnInit() {\n        this.hideModalOnBack()\n    }\n\n    hideModalOnBack() {\n        this.app.viewWillEnter.subscribe((view) => {\n            let closeModal = this.lastView && this.lastView.isOverlay\n            if (closeModal) this.lastView.dismiss()\n            this.lastView = view\n        })\n    }\n\n    fixTabSelect() {\n        this.tabs.ionChange.subscribe(() => {\n            if (!this.isFirstTabSelect) return\n            this.isFirstTabSelect = false\n            let selected = this.tabs.getSelected()\n            if (!selected || !selected._views || !(selected._views.length > 0)) return\n            let isRoot = selected._views && !(selected._views.length > 1)\n            let isWrongRoot = selected.root !== selected._views[0].id\n            if (isRoot && isWrongRoot) selected.setRoot(selected.root)\n        })\n    }\n\n    isDesktop() {\n        return window.innerWidth > 768\n    }\n\n    toggleDrawer() {\n        this.scrollLeft = !this.scrollLeft\n    }\n\n    appendStyles() {\n        let stylesElement = document.createElement('style')\n        stylesElement.id = 'ion-universal-navbar-colors'\n        stylesElement.innerHTML = `ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n        ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n        ion-universal-navbar [header] {\n            ${this.getLinearGradient(this.options.color)}\n        }\n        \n        @media(min-width: 768px) {\n            ion-navbar {\n                border-left: 1px solid ${this.options.color};\n            }\n            a.tab-button [aria-selected=true] {\n                ${this.getLinearGradient(this.options.color)}\n            }\n        }\n        \n        @media(max-width: 768px) {\n            a.tab-button[aria-selected=true] .tab-button-icon,\n            a.tab-button[aria-selected=true] .tab-button-text {\n                color: ${this.options.color};\n            }\n        }`\n        if (!document.querySelector('#ion-universal-navbar-colors')) document.head.appendChild(stylesElement)\n    }\n\n    getLinearGradient(color) {\n        let gradientBottom = Color(color).rotate(10).hex()\n\n        return `background: ${color};\n        /* Old browsers */\n        background: -moz-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* FF3.6+ */\n        background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, ${color}), color-stop(100%, ${gradientBottom}));\n        /* Chrome,Safari4+ */\n        background: -webkit-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Chrome10+,Safari5.1+ */\n        background: -o-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Opera 11.10+ */\n        background: -ms-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* IE10+ */\n        background: linear-gradient(to bottom, ${color} 0%, ${gradientBottom} 100%);\n        /* W3C */\n        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='${color}', endColorstr='${gradientBottom}', GradientType=0);\n        /* IE6-9 */`\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ion-universal-navbar.component.js","sourceRoot":"ng://ion-universal-navbar/","sources":["lib/ion-universal-navbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license MIT\n * @version 1.1.0\n * @author Leonardo Quevedo\n * @description universal navbar component.\n */\n\n\nimport { Component, Input, ViewEncapsulation } from '@angular/core'\nimport { Injectable } from '@angular/core'\nimport { ViewChild } from '@angular/core'\n\nimport { App } from 'ionic-angular'\n\nimport * as _color from 'color'\n\nconst Color = _color\n\n@Component({\n    selector: 'ion-universal-navbar',\n    templateUrl: 'ion-universal-navbar.component.html',\n    styleUrls: ['ion-universal-navbar.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\n\n@Injectable()\nexport class IonUniversalNavbar {\n\n    @Input('options') options: any = {\n        color: '#00FF00',\n        pages: [],\n        hide: false,\n        sidemenu: { heading: '' },\n        tabs: {\n            layout: 'icon-top',\n            placement: 'bottom',\n            selectedIndex: 0\n        }\n    }\n\n    @ViewChild('tabs') tabs: any\n\n    isFirstTabSelect: boolean = true\n    scrollLeft: boolean\n    lastView: any\n\n    constructor(private app: App) {\n        this.appendStyles()\n    }\n\n    ngOnInit() {\n        this.hideModalOnBack()\n    }\n\n    hideModalOnBack() {\n        this.app.viewWillEnter.subscribe((view) => {\n            let closeModal = this.lastView && this.lastView.isOverlay\n            if (closeModal) this.lastView.dismiss()\n            this.lastView = view\n        })\n    }\n\n    fixTabSelect() {\n        this.tabs.ionChange.subscribe(() => {\n            if (!this.isFirstTabSelect) return\n            this.isFirstTabSelect = false\n            let selected = this.tabs.getSelected()\n            if (!selected || !selected._views || !(selected._views.length > 0)) return\n            let isRoot = selected._views && !(selected._views.length > 1)\n            let isWrongRoot = selected.root !== selected._views[0].id\n            if (isRoot && isWrongRoot) selected.setRoot(selected.root)\n        })\n    }\n\n    isDesktop() {\n        return window.innerWidth > 768\n    }\n\n    toggleDrawer() {\n        this.scrollLeft = !this.scrollLeft\n    }\n\n    appendStyles() {\n        let stylesElement = document.createElement('style')\n        stylesElement.id = 'ion-universal-navbar-colors'\n        stylesElement.innerHTML = `ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n        ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n        ion-universal-navbar [header] {\n            ${this.getLinearGradient(this.options.color)}\n        }\n        \n        @media(min-width: 768px) {\n            ion-navbar {\n                border-left: 1px solid ${this.options.color};\n            }\n\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n                ${this.getLinearGradient(this.options.color)}\n            }\n        }\n        \n        @media(max-width: 768px) {\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n                color: ${this.options.color};\n            }\n        }`\n        if (!document.querySelector('#ion-universal-navbar-colors')) document.head.appendChild(stylesElement)\n    }\n\n    getLinearGradient(color) {\n        let gradientBottom = Color(color).rotate(10).hex()\n\n        return `background: ${color};\n        /* Old browsers */\n        background: -moz-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* FF3.6+ */\n        background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, ${color}), color-stop(100%, ${gradientBottom}));\n        /* Chrome,Safari4+ */\n        background: -webkit-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Chrome10+,Safari5.1+ */\n        background: -o-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Opera 11.10+ */\n        background: -ms-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* IE10+ */\n        background: linear-gradient(to bottom, ${color} 0%, ${gradientBottom} 100%);\n        /* W3C */\n        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='${color}', endColorstr='${gradientBottom}', GradientType=0);\n        /* IE6-9 */`\n    }\n}\n"]} |
@@ -112,3 +112,3 @@ /** | ||
stylesElement.id = 'ion-universal-navbar-colors'; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n a.tab-button [aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n a.tab-button[aria-selected=true] .tab-button-icon,\n a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
if (!document.querySelector('#ion-universal-navbar-colors')) | ||
@@ -167,2 +167,2 @@ document.head.appendChild(stylesElement); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ion-universal-navbar.component.js","sourceRoot":"ng://ion-universal-navbar/","sources":["lib/ion-universal-navbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license MIT\n * @version 1.1.0\n * @author Leonardo Quevedo\n * @description universal navbar component.\n */\n\n\nimport { Component, Input, ViewEncapsulation } from '@angular/core'\nimport { Injectable } from '@angular/core'\nimport { ViewChild } from '@angular/core'\n\nimport { App } from 'ionic-angular'\n\nimport * as _color from 'color'\n\nconst Color = _color\n\n@Component({\n    selector: 'ion-universal-navbar',\n    templateUrl: 'ion-universal-navbar.component.html',\n    styleUrls: ['ion-universal-navbar.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\n\n@Injectable()\nexport class IonUniversalNavbar {\n\n    @Input('options') options: any = {\n        color: '#00FF00',\n        pages: [],\n        hide: false,\n        sidemenu: { heading: '' },\n        tabs: {\n            layout: 'icon-top',\n            placement: 'bottom',\n            selectedIndex: 0\n        }\n    }\n\n    @ViewChild('tabs') tabs: any\n\n    isFirstTabSelect: boolean = true\n    scrollLeft: boolean\n    lastView: any\n\n    constructor(private app: App) {\n        this.appendStyles()\n     }\n\n    ngOnInit() {\n        this.hideModalOnBack()\n    }\n\n    hideModalOnBack() {\n        this.app.viewWillEnter.subscribe((view) => {\n            let closeModal = this.lastView && this.lastView.isOverlay\n            if (closeModal) this.lastView.dismiss()\n            this.lastView = view\n        })\n    }\n\n    fixTabSelect() {\n        this.tabs.ionChange.subscribe(() => {\n            if (!this.isFirstTabSelect) return\n            this.isFirstTabSelect = false\n            let selected = this.tabs.getSelected()\n            if (!selected || !selected._views || !(selected._views.length > 0)) return\n            let isRoot = selected._views && !(selected._views.length > 1)\n            let isWrongRoot = selected.root !== selected._views[0].id\n            if (isRoot && isWrongRoot) selected.setRoot(selected.root)\n        })\n    }\n\n    isDesktop() {\n        return window.innerWidth > 768\n    }\n\n    toggleDrawer() {\n        this.scrollLeft = !this.scrollLeft\n    }\n\n    appendStyles() {\n        let stylesElement = document.createElement('style')\n        stylesElement.id = 'ion-universal-navbar-colors'\n        stylesElement.innerHTML = `ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n        ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n        ion-universal-navbar [header] {\n            ${this.getLinearGradient(this.options.color)}\n        }\n        \n        @media(min-width: 768px) {\n            ion-navbar {\n                border-left: 1px solid ${this.options.color};\n            }\n            a.tab-button [aria-selected=true] {\n                ${this.getLinearGradient(this.options.color)}\n            }\n        }\n        \n        @media(max-width: 768px) {\n            a.tab-button[aria-selected=true] .tab-button-icon,\n            a.tab-button[aria-selected=true] .tab-button-text {\n                color: ${this.options.color};\n            }\n        }`\n        if (!document.querySelector('#ion-universal-navbar-colors')) document.head.appendChild(stylesElement)\n    }\n\n    getLinearGradient(color) {\n        let gradientBottom = Color(color).rotate(10).hex()\n\n        return `background: ${color};\n        /* Old browsers */\n        background: -moz-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* FF3.6+ */\n        background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, ${color}), color-stop(100%, ${gradientBottom}));\n        /* Chrome,Safari4+ */\n        background: -webkit-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Chrome10+,Safari5.1+ */\n        background: -o-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Opera 11.10+ */\n        background: -ms-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* IE10+ */\n        background: linear-gradient(to bottom, ${color} 0%, ${gradientBottom} 100%);\n        /* W3C */\n        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='${color}', endColorstr='${gradientBottom}', GradientType=0);\n        /* IE6-9 */`\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ion-universal-navbar.component.js","sourceRoot":"ng://ion-universal-navbar/","sources":["lib/ion-universal-navbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license MIT\n * @version 1.1.0\n * @author Leonardo Quevedo\n * @description universal navbar component.\n */\n\n\nimport { Component, Input, ViewEncapsulation } from '@angular/core'\nimport { Injectable } from '@angular/core'\nimport { ViewChild } from '@angular/core'\n\nimport { App } from 'ionic-angular'\n\nimport * as _color from 'color'\n\nconst Color = _color\n\n@Component({\n    selector: 'ion-universal-navbar',\n    templateUrl: 'ion-universal-navbar.component.html',\n    styleUrls: ['ion-universal-navbar.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\n\n@Injectable()\nexport class IonUniversalNavbar {\n\n    @Input('options') options: any = {\n        color: '#00FF00',\n        pages: [],\n        hide: false,\n        sidemenu: { heading: '' },\n        tabs: {\n            layout: 'icon-top',\n            placement: 'bottom',\n            selectedIndex: 0\n        }\n    }\n\n    @ViewChild('tabs') tabs: any\n\n    isFirstTabSelect: boolean = true\n    scrollLeft: boolean\n    lastView: any\n\n    constructor(private app: App) {\n        this.appendStyles()\n    }\n\n    ngOnInit() {\n        this.hideModalOnBack()\n    }\n\n    hideModalOnBack() {\n        this.app.viewWillEnter.subscribe((view) => {\n            let closeModal = this.lastView && this.lastView.isOverlay\n            if (closeModal) this.lastView.dismiss()\n            this.lastView = view\n        })\n    }\n\n    fixTabSelect() {\n        this.tabs.ionChange.subscribe(() => {\n            if (!this.isFirstTabSelect) return\n            this.isFirstTabSelect = false\n            let selected = this.tabs.getSelected()\n            if (!selected || !selected._views || !(selected._views.length > 0)) return\n            let isRoot = selected._views && !(selected._views.length > 1)\n            let isWrongRoot = selected.root !== selected._views[0].id\n            if (isRoot && isWrongRoot) selected.setRoot(selected.root)\n        })\n    }\n\n    isDesktop() {\n        return window.innerWidth > 768\n    }\n\n    toggleDrawer() {\n        this.scrollLeft = !this.scrollLeft\n    }\n\n    appendStyles() {\n        let stylesElement = document.createElement('style')\n        stylesElement.id = 'ion-universal-navbar-colors'\n        stylesElement.innerHTML = `ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n        ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n        ion-universal-navbar [header] {\n            ${this.getLinearGradient(this.options.color)}\n        }\n        \n        @media(min-width: 768px) {\n            ion-navbar {\n                border-left: 1px solid ${this.options.color};\n            }\n\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n                ${this.getLinearGradient(this.options.color)}\n            }\n        }\n        \n        @media(max-width: 768px) {\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n            ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n                color: ${this.options.color};\n            }\n        }`\n        if (!document.querySelector('#ion-universal-navbar-colors')) document.head.appendChild(stylesElement)\n    }\n\n    getLinearGradient(color) {\n        let gradientBottom = Color(color).rotate(10).hex()\n\n        return `background: ${color};\n        /* Old browsers */\n        background: -moz-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* FF3.6+ */\n        background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, ${color}), color-stop(100%, ${gradientBottom}));\n        /* Chrome,Safari4+ */\n        background: -webkit-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Chrome10+,Safari5.1+ */\n        background: -o-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* Opera 11.10+ */\n        background: -ms-linear-gradient(top, ${color} 0%, ${gradientBottom} 100%);\n        /* IE10+ */\n        background: linear-gradient(to bottom, ${color} 0%, ${gradientBottom} 100%);\n        /* W3C */\n        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='${color}', endColorstr='${gradientBottom}', GradientType=0);\n        /* IE6-9 */`\n    }\n}\n"]} |
@@ -99,3 +99,4 @@ import * as _color from 'color'; | ||
} | ||
a.tab-button [aria-selected=true] { | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] { | ||
${this.getLinearGradient(this.options.color)} | ||
@@ -106,4 +107,4 @@ } | ||
@media(max-width: 768px) { | ||
a.tab-button[aria-selected=true] .tab-button-icon, | ||
a.tab-button[aria-selected=true] .tab-button-text { | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon, | ||
ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text { | ||
color: ${this.options.color}; | ||
@@ -110,0 +111,0 @@ } |
@@ -106,3 +106,3 @@ import * as _color from 'color'; | ||
stylesElement.id = 'ion-universal-navbar-colors'; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n a.tab-button [aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n a.tab-button[aria-selected=true] .tab-button-icon,\n a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
stylesElement.innerHTML = "ion-navbar[color=primary] .toolbar-background.toolbar-background-md,\n ion-navbar[color=primary] .toolbar-background.toolbar-background-ios,\n ion-universal-navbar [header] {\n " + this.getLinearGradient(this.options.color) + "\n }\n \n @media(min-width: 768px) {\n ion-navbar {\n border-left: 1px solid " + this.options.color + ";\n }\n\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] {\n " + this.getLinearGradient(this.options.color) + "\n }\n }\n \n @media(max-width: 768px) {\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-icon,\n ion-tabs.tabs .tabbar a.tab-button[aria-selected=true] .tab-button-text {\n color: " + this.options.color + ";\n }\n }"; | ||
if (!document.querySelector('#ion-universal-navbar-colors')) | ||
@@ -109,0 +109,0 @@ document.head.appendChild(stylesElement); |
{ | ||
"name": "ion-universal-navbar", | ||
"version": "0.9.8-rc1", | ||
"version": "0.9.8-rc2", | ||
"description": "Simple authentication state handler for Angular.io.", | ||
@@ -5,0 +5,0 @@ "main": "bundles/ion-universal-navbar.umd.js", |
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
130092
1077