UNPKG

ionic-angular

Version:

A powerful framework for building mobile and progressive web apps with JavaScript and Angular

164 lines 6.83 kB
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 __()); }; })(); (function (factory) { if (typeof module === "object" && typeof module.exports === "object") { var v = factory(require, exports); if (v !== undefined) module.exports = v; } else if (typeof define === "function" && define.amd) { define(["require", "exports", "@angular/core", "../app/app", "../../config/config", "../../util/util", "../../navigation/nav-controller", "./toolbar-base", "../../navigation/view-controller"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var core_1 = require("@angular/core"); var app_1 = require("../app/app"); var config_1 = require("../../config/config"); var util_1 = require("../../util/util"); var nav_controller_1 = require("../../navigation/nav-controller"); var toolbar_base_1 = require("./toolbar-base"); var view_controller_1 = require("../../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 = util_1.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: core_1.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_1.App, }, { type: view_controller_1.ViewController, decorators: [{ type: core_1.Optional },] }, { type: nav_controller_1.NavController, decorators: [{ type: core_1.Optional },] }, { type: config_1.Config, }, { type: core_1.ElementRef, }, { type: core_1.Renderer, }, ]; }; Navbar.propDecorators = { 'hideBackButton': [{ type: core_1.Input },], }; return Navbar; }(toolbar_base_1.ToolbarBase)); exports.Navbar = Navbar; }); //# sourceMappingURL=navbar.js.map