@coreui/angular
Version:
CoreUI Components Library for Angular
113 lines • 14.8 kB
JavaScript
import { animate, animateChild, query, state, style, transition, trigger } from '@angular/animations';
import { Component, computed, HostBinding, HostListener, inject, input, numberAttribute, output, signal } from '@angular/core';
import { TabsService } from '../tabs.service';
import * as i0 from "@angular/core";
export class TabPanelComponent {
constructor() {
this.tabsService = inject(TabsService);
/**
* aria-labelledby attribute
* @type string
* @default undefined
*/
this.ariaLabelledBy = input(undefined, {
alias: 'aria-labelledby'
});
/**
* Element id attribute
* @type string
* @default undefined
*/
this.id = input();
/**
* Item key.
* @type string | number
* @required
*/
this.itemKey = input.required();
/**
* tabindex attribute.
* @type number
* @default 0
*/
this.tabindex = input(0, { transform: numberAttribute });
/**
* Enable fade in transition.
* @type boolean
* @default true
*/
this.transition = input(true);
/**
* visible change output
* @type OutputEmitterRef<VisibleChangeEvent>
*/
this.visibleChange = output();
this.show = signal(false);
this.visible = computed(() => {
const visible = this.tabsService.activeItemKey() === this.itemKey() && !this.tabsService.activeItem()?.disabled;
this.visibleChange.emit({ itemKey: this.itemKey(), visible });
return visible;
});
this.propId = computed(() => this.id() ?? `${this.tabsService.id()}-panel-${this.itemKey()}`);
this.attrAriaLabelledBy = computed(() => this.ariaLabelledBy() ?? `${this.tabsService.id()}-tab-${this.itemKey()}`);
this.hostClasses = computed(() => ({
'tab-pane': true,
active: this.show(),
fade: this.transition(),
show: this.show(),
invisible: this.tabsService.activeItem()?.disabled
}));
}
get animationDisabled() {
return !this.transition();
}
get animateType() {
return this.visible() ? 'show' : 'hide';
}
onAnimationDone($event) {
this.show.set(this.visible());
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TabPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.12", type: TabPanelComponent, isStandalone: true, selector: "c-tab-panel", inputs: { ariaLabelledBy: { classPropertyName: "ariaLabelledBy", publicName: "aria-labelledby", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null }, itemKey: { classPropertyName: "itemKey", publicName: "itemKey", isSignal: true, isRequired: true, transformFunction: null }, tabindex: { classPropertyName: "tabindex", publicName: "tabindex", isSignal: true, isRequired: false, transformFunction: null }, transition: { classPropertyName: "transition", publicName: "transition", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { visibleChange: "visibleChange" }, host: { attributes: { "role": "tabpanel" }, listeners: { "@fadeInOut.done": "onAnimationDone($event)" }, properties: { "class": "hostClasses()", "tabindex": "visible() ? tabindex(): -1", "attr.aria-labelledby": "attrAriaLabelledBy()", "id": "propId()", "@.disabled": "this.animationDisabled", "@fadeInOut": "this.animateType" } }, exportAs: ["cTabPanel"], ngImport: i0, template: '<ng-content />', isInline: true, animations: [
trigger('fadeInOut', [
state('show', style({ opacity: 1 })),
state('hide', style({ opacity: 0 })),
state('void', style({ opacity: 0 })),
transition('* => *', [query('@*', [animateChild()], { optional: true }), animate('150ms linear')])
])
] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: TabPanelComponent, decorators: [{
type: Component,
args: [{
exportAs: 'cTabPanel',
selector: 'c-tab-panel',
standalone: true,
template: '<ng-content />',
host: {
'[class]': 'hostClasses()',
'[tabindex]': 'visible() ? tabindex(): -1',
'[attr.aria-labelledby]': 'attrAriaLabelledBy()',
'[id]': 'propId()',
role: 'tabpanel'
},
animations: [
trigger('fadeInOut', [
state('show', style({ opacity: 1 })),
state('hide', style({ opacity: 0 })),
state('void', style({ opacity: 0 })),
transition('* => *', [query('@*', [animateChild()], { optional: true }), animate('150ms linear')])
])
]
}]
}], propDecorators: { animationDisabled: [{
type: HostBinding,
args: ['@.disabled']
}], animateType: [{
type: HostBinding,
args: ['@fadeInOut']
}], onAnimationDone: [{
type: HostListener,
args: ['@fadeInOut.done', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/coreui-angular/src/lib/tabs-2/tab-panel/tab-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { animate, animateChild, AnimationEvent, query, state, style, transition, trigger } from '@angular/animations';\nimport {\n  Component,\n  computed,\n  HostBinding,\n  HostListener,\n  inject,\n  input,\n  InputSignal,\n  InputSignalWithTransform,\n  numberAttribute,\n  output,\n  OutputEmitterRef,\n  signal\n} from '@angular/core';\nimport { TabsService } from '../tabs.service';\n\ntype AnimateType = 'hide' | 'show';\ntype VisibleChangeEvent = { itemKey: string | number; visible: boolean };\n\n@Component({\n  exportAs: 'cTabPanel',\n  selector: 'c-tab-panel',\n  standalone: true,\n  template: '<ng-content />',\n  host: {\n    '[class]': 'hostClasses()',\n    '[tabindex]': 'visible() ? tabindex(): -1',\n    '[attr.aria-labelledby]': 'attrAriaLabelledBy()',\n    '[id]': 'propId()',\n    role: 'tabpanel'\n  },\n  animations: [\n    trigger('fadeInOut', [\n      state('show', style({ opacity: 1 })),\n      state('hide', style({ opacity: 0 })),\n      state('void', style({ opacity: 0 })),\n      transition('* => *', [query('@*', [animateChild()], { optional: true }), animate('150ms linear')])\n    ])\n  ]\n})\nexport class TabPanelComponent {\n  readonly tabsService = inject(TabsService);\n\n  /**\n   * aria-labelledby attribute\n   * @type string\n   * @default undefined\n   */\n  readonly ariaLabelledBy: InputSignal<string | undefined> = input<string | undefined>(undefined, {\n    alias: 'aria-labelledby'\n  });\n\n  /**\n   * Element id attribute\n   * @type string\n   * @default undefined\n   */\n  readonly id: InputSignal<string | undefined> = input<string>();\n\n  /**\n   * Item key.\n   * @type string | number\n   * @required\n   */\n  readonly itemKey: InputSignal<string | number> = input.required();\n\n  /**\n   * tabindex attribute.\n   * @type number\n   * @default 0\n   */\n  readonly tabindex: InputSignalWithTransform<number, unknown> = input(0, { transform: numberAttribute });\n\n  /**\n   * Enable fade in transition.\n   * @type boolean\n   * @default true\n   */\n  readonly transition: InputSignal<boolean> = input(true);\n\n  /**\n   * visible change output\n   * @type OutputEmitterRef<VisibleChangeEvent>\n   */\n  readonly visibleChange: OutputEmitterRef<VisibleChangeEvent> = output<VisibleChangeEvent>();\n\n  readonly show = signal(false);\n\n  readonly visible = computed(() => {\n    const visible = this.tabsService.activeItemKey() === this.itemKey() && !this.tabsService.activeItem()?.disabled;\n    this.visibleChange.emit({ itemKey: this.itemKey(), visible });\n    return visible;\n  });\n\n  readonly propId = computed(() => this.id() ?? `${this.tabsService.id()}-panel-${this.itemKey()}`);\n\n  readonly attrAriaLabelledBy = computed(\n    () => this.ariaLabelledBy() ?? `${this.tabsService.id()}-tab-${this.itemKey()}`\n  );\n\n  readonly hostClasses = computed(() => ({\n    'tab-pane': true,\n    active: this.show(),\n    fade: this.transition(),\n    show: this.show(),\n    invisible: this.tabsService.activeItem()?.disabled\n  }));\n\n  @HostBinding('@.disabled')\n  get animationDisabled(): boolean {\n    return !this.transition();\n  }\n\n  @HostBinding('@fadeInOut')\n  get animateType(): AnimateType {\n    return this.visible() ? 'show' : 'hide';\n  }\n\n  @HostListener('@fadeInOut.done', ['$event'])\n  onAnimationDone($event: AnimationEvent): void {\n    this.show.set(this.visible());\n  }\n}\n"]}