@ngrdt/tabs 0.0.17 → 0.0.19

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.
@@ -1,270 +0,0 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, DestroyRef, ElementRef, EventEmitter, HostBinding, HostListener, inject, Input, Output, QueryList, Renderer2, ViewChild, ViewChildren, ViewEncapsulation, } from '@angular/core';
2
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { canTransition$, RDT_GUARDED_COMPONENT, RdtChildDirective, } from '@ngrdt/core';
4
- import { RdtHTMLUtils } from '@ngrdt/utils';
5
- import { firstValueFrom, timer } from 'rxjs';
6
- import { RdtTabControllerDirective } from '../../directives/rdt-tab-controller.directive';
7
- import { RdtTabComponent } from '../tab/rdt-tab.component';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@ngrdt/core";
10
- import * as i2 from "@angular/common";
11
- export class RdtTabContainerComponent {
12
- destroyRef = inject(DestroyRef);
13
- stateId = null;
14
- set value(val) {
15
- if (this.activeTab && this.activeTab.stateId !== val) {
16
- // TODO
17
- //this.activeTab.onViewWillLeave();
18
- }
19
- this._value = val;
20
- this.setCurrent();
21
- }
22
- get value() {
23
- return this._value;
24
- }
25
- _value;
26
- disabled = false;
27
- formAutofocus = true;
28
- panelPosition = 'top';
29
- valueChange = new EventEmitter();
30
- tabsList;
31
- tabHeaderButtons;
32
- tabContent;
33
- _active = false;
34
- get active() {
35
- return this._active;
36
- }
37
- set active(value) {
38
- this._active = value;
39
- this.cd.markForCheck();
40
- }
41
- get isTopLevel() {
42
- return !this.parentTab;
43
- }
44
- parentTab = inject(RdtTabComponent, { optional: true });
45
- controller = inject(RdtTabControllerDirective, {
46
- optional: true,
47
- });
48
- cd = inject(ChangeDetectorRef);
49
- elRef = inject(ElementRef);
50
- renderer = inject(Renderer2);
51
- currentTemplate = null;
52
- currentTab = null;
53
- get classes() {
54
- return `dp3-tab-container panel-${this.panelPosition}`;
55
- }
56
- get isHorizontal() {
57
- return this.panelPosition === 'top' || this.panelPosition === 'bottom';
58
- }
59
- get isVertical() {
60
- return !this.isHorizontal;
61
- }
62
- attrRole = 'tablist';
63
- get hasNonDisabledTabs() {
64
- return this.tabsList.some((tab) => !tab.disabled);
65
- }
66
- get activeTab() {
67
- return this.getTabByValue(this.value);
68
- }
69
- getTabByValue(value) {
70
- return this.tabsList?.find((tab) => tab.stateId === value);
71
- }
72
- ngAfterContentInit() {
73
- this.controller?.onTabContainerChanges();
74
- timer(0)
75
- .pipe(takeUntilDestroyed(this.destroyRef))
76
- .subscribe(() => this.setCurrent());
77
- this.tabsList.changes
78
- .pipe(takeUntilDestroyed(this.destroyRef))
79
- .subscribe(() => {
80
- this.controller?.onTabChanges();
81
- this.setCurrent();
82
- this.cd.markForCheck();
83
- });
84
- if (this.stateId === null && this.controller) {
85
- const id = this.controller.getTabContainerIndex(this);
86
- this.stateId = `tab-container-${id}`;
87
- }
88
- }
89
- getState() {
90
- return {
91
- id: this.stateId,
92
- value: this.value,
93
- tabStates: this.tabsList.map((tab) => tab.getState()),
94
- };
95
- }
96
- applyState(state) {
97
- this.value = state.value;
98
- this.scrollCurrentButtonIntoView();
99
- const states = [...state.tabStates];
100
- const tabs = this.tabsList.toArray();
101
- const minLen = Math.min(states.length, tabs.length);
102
- for (let i = 0; i < minLen; i++) {
103
- if (tabs[i].stateId === states[i].id) {
104
- tabs[i].applyState(states[i]);
105
- tabs[i] = states[i] = null;
106
- }
107
- }
108
- tabs.forEach((tab, tabI) => {
109
- if (!tab) {
110
- return;
111
- }
112
- for (let offset = 0; offset < states.length; offset++) {
113
- const prev = tabI - offset;
114
- const next = tabI + offset;
115
- if (prev > 0 && states[prev]?.id === tab.stateId) {
116
- tab.applyState(states[prev]);
117
- states[prev] = null;
118
- return;
119
- }
120
- else if (next < states.length && states[next]?.id === tab.stateId) {
121
- tab.applyState(states[next]);
122
- states[next] = null;
123
- return;
124
- }
125
- }
126
- });
127
- }
128
- scrollIntoView() {
129
- this.elRef?.nativeElement?.scrollIntoView({ behavior: 'smooth' });
130
- }
131
- async activateTab(value) {
132
- const nextTab = this.getTabByValue(value);
133
- const can = await firstValueFrom(canTransition$(this.activeTab?.contDir, nextTab?.contDir));
134
- if (can) {
135
- this.value = value;
136
- this.valueChange.emit(value);
137
- }
138
- }
139
- scrollCurrentButtonIntoView() {
140
- if (!this.tabsList || !this.tabHeaderButtons) {
141
- return;
142
- }
143
- const tabIndex = this.tabsList
144
- .toArray()
145
- .findIndex((tab) => tab.stateId === this.value);
146
- const buttonRef = this.tabHeaderButtons.get(tabIndex);
147
- if (buttonRef) {
148
- RdtHTMLUtils.scrollIntoViewHorizontallyWithinParent(buttonRef.nativeElement);
149
- }
150
- }
151
- onClick(event) {
152
- this.controller?.activateTabContainerFromClick(this, event.timeStamp);
153
- }
154
- setCurrent() {
155
- if (!this.tabsList) {
156
- return;
157
- }
158
- if (this.value == undefined) {
159
- const firstEnabled = this.getFirstEnabledTab();
160
- if (firstEnabled) {
161
- this.value = firstEnabled.stateId;
162
- }
163
- else {
164
- return;
165
- }
166
- }
167
- const found = this.tabsList.find((tab) => tab.stateId === this.value);
168
- if (!found) {
169
- const first = this.getFirstEnabledTab();
170
- if (first) {
171
- this.activateTab(first.stateId);
172
- return;
173
- }
174
- else {
175
- console.error('Active tab not found.', this.tabsList.toArray(), this.value);
176
- return;
177
- }
178
- }
179
- this.setTab(found);
180
- }
181
- setTab(tab) {
182
- if (this.currentTab !== tab) {
183
- this.solidifyTabContentSize();
184
- this.currentTab = tab;
185
- this.currentTemplate = tab.templateRef;
186
- this.cd.markForCheck();
187
- //tab.onViewWillEnter();
188
- }
189
- if (this.formAutofocus && tab.formAutofocus) {
190
- // Wait until template is attached to DOM
191
- timer(0)
192
- .pipe(takeUntilDestroyed(this.destroyRef), takeUntilDestroyed(tab.destroyRef))
193
- .subscribe(() => tab.focusForm());
194
- }
195
- setTimeout(() => this.releaseTabContentSize());
196
- }
197
- // Swapping template in template outlet will cause large css recalc
198
- // fix size to previous tab and in case they are the same size
199
- // the recalc isn't noticable
200
- solidifyTabContentSize() {
201
- const el = this.tabContent.nativeElement;
202
- const bb = el.getBoundingClientRect();
203
- this.renderer.setStyle(el, 'width', bb.width + 'px');
204
- this.renderer.setStyle(el, 'height', bb.height + 'px');
205
- }
206
- releaseTabContentSize() {
207
- const el = this.tabContent.nativeElement;
208
- this.renderer.removeStyle(el, 'width');
209
- this.renderer.removeStyle(el, 'height');
210
- }
211
- getFirstEnabledTab() {
212
- return this.tabsList.find((t) => !t.disabled);
213
- }
214
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtTabContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
215
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: RdtTabContainerComponent, selector: "rdt-tab-container", inputs: { stateId: "stateId", value: "value", disabled: "disabled", formAutofocus: "formAutofocus", panelPosition: "panelPosition" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "click": "onClick($event)" }, properties: { "class.active": "this._active", "class": "this.classes", "class.panel-horizontal": "this.isHorizontal", "class.panel-vertical": "this.isVertical", "attr.role": "this.attrRole" } }, providers: [
216
- {
217
- provide: RDT_GUARDED_COMPONENT,
218
- useExisting: RdtTabContainerComponent,
219
- },
220
- ], queries: [{ propertyName: "tabsList", predicate: RdtTabComponent }], viewQueries: [{ propertyName: "tabContent", first: true, predicate: ["tabContent"], descendants: true, static: true }, { propertyName: "tabHeaderButtons", predicate: ["headerButton"], descendants: true }], hostDirectives: [{ directive: i1.RdtChildDirective }], ngImport: i0, template: "<div class=\"tab-header-panel\" *ngIf=\"tabsList\">\r\n <button\r\n *ngFor=\"let tab of tabsList\"\r\n #headerButton\r\n class=\"px-2 py-1 tab-header-button\"\r\n (click)=\"activateTab(tab.stateId)\"\r\n [class.active]=\"value === tab.stateId\"\r\n [disabled]=\"tab.disabled\"\r\n [hidden]=\"!tab.visible\"\r\n role=\"tab\"\r\n [attr.aria-selected]=\"value === tab.stateId\"\r\n [attr.aria-controls]=\"'panel-' + tab.stateId\"\r\n [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\r\n [id]=\"'tab-' + tab.stateId\"\r\n [class]=\"tab.buttonClass\"\r\n type=\"button\"\r\n >\r\n {{ tab.label }}\r\n </button>\r\n</div>\r\n<div\r\n class=\"tab-content\"\r\n role=\"tabpanel\"\r\n [id]=\"'panel-' + value\"\r\n [attr.aria-labelledby]=\"'tab-' + value\"\r\n #tabContent\r\n>\r\n <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\r\n</div>\r\n", styles: ["dp3-tab-container{--tab-header-border-height: 2px;--tab-header-border-color: #e2e8f0;--tab-text-color: rgb(100, 116, 139);--active-tab-text-color: var(--primary-blue);--active-tab-border-color: var(--primary-blue);--disabled-tab-text-color: #b1b9c5;--tab-vertical-button-width: 200px;display:block;position:relative}dp3-tab-container.active>.tab-header-panel{background-color:var(--hover-blue)}dp3-tab-container.panel-vertical{display:flex}dp3-tab-container.panel-vertical>.tab-header-panel{position:absolute;top:0;height:100%;width:var(--tab-vertical-button-width);overflow-y:auto}dp3-tab-container.panel-vertical>.tab-header-panel>button{text-align:left;width:100%;white-space:nowrap;overflow-x:hidden;text-overflow:ellipsis}dp3-tab-container.panel-vertical>.tab-content{width:calc(100% - var(--tab-vertical-button-width))}dp3-tab-container.panel-right{flex-direction:row-reverse}dp3-tab-container.panel-right>.tab-header-panel{right:0}dp3-tab-container.panel-left>.tab-header-panel{left:0}dp3-tab-container.panel-left>.tab-content{margin-left:var(--tab-vertical-button-width)}dp3-tab-container.panel-horizontal>.tab-header-panel{width:100%;white-space:nowrap;overflow-x:auto}dp3-tab-container.panel-bottom{display:flex;flex-direction:column-reverse}dp3-tab-container .tab-header-panel{position:relative;background-color:rgba(var(--primary-blue-rgb),.045)}dp3-tab-container .tab-header-panel:after{content:\"\";position:absolute;width:100%;height:var(--tab-header-border-height);background-color:var(--tab-header-border-color);margin-top:var(--tab-header-border-height);bottom:0;left:0;z-index:-1}dp3-tab-container .dot{position:absolute;width:.85rem;height:.85rem;padding:0 .1rem;background-color:var(--primary-blue);color:var(--white);font-size:x-small;border-radius:100%;top:.25rem;right:0rem}dp3-tab-container .tab-header-button{position:relative;background:none;font:inherit;outline:inherit;border:none;color:var(--tab-text-color);font-weight:700;font-size:1.1rem}dp3-tab-container .tab-header-button.active{position:relative;color:var(--active-tab-text-color)}dp3-tab-container .tab-header-button.active:after{content:\"\";position:absolute;width:100%;height:var(--tab-header-border-height);background-color:var(--active-tab-text-color);margin-top:var(--tab-header-border-height);bottom:0;left:0}dp3-tab-container .tab-header-button:disabled{color:var(--disabled-tab-text-color)}dp3-tab-container .tab-header-button.padding-small{padding-right:1.1rem!important}dp3-tab-container .tab-header-button.padding-large{padding-right:1.3rem!important}dp3-tab-container>.tab-content{min-width:0;width:100%;padding:.5rem}dp3-tab-container>.tab-content:has(>.dp3-tab-container){padding:0}dp3-tab-container>.tab-content>.dp3-tab-container{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
221
- }
222
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtTabContainerComponent, decorators: [{
223
- type: Component,
224
- args: [{ selector: 'rdt-tab-container', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
225
- {
226
- provide: RDT_GUARDED_COMPONENT,
227
- useExisting: RdtTabContainerComponent,
228
- },
229
- ], hostDirectives: [RdtChildDirective], encapsulation: ViewEncapsulation.None, template: "<div class=\"tab-header-panel\" *ngIf=\"tabsList\">\r\n <button\r\n *ngFor=\"let tab of tabsList\"\r\n #headerButton\r\n class=\"px-2 py-1 tab-header-button\"\r\n (click)=\"activateTab(tab.stateId)\"\r\n [class.active]=\"value === tab.stateId\"\r\n [disabled]=\"tab.disabled\"\r\n [hidden]=\"!tab.visible\"\r\n role=\"tab\"\r\n [attr.aria-selected]=\"value === tab.stateId\"\r\n [attr.aria-controls]=\"'panel-' + tab.stateId\"\r\n [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\r\n [id]=\"'tab-' + tab.stateId\"\r\n [class]=\"tab.buttonClass\"\r\n type=\"button\"\r\n >\r\n {{ tab.label }}\r\n </button>\r\n</div>\r\n<div\r\n class=\"tab-content\"\r\n role=\"tabpanel\"\r\n [id]=\"'panel-' + value\"\r\n [attr.aria-labelledby]=\"'tab-' + value\"\r\n #tabContent\r\n>\r\n <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\r\n</div>\r\n", styles: ["dp3-tab-container{--tab-header-border-height: 2px;--tab-header-border-color: #e2e8f0;--tab-text-color: rgb(100, 116, 139);--active-tab-text-color: var(--primary-blue);--active-tab-border-color: var(--primary-blue);--disabled-tab-text-color: #b1b9c5;--tab-vertical-button-width: 200px;display:block;position:relative}dp3-tab-container.active>.tab-header-panel{background-color:var(--hover-blue)}dp3-tab-container.panel-vertical{display:flex}dp3-tab-container.panel-vertical>.tab-header-panel{position:absolute;top:0;height:100%;width:var(--tab-vertical-button-width);overflow-y:auto}dp3-tab-container.panel-vertical>.tab-header-panel>button{text-align:left;width:100%;white-space:nowrap;overflow-x:hidden;text-overflow:ellipsis}dp3-tab-container.panel-vertical>.tab-content{width:calc(100% - var(--tab-vertical-button-width))}dp3-tab-container.panel-right{flex-direction:row-reverse}dp3-tab-container.panel-right>.tab-header-panel{right:0}dp3-tab-container.panel-left>.tab-header-panel{left:0}dp3-tab-container.panel-left>.tab-content{margin-left:var(--tab-vertical-button-width)}dp3-tab-container.panel-horizontal>.tab-header-panel{width:100%;white-space:nowrap;overflow-x:auto}dp3-tab-container.panel-bottom{display:flex;flex-direction:column-reverse}dp3-tab-container .tab-header-panel{position:relative;background-color:rgba(var(--primary-blue-rgb),.045)}dp3-tab-container .tab-header-panel:after{content:\"\";position:absolute;width:100%;height:var(--tab-header-border-height);background-color:var(--tab-header-border-color);margin-top:var(--tab-header-border-height);bottom:0;left:0;z-index:-1}dp3-tab-container .dot{position:absolute;width:.85rem;height:.85rem;padding:0 .1rem;background-color:var(--primary-blue);color:var(--white);font-size:x-small;border-radius:100%;top:.25rem;right:0rem}dp3-tab-container .tab-header-button{position:relative;background:none;font:inherit;outline:inherit;border:none;color:var(--tab-text-color);font-weight:700;font-size:1.1rem}dp3-tab-container .tab-header-button.active{position:relative;color:var(--active-tab-text-color)}dp3-tab-container .tab-header-button.active:after{content:\"\";position:absolute;width:100%;height:var(--tab-header-border-height);background-color:var(--active-tab-text-color);margin-top:var(--tab-header-border-height);bottom:0;left:0}dp3-tab-container .tab-header-button:disabled{color:var(--disabled-tab-text-color)}dp3-tab-container .tab-header-button.padding-small{padding-right:1.1rem!important}dp3-tab-container .tab-header-button.padding-large{padding-right:1.3rem!important}dp3-tab-container>.tab-content{min-width:0;width:100%;padding:.5rem}dp3-tab-container>.tab-content:has(>.dp3-tab-container){padding:0}dp3-tab-container>.tab-content>.dp3-tab-container{width:100%;height:100%}\n"] }]
230
- }], propDecorators: { stateId: [{
231
- type: Input
232
- }], value: [{
233
- type: Input
234
- }], disabled: [{
235
- type: Input
236
- }], formAutofocus: [{
237
- type: Input
238
- }], panelPosition: [{
239
- type: Input
240
- }], valueChange: [{
241
- type: Output
242
- }], tabsList: [{
243
- type: ContentChildren,
244
- args: [RdtTabComponent]
245
- }], tabHeaderButtons: [{
246
- type: ViewChildren,
247
- args: ['headerButton']
248
- }], tabContent: [{
249
- type: ViewChild,
250
- args: ['tabContent', { static: true }]
251
- }], _active: [{
252
- type: HostBinding,
253
- args: ['class.active']
254
- }], classes: [{
255
- type: HostBinding,
256
- args: ['class']
257
- }], isHorizontal: [{
258
- type: HostBinding,
259
- args: ['class.panel-horizontal']
260
- }], isVertical: [{
261
- type: HostBinding,
262
- args: ['class.panel-vertical']
263
- }], attrRole: [{
264
- type: HostBinding,
265
- args: ['attr.role']
266
- }], onClick: [{
267
- type: HostListener,
268
- args: ['click', ['$event']]
269
- }] } });
270
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rdt-tab-container.component.js","sourceRoot":"","sources":["../../../../../../../@ngrdt/tabs/src/lib/components/tab-container/rdt-tab-container.component.ts","../../../../../../../@ngrdt/tabs/src/lib/components/tab-container/rdt-tab-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterContentInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChildren,\r\n  DestroyRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  inject,\r\n  Input,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewChildren,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport {\r\n  canTransition$,\r\n  RDT_GUARDED_COMPONENT,\r\n  RdtChildDirective,\r\n} from '@ngrdt/core';\r\nimport { RdtHTMLUtils } from '@ngrdt/utils';\r\nimport { firstValueFrom, timer } from 'rxjs';\r\nimport { RdtTabControllerDirective } from '../../directives/rdt-tab-controller.directive';\r\nimport { RdtTabContainerState, RdtTabState } from '../../rdt-tabs-models';\r\nimport { RdtTabComponent } from '../tab/rdt-tab.component';\r\n\r\n@Component({\r\n  selector: 'rdt-tab-container',\r\n  templateUrl: './rdt-tab-container.component.html',\r\n  styleUrls: ['./rdt-tab-container.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: RDT_GUARDED_COMPONENT,\r\n      useExisting: RdtTabContainerComponent,\r\n    },\r\n  ],\r\n  hostDirectives: [RdtChildDirective],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class RdtTabContainerComponent implements AfterContentInit {\r\n  readonly destroyRef = inject(DestroyRef);\r\n\r\n  @Input()\r\n  stateId: any = null;\r\n\r\n  @Input()\r\n  set value(val: string) {\r\n    if (this.activeTab && this.activeTab.stateId !== val) {\r\n      // TODO\r\n      //this.activeTab.onViewWillLeave();\r\n    }\r\n    this._value = val;\r\n    this.setCurrent();\r\n  }\r\n  get value() {\r\n    return this._value;\r\n  }\r\n  private _value!: string;\r\n\r\n  @Input()\r\n  disabled = false;\r\n\r\n  @Input()\r\n  formAutofocus = true;\r\n\r\n  @Input()\r\n  panelPosition: 'left' | 'right' | 'top' | 'bottom' = 'top';\r\n\r\n  @Output()\r\n  valueChange = new EventEmitter();\r\n\r\n  @ContentChildren(RdtTabComponent)\r\n  tabsList!: QueryList<RdtTabComponent>;\r\n\r\n  @ViewChildren('headerButton')\r\n  tabHeaderButtons?: QueryList<ElementRef<HTMLElement>>;\r\n\r\n  @ViewChild('tabContent', { static: true })\r\n  tabContent!: ElementRef<HTMLElement>;\r\n\r\n  @HostBinding('class.active')\r\n  private _active = false;\r\n  get active() {\r\n    return this._active;\r\n  }\r\n  set active(value: boolean) {\r\n    this._active = value;\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  get isTopLevel(): boolean {\r\n    return !this.parentTab;\r\n  }\r\n\r\n  readonly parentTab = inject(RdtTabComponent, { optional: true });\r\n  readonly controller = inject(RdtTabControllerDirective, {\r\n    optional: true,\r\n  });\r\n  readonly cd = inject(ChangeDetectorRef);\r\n  readonly elRef = inject(ElementRef);\r\n  protected readonly renderer = inject(Renderer2);\r\n\r\n  protected currentTemplate: TemplateRef<any> | null = null;\r\n  protected currentTab: RdtTabComponent | null = null;\r\n\r\n  @HostBinding('class')\r\n  get classes() {\r\n    return `dp3-tab-container panel-${this.panelPosition}`;\r\n  }\r\n\r\n  @HostBinding('class.panel-horizontal')\r\n  get isHorizontal() {\r\n    return this.panelPosition === 'top' || this.panelPosition === 'bottom';\r\n  }\r\n\r\n  @HostBinding('class.panel-vertical')\r\n  get isVertical() {\r\n    return !this.isHorizontal;\r\n  }\r\n\r\n  @HostBinding('attr.role')\r\n  private attrRole = 'tablist';\r\n\r\n  get hasNonDisabledTabs() {\r\n    return this.tabsList.some((tab) => !tab.disabled);\r\n  }\r\n\r\n  get activeTab() {\r\n    return this.getTabByValue(this.value);\r\n  }\r\n\r\n  getTabByValue(value: string) {\r\n    return this.tabsList?.find((tab) => tab.stateId === value);\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.controller?.onTabContainerChanges();\r\n    timer(0)\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(() => this.setCurrent());\r\n\r\n    this.tabsList.changes\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(() => {\r\n        this.controller?.onTabChanges();\r\n        this.setCurrent();\r\n        this.cd.markForCheck();\r\n      });\r\n\r\n    if (this.stateId === null && this.controller) {\r\n      const id = this.controller.getTabContainerIndex(this);\r\n      this.stateId = `tab-container-${id}`;\r\n    }\r\n  }\r\n\r\n  getState(): RdtTabContainerState {\r\n    return {\r\n      id: this.stateId,\r\n      value: this.value,\r\n      tabStates: this.tabsList.map((tab) => tab.getState()),\r\n    };\r\n  }\r\n\r\n  applyState(state: RdtTabContainerState) {\r\n    this.value = state.value;\r\n    this.scrollCurrentButtonIntoView();\r\n\r\n    const states: (RdtTabState | null)[] = [...state.tabStates];\r\n    const tabs: (RdtTabComponent | null)[] = this.tabsList.toArray();\r\n    const minLen = Math.min(states.length, tabs.length);\r\n\r\n    for (let i = 0; i < minLen; i++) {\r\n      if (tabs[i]!.stateId === states[i]!.id) {\r\n        tabs[i]!.applyState(states[i]!);\r\n        tabs[i] = states[i] = null;\r\n      }\r\n    }\r\n    tabs.forEach((tab, tabI) => {\r\n      if (!tab) {\r\n        return;\r\n      }\r\n      for (let offset = 0; offset < states.length; offset++) {\r\n        const prev = tabI - offset;\r\n        const next = tabI + offset;\r\n        if (prev > 0 && states[prev]?.id === tab.stateId) {\r\n          tab.applyState(states[prev]!);\r\n          states[prev] = null;\r\n          return;\r\n        } else if (next < states.length && states[next]?.id === tab.stateId) {\r\n          tab.applyState(states[next]!);\r\n          states[next] = null;\r\n          return;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  scrollIntoView() {\r\n    this.elRef?.nativeElement?.scrollIntoView({ behavior: 'smooth' });\r\n  }\r\n\r\n  async activateTab(value: string) {\r\n    const nextTab = this.getTabByValue(value);\r\n\r\n    const can = await firstValueFrom(\r\n      canTransition$(this.activeTab?.contDir, nextTab?.contDir)\r\n    );\r\n    if (can) {\r\n      this.value = value;\r\n      this.valueChange.emit(value);\r\n    }\r\n  }\r\n\r\n  scrollCurrentButtonIntoView() {\r\n    if (!this.tabsList || !this.tabHeaderButtons) {\r\n      return;\r\n    }\r\n    const tabIndex = this.tabsList\r\n      .toArray()\r\n      .findIndex((tab) => tab.stateId === this.value);\r\n    const buttonRef = this.tabHeaderButtons.get(tabIndex);\r\n    if (buttonRef) {\r\n      RdtHTMLUtils.scrollIntoViewHorizontallyWithinParent(\r\n        buttonRef.nativeElement\r\n      );\r\n    }\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  private onClick(event: PointerEvent) {\r\n    this.controller?.activateTabContainerFromClick(this, event.timeStamp);\r\n  }\r\n\r\n  private setCurrent() {\r\n    if (!this.tabsList) {\r\n      return;\r\n    }\r\n    if (this.value == undefined) {\r\n      const firstEnabled = this.getFirstEnabledTab();\r\n      if (firstEnabled) {\r\n        this.value = firstEnabled.stateId;\r\n      } else {\r\n        return;\r\n      }\r\n    }\r\n\r\n    const found = this.tabsList.find((tab) => tab.stateId === this.value);\r\n    if (!found) {\r\n      const first = this.getFirstEnabledTab();\r\n      if (first) {\r\n        this.activateTab(first.stateId);\r\n        return;\r\n      } else {\r\n        console.error(\r\n          'Active tab not found.',\r\n          this.tabsList.toArray(),\r\n          this.value\r\n        );\r\n        return;\r\n      }\r\n    }\r\n    this.setTab(found);\r\n  }\r\n\r\n  private setTab(tab: RdtTabComponent) {\r\n    if (this.currentTab !== tab) {\r\n      this.solidifyTabContentSize();\r\n      this.currentTab = tab;\r\n      this.currentTemplate = tab.templateRef;\r\n      this.cd.markForCheck();\r\n      //tab.onViewWillEnter();\r\n    }\r\n\r\n    if (this.formAutofocus && tab.formAutofocus) {\r\n      // Wait until template is attached to DOM\r\n      timer(0)\r\n        .pipe(\r\n          takeUntilDestroyed(this.destroyRef),\r\n          takeUntilDestroyed(tab.destroyRef)\r\n        )\r\n        .subscribe(() => tab.focusForm());\r\n    }\r\n\r\n    setTimeout(() => this.releaseTabContentSize());\r\n  }\r\n\r\n  // Swapping template in template outlet will cause large css recalc\r\n  // fix size to previous tab and in case they are the same size\r\n  // the recalc isn't noticable\r\n  private solidifyTabContentSize() {\r\n    const el = this.tabContent.nativeElement;\r\n    const bb = el.getBoundingClientRect();\r\n    this.renderer.setStyle(el, 'width', bb.width + 'px');\r\n    this.renderer.setStyle(el, 'height', bb.height + 'px');\r\n  }\r\n\r\n  private releaseTabContentSize() {\r\n    const el = this.tabContent.nativeElement;\r\n    this.renderer.removeStyle(el, 'width');\r\n    this.renderer.removeStyle(el, 'height');\r\n  }\r\n\r\n  private getFirstEnabledTab() {\r\n    return this.tabsList.find((t) => !t.disabled);\r\n  }\r\n}\r\n","<div class=\"tab-header-panel\" *ngIf=\"tabsList\">\r\n  <button\r\n    *ngFor=\"let tab of tabsList\"\r\n    #headerButton\r\n    class=\"px-2 py-1 tab-header-button\"\r\n    (click)=\"activateTab(tab.stateId)\"\r\n    [class.active]=\"value === tab.stateId\"\r\n    [disabled]=\"tab.disabled\"\r\n    [hidden]=\"!tab.visible\"\r\n    role=\"tab\"\r\n    [attr.aria-selected]=\"value === tab.stateId\"\r\n    [attr.aria-controls]=\"'panel-' + tab.stateId\"\r\n    [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\r\n    [id]=\"'tab-' + tab.stateId\"\r\n    [class]=\"tab.buttonClass\"\r\n    type=\"button\"\r\n  >\r\n    {{ tab.label }}\r\n  </button>\r\n</div>\r\n<div\r\n  class=\"tab-content\"\r\n  role=\"tabpanel\"\r\n  [id]=\"'panel-' + value\"\r\n  [attr.aria-labelledby]=\"'tab-' + value\"\r\n  #tabContent\r\n>\r\n  <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\r\n</div>\r\n"]}
@@ -1,14 +0,0 @@
1
- import { Directive, inject, TemplateRef } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class RdtDestroyInactiveDirective {
4
- template = inject(TemplateRef);
5
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtDestroyInactiveDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
6
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: RdtDestroyInactiveDirective, selector: "[rdtDestroyInactive]", ngImport: i0 });
7
- }
8
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtDestroyInactiveDirective, decorators: [{
9
- type: Directive,
10
- args: [{
11
- selector: '[rdtDestroyInactive]',
12
- }]
13
- }] });
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWRlc3Ryb3ktaW5hY3RpdmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vQG5ncmR0L3RhYnMvc3JjL2xpYi9kaXJlY3RpdmVzL3JkdC1kZXN0cm95LWluYWN0aXZlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSy9ELE1BQU0sT0FBTywyQkFBMkI7SUFDdEIsUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQzt1R0FEcEMsMkJBQTJCOzJGQUEzQiwyQkFBMkI7OzJGQUEzQiwyQkFBMkI7a0JBSHZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3JkdERlc3Ryb3lJbmFjdGl2ZV0nLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmR0RGVzdHJveUluYWN0aXZlRGlyZWN0aXZlIHtcclxuICBwdWJsaWMgcmVhZG9ubHkgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xyXG59XHJcbiJdfQ==