@ngrdt/tabs 0.0.3 → 0.0.18

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.
package/index.d.ts CHANGED
@@ -1,8 +1,218 @@
1
- export * from './lib/components/tab-container/rdt-tab-container.component';
2
- export * from './lib/components/tab/rdt-tab.component';
3
- export * from './lib/directives/rdt-destroy-inactive.directive';
4
- export * from './lib/directives/rdt-tab-controller.directive';
5
- export * from './lib/rdt-tabs-models';
6
- export * from './lib/rdt-tabs.module';
7
- export * from './lib/strategies/rdt-tabs-shortcut-strategy';
8
- export * from './lib/strategies/static-rdt-tabs-shortcut-strategy';
1
+ import * as i0 from '@angular/core';
2
+ import { OnChanges, OnInit, DestroyRef, TemplateRef, SimpleChanges, AfterContentInit, OnDestroy, QueryList, EventEmitter, ElementRef, ChangeDetectorRef, Renderer2 } from '@angular/core';
3
+ import * as i1 from '@ngrdt/core';
4
+ import { RdtIsActive, RdtContainerDirective } from '@ngrdt/core';
5
+ import { RdtShortcut } from '@ngrdt/shortcuts';
6
+ import { Nullable } from '@ngrdt/utils';
7
+ import * as i5 from '@angular/common';
8
+
9
+ interface RdtTabContainerState {
10
+ id: any;
11
+ value: any;
12
+ tabStates: RdtTabState[];
13
+ }
14
+ interface RdtTabState {
15
+ id: any;
16
+ containerStates: RdtTabContainerState[];
17
+ }
18
+ declare enum RdtTabMode {
19
+ }
20
+
21
+ declare class RdtTabComponent implements OnChanges, OnInit, RdtIsActive {
22
+ private readonly injector;
23
+ readonly destroyRef: DestroyRef;
24
+ private _contDir;
25
+ get contDir(): RdtContainerDirective;
26
+ get stateId(): string;
27
+ set stateId(value: string);
28
+ private _stateId;
29
+ disabled: boolean;
30
+ visible: boolean;
31
+ label: string;
32
+ formAutofocus: boolean;
33
+ buttonClass: Nullable<string>;
34
+ private readonly implicitContent;
35
+ private readonly explicitContent;
36
+ get templateRef(): TemplateRef<any>;
37
+ readonly tabContainer: RdtTabContainerComponent;
38
+ get childContainers(): RdtTabContainerComponent[];
39
+ rdtIsActive(): boolean;
40
+ ngOnInit(): void;
41
+ ngOnChanges(changes: SimpleChanges): void;
42
+ get isTopLevel(): boolean;
43
+ getState(): RdtTabState;
44
+ applyState(state: RdtTabState): void;
45
+ focusForm(): void;
46
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdtTabComponent, never>;
47
+ static ɵcmp: i0.ɵɵComponentDeclaration<RdtTabComponent, "rdt-tab", never, { "stateId": { "alias": "stateId"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "visible": { "alias": "visible"; "required": false; }; "label": { "alias": "label"; "required": true; }; "formAutofocus": { "alias": "formAutofocus"; "required": false; }; "buttonClass": { "alias": "buttonClass"; "required": false; }; }, {}, ["explicitContent"], ["*"], false, [{ directive: typeof i1.RdtContainerDirective; inputs: {}; outputs: {}; }]>;
48
+ static ngAcceptInputType_disabled: unknown;
49
+ static ngAcceptInputType_visible: unknown;
50
+ static ngAcceptInputType_formAutofocus: unknown;
51
+ }
52
+
53
+ declare abstract class RdtTabsShortcutStrategy {
54
+ /**
55
+ * Gets called onInit and whenever tabs are added/removed from Controller.
56
+ * @param ctrl Controller using this strategy.
57
+ * @returns List of shortcuts to register.
58
+ */
59
+ abstract updateShortcuts(ctrl: RdtTabControllerDirective): RdtShortcut[];
60
+ /**
61
+ * Gets called whenever hotkeys detects one of the registered shortcuts.
62
+ * @param shortcut Registered shortcut.
63
+ * @param ctrl Controller using this strategy.
64
+ */
65
+ abstract onShortcut(shortcut: RdtShortcut, ctrl: RdtTabControllerDirective): void;
66
+ }
67
+
68
+ declare class RdtTabControllerDirective implements OnInit, AfterContentInit, OnDestroy {
69
+ private readonly destroyRef;
70
+ private readonly injector;
71
+ private readonly shortcutService;
72
+ private shortcutSub;
73
+ set rdtTabController(value: RdtTabsShortcutStrategy | string | null);
74
+ protected get tabContainers(): RdtTabContainerComponent[];
75
+ protected get tabs(): RdtTabComponent[];
76
+ protected childControllers: QueryList<RdtTabControllerDirective>;
77
+ get strategy(): RdtTabsShortcutStrategy;
78
+ private _strategy;
79
+ private _lastActiveTabContainer;
80
+ private _contentWasInit;
81
+ get disabled(): boolean;
82
+ private _disabled;
83
+ get shortcuts(): RdtShortcut[];
84
+ set shortcuts(value: RdtShortcut[]);
85
+ private _shortcuts;
86
+ get activeContainer(): RdtTabContainerComponent | undefined;
87
+ protected containerDirective: RdtContainerDirective;
88
+ ngOnInit(): void;
89
+ ngAfterContentInit(): void;
90
+ ngOnDestroy(): void;
91
+ getTabContainerIndex(cont: RdtTabContainerComponent): number;
92
+ /**
93
+ * Activates first parent container of current container
94
+ * that is not disabled and has any non disabled tabs.
95
+ */
96
+ goLevelUp(): boolean;
97
+ /**
98
+ * Activates first container under current tab which
99
+ * is not disabled and has any non disabled tabs.
100
+ */
101
+ goLevelDown(): boolean;
102
+ /**
103
+ * Activates next container on current level
104
+ * (under parent container of currently active container).
105
+ * Is cyclic.
106
+ */
107
+ goToNextContainer(): boolean;
108
+ /**
109
+ * Activates previous container on current level
110
+ * (under parent container of currently active container).
111
+ * Is cyclic.
112
+ */
113
+ goToPrevContainer(): boolean;
114
+ /**
115
+ * Activates tab within active container at the index of argument.
116
+ */
117
+ goToTabWithIndex(index: number): boolean;
118
+ /**
119
+ * Activates next tab within active container. Is cyclic.
120
+ */
121
+ goToNextTab(): boolean;
122
+ /**
123
+ * Activates previous tab within active container. Is cyclic.
124
+ */
125
+ goToPrevTab(): boolean;
126
+ private goToAdjacentContainer;
127
+ private goToAdjacentTab;
128
+ private getSameLevelContainers;
129
+ getTabByValue(value: string): RdtTabComponent | null;
130
+ activateTabContainer(tabs: RdtTabContainerComponent, scrollIntoView?: boolean): void;
131
+ activateTabContainerFromClick(tabs: RdtTabContainerComponent, timestamp: number): void;
132
+ activateTab(tab: RdtTabComponent): Promise<void>;
133
+ canActivateTab(tab: RdtTabComponent): boolean;
134
+ canActivateTabForms(tab: RdtTabComponent): Promise<boolean>;
135
+ onTabChanges(): void;
136
+ onTabContainerChanges(): void;
137
+ private disableSelfWhenChildCtrlExists;
138
+ private setDefaultActive;
139
+ private setDefaultActiveWhenAvailable;
140
+ private canContainerBeDefault;
141
+ private updateShortcuts;
142
+ private bindAll;
143
+ private unbindAll;
144
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdtTabControllerDirective, never>;
145
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdtTabControllerDirective, "[rdtTabController]", never, { "rdtTabController": { "alias": "rdtTabController"; "required": false; }; }, {}, ["childControllers"], never, false, [{ directive: typeof i1.RdtContainerDirective; inputs: {}; outputs: {}; }]>;
146
+ }
147
+
148
+ declare class RdtTabContainerComponent implements AfterContentInit {
149
+ readonly destroyRef: DestroyRef;
150
+ stateId: any;
151
+ set value(val: string);
152
+ get value(): string;
153
+ private _value;
154
+ disabled: boolean;
155
+ formAutofocus: boolean;
156
+ panelPosition: 'left' | 'right' | 'top' | 'bottom';
157
+ valueChange: EventEmitter<any>;
158
+ tabsList: QueryList<RdtTabComponent>;
159
+ tabHeaderButtons?: QueryList<ElementRef<HTMLElement>>;
160
+ tabContent: ElementRef<HTMLElement>;
161
+ private _active;
162
+ get active(): boolean;
163
+ set active(value: boolean);
164
+ get isTopLevel(): boolean;
165
+ readonly parentTab: RdtTabComponent | null;
166
+ readonly controller: RdtTabControllerDirective | null;
167
+ readonly cd: ChangeDetectorRef;
168
+ readonly elRef: ElementRef<any>;
169
+ protected readonly renderer: Renderer2;
170
+ protected currentTemplate: TemplateRef<any> | null;
171
+ protected currentTab: RdtTabComponent | null;
172
+ get classes(): string;
173
+ get isHorizontal(): boolean;
174
+ get isVertical(): boolean;
175
+ private attrRole;
176
+ get hasNonDisabledTabs(): boolean;
177
+ get activeTab(): RdtTabComponent | undefined;
178
+ getTabByValue(value: string): RdtTabComponent | undefined;
179
+ ngAfterContentInit(): void;
180
+ getState(): RdtTabContainerState;
181
+ applyState(state: RdtTabContainerState): void;
182
+ scrollIntoView(): void;
183
+ activateTab(value: string): Promise<void>;
184
+ scrollCurrentButtonIntoView(): void;
185
+ private onClick;
186
+ private setCurrent;
187
+ private setTab;
188
+ private solidifyTabContentSize;
189
+ private releaseTabContentSize;
190
+ private getFirstEnabledTab;
191
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdtTabContainerComponent, never>;
192
+ static ɵcmp: i0.ɵɵComponentDeclaration<RdtTabContainerComponent, "rdt-tab-container", never, { "stateId": { "alias": "stateId"; "required": false; }; "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "formAutofocus": { "alias": "formAutofocus"; "required": false; }; "panelPosition": { "alias": "panelPosition"; "required": false; }; }, { "valueChange": "valueChange"; }, ["tabsList"], never, false, [{ directive: typeof i1.RdtChildDirective; inputs: {}; outputs: {}; }]>;
193
+ }
194
+
195
+ declare class RdtDestroyInactiveDirective {
196
+ readonly template: TemplateRef<any>;
197
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdtDestroyInactiveDirective, never>;
198
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RdtDestroyInactiveDirective, "[rdtDestroyInactive]", never, {}, {}, never, never, false, never>;
199
+ }
200
+
201
+ declare class RdtTabsModule {
202
+ static ɵfac: i0.ɵɵFactoryDeclaration<RdtTabsModule, never>;
203
+ static ɵmod: i0.ɵɵNgModuleDeclaration<RdtTabsModule, [typeof RdtTabComponent, typeof RdtTabContainerComponent, typeof RdtTabControllerDirective, typeof RdtDestroyInactiveDirective], [typeof i5.CommonModule], [typeof RdtTabComponent, typeof RdtTabContainerComponent, typeof RdtTabControllerDirective, typeof RdtDestroyInactiveDirective]>;
204
+ static ɵinj: i0.ɵɵInjectorDeclaration<RdtTabsModule>;
205
+ }
206
+
207
+ interface StaticRdtTabsConfig {
208
+ shortcuts: Map<RdtShortcut, string>;
209
+ }
210
+ declare class StaticRdtTabsShortcutStrategy implements RdtTabsShortcutStrategy {
211
+ private config;
212
+ constructor(config: StaticRdtTabsConfig);
213
+ updateShortcuts(): RdtShortcut[];
214
+ onShortcut(shortcut: RdtShortcut, ctrl: RdtTabControllerDirective): void;
215
+ }
216
+
217
+ export { RdtDestroyInactiveDirective, RdtTabComponent, RdtTabContainerComponent, RdtTabControllerDirective, RdtTabMode, RdtTabsModule, RdtTabsShortcutStrategy, StaticRdtTabsShortcutStrategy };
218
+ export type { RdtTabContainerState, RdtTabState, StaticRdtTabsConfig };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ngrdt/tabs",
3
- "version": "0.0.3",
3
+ "version": "v0.0.18",
4
4
  "peerDependencies": {
5
5
  "@angular/common": ">=18.2.0",
6
6
  "@angular/core": ">=18.2.0",
@@ -18,8 +18,6 @@
18
18
  },
19
19
  ".": {
20
20
  "types": "./index.d.ts",
21
- "esm2022": "./esm2022/ngrdt-tabs.mjs",
22
- "esm": "./esm2022/ngrdt-tabs.mjs",
23
21
  "default": "./fesm2022/ngrdt-tabs.mjs"
24
22
  }
25
23
  },
package/esm2022/index.mjs DELETED
@@ -1,9 +0,0 @@
1
- export * from './lib/components/tab-container/rdt-tab-container.component';
2
- export * from './lib/components/tab/rdt-tab.component';
3
- export * from './lib/directives/rdt-destroy-inactive.directive';
4
- export * from './lib/directives/rdt-tab-controller.directive';
5
- export * from './lib/rdt-tabs-models';
6
- export * from './lib/rdt-tabs.module';
7
- export * from './lib/strategies/rdt-tabs-shortcut-strategy';
8
- export * from './lib/strategies/static-rdt-tabs-shortcut-strategy';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9AbmdyZHQvdGFicy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLG9EQUFvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90YWItY29udGFpbmVyL3JkdC10YWItY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RhYi9yZHQtdGFiLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JkdC1kZXN0cm95LWluYWN0aXZlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JkdC10YWItY29udHJvbGxlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmR0LXRhYnMtbW9kZWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JkdC10YWJzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdHJhdGVnaWVzL3JkdC10YWJzLXNob3J0Y3V0LXN0cmF0ZWd5JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0cmF0ZWdpZXMvc3RhdGljLXJkdC10YWJzLXNob3J0Y3V0LXN0cmF0ZWd5JztcbiJdfQ==
@@ -1,145 +0,0 @@
1
- import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChild, DestroyRef, inject, Injector, Input, TemplateRef, ViewChild, } from '@angular/core';
2
- import { RDT_GUARDED_COMPONENT, RdtContainerDirective, } from '@ngrdt/core';
3
- import { RdtDestroyInactiveDirective } from '../../directives/rdt-destroy-inactive.directive';
4
- import { RdtTabContainerComponent } from '../tab-container/rdt-tab-container.component';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@ngrdt/core";
7
- export class RdtTabComponent {
8
- injector = inject(Injector);
9
- destroyRef = inject(DestroyRef);
10
- _contDir;
11
- get contDir() {
12
- return this._contDir;
13
- }
14
- get stateId() {
15
- if (this._stateId === null) {
16
- if (this.label !== '') {
17
- this._stateId = this.label;
18
- }
19
- else {
20
- const index = this.tabContainer?.tabsList?.toArray().indexOf(this);
21
- this._stateId = `tab-${index}`;
22
- }
23
- }
24
- return this._stateId;
25
- }
26
- set stateId(value) {
27
- this._stateId = value;
28
- }
29
- _stateId = null;
30
- disabled = false;
31
- visible = true;
32
- label;
33
- formAutofocus = true;
34
- buttonClass = null;
35
- implicitContent;
36
- explicitContent;
37
- get templateRef() {
38
- return this.explicitContent ?? this.implicitContent;
39
- }
40
- tabContainer = inject(RdtTabContainerComponent);
41
- //get forms() {
42
- // return this.getChildrenByClass(RdtBaseFormComponent);
43
- //}
44
- get childContainers() {
45
- return this.contDir.getChildrenByClass(RdtTabContainerComponent);
46
- }
47
- rdtIsActive() {
48
- return (this.visible && !this.disabled && this.tabContainer.activeTab === this);
49
- }
50
- ngOnInit() {
51
- this._contDir = this.injector.get(RdtContainerDirective);
52
- }
53
- ngOnChanges(changes) {
54
- if ('label' in changes ||
55
- 'value' in changes ||
56
- 'visible' in changes ||
57
- 'stateId' in changes) {
58
- this.tabContainer.cd.markForCheck();
59
- }
60
- }
61
- get isTopLevel() {
62
- return this.tabContainer.isTopLevel;
63
- }
64
- getState() {
65
- return {
66
- id: this.stateId,
67
- containerStates: this.childContainers.map((cont) => cont.getState()),
68
- };
69
- }
70
- applyState(state) {
71
- const states = [...state.containerStates];
72
- const conts = this.childContainers;
73
- const minLen = Math.min(states.length, conts.length);
74
- for (let i = 0; i < minLen; i++) {
75
- if (conts[i].stateId === states[i].id) {
76
- conts[i].applyState(states[i]);
77
- conts[i] = states[i] = null;
78
- }
79
- }
80
- conts.forEach((cont, contI) => {
81
- if (!cont) {
82
- return;
83
- }
84
- for (let offset = 0; offset < states.length; offset++) {
85
- const prev = contI - offset;
86
- const next = contI + offset;
87
- if (prev > 0 && states[prev]?.id === cont.stateId) {
88
- cont.applyState(states[prev]);
89
- states[prev] = null;
90
- return;
91
- }
92
- else if (next < states.length && states[next]?.id === cont.stateId) {
93
- cont.applyState(states[next]);
94
- states[next] = null;
95
- return;
96
- }
97
- }
98
- });
99
- }
100
- focusForm() {
101
- //TODO: getRdtAutofocusable(this.forms)?.rdtFocus();
102
- }
103
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtTabComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
104
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.7", type: RdtTabComponent, selector: "rdt-tab", inputs: { stateId: "stateId", disabled: ["disabled", "disabled", booleanAttribute], visible: ["visible", "visible", booleanAttribute], label: "label", formAutofocus: ["formAutofocus", "formAutofocus", booleanAttribute], buttonClass: "buttonClass" }, providers: [
105
- {
106
- provide: RDT_GUARDED_COMPONENT,
107
- useExisting: RdtTabComponent,
108
- },
109
- ], queries: [{ propertyName: "explicitContent", first: true, predicate: RdtDestroyInactiveDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "implicitContent", first: true, predicate: TemplateRef, descendants: true, static: true }], usesOnChanges: true, hostDirectives: [{ directive: i1.RdtContainerDirective }], ngImport: i0, template: "<ng-template>\n <ng-content></ng-content>\n</ng-template>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush });
110
- }
111
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: RdtTabComponent, decorators: [{
112
- type: Component,
113
- args: [{ selector: 'rdt-tab', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
114
- {
115
- provide: RDT_GUARDED_COMPONENT,
116
- useExisting: RdtTabComponent,
117
- },
118
- ], hostDirectives: [RdtContainerDirective], template: "<ng-template>\n <ng-content></ng-content>\n</ng-template>\n" }]
119
- }], propDecorators: { stateId: [{
120
- type: Input
121
- }], disabled: [{
122
- type: Input,
123
- args: [{ transform: booleanAttribute }]
124
- }], visible: [{
125
- type: Input,
126
- args: [{ transform: booleanAttribute }]
127
- }], label: [{
128
- type: Input,
129
- args: [{ required: true }]
130
- }], formAutofocus: [{
131
- type: Input,
132
- args: [{ transform: booleanAttribute }]
133
- }], buttonClass: [{
134
- type: Input
135
- }], implicitContent: [{
136
- type: ViewChild,
137
- args: [TemplateRef, { static: true }]
138
- }], explicitContent: [{
139
- type: ContentChild,
140
- args: [RdtDestroyInactiveDirective, {
141
- read: TemplateRef,
142
- static: true,
143
- }]
144
- }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rdt-tab.component.js","sourceRoot":"","sources":["../../../../../../../@ngrdt/tabs/src/lib/components/tab/rdt-tab.component.ts","../../../../../../../@ngrdt/tabs/src/lib/components/tab/rdt-tab.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  DestroyRef,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  RDT_GUARDED_COMPONENT,\n  RdtContainerDirective,\n  RdtIsActive,\n} from '@ngrdt/core';\nimport { Nullable } from '@ngrdt/utils';\nimport { RdtDestroyInactiveDirective } from '../../directives/rdt-destroy-inactive.directive';\nimport { RdtTabContainerState, RdtTabState } from '../../rdt-tabs-models';\nimport { RdtTabContainerComponent } from '../tab-container/rdt-tab-container.component';\n\n@Component({\n  selector: 'rdt-tab',\n  templateUrl: './rdt-tab.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: RDT_GUARDED_COMPONENT,\n      useExisting: RdtTabComponent,\n    },\n  ],\n  hostDirectives: [RdtContainerDirective],\n})\nexport class RdtTabComponent implements OnChanges, OnInit, RdtIsActive {\n  private readonly injector = inject(Injector);\n  readonly destroyRef = inject(DestroyRef);\n\n  private _contDir!: RdtContainerDirective;\n  get contDir() {\n    return this._contDir;\n  }\n\n  @Input()\n  get stateId() {\n    if (this._stateId === null) {\n      if (this.label !== '') {\n        this._stateId = this.label;\n      } else {\n        const index = this.tabContainer?.tabsList?.toArray().indexOf(this);\n        this._stateId = `tab-${index}`;\n      }\n    }\n    return this._stateId;\n  }\n  set stateId(value: string) {\n    this._stateId = value;\n  }\n  private _stateId: string = null as unknown as string;\n\n  @Input({ transform: booleanAttribute })\n  disabled = false;\n\n  @Input({ transform: booleanAttribute })\n  visible = true;\n\n  @Input({ required: true })\n  label!: string;\n\n  @Input({ transform: booleanAttribute })\n  formAutofocus = true;\n\n  @Input()\n  buttonClass: Nullable<string> = null;\n\n  @ViewChild(TemplateRef, { static: true })\n  private readonly implicitContent!: TemplateRef<any>;\n\n  @ContentChild(RdtDestroyInactiveDirective, {\n    read: TemplateRef,\n    static: true,\n  })\n  private readonly explicitContent!: TemplateRef<any>;\n\n  get templateRef() {\n    return this.explicitContent ?? this.implicitContent;\n  }\n\n  readonly tabContainer = inject(RdtTabContainerComponent);\n\n  //get forms() {\n  //  return this.getChildrenByClass(RdtBaseFormComponent);\n  //}\n\n  get childContainers() {\n    return this.contDir.getChildrenByClass(RdtTabContainerComponent);\n  }\n\n  rdtIsActive(): boolean {\n    return (\n      this.visible && !this.disabled && this.tabContainer.activeTab === this\n    );\n  }\n\n  ngOnInit() {\n    this._contDir = this.injector.get(RdtContainerDirective);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (\n      'label' in changes ||\n      'value' in changes ||\n      'visible' in changes ||\n      'stateId' in changes\n    ) {\n      this.tabContainer.cd.markForCheck();\n    }\n  }\n\n  get isTopLevel() {\n    return this.tabContainer.isTopLevel;\n  }\n\n  getState(): RdtTabState {\n    return {\n      id: this.stateId,\n      containerStates: this.childContainers.map((cont) => cont.getState()),\n    };\n  }\n\n  applyState(state: RdtTabState) {\n    const states: (RdtTabContainerState | null)[] = [...state.containerStates];\n    const conts: (RdtTabContainerComponent | null)[] = this.childContainers;\n    const minLen = Math.min(states.length, conts.length);\n\n    for (let i = 0; i < minLen; i++) {\n      if (conts[i]!.stateId === states[i]!.id) {\n        conts[i]!.applyState(states[i]!);\n        conts[i] = states[i] = null;\n      }\n    }\n    conts.forEach((cont, contI) => {\n      if (!cont) {\n        return;\n      }\n      for (let offset = 0; offset < states.length; offset++) {\n        const prev = contI - offset;\n        const next = contI + offset;\n        if (prev > 0 && states[prev]?.id === cont.stateId) {\n          cont.applyState(states[prev]!);\n          states[prev] = null;\n          return;\n        } else if (next < states.length && states[next]?.id === cont.stateId) {\n          cont.applyState(states[next]!);\n          states[next] = null;\n          return;\n        }\n      }\n    });\n  }\n\n  focusForm() {\n    //TODO: getRdtAutofocusable(this.forms)?.rdtFocus();\n  }\n}\n","<ng-template>\n  <ng-content></ng-content>\n</ng-template>\n"]}