@coreui/angular
Version:
CoreUI Angular Bootstrap 4 components
194 lines • 15.3 kB
JavaScript
/**
* @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"]}