@hxui/angular
Version:
* * *
220 lines • 17 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import { Component, HostBinding, Input } from '@angular/core';
import { TabsetConfig } from './tabset.config';
export class TabsetComponent {
/**
* @param {?} config
*/
constructor(config) {
this.clazn = true;
this.tabs = [];
this.classMap = {};
Object.assign(this, config);
}
/**
* if true tabs will be placed vertically
* @return {?}
*/
get vertical() {
return this._vertical;
}
/**
* @param {?} value
* @return {?}
*/
set vertical(value) {
this._vertical = value;
this.setClassMap();
}
/**
* if true tabs fill the container and have a consistent width
* @return {?}
*/
get justified() {
return this._justified;
}
/**
* @param {?} value
* @return {?}
*/
set justified(value) {
this._justified = value;
this.setClassMap();
}
/**
* @return {?}
*/
get hasInfo() {
return this._hasInfo;
}
/**
* @param {?} value
* @return {?}
*/
set hasInfo(value) {
this._hasInfo = value;
this.setClassMap();
}
/**
* navigation context class: 'tabs' or 'pills'
* @return {?}
*/
get type() {
return this._type;
}
/**
* @param {?} value
* @return {?}
*/
set type(value) {
this._type = value;
this.setClassMap();
}
/**
* @return {?}
*/
ngOnDestroy() {
this.isDestroyed = true;
}
/**
* @param {?} tab
* @return {?}
*/
addTab(tab) {
this.tabs.push(tab);
tab.active = this.tabs.length === 1 && tab.active !== false;
}
/**
* @param {?} tab
* @param {?=} options
* @return {?}
*/
removeTab(tab, options = { reselect: true, emit: true }) {
/** @type {?} */
const index = this.tabs.indexOf(tab);
if (index === -1 || this.isDestroyed) {
return;
}
// Select a new tab if the tab to be removed is selected and not destroyed
if (options.reselect && tab.active && this.hasAvailableTabs(index)) {
/** @type {?} */
const newActiveIndex = this.getClosestTabIndex(index);
this.tabs[newActiveIndex].active = true;
}
if (options.emit) {
tab.removed.emit(tab);
}
this.tabs.splice(index, 1);
if (tab.elementRef.nativeElement && tab.elementRef.nativeElement.remove) {
tab.elementRef.nativeElement.remove();
}
}
/**
* @param {?} index
* @return {?}
*/
getClosestTabIndex(index) {
/** @type {?} */
const tabsLength = this.tabs.length;
if (!tabsLength) {
return -1;
}
for (let step = 1; step <= tabsLength; step += 1) {
/** @type {?} */
const prevIndex = index - step;
/** @type {?} */
const nextIndex = index + step;
if (this.tabs[prevIndex] && !this.tabs[prevIndex].disabled) {
return prevIndex;
}
if (this.tabs[nextIndex] && !this.tabs[nextIndex].disabled) {
return nextIndex;
}
}
return -1;
}
/**
* @param {?} index
* @return {?}
*/
hasAvailableTabs(index) {
/** @type {?} */
const tabsLength = this.tabs.length;
if (!tabsLength) {
return false;
}
for (let i = 0; i < tabsLength; i += 1) {
if (!this.tabs[i].disabled && i !== index) {
return true;
}
}
return false;
}
/**
* @return {?}
*/
setClassMap() {
this.classMap = {
'is-vertical': this.vertical,
'is-justified': this.justified,
'has-info': this.hasInfo,
[`hx-nav-${this.type}`]: true
};
}
}
TabsetComponent.decorators = [
{ type: Component, args: [{
selector: 'hx-tabset',
template: `
<ul class="hx-nav" [ngClass]="classMap" (click)="$event.preventDefault()">
<li *ngFor="let tabz of tabs" [ngClass]="['hx-nav-item', tabz.customClass || '']"
[class.is-active]="tabz.active" [class.is-disabled]="tabz.disabled">
<a href="javascript:void(0);" class="hx-nav-link"
[class.is-active]="tabz.active" [class.is-disabled]="tabz.disabled"
(click)="tabz.active = true">
<span [ngTransclude]="tabz.headingRef">{{tabz.heading}}</span>
<span *ngIf="tabz.removable">
<span (click)="$event.preventDefault(); removeTab(tabz);" class="icon close-outline is-small"></span>
</span>
</a>
</li>
</ul>
<div class="hx-tab-content">
<ng-content></ng-content>
</div>
`
},] },
];
/** @nocollapse */
TabsetComponent.ctorParameters = () => [
{ type: TabsetConfig }
];
TabsetComponent.propDecorators = {
vertical: [{ type: Input }],
justified: [{ type: Input }],
hasInfo: [{ type: Input }],
type: [{ type: Input }],
clazn: [{ type: HostBinding, args: ['class.hx-tab-container',] }]
};
if (false) {
/** @type {?} */
TabsetComponent.prototype.clazn;
/** @type {?} */
TabsetComponent.prototype.tabs;
/** @type {?} */
TabsetComponent.prototype.classMap;
/** @type {?} */
TabsetComponent.prototype.isDestroyed;
/** @type {?} */
TabsetComponent.prototype._vertical;
/** @type {?} */
TabsetComponent.prototype._justified;
/** @type {?} */
TabsetComponent.prototype._hasInfo;
/** @type {?} */
TabsetComponent.prototype._type;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabset.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/tabs/tabset.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnDestroy } from '@angular/core';\r\n\r\nimport { TabDirective } from './tab.directive';\r\nimport { TabsetConfig } from './tabset.config';\r\n\r\n@Component({\r\n  selector: 'hx-tabset',\r\n  template: `\r\n    <ul class=\"hx-nav\" [ngClass]=\"classMap\" (click)=\"$event.preventDefault()\">\r\n        <li *ngFor=\"let tabz of tabs\" [ngClass]=\"['hx-nav-item', tabz.customClass || '']\"\r\n          [class.is-active]=\"tabz.active\" [class.is-disabled]=\"tabz.disabled\">\r\n          <a href=\"javascript:void(0);\" class=\"hx-nav-link\"\r\n            [class.is-active]=\"tabz.active\" [class.is-disabled]=\"tabz.disabled\"\r\n            (click)=\"tabz.active = true\">\r\n            <span [ngTransclude]=\"tabz.headingRef\">{{tabz.heading}}</span>\r\n            <span *ngIf=\"tabz.removable\">\r\n              <span (click)=\"$event.preventDefault(); removeTab(tabz);\" class=\"icon close-outline is-small\"></span>\r\n            </span>\r\n          </a>\r\n        </li>\r\n    </ul>\r\n    <div class=\"hx-tab-content\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  `\r\n})\r\nexport class TabsetComponent implements OnDestroy {\r\n  /** if true tabs will be placed vertically */\r\n  @Input()\r\n  public get vertical(): boolean {\r\n    return this._vertical;\r\n  }\r\n  public set vertical(value: boolean) {\r\n    this._vertical = value;\r\n    this.setClassMap();\r\n  }\r\n\r\n  /** if true tabs fill the container and have a consistent width */\r\n  @Input()\r\n  public get justified(): boolean {\r\n    return this._justified;\r\n  }\r\n  public set justified(value: boolean) {\r\n    this._justified = value;\r\n    this.setClassMap();\r\n  }\r\n\r\n  @Input()\r\n  public get hasInfo(): boolean {\r\n    return this._hasInfo;\r\n  }\r\n  public set hasInfo(value: boolean) {\r\n    this._hasInfo = value;\r\n    this.setClassMap();\r\n  }\r\n\r\n  /** navigation context class: 'tabs' or 'pills' */\r\n  @Input()\r\n  public get type(): string {\r\n    return this._type;\r\n  }\r\n  public set type(value: string) {\r\n    this._type = value;\r\n    this.setClassMap();\r\n  }\r\n\r\n  @HostBinding('class.hx-tab-container') public clazn = true;\r\n\r\n  public tabs: TabDirective[] = [];\r\n  public classMap: any = {};\r\n\r\n  protected isDestroyed: boolean;\r\n  protected _vertical: boolean;\r\n  protected _justified: boolean;\r\n  protected _hasInfo: boolean;\r\n  protected _type: string;\r\n\r\n  public constructor(config: TabsetConfig) {\r\n    Object.assign(this, config);\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.isDestroyed = true;\r\n  }\r\n\r\n  public addTab(tab: TabDirective): void {\r\n    this.tabs.push(tab);\r\n    tab.active = this.tabs.length === 1 && tab.active !== false;\r\n  }\r\n\r\n  public removeTab(tab: TabDirective, options = {reselect: true, emit: true}): void {\r\n    const index = this.tabs.indexOf(tab);\r\n    if (index === -1 || this.isDestroyed) {\r\n      return;\r\n    }\r\n    // Select a new tab if the tab to be removed is selected and not destroyed\r\n    if (options.reselect && tab.active && this.hasAvailableTabs(index)) {\r\n      const newActiveIndex = this.getClosestTabIndex(index);\r\n      this.tabs[newActiveIndex].active = true;\r\n    }\r\n    if (options.emit) {\r\n      tab.removed.emit(tab);\r\n    }\r\n    this.tabs.splice(index, 1);\r\n    if (tab.elementRef.nativeElement && tab.elementRef.nativeElement.remove) {\r\n      tab.elementRef.nativeElement.remove();\r\n    }\r\n  }\r\n\r\n  protected getClosestTabIndex(index: number): number {\r\n    const tabsLength = this.tabs.length;\r\n    if (!tabsLength) {\r\n      return -1;\r\n    }\r\n\r\n    for (let step = 1; step <= tabsLength; step += 1) {\r\n      const prevIndex = index - step;\r\n      const nextIndex = index + step;\r\n      if (this.tabs[prevIndex] && !this.tabs[prevIndex].disabled) {\r\n        return prevIndex;\r\n      }\r\n      if (this.tabs[nextIndex] && !this.tabs[nextIndex].disabled) {\r\n        return nextIndex;\r\n      }\r\n    }\r\n    return -1;\r\n  }\r\n\r\n  protected hasAvailableTabs(index: number): boolean {\r\n    const tabsLength = this.tabs.length;\r\n    if (!tabsLength) {\r\n      return false;\r\n    }\r\n\r\n    for (let i = 0; i < tabsLength; i += 1) {\r\n      if (!this.tabs[i].disabled && i !== index) {\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  protected setClassMap(): void {\r\n    this.classMap = {\r\n      'is-vertical': this.vertical,\r\n      'is-justified': this.justified,\r\n      'has-info': this.hasInfo,\r\n      [`hx-nav-${this.type}`]: true\r\n    };\r\n  }\r\n}\r\n"]}