@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
164 lines • 14.9 kB
JavaScript
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"]}