UNPKG

@catull/igniteui-angular

Version:

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

164 lines 14.9 kB
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. */ var IgxActionIconDirective = /** @class */ (function () { function IgxActionIconDirective() { } IgxActionIconDirective = __decorate([ Directive({ // tslint:disable-next-line:directive-selector selector: 'igx-action-icon' }) ], IgxActionIconDirective); return IgxActionIconDirective; }()); export { IgxActionIconDirective }; var 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> * ``` */ var IgxNavbarComponent = /** @class */ (function () { function IgxNavbarComponent() { 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++; } IgxNavbarComponent_1 = IgxNavbarComponent; Object.defineProperty(IgxNavbarComponent.prototype, "isActionButtonVisible", { /** *Returns whether the `IgxNavbarComponent` action button is visible, true/false. *```typescript *@ViewChild("MyChild") *public navBar: IgxNavbarComponent; *ngAfterViewInit(){ * let actionButtonVisibile = this.navBar.isActionButtonVisible; *} *``` */ get: function () { 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: function (value) { this.isVisible = value; }, enumerable: true, configurable: true }); /** *@hidden */ IgxNavbarComponent.prototype._triggerAction = function () { this.onAction.emit(this); }; var IgxNavbarComponent_1; 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: ["\n :host {\n display: block;\n }\n "] }) ], IgxNavbarComponent); return IgxNavbarComponent; }()); export { IgxNavbarComponent }; /** * @hidden */ var IgxNavbarModule = /** @class */ (function () { function IgxNavbarModule() { } IgxNavbarModule = __decorate([ NgModule({ declarations: [IgxNavbarComponent, IgxActionIconDirective], exports: [IgxNavbarComponent, IgxActionIconDirective], imports: [IgxButtonModule, IgxIconModule, CommonModule] }) ], IgxNavbarModule); return 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;IAAsC,CAAC;IAA1B,sBAAsB;QAJlC,SAAS,CAAC;YACP,8CAA8C;YAC9C,QAAQ,EAAE,iBAAiB;SAC9B,CAAC;OACW,sBAAsB,CAAI;IAAD,6BAAC;CAAA,AAAvC,IAAuC;SAA1B,sBAAsB;AAEnC,IAAI,OAAO,GAAG,CAAC,CAAC;AAChB;;;;;;;;;;;;;;;GAeG;AAaH;IAAA;QAEY,cAAS,GAAG,IAAI,CAAC;QAEzB;;;;;WAKG;QAGI,OAAE,GAAG,gBAAc,OAAO,EAAI,CAAC;QA4CtC;;;;;;;;;;;;WAYG;QACc,aAAQ,GAAG,IAAI,YAAY,EAAsB,CAAC;QAEnE;;;;;WAKG;QAEI,YAAO,GAAG,gBAAc,oBAAkB,CAAC,OAAO,EAAI,CAAC;IAclE,CAAC;2BA5FY,kBAAkB;IAwB3B,sBAAW,qDAAqB;QAXhC;;;;;;;;;WASG;aAEH;YACI,IAAI,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;gBACnD,OAAO,KAAK,CAAC;aAChB;YACD,OAAO,IAAI,CAAC,SAAS,CAAC;QAC1B,CAAC;QAED;;;;;WAKG;aACH,UAAiC,KAAc;YAC3C,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAC3B,CAAC;;;OAVA;IAyDD;;OAEG;IACI,2CAAc,GAArB;QACI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;IA1Fc,0BAAO,GAAG,CAAC,CAAC;IAW3B;QAFC,WAAW,CAAC,SAAS,CAAC;QACtB,KAAK,EAAE;;kDAC8B;IAYtC;QADC,KAAK,EAAE;;;mEAMP;IAiBQ;QAAR,KAAK,EAAE;;gEAAiC;IAQhC;QAAR,KAAK,EAAE;;qDAAsB;IAepB;QAAT,MAAM,EAAE;;wDAA0D;IASnE;QADC,KAAK,EAAE;;uDACsD;IAM9D;QADC,YAAY,CAAC,sBAAsB,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC;kCACzC,sBAAsB;kEAAC;IApF5C,kBAAkB;QAX9B,SAAS,CAAC;YACP,QAAQ,EAAE,YAAY;YACtB,kgBAAoC;qBAC3B,iEAIR;SAEJ,CAAC;OAEW,kBAAkB,CA4F9B;IAAD,yBAAC;CAAA,AA5FD,IA4FC;SA5FY,kBAAkB;AA8F/B;;GAEG;AAMH;IAAA;IACA,CAAC;IADY,eAAe;QAL3B,QAAQ,CAAC;YACN,YAAY,EAAE,CAAC,kBAAkB,EAAE,sBAAsB,CAAC;YAC1D,OAAO,EAAE,CAAC,kBAAkB,EAAE,sBAAsB,CAAC;YACrD,OAAO,EAAE,CAAC,eAAe,EAAE,aAAa,EAAE,YAAY,CAAC;SAC1D,CAAC;OACW,eAAe,CAC3B;IAAD,sBAAC;CAAA,AADD,IACC;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"]}