ionic-angular
Version:
A powerful framework for building mobile and progressive web apps with JavaScript and Angular
152 lines • 5.59 kB
JavaScript
var __extends = (this && this.__extends) || (function () {
var extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
import { Component, ElementRef, Input, Optional, Renderer } from '@angular/core';
import { App } from '../app/app';
import { Config } from '../../config/config';
import { isTrueProperty } from '../../util/util';
import { NavController } from '../../navigation/nav-controller';
import { ToolbarBase } from './toolbar-base';
import { ViewController } from '../../navigation/view-controller';
/**
* @name Navbar
* @description
* Navbar acts as the navigational toolbar, which also comes with a back
* button. A navbar can contain a `ion-title`, any number of buttons,
* a segment, or a searchbar. Navbars must be placed within an
* `<ion-header>` in order for them to be placed above the content.
* It's important to note that navbar's are part of the dynamic navigation
* stack. If you need a static toolbar, use ion-toolbar.
*
* @usage
* ```html
* <ion-header>
*
* <ion-navbar>
* <button ion-button icon-only menuToggle>
* <ion-icon name="menu"></ion-icon>
* </button>
*
* <ion-title>
* Page Title
* </ion-title>
*
* <ion-buttons end>
* <button ion-button icon-only (click)="openModal()">
* <ion-icon name="options"></ion-icon>
* </button>
* </ion-buttons>
* </ion-navbar>
*
* </ion-header>
* ```
*
* @demo /docs/demos/src/navbar/
* @see {@link ../../toolbar/Toolbar/ Toolbar API Docs}
*/
var Navbar = (function (_super) {
__extends(Navbar, _super);
function Navbar(_app, viewCtrl, navCtrl, config, elementRef, renderer) {
var _this = _super.call(this, config, elementRef, renderer) || this;
_this._app = _app;
_this.navCtrl = navCtrl;
/**
* @hidden
*/
_this._hidden = false;
/**
* @hidden
*/
_this._hideBb = false;
viewCtrl && viewCtrl._setNavbar(_this);
_this._bbIcon = config.get('backButtonIcon');
_this._sbPadding = config.getBoolean('statusbarPadding');
_this._backText = config.get('backButtonText', 'Back');
return _this;
}
Object.defineProperty(Navbar.prototype, "hideBackButton", {
/**
* @input {boolean} If true, the back button will be hidden.
*/
get: function () {
return this._hideBb;
},
set: function (val) {
this._hideBb = isTrueProperty(val);
},
enumerable: true,
configurable: true
});
Navbar.prototype.backButtonClick = function (ev) {
ev.preventDefault();
ev.stopPropagation();
this.navCtrl && this.navCtrl.pop(null, null);
};
/**
* Set the text of the Back Button in the Nav Bar. Defaults to "Back".
*/
Navbar.prototype.setBackButtonText = function (text) {
this._backText = text;
};
/**
* @hidden
*/
Navbar.prototype.didEnter = function () {
try {
this._app.setTitle(this.getTitleText());
}
catch (e) {
console.error(e);
}
};
/**
* @hidden
*/
Navbar.prototype.setHidden = function (isHidden) {
// used to display none/block the navbar
this._hidden = isHidden;
};
Navbar.decorators = [
{ type: Component, args: [{
selector: 'ion-navbar',
template: '<div class="toolbar-background" [ngClass]="\'toolbar-background-\' + _mode"></div>' +
'<button (click)="backButtonClick($event)" ion-button="bar-button" class="back-button" [ngClass]="\'back-button-\' + _mode" [hidden]="_hideBb">' +
'<ion-icon class="back-button-icon" [ngClass]="\'back-button-icon-\' + _mode" [name]="_bbIcon"></ion-icon>' +
'<span class="back-button-text" [ngClass]="\'back-button-text-\' + _mode">{{_backText}}</span>' +
'</button>' +
'<ng-content select="[menuToggle],ion-buttons[left]"></ng-content>' +
'<ng-content select="ion-buttons[start]"></ng-content>' +
'<ng-content select="ion-buttons[end],ion-buttons[right]"></ng-content>' +
'<div class="toolbar-content" [ngClass]="\'toolbar-content-\' + _mode">' +
'<ng-content></ng-content>' +
'</div>',
host: {
'[hidden]': '_hidden',
'class': 'toolbar',
'[class.statusbar-padding]': '_sbPadding'
}
},] },
];
/** @nocollapse */
Navbar.ctorParameters = function () { return [
{ type: App, },
{ type: ViewController, decorators: [{ type: Optional },] },
{ type: NavController, decorators: [{ type: Optional },] },
{ type: Config, },
{ type: ElementRef, },
{ type: Renderer, },
]; };
Navbar.propDecorators = {
'hideBackButton': [{ type: Input },],
};
return Navbar;
}(ToolbarBase));
export { Navbar };
//# sourceMappingURL=navbar.js.map