UNPKG

@hxui/angular

Version:

This README includes the steps that are necessary to import the HxUi-angular into a project or to contribute with development.

248 lines (247 loc) 19.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, HostBinding, Input } from '@angular/core'; import { TabsetConfig } from './tabset.config'; var TabsetComponent = /** @class */ (function () { function TabsetComponent(config) { this.clazn = true; this.tabs = []; this.classMap = {}; Object.assign(this, config); } Object.defineProperty(TabsetComponent.prototype, "vertical", { get: /** * if true tabs will be placed vertically * @return {?} */ function () { return this._vertical; }, set: /** * @param {?} value * @return {?} */ function (value) { this._vertical = value; this.setClassMap(); }, enumerable: true, configurable: true }); Object.defineProperty(TabsetComponent.prototype, "justified", { get: /** * if true tabs fill the container and have a consistent width * @return {?} */ function () { return this._justified; }, set: /** * @param {?} value * @return {?} */ function (value) { this._justified = value; this.setClassMap(); }, enumerable: true, configurable: true }); Object.defineProperty(TabsetComponent.prototype, "hasInfo", { get: /** * @return {?} */ function () { return this._hasInfo; }, set: /** * @param {?} value * @return {?} */ function (value) { this._hasInfo = value; this.setClassMap(); }, enumerable: true, configurable: true }); Object.defineProperty(TabsetComponent.prototype, "type", { get: /** * navigation context class: 'tabs' or 'pills' * @return {?} */ function () { return this._type; }, set: /** * @param {?} value * @return {?} */ function (value) { this._type = value; this.setClassMap(); }, enumerable: true, configurable: true }); /** * @return {?} */ TabsetComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.isDestroyed = true; }; /** * @param {?} tab * @return {?} */ TabsetComponent.prototype.addTab = /** * @param {?} tab * @return {?} */ function (tab) { this.tabs.push(tab); tab.active = this.tabs.length === 1 && tab.active !== false; }; /** * @param {?} tab * @param {?=} options * @return {?} */ TabsetComponent.prototype.removeTab = /** * @param {?} tab * @param {?=} options * @return {?} */ function (tab, options) { if (options === void 0) { options = { reselect: true, emit: true }; } var /** @type {?} */ 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)) { var /** @type {?} */ 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 {?} */ TabsetComponent.prototype.getClosestTabIndex = /** * @param {?} index * @return {?} */ function (index) { var /** @type {?} */ tabsLength = this.tabs.length; if (!tabsLength) { return -1; } for (var /** @type {?} */ step = 1; step <= tabsLength; step += 1) { var /** @type {?} */ prevIndex = index - step; var /** @type {?} */ 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 {?} */ TabsetComponent.prototype.hasAvailableTabs = /** * @param {?} index * @return {?} */ function (index) { var /** @type {?} */ tabsLength = this.tabs.length; if (!tabsLength) { return false; } for (var /** @type {?} */ i = 0; i < tabsLength; i += 1) { if (!this.tabs[i].disabled && i !== index) { return true; } } return false; }; /** * @return {?} */ TabsetComponent.prototype.setClassMap = /** * @return {?} */ function () { this.classMap = (_a = { 'is-vertical': this.vertical, 'is-justified': this.justified, 'has-info': this.hasInfo }, _a["hx-nav-" + this.type] = true, _a); var _a; }; TabsetComponent.decorators = [ { type: Component, args: [{ selector: 'hx-tabset', template: "\n <ul class=\"hx-nav\" [ngClass]=\"classMap\" (click)=\"$event.preventDefault()\">\n <li *ngFor=\"let tabz of tabs\" [ngClass]=\"['hx-nav-item', tabz.customClass || '']\"\n [class.is-active]=\"tabz.active\" [class.is-disabled]=\"tabz.disabled\">\n <a href=\"javascript:void(0);\" class=\"hx-nav-link\"\n [class.is-active]=\"tabz.active\" [class.is-disabled]=\"tabz.disabled\"\n (click)=\"tabz.active = true\">\n <span [ngTransclude]=\"tabz.headingRef\">{{tabz.heading}}</span>\n <span *ngIf=\"tabz.removable\">\n <span (click)=\"$event.preventDefault(); removeTab(tabz);\" class=\"icon close-outline is-small\"></span>\n </span>\n </a>\n </li>\n </ul>\n <div class=\"hx-tab-content\">\n <ng-content></ng-content>\n </div>\n " },] }, ]; /** @nocollapse */ TabsetComponent.ctorParameters = function () { return [ { type: TabsetConfig, }, ]; }; TabsetComponent.propDecorators = { "vertical": [{ type: Input },], "justified": [{ type: Input },], "hasInfo": [{ type: Input },], "type": [{ type: Input },], "clazn": [{ type: HostBinding, args: ['class.hx-tab-container',] },], }; return TabsetComponent; }()); export { TabsetComponent }; function TabsetComponent_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ TabsetComponent.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ TabsetComponent.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ TabsetComponent.propDecorators; /** @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"]}