UNPKG

@coreui/angular

Version:

CoreUI Components Library for Angular

113 lines 14.8 kB
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"]}