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