UNPKG

@coreui/angular

Version:

CoreUI Angular Bootstrap 4 components

194 lines 15.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, Input, Inject, Renderer2 } from '@angular/core'; import { DOCUMENT } from '@angular/common'; import { Replace } from '../shared'; export class AppHeaderComponent { /** * @param {?} document * @param {?} renderer * @param {?} el */ constructor(document, renderer, el) { this.document = document; this.renderer = renderer; this.el = el; this.navbarBrandText = { icon: '🅲', text: '🅲 CoreUI' }; this.navbarBrandHref = ''; } /** * @return {?} */ ngOnInit() { Replace(this.el); this.isFixed(this.fixed); this.navbarBrandImg = Boolean(this.navbarBrand || this.navbarBrandFull || this.navbarBrandMinimized); } /** * @return {?} */ ngOnDestroy() { this.renderer.removeClass(this.document.body, 'header-fixed'); } /** * @param {?=} fixed * @return {?} */ isFixed(fixed = this.fixed) { if (fixed) { this.renderer.addClass(this.document.body, 'header-fixed'); } } /** * @param {?} brand * @return {?} */ imgSrc(brand) { return brand.src ? brand.src : ''; } /** * @param {?} brand * @return {?} */ imgWidth(brand) { return brand.width ? brand.width : 'auto'; } /** * @param {?} brand * @return {?} */ imgHeight(brand) { return brand.height ? brand.height : 'auto'; } /** * @param {?} brand * @return {?} */ imgAlt(brand) { return brand.alt ? brand.alt : ''; } /** * @param {?} breakpoint * @return {?} */ breakpoint(breakpoint) { console.log(breakpoint); return breakpoint ? breakpoint : ''; } } AppHeaderComponent.decorators = [ { type: Component, args: [{ selector: 'app-header', template: ` <header class="app-header navbar"> <ng-template [ngIf]="mobileSidebarToggler != false"> <button class="navbar-toggler d-lg-none" type="button" appSidebarToggler> <span class="navbar-toggler-icon"></span> </button> </ng-template> <a class="navbar-brand" [href]="navbarBrandHref"> <ng-template [ngIf]="navbarBrandImg"> <img *ngIf="navbarBrand" [src]="imgSrc(navbarBrand)" [attr.width]="imgWidth(navbarBrand)" [attr.height]="imgHeight(navbarBrand)" [attr.alt]="imgAlt(navbarBrand)" class="navbar-brand"> <img *ngIf="navbarBrandFull" [src]="imgSrc(navbarBrandFull)" [attr.width]="imgWidth(navbarBrandFull)" [attr.height]="imgHeight(navbarBrandFull)" [attr.alt]="imgAlt(navbarBrandFull)" class="navbar-brand-full"> <img *ngIf="navbarBrandMinimized" [src]="imgSrc(navbarBrandMinimized)" [attr.width]="imgWidth(navbarBrandMinimized)" [attr.height]="imgHeight(navbarBrandMinimized)" [attr.alt]="imgAlt(navbarBrandMinimized)" class="navbar-brand-minimized"> </ng-template> <ng-template [ngIf]="!navbarBrandImg"> <div class="navbar-brand-full" [innerHTML]="navbarBrandText.text"></div> <div class="navbar-brand-minimized" [innerHTML]="navbarBrandText.icon"></div> </ng-template> </a> <ng-template [ngIf]="sidebarToggler != false"> <button class="navbar-toggler d-md-down-none" type="button" [appSidebarToggler]="sidebarToggler"> <span class="navbar-toggler-icon"></span> </button> </ng-template> <ng-content></ng-content> <ng-template [ngIf]="asideMenuToggler != false"> <button class="navbar-toggler d-md-down-none" type="button" [appAsideMenuToggler]="asideMenuToggler"> <span class="navbar-toggler-icon"></span> </button> </ng-template> <ng-template [ngIf]="mobileAsideMenuToggler != false"> <button class="navbar-toggler d-lg-none" type="button" appAsideMenuToggler> <span class="navbar-toggler-icon"></span> </button> </ng-template> </header> ` }] } ]; /** @nocollapse */ AppHeaderComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }, { type: Renderer2 }, { type: ElementRef } ]; AppHeaderComponent.propDecorators = { fixed: [{ type: Input }], navbarBrand: [{ type: Input }], navbarBrandFull: [{ type: Input }], navbarBrandMinimized: [{ type: Input }], navbarBrandText: [{ type: Input }], navbarBrandHref: [{ type: Input }], sidebarToggler: [{ type: Input }], mobileSidebarToggler: [{ type: Input }], asideMenuToggler: [{ type: Input }], mobileAsideMenuToggler: [{ type: Input }] }; if (false) { /** @type {?} */ AppHeaderComponent.prototype.fixed; /** @type {?} */ AppHeaderComponent.prototype.navbarBrand; /** @type {?} */ AppHeaderComponent.prototype.navbarBrandFull; /** @type {?} */ AppHeaderComponent.prototype.navbarBrandMinimized; /** @type {?} */ AppHeaderComponent.prototype.navbarBrandText; /** @type {?} */ AppHeaderComponent.prototype.navbarBrandHref; /** @type {?} */ AppHeaderComponent.prototype.sidebarToggler; /** @type {?} */ AppHeaderComponent.prototype.mobileSidebarToggler; /** @type {?} */ AppHeaderComponent.prototype.asideMenuToggler; /** @type {?} */ AppHeaderComponent.prototype.mobileAsideMenuToggler; /** @type {?} */ AppHeaderComponent.prototype.navbarBrandImg; /** * @type {?} * @private */ AppHeaderComponent.prototype.document; /** * @type {?} * @private */ AppHeaderComponent.prototype.renderer; /** * @type {?} * @private */ AppHeaderComponent.prototype.el; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-header.component.js","sourceRoot":"ng://@coreui/angular/","sources":["lib/header/app-header.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAwDpC,MAAM,OAAO,kBAAkB;;;;;;IAkB7B,YAC4B,QAAa,EAC/B,QAAmB,EACnB,EAAc;QAFI,aAAQ,GAAR,QAAQ,CAAK;QAC/B,aAAQ,GAAR,QAAQ,CAAW;QACnB,OAAE,GAAF,EAAE,CAAY;QAdf,oBAAe,GAAQ,EAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAC,CAAC;QACvD,oBAAe,GAAQ,EAAE,CAAC;IAchC,CAAC;;;;IAEJ,QAAQ;QACN,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,oBAAoB,CAAC,CAAC;IACvG,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;IAChE,CAAC;;;;;IAED,OAAO,CAAC,QAAiB,IAAI,CAAC,KAAK;QACjC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;SAC5D;IACH,CAAC;;;;;IAED,MAAM,CAAC,KAAU;QACf,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACpC,CAAC;;;;;IAED,QAAQ,CAAC,KAAU;QACjB,OAAO,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;IAC5C,CAAC;;;;;IAED,SAAS,CAAC,KAAU;QAClB,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;IAC9C,CAAC;;;;;IAED,MAAM,CAAC,KAAU;QACf,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;IACpC,CAAC;;;;;IAED,UAAU,CAAC,UAAe;QACxB,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxB,OAAO,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;IACtC,CAAC;;;YAjHF,SAAS,SAAC;gBACT,QAAQ,EAAE,YAAY;gBACtB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDT;aACF;;;;4CAoBI,MAAM,SAAC,QAAQ;YA9E8C,SAAS;YAAvD,UAAU;;;oBA6D3B,KAAK;0BAEL,KAAK;8BACL,KAAK;mCACL,KAAK;8BACL,KAAK;8BACL,KAAK;6BAEL,KAAK;mCACL,KAAK;+BAEL,KAAK;qCACL,KAAK;;;;IAZN,mCAAwB;;IAExB,yCAA0B;;IAC1B,6CAA8B;;IAC9B,kDAAmC;;IACnC,6CAAgE;;IAChE,6CAAmC;;IAEnC,4CAA6B;;IAC7B,kDAAmC;;IAEnC,8CAA+B;;IAC/B,oDAAqC;;IAErC,4CAAwB;;;;;IAGtB,sCAAuC;;;;;IACvC,sCAA2B;;;;;IAC3B,gCAAsB","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnDestroy, Inject, Renderer2 } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\nimport { Replace } from '../shared';\r\n\r\n@Component({\r\n  selector: 'app-header',\r\n  template: `\r\n    <header class=\"app-header navbar\">\r\n      <ng-template [ngIf]=\"mobileSidebarToggler != false\">\r\n        <button class=\"navbar-toggler d-lg-none\" type=\"button\" appSidebarToggler>\r\n          <span class=\"navbar-toggler-icon\"></span>\r\n        </button>\r\n      </ng-template>\r\n        <a class=\"navbar-brand\" [href]=\"navbarBrandHref\">\r\n          <ng-template [ngIf]=\"navbarBrandImg\">\r\n          <img *ngIf=\"navbarBrand\"\r\n               [src]=\"imgSrc(navbarBrand)\"\r\n               [attr.width]=\"imgWidth(navbarBrand)\"\r\n               [attr.height]=\"imgHeight(navbarBrand)\"\r\n               [attr.alt]=\"imgAlt(navbarBrand)\"\r\n               class=\"navbar-brand\">\r\n          <img *ngIf=\"navbarBrandFull\"\r\n               [src]=\"imgSrc(navbarBrandFull)\"\r\n               [attr.width]=\"imgWidth(navbarBrandFull)\"\r\n               [attr.height]=\"imgHeight(navbarBrandFull)\"\r\n               [attr.alt]=\"imgAlt(navbarBrandFull)\"\r\n               class=\"navbar-brand-full\">\r\n          <img *ngIf=\"navbarBrandMinimized\"\r\n               [src]=\"imgSrc(navbarBrandMinimized)\"\r\n               [attr.width]=\"imgWidth(navbarBrandMinimized)\"\r\n               [attr.height]=\"imgHeight(navbarBrandMinimized)\"\r\n               [attr.alt]=\"imgAlt(navbarBrandMinimized)\"\r\n               class=\"navbar-brand-minimized\">\r\n          </ng-template>\r\n          <ng-template [ngIf]=\"!navbarBrandImg\">\r\n            <div class=\"navbar-brand-full\" [innerHTML]=\"navbarBrandText.text\"></div>\r\n            <div class=\"navbar-brand-minimized\" [innerHTML]=\"navbarBrandText.icon\"></div>\r\n          </ng-template>\r\n        </a>\r\n      <ng-template [ngIf]=\"sidebarToggler != false\">\r\n        <button class=\"navbar-toggler d-md-down-none\" type=\"button\" [appSidebarToggler]=\"sidebarToggler\">\r\n          <span class=\"navbar-toggler-icon\"></span>\r\n        </button>\r\n      </ng-template>\r\n      <ng-content></ng-content>\r\n      <ng-template [ngIf]=\"asideMenuToggler != false\">\r\n        <button class=\"navbar-toggler d-md-down-none\" type=\"button\" [appAsideMenuToggler]=\"asideMenuToggler\">\r\n          <span class=\"navbar-toggler-icon\"></span>\r\n        </button>\r\n      </ng-template>\r\n      <ng-template [ngIf]=\"mobileAsideMenuToggler != false\">\r\n        <button class=\"navbar-toggler d-lg-none\" type=\"button\" appAsideMenuToggler>\r\n          <span class=\"navbar-toggler-icon\"></span>\r\n        </button>\r\n      </ng-template>\r\n    </header>\r\n  `\r\n})\r\nexport class AppHeaderComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() fixed: boolean;\r\n\r\n  @Input() navbarBrand: any;\r\n  @Input() navbarBrandFull: any;\r\n  @Input() navbarBrandMinimized: any;\r\n  @Input() navbarBrandText: any = {icon: '🅲', text: '🅲 CoreUI'};\r\n  @Input() navbarBrandHref: any = '';\r\n\r\n  @Input() sidebarToggler: any;\r\n  @Input() mobileSidebarToggler: any;\r\n\r\n  @Input() asideMenuToggler: any;\r\n  @Input() mobileAsideMenuToggler: any;\r\n\r\n  navbarBrandImg: boolean;\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private document: any,\r\n    private renderer: Renderer2,\r\n    private el: ElementRef\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    Replace(this.el);\r\n    this.isFixed(this.fixed);\r\n    this.navbarBrandImg = Boolean(this.navbarBrand || this.navbarBrandFull || this.navbarBrandMinimized);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.renderer.removeClass(this.document.body, 'header-fixed');\r\n  }\r\n\r\n  isFixed(fixed: boolean = this.fixed): void {\r\n    if (fixed) {\r\n      this.renderer.addClass(this.document.body, 'header-fixed');\r\n    }\r\n  }\r\n\r\n  imgSrc(brand: any): void {\r\n    return brand.src ? brand.src : '';\r\n  }\r\n\r\n  imgWidth(brand: any): void {\r\n    return brand.width ? brand.width : 'auto';\r\n  }\r\n\r\n  imgHeight(brand: any): void {\r\n    return brand.height ? brand.height : 'auto';\r\n  }\r\n\r\n  imgAlt(brand: any): void {\r\n    return brand.alt ? brand.alt : '';\r\n  }\r\n\r\n  breakpoint(breakpoint: any): void {\r\n    console.log(breakpoint);\r\n    return breakpoint ? breakpoint : '';\r\n  }\r\n}\r\n"]}