UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

156 lines 14.2 kB
var IgxNavbarComponent_1; import { __decorate, __metadata } from "tslib"; import { CommonModule } from '@angular/common'; import { Component, EventEmitter, HostBinding, Input, NgModule, Output, Directive, ContentChild } from '@angular/core'; import { IgxButtonModule } from '../directives/button/button.directive'; import { IgxIconModule } from '../icon/index'; /** * IgxActionIcon is a container for the action nav icon of the IgxNavbar. */ let IgxActionIconDirective = class IgxActionIconDirective { }; IgxActionIconDirective = __decorate([ Directive({ // tslint:disable-next-line:directive-selector selector: 'igx-action-icon' }) ], IgxActionIconDirective); export { IgxActionIconDirective }; let NEXT_ID = 0; /** * **Ignite UI for Angular Navbar** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/navbar.html) * * The Ignite UI Navbar is most commonly used to provide an app header with a hamburger menu and navigation * state such as a "Go Back" button. It also supports other actions represented by icons. * * Example: * ```html * <igx-navbar title="Sample App" actionButtonIcon="menu"> * <igx-icon>search</igx-icon> * <igx-icon>favorite</igx-icon> * <igx-icon>more_vert</igx-icon> * </igx-navbar> * ``` */ let IgxNavbarComponent = IgxNavbarComponent_1 = class IgxNavbarComponent { constructor() { this.isVisible = true; /** *An @Input property that sets the value of the `id` attribute. If not provided it will be automatically generated. *```html *<igx-navbar [id]="'igx-navbar-12'" title="Sample App" actionButtonIcon="menu"> *``` */ this.id = `igx-navbar-${NEXT_ID++}`; /** *The event that will be thrown when the action is executed, *provides reference to the `IgxNavbar` component as argument *```typescript *public actionExc(event){ * alert("Action Execute!"); *} * //.. *``` *```html *<igx-navbar (onAction)="actionExc($event)" title="Sample App" actionButtonIcon="menu"> *``` */ this.onAction = new EventEmitter(); /** *An @Input property that sets the titleId of the `IgxNavbarComponent`. If not set it will be automatically generated. *```html *<igx-navbar [titleId]="'igx-navbar-7'" title="Sample App" actionButtonIcon="menu"> *``` */ this.titleId = `igx-navbar-${IgxNavbarComponent_1.NEXT_ID++}`; } /** *Returns whether the `IgxNavbarComponent` action button is visible, true/false. *```typescript *@ViewChild("MyChild") *public navBar: IgxNavbarComponent; *ngAfterViewInit(){ * let actionButtonVisibile = this.navBar.isActionButtonVisible; *} *``` */ get isActionButtonVisible() { if (this.actionIconTemplate || !this.actionButtonIcon) { return false; } return this.isVisible; } /** *Sets whether the action button of the `IgxNavbarComponent` is visible. *```html *<igx-navbar [title]="currentView" [isActionButtonVisible]="'false'"></igx-navbar> *``` */ set isActionButtonVisible(value) { this.isVisible = value; } /** *@hidden */ _triggerAction() { this.onAction.emit(this); } }; IgxNavbarComponent.NEXT_ID = 1; __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxNavbarComponent.prototype, "id", void 0); __decorate([ Input(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxNavbarComponent.prototype, "isActionButtonVisible", null); __decorate([ Input(), __metadata("design:type", String) ], IgxNavbarComponent.prototype, "actionButtonIcon", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxNavbarComponent.prototype, "title", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxNavbarComponent.prototype, "onAction", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxNavbarComponent.prototype, "titleId", void 0); __decorate([ ContentChild(IgxActionIconDirective, { read: IgxActionIconDirective }), __metadata("design:type", IgxActionIconDirective) ], IgxNavbarComponent.prototype, "actionIconTemplate", void 0); IgxNavbarComponent = IgxNavbarComponent_1 = __decorate([ Component({ selector: 'igx-navbar', template: "<nav class=\"igx-navbar\" role=\"navigation\" [attr.aria-labelledby]=\"titleId\">\n <div class=\"igx-navbar__left\">\n <igx-icon (click)=\"_triggerAction()\" fontSet=\"material\" *ngIf=\"isActionButtonVisible\">{{actionButtonIcon}}</igx-icon>\n <ng-content select=\"igx-action-icon\"></ng-content>\n <h1 class=\"igx-navbar__title\" [attr.id]=\"titleId\">{{ title }}</h1>\n </div>\n <div class=\"igx-navbar__right\">\n <ng-content></ng-content>\n </div>\n</nav>\n", styles: [` :host { display: block; } `] }) ], IgxNavbarComponent); export { IgxNavbarComponent }; /** * @hidden */ let IgxNavbarModule = class IgxNavbarModule { }; IgxNavbarModule = __decorate([ NgModule({ declarations: [IgxNavbarComponent, IgxActionIconDirective], exports: [IgxNavbarComponent, IgxActionIconDirective], imports: [IgxButtonModule, IgxIconModule, CommonModule] }) ], IgxNavbarModule); export { IgxNavbarModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navbar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/navbar/navbar.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,SAAS,EACT,YAAY,EACZ,WAAW,EACX,KAAK,EACL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,YAAY,EACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAE9C;;GAEG;AAKH,IAAa,sBAAsB,GAAnC,MAAa,sBAAsB;CAAI,CAAA;AAA1B,sBAAsB;IAJlC,SAAS,CAAC;QACP,8CAA8C;QAC9C,QAAQ,EAAE,iBAAiB;KAC9B,CAAC;GACW,sBAAsB,CAAI;SAA1B,sBAAsB;AAEnC,IAAI,OAAO,GAAG,CAAC,CAAC;AAChB;;;;;;;;;;;;;;;GAeG;AAaH,IAAa,kBAAkB,0BAA/B,MAAa,kBAAkB;IAA/B;QAEY,cAAS,GAAG,IAAI,CAAC;QAEzB;;;;;WAKG;QAGI,OAAE,GAAG,cAAc,OAAO,EAAE,EAAE,CAAC;QA4CtC;;;;;;;;;;;;WAYG;QACc,aAAQ,GAAG,IAAI,YAAY,EAAsB,CAAC;QAEnE;;;;;WAKG;QAEI,YAAO,GAAG,cAAc,oBAAkB,CAAC,OAAO,EAAE,EAAE,CAAC;IAclE,CAAC;IA/EG;;;;;;;;;OASG;IAEH,IAAW,qBAAqB;QAC5B,IAAI,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACnD,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;;;;OAKG;IACH,IAAW,qBAAqB,CAAC,KAAc;QAC3C,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IA+CD;;OAEG;IACI,cAAc;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;CACJ,CAAA;AA3FkB,0BAAO,GAAG,CAAC,CAAC;AAW3B;IAFC,WAAW,CAAC,SAAS,CAAC;IACtB,KAAK,EAAE;;8CAC8B;AAYtC;IADC,KAAK,EAAE;;;+DAMP;AAiBQ;IAAR,KAAK,EAAE;;4DAAiC;AAQhC;IAAR,KAAK,EAAE;;iDAAsB;AAepB;IAAT,MAAM,EAAE;;oDAA0D;AASnE;IADC,KAAK,EAAE;;mDACsD;AAM9D;IADC,YAAY,CAAC,sBAAsB,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC;8BACzC,sBAAsB;8DAAC;AApF5C,kBAAkB;IAX9B,SAAS,CAAC;QACP,QAAQ,EAAE,YAAY;QACtB,kgBAAoC;iBAC3B;;;;KAIR;KAEJ,CAAC;GAEW,kBAAkB,CA4F9B;SA5FY,kBAAkB;AA8F/B;;GAEG;AAMH,IAAa,eAAe,GAA5B,MAAa,eAAe;CAC3B,CAAA;AADY,eAAe;IAL3B,QAAQ,CAAC;QACN,YAAY,EAAE,CAAC,kBAAkB,EAAE,sBAAsB,CAAC;QAC1D,OAAO,EAAE,CAAC,kBAAkB,EAAE,sBAAsB,CAAC;QACrD,OAAO,EAAE,CAAC,eAAe,EAAE,aAAa,EAAE,YAAY,CAAC;KAC1D,CAAC;GACW,eAAe,CAC3B;SADY,eAAe","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgModule,\n    Output,\n    Directive,\n    ContentChild\n} from '@angular/core';\nimport { IgxButtonModule } from '../directives/button/button.directive';\nimport { IgxIconModule } from '../icon/index';\n\n/**\n * IgxActionIcon is a container for the action nav icon of the IgxNavbar.\n */\n@Directive({\n    // tslint:disable-next-line:directive-selector\n    selector: 'igx-action-icon'\n})\nexport class IgxActionIconDirective { }\n\nlet NEXT_ID = 0;\n/**\n * **Ignite UI for Angular Navbar** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/navbar.html)\n *\n * The Ignite UI Navbar is most commonly used to provide an app header with a hamburger menu and navigation\n * state such as a \"Go Back\" button. It also supports other actions represented by icons.\n *\n * Example:\n * ```html\n * <igx-navbar title=\"Sample App\" actionButtonIcon=\"menu\">\n *   <igx-icon>search</igx-icon>\n *   <igx-icon>favorite</igx-icon>\n *   <igx-icon>more_vert</igx-icon>\n * </igx-navbar>\n * ```\n */\n\n@Component({\n    selector: 'igx-navbar',\n    templateUrl: 'navbar.component.html',\n    styles: [`\n        :host {\n            display: block;\n        }\n    `\n    ]\n})\n\nexport class IgxNavbarComponent {\n    private static NEXT_ID = 1;\n    private isVisible = true;\n\n    /**\n     *An @Input property that sets the value of the `id` attribute. If not provided it will be automatically generated.\n     *```html\n     *<igx-navbar [id]=\"'igx-navbar-12'\" title=\"Sample App\" actionButtonIcon=\"menu\">\n     *```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-navbar-${NEXT_ID++}`;\n    /**\n     *Returns whether the `IgxNavbarComponent` action button is visible, true/false.\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *public navBar: IgxNavbarComponent;\n     *ngAfterViewInit(){\n     *    let actionButtonVisibile = this.navBar.isActionButtonVisible;\n     *}\n     *```\n     */\n    @Input()\n    public get isActionButtonVisible(): boolean {\n        if (this.actionIconTemplate || !this.actionButtonIcon) {\n            return false;\n        }\n        return this.isVisible;\n    }\n\n    /**\n     *Sets whether the action button of the `IgxNavbarComponent` is visible.\n     *```html\n     *<igx-navbar [title]=\"currentView\" [isActionButtonVisible]=\"'false'\"></igx-navbar>\n     *```\n     */\n    public set isActionButtonVisible(value: boolean) {\n        this.isVisible = value;\n    }\n    /**\n     *An @Input property that sets the icon of the `IgxNavbarComponent`.\n     *```html\n     *<igx-navbar [title]=\"currentView\" actionButtonIcon=\"arrow_back\"></igx-navbar>\n     *```\n     */\n    @Input() public actionButtonIcon: string;\n\n    /**\n     *An @Input property that sets the title of the `IgxNavbarComponent`.\n     *```html\n     *<igx-navbar title=\"Sample App\" actionButtonIcon=\"menu\">\n     *```\n     */\n    @Input() public title: string;\n\n    /**\n     *The event that will be thrown when the action is executed,\n     *provides reference to the `IgxNavbar` component as argument\n     *```typescript\n     *public actionExc(event){\n     *    alert(\"Action Execute!\");\n     *}\n     * //..\n     *```\n     *```html\n     *<igx-navbar (onAction)=\"actionExc($event)\" title=\"Sample App\" actionButtonIcon=\"menu\">\n     *```\n     */\n    @Output() public onAction = new EventEmitter<IgxNavbarComponent>();\n\n    /**\n     *An @Input property that sets the titleId of the `IgxNavbarComponent`. If not set it will be automatically generated.\n     *```html\n     *<igx-navbar [titleId]=\"'igx-navbar-7'\" title=\"Sample App\" actionButtonIcon=\"menu\">\n     *```\n     */\n    @Input()\n    public titleId = `igx-navbar-${IgxNavbarComponent.NEXT_ID++}`;\n\n    /**\n     * @hidden\n     */\n    @ContentChild(IgxActionIconDirective, { read: IgxActionIconDirective })\n    protected actionIconTemplate: IgxActionIconDirective;\n\n    /**\n     *@hidden\n     */\n    public _triggerAction() {\n        this.onAction.emit(this);\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxNavbarComponent, IgxActionIconDirective],\n    exports: [IgxNavbarComponent, IgxActionIconDirective],\n    imports: [IgxButtonModule, IgxIconModule, CommonModule]\n})\nexport class IgxNavbarModule {\n}\n"]}