@wizco/fenixds-ngx 17.10.0 → 17.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,109 @@
1
+ import { Component, EventEmitter, HostListener, Input, Output, ViewEncapsulation, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SubTabsComponent {
4
+ el;
5
+ selectedIndex = 0;
6
+ tabChange = new EventEmitter();
7
+ indicator;
8
+ resizeObserver;
9
+ constructor(el) {
10
+ this.el = el;
11
+ }
12
+ ngAfterContentInit() {
13
+ this.indicator = document.createElement('div');
14
+ this.indicator.className = 'wco-sub-tabs__indicator';
15
+ this.el.nativeElement.prepend(this.indicator);
16
+ setTimeout(() => {
17
+ this.reserveBoldWidth();
18
+ this.indicator.style.transition = 'none';
19
+ this.applySelection(this.selectedIndex, false);
20
+ requestAnimationFrame(() => requestAnimationFrame(() => {
21
+ this.indicator.style.transition = '';
22
+ }));
23
+ }, 0);
24
+ this.resizeObserver = new ResizeObserver(() => {
25
+ this.refreshIndicator();
26
+ });
27
+ this.resizeObserver.observe(this.el.nativeElement);
28
+ }
29
+ ngOnChanges(changes) {
30
+ if (changes['selectedIndex'] && !changes['selectedIndex'].firstChange) {
31
+ this.applySelection(this.selectedIndex, false);
32
+ }
33
+ }
34
+ onClick(event) {
35
+ const items = this.getItems();
36
+ const target = event.target;
37
+ for (let i = 0; i < items.length; i++) {
38
+ if (items[i] === target || items[i].contains(target)) {
39
+ this.applySelection(i, true);
40
+ break;
41
+ }
42
+ }
43
+ }
44
+ getItems() {
45
+ return Array.from(this.el.nativeElement.children).filter((c) => !c.classList.contains('wco-sub-tabs__indicator'));
46
+ }
47
+ reserveBoldWidth() {
48
+ const items = this.getItems();
49
+ const host = this.el.nativeElement;
50
+ items.forEach((item) => {
51
+ const clone = item.cloneNode(true);
52
+ clone.style.cssText = `
53
+ font-weight: 600;
54
+ visibility: hidden;
55
+ position: absolute;
56
+ pointer-events: none;
57
+ white-space: nowrap;
58
+ `;
59
+ host.appendChild(clone);
60
+ const boldWidth = clone.offsetWidth;
61
+ host.removeChild(clone);
62
+ item.style.minWidth = boldWidth + 'px';
63
+ });
64
+ }
65
+ applySelection(index, emit) {
66
+ const items = this.getItems();
67
+ if (!items.length)
68
+ return;
69
+ const clamped = Math.max(0, Math.min(index, items.length - 1));
70
+ this.selectedIndex = clamped;
71
+ items.forEach((item, i) => {
72
+ item.classList.toggle('wco-subtab-selected', i === clamped);
73
+ });
74
+ this.moveIndicator(items[clamped]);
75
+ if (emit) {
76
+ this.tabChange.emit(clamped);
77
+ }
78
+ }
79
+ refreshIndicator() {
80
+ const items = this.getItems();
81
+ const selected = items[this.selectedIndex];
82
+ if (selected) {
83
+ this.moveIndicator(selected);
84
+ }
85
+ }
86
+ moveIndicator(element) {
87
+ if (!this.indicator)
88
+ return;
89
+ this.el.nativeElement.style.setProperty('--subtab-left', element.offsetLeft + 'px');
90
+ this.el.nativeElement.style.setProperty('--subtab-width', element.offsetWidth + 'px');
91
+ }
92
+ ngOnDestroy() {
93
+ this.resizeObserver?.disconnect();
94
+ }
95
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SubTabsComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
96
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SubTabsComponent, isStandalone: true, selector: "wco-sub-tabs", inputs: { selectedIndex: "selectedIndex" }, outputs: { tabChange: "tabChange" }, host: { listeners: { "click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: ["wco-sub-tabs{display:inline-flex;position:relative;background:#e5e5e5;border-radius:8px;padding:4px}wco-sub-tabs>.wco-sub-tabs__indicator{position:absolute;top:4px;bottom:4px;left:var(--subtab-left, 0px);width:var(--subtab-width, 0px);background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001f;pointer-events:none;z-index:0;transition:left .22s cubic-bezier(.645,.045,.355,1),width .15s cubic-bezier(.645,.045,.355,1)}wco-sub-tabs>*:not(.wco-sub-tabs__indicator){position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;background:transparent;border:none;cursor:pointer;font-size:var(--wco-font-size-xs);font-weight:500;color:var(--wco-color-neutral-700);border-radius:6px;white-space:nowrap;line-height:1.4;transition:color .2s ease}wco-sub-tabs>*:not(.wco-sub-tabs__indicator):focus-visible{outline:2px solid var(--wco-color-primary-400);outline-offset:-2px}wco-sub-tabs>*.wco-subtab-selected{color:var(--wco-color-neutral-900);font-weight:600}\n"], encapsulation: i0.ViewEncapsulation.None });
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SubTabsComponent, decorators: [{
99
+ type: Component,
100
+ args: [{ selector: 'wco-sub-tabs', standalone: true, imports: [], template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, styles: ["wco-sub-tabs{display:inline-flex;position:relative;background:#e5e5e5;border-radius:8px;padding:4px}wco-sub-tabs>.wco-sub-tabs__indicator{position:absolute;top:4px;bottom:4px;left:var(--subtab-left, 0px);width:var(--subtab-width, 0px);background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001f;pointer-events:none;z-index:0;transition:left .22s cubic-bezier(.645,.045,.355,1),width .15s cubic-bezier(.645,.045,.355,1)}wco-sub-tabs>*:not(.wco-sub-tabs__indicator){position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;background:transparent;border:none;cursor:pointer;font-size:var(--wco-font-size-xs);font-weight:500;color:var(--wco-color-neutral-700);border-radius:6px;white-space:nowrap;line-height:1.4;transition:color .2s ease}wco-sub-tabs>*:not(.wco-sub-tabs__indicator):focus-visible{outline:2px solid var(--wco-color-primary-400);outline-offset:-2px}wco-sub-tabs>*.wco-subtab-selected{color:var(--wco-color-neutral-900);font-weight:600}\n"] }]
101
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { selectedIndex: [{
102
+ type: Input
103
+ }], tabChange: [{
104
+ type: Output
105
+ }], onClick: [{
106
+ type: HostListener,
107
+ args: ['click', ['$event']]
108
+ }] } });
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sub-tabs.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-components/src/lib/sub-tabs/sub-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\n\n@Component({\n  selector: 'wco-sub-tabs',\n  standalone: true,\n  imports: [],\n  template: `<ng-content></ng-content>`,\n  styleUrls: ['./sub-tabs.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SubTabsComponent implements AfterContentInit, OnChanges, OnDestroy {\n  @Input()\n  public selectedIndex = 0;\n\n  @Output()\n  public tabChange = new EventEmitter<number>();\n\n  private indicator!: HTMLElement;\n  private resizeObserver?: ResizeObserver;\n\n  constructor(private el: ElementRef<HTMLElement>) {}\n\n  ngAfterContentInit(): void {\n    this.indicator = document.createElement('div');\n    this.indicator.className = 'wco-sub-tabs__indicator';\n    this.el.nativeElement.prepend(this.indicator);\n\n    setTimeout(() => {\n      this.reserveBoldWidth();\n      this.indicator.style.transition = 'none';\n      this.applySelection(this.selectedIndex, false);\n      requestAnimationFrame(() => requestAnimationFrame(() => {\n        this.indicator.style.transition = '';\n      }));\n    }, 0);\n\n    this.resizeObserver = new ResizeObserver(() => {\n      this.refreshIndicator();\n    });\n    this.resizeObserver.observe(this.el.nativeElement);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['selectedIndex'] && !changes['selectedIndex'].firstChange) {\n      this.applySelection(this.selectedIndex, false);\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: Event): void {\n    const items = this.getItems();\n    const target = event.target as HTMLElement;\n\n    for (let i = 0; i < items.length; i++) {\n      if (items[i] === target || items[i].contains(target)) {\n        this.applySelection(i, true);\n        break;\n      }\n    }\n  }\n\n  private getItems(): HTMLElement[] {\n    return Array.from(this.el.nativeElement.children).filter(\n      (c) => !c.classList.contains('wco-sub-tabs__indicator')\n    ) as HTMLElement[];\n  }\n\n  private reserveBoldWidth(): void {\n    const items = this.getItems();\n    const host = this.el.nativeElement;\n\n    items.forEach((item) => {\n      const clone = item.cloneNode(true) as HTMLElement;\n      clone.style.cssText = `\n        font-weight: 600;\n        visibility: hidden;\n        position: absolute;\n        pointer-events: none;\n        white-space: nowrap;\n      `;\n      host.appendChild(clone);\n      const boldWidth = clone.offsetWidth;\n      host.removeChild(clone);\n      item.style.minWidth = boldWidth + 'px';\n    });\n  }\n\n  private applySelection(index: number, emit: boolean): void {\n    const items = this.getItems();\n    if (!items.length) return;\n\n    const clamped = Math.max(0, Math.min(index, items.length - 1));\n    this.selectedIndex = clamped;\n\n    items.forEach((item, i) => {\n      item.classList.toggle('wco-subtab-selected', i === clamped);\n    });\n\n    this.moveIndicator(items[clamped]);\n\n    if (emit) {\n      this.tabChange.emit(clamped);\n    }\n  }\n\n  private refreshIndicator(): void {\n    const items = this.getItems();\n    const selected = items[this.selectedIndex];\n    if (selected) {\n      this.moveIndicator(selected);\n    }\n  }\n\n  private moveIndicator(element: HTMLElement): void {\n    if (!this.indicator) return;\n    this.el.nativeElement.style.setProperty('--subtab-left', element.offsetLeft + 'px');\n    this.el.nativeElement.style.setProperty('--subtab-width', element.offsetWidth + 'px');\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserver?.disconnect();\n  }\n}\n"]}
@@ -30,4 +30,6 @@ export * from './lib/modal-alert/modal-alert.types';
30
30
  // Table
31
31
  export * from './lib/table/table.component';
32
32
  export * from './lib/table/table.types';
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb25lbnRzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDJCQUEyQixDQUFDO0FBRTFDLG1CQUFtQjtBQUNuQixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsOENBQThDLENBQUM7QUFFN0QsYUFBYTtBQUNiLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxZQUFZO0FBQ1osY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxTQUFTO0FBQ1QsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxlQUFlO0FBQ2YsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLG1EQUFtRCxDQUFDO0FBRWxFLFdBQVc7QUFDWCxjQUFjLG1DQUFtQyxDQUFDO0FBRWxELGVBQWU7QUFDZixjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsUUFBUTtBQUNSLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUVwRCxRQUFRO0FBQ1IsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZ3gtZmVuaXhkc1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0ZXAvc3RlcC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RlcHBlci9zdGVwcGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGVwcGVyLWdyb3VwL3N0ZXBwZXItZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VwbG9hZC91cGxvYWQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VwbG9hZC91cGxvYWQudHlwZXMnO1xuXG4vLyBtc2cgYm94IGZlZWRiYWNrXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tc2ctYm94LWZlZWRiYWNrL21zZy1ib3gtZmVlZGJhY2suY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21zZy1ib3gtZmVlZGJhY2svbXNnLWJveC1mZWViYWNrLnR5cGVzJztcblxuLy9tc2cgbmF2dGFic1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFicy90YWJzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJzL3RhYnMudHlwZXMnO1xuXG4vL1BhZ2luYXRpb25cbmV4cG9ydCAqIGZyb20gJy4vbGliL3BhZ2luYXRpb24vcGFnaW5hdGlvbi5jb21wb25lbnQnO1xuXG4vLyBBdmF0YXJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItYXZhdGFyL3VzZXItYXZhdGFyLmNvbXBvbmVudCc7XG5cbi8vIFNtYXJ0IFNlbGVjdFxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtc2VsZWN0L3NtYXJ0LXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtc2VsZWN0L3NtYXJ0LXNlbGVjdC1vcHRpb25zLmNvbXBvbmVudCc7XG5cbi8vIFRpbWVsaW5lXG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lbGluZS90aW1lbGluZS5jb21wb25lbnQnO1xuXG4vLyBQcmV2aWV3IEZpbGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByZXZpZXctZmlsZS9wcmV2aWV3LWZpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByZXZpZXctZmlsZS9wcmV2aWV3LWZpbGUudHlwZXMnO1xuXG4vLyBNb2RhbFxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kYWwtYWxlcnQvbW9kYWwtYWxlcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGFsLWFsZXJ0L21vZGFsLWFsZXJ0LnR5cGVzJztcblxuLy8gVGFibGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlL3RhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS90YWJsZS50eXBlcyc7XG4iXX0=
33
+ // Sub Tabs
34
+ export * from './lib/sub-tabs/sub-tabs.component';
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1jb21wb25lbnRzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDJCQUEyQixDQUFDO0FBRTFDLG1CQUFtQjtBQUNuQixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsOENBQThDLENBQUM7QUFFN0QsYUFBYTtBQUNiLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxZQUFZO0FBQ1osY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxTQUFTO0FBQ1QsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxlQUFlO0FBQ2YsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLG1EQUFtRCxDQUFDO0FBRWxFLFdBQVc7QUFDWCxjQUFjLG1DQUFtQyxDQUFDO0FBRWxELGVBQWU7QUFDZixjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsdUNBQXVDLENBQUM7QUFFdEQsUUFBUTtBQUNSLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUVwRCxRQUFRO0FBQ1IsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHlCQUF5QixDQUFDO0FBRXhDLFdBQVc7QUFDWCxjQUFjLG1DQUFtQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZ3gtZmVuaXhkc1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0ZXAvc3RlcC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RlcHBlci9zdGVwcGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGVwcGVyLWdyb3VwL3N0ZXBwZXItZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VwbG9hZC91cGxvYWQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VwbG9hZC91cGxvYWQudHlwZXMnO1xuXG4vLyBtc2cgYm94IGZlZWRiYWNrXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tc2ctYm94LWZlZWRiYWNrL21zZy1ib3gtZmVlZGJhY2suY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21zZy1ib3gtZmVlZGJhY2svbXNnLWJveC1mZWViYWNrLnR5cGVzJztcblxuLy9tc2cgbmF2dGFic1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFicy90YWJzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJzL3RhYnMudHlwZXMnO1xuXG4vL1BhZ2luYXRpb25cbmV4cG9ydCAqIGZyb20gJy4vbGliL3BhZ2luYXRpb24vcGFnaW5hdGlvbi5jb21wb25lbnQnO1xuXG4vLyBBdmF0YXJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItYXZhdGFyL3VzZXItYXZhdGFyLmNvbXBvbmVudCc7XG5cbi8vIFNtYXJ0IFNlbGVjdFxuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtc2VsZWN0L3NtYXJ0LXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc21hcnQtc2VsZWN0L3NtYXJ0LXNlbGVjdC1vcHRpb25zLmNvbXBvbmVudCc7XG5cbi8vIFRpbWVsaW5lXG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lbGluZS90aW1lbGluZS5jb21wb25lbnQnO1xuXG4vLyBQcmV2aWV3IEZpbGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByZXZpZXctZmlsZS9wcmV2aWV3LWZpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByZXZpZXctZmlsZS9wcmV2aWV3LWZpbGUudHlwZXMnO1xuXG4vLyBNb2RhbFxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kYWwtYWxlcnQvbW9kYWwtYWxlcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGFsLWFsZXJ0L21vZGFsLWFsZXJ0LnR5cGVzJztcblxuLy8gVGFibGVcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlL3RhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS90YWJsZS50eXBlcyc7XG5cbi8vIFN1YiBUYWJzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdWItdGFicy9zdWItdGFicy5jb21wb25lbnQnO1xuIl19
@@ -2187,6 +2187,113 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
2187
2187
  args: ['table']
2188
2188
  }] } });
2189
2189
 
2190
+ class SubTabsComponent {
2191
+ el;
2192
+ selectedIndex = 0;
2193
+ tabChange = new EventEmitter();
2194
+ indicator;
2195
+ resizeObserver;
2196
+ constructor(el) {
2197
+ this.el = el;
2198
+ }
2199
+ ngAfterContentInit() {
2200
+ this.indicator = document.createElement('div');
2201
+ this.indicator.className = 'wco-sub-tabs__indicator';
2202
+ this.el.nativeElement.prepend(this.indicator);
2203
+ setTimeout(() => {
2204
+ this.reserveBoldWidth();
2205
+ this.indicator.style.transition = 'none';
2206
+ this.applySelection(this.selectedIndex, false);
2207
+ requestAnimationFrame(() => requestAnimationFrame(() => {
2208
+ this.indicator.style.transition = '';
2209
+ }));
2210
+ }, 0);
2211
+ this.resizeObserver = new ResizeObserver(() => {
2212
+ this.refreshIndicator();
2213
+ });
2214
+ this.resizeObserver.observe(this.el.nativeElement);
2215
+ }
2216
+ ngOnChanges(changes) {
2217
+ if (changes['selectedIndex'] && !changes['selectedIndex'].firstChange) {
2218
+ this.applySelection(this.selectedIndex, false);
2219
+ }
2220
+ }
2221
+ onClick(event) {
2222
+ const items = this.getItems();
2223
+ const target = event.target;
2224
+ for (let i = 0; i < items.length; i++) {
2225
+ if (items[i] === target || items[i].contains(target)) {
2226
+ this.applySelection(i, true);
2227
+ break;
2228
+ }
2229
+ }
2230
+ }
2231
+ getItems() {
2232
+ return Array.from(this.el.nativeElement.children).filter((c) => !c.classList.contains('wco-sub-tabs__indicator'));
2233
+ }
2234
+ reserveBoldWidth() {
2235
+ const items = this.getItems();
2236
+ const host = this.el.nativeElement;
2237
+ items.forEach((item) => {
2238
+ const clone = item.cloneNode(true);
2239
+ clone.style.cssText = `
2240
+ font-weight: 600;
2241
+ visibility: hidden;
2242
+ position: absolute;
2243
+ pointer-events: none;
2244
+ white-space: nowrap;
2245
+ `;
2246
+ host.appendChild(clone);
2247
+ const boldWidth = clone.offsetWidth;
2248
+ host.removeChild(clone);
2249
+ item.style.minWidth = boldWidth + 'px';
2250
+ });
2251
+ }
2252
+ applySelection(index, emit) {
2253
+ const items = this.getItems();
2254
+ if (!items.length)
2255
+ return;
2256
+ const clamped = Math.max(0, Math.min(index, items.length - 1));
2257
+ this.selectedIndex = clamped;
2258
+ items.forEach((item, i) => {
2259
+ item.classList.toggle('wco-subtab-selected', i === clamped);
2260
+ });
2261
+ this.moveIndicator(items[clamped]);
2262
+ if (emit) {
2263
+ this.tabChange.emit(clamped);
2264
+ }
2265
+ }
2266
+ refreshIndicator() {
2267
+ const items = this.getItems();
2268
+ const selected = items[this.selectedIndex];
2269
+ if (selected) {
2270
+ this.moveIndicator(selected);
2271
+ }
2272
+ }
2273
+ moveIndicator(element) {
2274
+ if (!this.indicator)
2275
+ return;
2276
+ this.el.nativeElement.style.setProperty('--subtab-left', element.offsetLeft + 'px');
2277
+ this.el.nativeElement.style.setProperty('--subtab-width', element.offsetWidth + 'px');
2278
+ }
2279
+ ngOnDestroy() {
2280
+ this.resizeObserver?.disconnect();
2281
+ }
2282
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SubTabsComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
2283
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SubTabsComponent, isStandalone: true, selector: "wco-sub-tabs", inputs: { selectedIndex: "selectedIndex" }, outputs: { tabChange: "tabChange" }, host: { listeners: { "click": "onClick($event)" } }, usesOnChanges: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: ["wco-sub-tabs{display:inline-flex;position:relative;background:#e5e5e5;border-radius:8px;padding:4px}wco-sub-tabs>.wco-sub-tabs__indicator{position:absolute;top:4px;bottom:4px;left:var(--subtab-left, 0px);width:var(--subtab-width, 0px);background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001f;pointer-events:none;z-index:0;transition:left .22s cubic-bezier(.645,.045,.355,1),width .15s cubic-bezier(.645,.045,.355,1)}wco-sub-tabs>*:not(.wco-sub-tabs__indicator){position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;background:transparent;border:none;cursor:pointer;font-size:var(--wco-font-size-xs);font-weight:500;color:var(--wco-color-neutral-700);border-radius:6px;white-space:nowrap;line-height:1.4;transition:color .2s ease}wco-sub-tabs>*:not(.wco-sub-tabs__indicator):focus-visible{outline:2px solid var(--wco-color-primary-400);outline-offset:-2px}wco-sub-tabs>*.wco-subtab-selected{color:var(--wco-color-neutral-900);font-weight:600}\n"], encapsulation: i0.ViewEncapsulation.None });
2284
+ }
2285
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SubTabsComponent, decorators: [{
2286
+ type: Component,
2287
+ args: [{ selector: 'wco-sub-tabs', standalone: true, imports: [], template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, styles: ["wco-sub-tabs{display:inline-flex;position:relative;background:#e5e5e5;border-radius:8px;padding:4px}wco-sub-tabs>.wco-sub-tabs__indicator{position:absolute;top:4px;bottom:4px;left:var(--subtab-left, 0px);width:var(--subtab-width, 0px);background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001f;pointer-events:none;z-index:0;transition:left .22s cubic-bezier(.645,.045,.355,1),width .15s cubic-bezier(.645,.045,.355,1)}wco-sub-tabs>*:not(.wco-sub-tabs__indicator){position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;background:transparent;border:none;cursor:pointer;font-size:var(--wco-font-size-xs);font-weight:500;color:var(--wco-color-neutral-700);border-radius:6px;white-space:nowrap;line-height:1.4;transition:color .2s ease}wco-sub-tabs>*:not(.wco-sub-tabs__indicator):focus-visible{outline:2px solid var(--wco-color-primary-400);outline-offset:-2px}wco-sub-tabs>*.wco-subtab-selected{color:var(--wco-color-neutral-900);font-weight:600}\n"] }]
2288
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { selectedIndex: [{
2289
+ type: Input
2290
+ }], tabChange: [{
2291
+ type: Output
2292
+ }], onClick: [{
2293
+ type: HostListener,
2294
+ args: ['click', ['$event']]
2295
+ }] } });
2296
+
2190
2297
  /*
2191
2298
  * Public API Surface of ngx-fenixds
2192
2299
  */
@@ -2195,5 +2302,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
2195
2302
  * Generated bundle index. Do not edit.
2196
2303
  */
2197
2304
 
2198
- export { MsgBoxFeedbackComponent, PaginationComponent, PreviewFileComponent, SmartSelectComponent, SmartSelectOptionComponent, StepComponent, StepperComponent, StepperGroupComponent, TableComponent, TabsComponent, TimelineComponent, UploadComponent, UserAvatarComponent, WcoModalAlertComponent };
2305
+ export { MsgBoxFeedbackComponent, PaginationComponent, PreviewFileComponent, SmartSelectComponent, SmartSelectOptionComponent, StepComponent, StepperComponent, StepperGroupComponent, SubTabsComponent, TableComponent, TabsComponent, TimelineComponent, UploadComponent, UserAvatarComponent, WcoModalAlertComponent };
2199
2306
  //# sourceMappingURL=wizco-fenixds-ngx.mjs.map