123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- 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}
- */
- export class Navbar extends ToolbarBase {
- constructor(_app, viewCtrl, navCtrl, config, elementRef, renderer) {
- super(config, elementRef, renderer);
- 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');
- }
- /**
- * @input {boolean} If true, the back button will be hidden.
- */
- get hideBackButton() {
- return this._hideBb;
- }
- set hideBackButton(val) {
- this._hideBb = isTrueProperty(val);
- }
- backButtonClick(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".
- */
- setBackButtonText(text) {
- this._backText = text;
- }
- /**
- * @hidden
- */
- didEnter() {
- try {
- this._app.setTitle(this.getTitleText());
- }
- catch (e) {
- console.error(e);
- }
- }
- /**
- * @hidden
- */
- setHidden(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 = () => [
- { type: App, },
- { type: ViewController, decorators: [{ type: Optional },] },
- { type: NavController, decorators: [{ type: Optional },] },
- { type: Config, },
- { type: ElementRef, },
- { type: Renderer, },
- ];
- Navbar.propDecorators = {
- 'hideBackButton': [{ type: Input },],
- };
- //# sourceMappingURL=navbar.js.map
|