@coreui/angular
Version:
CoreUI Components Library for Angular
141 lines • 14 kB
JavaScript
import { booleanAttribute, Directive, HostBinding, HostListener, Input, numberAttribute } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "./tab.service";
export class TabContentRefDirective {
constructor(changeDetectorRef, tabService) {
this.changeDetectorRef = changeDetectorRef;
this.tabService = tabService;
this._active = false;
this._disabled = false;
/**
* c-tab-pane index respectively
* @type number
*/
this.tabPaneIdx = -1;
this.role = 'tab';
this.subscribeTabService();
}
/**
* Set active state of tab content
* @type boolean
* @default false
*/
set active(value) {
const newValue = value;
if (this._active !== newValue) {
this._active = newValue;
this.changeDetectorRef.detectChanges();
}
}
get active() {
return this._active;
}
/**
* Set disabled state of tab content
* @type boolean
*/
set disabled(value) {
this._disabled = value;
}
get disabled() {
return this._disabled || this.tabPaneIdx >= this.tabContentRef?.panes?.length;
}
get hostClasses() {
return {
active: this.active,
disabled: this.disabled
};
}
get isDisabled() {
return this.disabled || null;
}
get attrDisabled() {
return this.disabled ? '' : null;
}
get ariaSelected() {
return this.active;
}
get getTabindex() {
return this.disabled ? '-1' : null;
}
ngOnChanges(changes) {
if (changes['active']?.currentValue) {
this.setActiveTabPane();
}
}
toggleOpen($event) {
$event.preventDefault();
this.setActiveTabPane();
}
setActiveTabPane() {
setTimeout(() => {
if (this.tabPaneIdx < this.tabContentRef.panes.length) {
this.active = true;
this.tabService.setActiveTabIdx({ tabContent: this.tabContentRef, activeIdx: this.tabPaneIdx });
}
else {
this.active = false;
}
});
}
ngOnDestroy() {
this.subscribeTabService(false);
}
subscribeTabService(subscribe = true) {
if (subscribe) {
this.tabServiceSubscription = this.tabService.activeTabPaneIdx$.subscribe((tabContentState) => {
if (tabContentState.tabContent === this.tabContentRef) {
this.active = tabContentState.activeIdx === this.tabPaneIdx;
}
});
}
else {
this.tabServiceSubscription?.unsubscribe();
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TabContentRefDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TabService }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.12", type: TabContentRefDirective, isStandalone: true, selector: "[cTabContent]", inputs: { tabContentRef: ["cTabContent", "tabContentRef"], active: ["active", "active", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], tabPaneIdx: ["tabPaneIdx", "tabPaneIdx", numberAttribute], role: "role" }, host: { listeners: { "click": "toggleOpen($event)" }, properties: { "class": "this.hostClasses", "attr.aria-disabled": "this.isDisabled", "attr.disabled": "this.attrDisabled", "attr.aria-selected": "this.ariaSelected", "attr.role": "this.role", "attr.tabindex": "this.getTabindex" } }, usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TabContentRefDirective, decorators: [{
type: Directive,
args: [{
selector: '[cTabContent]',
standalone: true
}]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.TabService }], propDecorators: { tabContentRef: [{
type: Input,
args: ['cTabContent']
}], active: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], disabled: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], tabPaneIdx: [{
type: Input,
args: [{ transform: numberAttribute }]
}], hostClasses: [{
type: HostBinding,
args: ['class']
}], isDisabled: [{
type: HostBinding,
args: ['attr.aria-disabled']
}], attrDisabled: [{
type: HostBinding,
args: ['attr.disabled']
}], ariaSelected: [{
type: HostBinding,
args: ['attr.aria-selected']
}], role: [{
type: Input
}, {
type: HostBinding,
args: ['attr.role']
}], getTabindex: [{
type: HostBinding,
args: ['attr.tabindex']
}], toggleOpen: [{
type: HostListener,
args: ['click', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-content-ref.directive.js","sourceRoot":"","sources":["../../../../../projects/coreui-angular/src/lib/tabs/tab-content-ref.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectorRef,\n  Directive,\n  HostBinding,\n  HostListener,\n  Input,\n  numberAttribute,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { TabService } from './tab.service';\n\n@Directive({\n  selector: '[cTabContent]',\n  standalone: true\n})\nexport class TabContentRefDirective implements OnChanges, OnDestroy {\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    private tabService: TabService\n  ) {\n    this.subscribeTabService();\n  }\n\n  private tabServiceSubscription!: Subscription;\n\n  /**\n   * Template Ref\n   * @type TemplateRef\n   */\n  @Input('cTabContent') tabContentRef!: any;\n\n  /**\n   * Set active state of tab content\n   * @type boolean\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  set active(value: boolean) {\n    const newValue = value;\n    if (this._active !== newValue) {\n      this._active = newValue;\n      this.changeDetectorRef.detectChanges();\n    }\n  }\n\n  get active() {\n    return this._active;\n  }\n\n  private _active = false;\n\n  /**\n   * Set disabled state of tab content\n   * @type boolean\n   */\n  @Input({ transform: booleanAttribute })\n  set disabled(value: boolean) {\n    this._disabled = value;\n  }\n\n  get disabled(): boolean {\n    return this._disabled || this.tabPaneIdx >= this.tabContentRef?.panes?.length;\n  }\n\n  private _disabled = false;\n\n  /**\n   * c-tab-pane index respectively\n   * @type number\n   */\n  @Input({ transform: numberAttribute }) tabPaneIdx = -1;\n\n  @HostBinding('class')\n  get hostClasses() {\n    return {\n      active: this.active,\n      disabled: this.disabled\n    };\n  }\n\n  @HostBinding('attr.aria-disabled')\n  get isDisabled(): boolean | null {\n    return this.disabled || null;\n  }\n\n  @HostBinding('attr.disabled')\n  get attrDisabled() {\n    return this.disabled ? '' : null;\n  }\n\n  @HostBinding('attr.aria-selected')\n  private get ariaSelected() {\n    return this.active;\n  }\n\n  @Input()\n  @HostBinding('attr.role')\n  role = 'tab';\n\n  @HostBinding('attr.tabindex')\n  get getTabindex(): string | null {\n    return this.disabled ? '-1' : null;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['active']?.currentValue) {\n      this.setActiveTabPane();\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  toggleOpen($event: any): void {\n    $event.preventDefault();\n    this.setActiveTabPane();\n  }\n\n  setActiveTabPane() {\n    setTimeout(() => {\n      if (this.tabPaneIdx < this.tabContentRef.panes.length) {\n        this.active = true;\n        this.tabService.setActiveTabIdx({ tabContent: this.tabContentRef, activeIdx: this.tabPaneIdx });\n      } else {\n        this.active = false;\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.subscribeTabService(false);\n  }\n\n  subscribeTabService(subscribe: boolean = true) {\n    if (subscribe) {\n      this.tabServiceSubscription = this.tabService.activeTabPaneIdx$.subscribe((tabContentState) => {\n        if (tabContentState.tabContent === this.tabContentRef) {\n          this.active = tabContentState.activeIdx === this.tabPaneIdx;\n        }\n      });\n    } else {\n      this.tabServiceSubscription?.unsubscribe();\n    }\n  }\n}\n"]}