@ngrdt/tabs 0.0.1 → 0.0.2

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.
Files changed (45) hide show
  1. package/esm2022/index.mjs +9 -0
  2. package/esm2022/lib/components/tab/rdt-tab.component.mjs +145 -0
  3. package/esm2022/lib/components/tab-container/rdt-tab-container.component.mjs +270 -0
  4. package/esm2022/lib/directives/rdt-destroy-inactive.directive.mjs +14 -0
  5. package/esm2022/lib/directives/rdt-tab-controller.directive.mjs +366 -0
  6. package/esm2022/lib/rdt-tabs-models.mjs +4 -0
  7. package/esm2022/lib/rdt-tabs.module.mjs +38 -0
  8. package/esm2022/lib/strategies/auto-rdt-tabs-shortcut-strategy.mjs +64 -0
  9. package/esm2022/lib/strategies/rdt-tabs-shortcut-strategy.mjs +3 -0
  10. package/esm2022/lib/strategies/static-rdt-tabs-shortcut-strategy.mjs +23 -0
  11. package/esm2022/ngrdt-tabs.mjs +5 -0
  12. package/fesm2022/ngrdt-tabs.mjs +907 -0
  13. package/fesm2022/ngrdt-tabs.mjs.map +1 -0
  14. package/lib/components/tab/rdt-tab.component.d.ts +38 -0
  15. package/lib/components/tab-container/rdt-tab-container.component.d.ts +52 -0
  16. package/lib/directives/rdt-destroy-inactive.directive.d.ts +7 -0
  17. package/lib/directives/rdt-tab-controller.directive.d.ts +87 -0
  18. package/lib/rdt-tabs-models.d.ts +11 -0
  19. package/lib/rdt-tabs.module.d.ts +12 -0
  20. package/lib/strategies/auto-rdt-tabs-shortcut-strategy.d.ts +11 -0
  21. package/lib/strategies/rdt-tabs-shortcut-strategy.d.ts +16 -0
  22. package/lib/strategies/static-rdt-tabs-shortcut-strategy.d.ts +12 -0
  23. package/package.json +25 -4
  24. package/eslint.config.js +0 -44
  25. package/jest.config.ts +0 -21
  26. package/ng-package.json +0 -7
  27. package/project.json +0 -36
  28. package/src/lib/components/tab/rdt-tab.component.html +0 -3
  29. package/src/lib/components/tab/rdt-tab.component.ts +0 -158
  30. package/src/lib/components/tab-container/rdt-tab-container.component.html +0 -29
  31. package/src/lib/components/tab-container/rdt-tab-container.component.scss +0 -155
  32. package/src/lib/components/tab-container/rdt-tab-container.component.ts +0 -315
  33. package/src/lib/directives/rdt-destroy-inactive.directive.ts +0 -8
  34. package/src/lib/directives/rdt-tab-controller.directive.ts +0 -440
  35. package/src/lib/rdt-tabs-models.ts +0 -12
  36. package/src/lib/rdt-tabs.module.ts +0 -24
  37. package/src/lib/strategies/auto-rdt-tabs-shortcut-strategy.ts +0 -81
  38. package/src/lib/strategies/rdt-tabs-shortcut-strategy.ts +0 -20
  39. package/src/lib/strategies/static-rdt-tabs-shortcut-strategy.ts +0 -30
  40. package/src/test-setup.ts +0 -8
  41. package/tsconfig.json +0 -28
  42. package/tsconfig.lib.json +0 -17
  43. package/tsconfig.lib.prod.json +0 -9
  44. package/tsconfig.spec.json +0 -16
  45. /package/{src/index.ts → index.d.ts} +0 -0
@@ -0,0 +1,9 @@
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==
@@ -0,0 +1,145 @@
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":"AAAA,OAAO,EACL,gBAAgB,EAChB,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,MAAM,EACN,QAAQ,EACR,KAAK,EAIL,WAAW,EACX,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,qBAAqB,EACrB,qBAAqB,GAEtB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,2BAA2B,EAAE,MAAM,iDAAiD,CAAC;AAE9F,OAAO,EAAE,wBAAwB,EAAE,MAAM,8CAA8C,CAAC;;;AAcxF,MAAM,OAAO,eAAe;IACT,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;IACpC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAEjC,QAAQ,CAAyB;IACzC,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IACI,OAAO;QACT,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,EAAE,CAAC;YAC3B,IAAI,IAAI,CAAC,KAAK,KAAK,EAAE,EAAE,CAAC;gBACtB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBACnE,IAAI,CAAC,QAAQ,GAAG,OAAO,KAAK,EAAE,CAAC;YACjC,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IACD,IAAI,OAAO,CAAC,KAAa;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACO,QAAQ,GAAW,IAAyB,CAAC;IAGrD,QAAQ,GAAG,KAAK,CAAC;IAGjB,OAAO,GAAG,IAAI,CAAC;IAGf,KAAK,CAAU;IAGf,aAAa,GAAG,IAAI,CAAC;IAGrB,WAAW,GAAqB,IAAI,CAAC;IAGpB,eAAe,CAAoB;IAMnC,eAAe,CAAoB;IAEpD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC;IACtD,CAAC;IAEQ,YAAY,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;IAEzD,eAAe;IACf,yDAAyD;IACzD,GAAG;IAEH,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,CAAC;IACnE,CAAC;IAED,WAAW;QACT,OAAO,CACL,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,YAAY,CAAC,SAAS,KAAK,IAAI,CACvE,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IACE,OAAO,IAAI,OAAO;YAClB,OAAO,IAAI,OAAO;YAClB,SAAS,IAAI,OAAO;YACpB,SAAS,IAAI,OAAO,EACpB,CAAC;YACD,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QACtC,CAAC;IACH,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;IACtC,CAAC;IAED,QAAQ;QACN,OAAO;YACL,EAAE,EAAE,IAAI,CAAC,OAAO;YAChB,eAAe,EAAE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;SACrE,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,KAAkB;QAC3B,MAAM,MAAM,GAAoC,CAAC,GAAG,KAAK,CAAC,eAAe,CAAC,CAAC;QAC3E,MAAM,KAAK,GAAwC,IAAI,CAAC,eAAe,CAAC;QACxE,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QAErD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,IAAI,KAAK,CAAC,CAAC,CAAE,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAE,CAAC,EAAE,EAAE,CAAC;gBACxC,KAAK,CAAC,CAAC,CAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAE,CAAC,CAAC;gBACjC,KAAK,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;YAC9B,CAAC;QACH,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC5B,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,OAAO;YACT,CAAC;YACD,KAAK,IAAI,MAAM,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,CAAC;gBACtD,MAAM,IAAI,GAAG,KAAK,GAAG,MAAM,CAAC;gBAC5B,MAAM,IAAI,GAAG,KAAK,GAAG,MAAM,CAAC;gBAC5B,IAAI,IAAI,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,IAAI,CAAC,OAAO,EAAE,CAAC;oBAClD,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAE,CAAC,CAAC;oBAC/B,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;oBACpB,OAAO;gBACT,CAAC;qBAAM,IAAI,IAAI,GAAG,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,IAAI,CAAC,OAAO,EAAE,CAAC;oBACrE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAE,CAAC,CAAC;oBAC/B,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;oBACpB,OAAO;gBACT,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,SAAS;QACP,oDAAoD;IACtD,CAAC;uGAjIU,eAAe;2FAAf,eAAe,wFA0BN,gBAAgB,mCAGhB,gBAAgB,qEAMhB,gBAAgB,4CA3CzB;YACT;gBACE,OAAO,EAAE,qBAAqB;gBAC9B,WAAW,EAAE,eAAe;aAC7B;SACF,uEA+Ca,2BAA2B,2BACjC,WAAW,4FAJR,WAAW,8IC9ExB,8DAGA;;2FDkCa,eAAe;kBAZ3B,SAAS;+BACE,SAAS,mBAEF,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,qBAAqB;4BAC9B,WAAW,iBAAiB;yBAC7B;qBACF,kBACe,CAAC,qBAAqB,CAAC;8BAYnC,OAAO;sBADV,KAAK;gBAkBN,QAAQ;sBADP,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,OAAO;sBADN,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,KAAK;sBADJ,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAIzB,aAAa;sBADZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,WAAW;sBADV,KAAK;gBAIW,eAAe;sBAD/B,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAOvB,eAAe;sBAJ/B,YAAY;uBAAC,2BAA2B,EAAE;wBACzC,IAAI,EAAE,WAAW;wBACjB,MAAM,EAAE,IAAI;qBACb","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"]}
@@ -0,0 +1,270 @@
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\">\n <button\n *ngFor=\"let tab of tabsList\"\n #headerButton\n class=\"px-2 py-1 tab-header-button\"\n (click)=\"activateTab(tab.stateId)\"\n [class.active]=\"value === tab.stateId\"\n [disabled]=\"tab.disabled\"\n [hidden]=\"!tab.visible\"\n role=\"tab\"\n [attr.aria-selected]=\"value === tab.stateId\"\n [attr.aria-controls]=\"'panel-' + tab.stateId\"\n [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\n [id]=\"'tab-' + tab.stateId\"\n [class]=\"tab.buttonClass\"\n type=\"button\"\n >\n {{ tab.label }}\n </button>\n</div>\n<div\n class=\"tab-content\"\n role=\"tabpanel\"\n [id]=\"'panel-' + value\"\n [attr.aria-labelledby]=\"'tab-' + value\"\n #tabContent\n>\n <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\n</div>\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\">\n <button\n *ngFor=\"let tab of tabsList\"\n #headerButton\n class=\"px-2 py-1 tab-header-button\"\n (click)=\"activateTab(tab.stateId)\"\n [class.active]=\"value === tab.stateId\"\n [disabled]=\"tab.disabled\"\n [hidden]=\"!tab.visible\"\n role=\"tab\"\n [attr.aria-selected]=\"value === tab.stateId\"\n [attr.aria-controls]=\"'panel-' + tab.stateId\"\n [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\n [id]=\"'tab-' + tab.stateId\"\n [class]=\"tab.buttonClass\"\n type=\"button\"\n >\n {{ tab.label }}\n </button>\n</div>\n<div\n class=\"tab-content\"\n role=\"tabpanel\"\n [id]=\"'panel-' + value\"\n [attr.aria-labelledby]=\"'tab-' + value\"\n #tabContent\n>\n <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\n</div>\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 {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  inject,\n  Input,\n  Output,\n  QueryList,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  canTransition$,\n  RDT_GUARDED_COMPONENT,\n  RdtChildDirective,\n} from '@ngrdt/core';\nimport { RdtHTMLUtils } from '@ngrdt/utils';\nimport { firstValueFrom, timer } from 'rxjs';\nimport { RdtTabControllerDirective } from '../../directives/rdt-tab-controller.directive';\nimport { RdtTabContainerState, RdtTabState } from '../../rdt-tabs-models';\nimport { RdtTabComponent } from '../tab/rdt-tab.component';\n\n@Component({\n  selector: 'rdt-tab-container',\n  templateUrl: './rdt-tab-container.component.html',\n  styleUrls: ['./rdt-tab-container.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: RDT_GUARDED_COMPONENT,\n      useExisting: RdtTabContainerComponent,\n    },\n  ],\n  hostDirectives: [RdtChildDirective],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class RdtTabContainerComponent implements AfterContentInit {\n  readonly destroyRef = inject(DestroyRef);\n\n  @Input()\n  stateId: any = null;\n\n  @Input()\n  set value(val: string) {\n    if (this.activeTab && this.activeTab.stateId !== val) {\n      // TODO\n      //this.activeTab.onViewWillLeave();\n    }\n    this._value = val;\n    this.setCurrent();\n  }\n  get value() {\n    return this._value;\n  }\n  private _value!: string;\n\n  @Input()\n  disabled = false;\n\n  @Input()\n  formAutofocus = true;\n\n  @Input()\n  panelPosition: 'left' | 'right' | 'top' | 'bottom' = 'top';\n\n  @Output()\n  valueChange = new EventEmitter();\n\n  @ContentChildren(RdtTabComponent)\n  tabsList!: QueryList<RdtTabComponent>;\n\n  @ViewChildren('headerButton')\n  tabHeaderButtons?: QueryList<ElementRef<HTMLElement>>;\n\n  @ViewChild('tabContent', { static: true })\n  tabContent!: ElementRef<HTMLElement>;\n\n  @HostBinding('class.active')\n  private _active = false;\n  get active() {\n    return this._active;\n  }\n  set active(value: boolean) {\n    this._active = value;\n    this.cd.markForCheck();\n  }\n\n  get isTopLevel(): boolean {\n    return !this.parentTab;\n  }\n\n  readonly parentTab = inject(RdtTabComponent, { optional: true });\n  readonly controller = inject(RdtTabControllerDirective, {\n    optional: true,\n  });\n  readonly cd = inject(ChangeDetectorRef);\n  readonly elRef = inject(ElementRef);\n  protected readonly renderer = inject(Renderer2);\n\n  protected currentTemplate: TemplateRef<any> | null = null;\n  protected currentTab: RdtTabComponent | null = null;\n\n  @HostBinding('class')\n  get classes() {\n    return `dp3-tab-container panel-${this.panelPosition}`;\n  }\n\n  @HostBinding('class.panel-horizontal')\n  get isHorizontal() {\n    return this.panelPosition === 'top' || this.panelPosition === 'bottom';\n  }\n\n  @HostBinding('class.panel-vertical')\n  get isVertical() {\n    return !this.isHorizontal;\n  }\n\n  @HostBinding('attr.role')\n  private attrRole = 'tablist';\n\n  get hasNonDisabledTabs() {\n    return this.tabsList.some((tab) => !tab.disabled);\n  }\n\n  get activeTab() {\n    return this.getTabByValue(this.value);\n  }\n\n  getTabByValue(value: string) {\n    return this.tabsList?.find((tab) => tab.stateId === value);\n  }\n\n  ngAfterContentInit() {\n    this.controller?.onTabContainerChanges();\n    timer(0)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => this.setCurrent());\n\n    this.tabsList.changes\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(() => {\n        this.controller?.onTabChanges();\n        this.setCurrent();\n        this.cd.markForCheck();\n      });\n\n    if (this.stateId === null && this.controller) {\n      const id = this.controller.getTabContainerIndex(this);\n      this.stateId = `tab-container-${id}`;\n    }\n  }\n\n  getState(): RdtTabContainerState {\n    return {\n      id: this.stateId,\n      value: this.value,\n      tabStates: this.tabsList.map((tab) => tab.getState()),\n    };\n  }\n\n  applyState(state: RdtTabContainerState) {\n    this.value = state.value;\n    this.scrollCurrentButtonIntoView();\n\n    const states: (RdtTabState | null)[] = [...state.tabStates];\n    const tabs: (RdtTabComponent | null)[] = this.tabsList.toArray();\n    const minLen = Math.min(states.length, tabs.length);\n\n    for (let i = 0; i < minLen; i++) {\n      if (tabs[i]!.stateId === states[i]!.id) {\n        tabs[i]!.applyState(states[i]!);\n        tabs[i] = states[i] = null;\n      }\n    }\n    tabs.forEach((tab, tabI) => {\n      if (!tab) {\n        return;\n      }\n      for (let offset = 0; offset < states.length; offset++) {\n        const prev = tabI - offset;\n        const next = tabI + offset;\n        if (prev > 0 && states[prev]?.id === tab.stateId) {\n          tab.applyState(states[prev]!);\n          states[prev] = null;\n          return;\n        } else if (next < states.length && states[next]?.id === tab.stateId) {\n          tab.applyState(states[next]!);\n          states[next] = null;\n          return;\n        }\n      }\n    });\n  }\n\n  scrollIntoView() {\n    this.elRef?.nativeElement?.scrollIntoView({ behavior: 'smooth' });\n  }\n\n  async activateTab(value: string) {\n    const nextTab = this.getTabByValue(value);\n\n    const can = await firstValueFrom(\n      canTransition$(this.activeTab?.contDir, nextTab?.contDir)\n    );\n    if (can) {\n      this.value = value;\n      this.valueChange.emit(value);\n    }\n  }\n\n  scrollCurrentButtonIntoView() {\n    if (!this.tabsList || !this.tabHeaderButtons) {\n      return;\n    }\n    const tabIndex = this.tabsList\n      .toArray()\n      .findIndex((tab) => tab.stateId === this.value);\n    const buttonRef = this.tabHeaderButtons.get(tabIndex);\n    if (buttonRef) {\n      RdtHTMLUtils.scrollIntoViewHorizontallyWithinParent(\n        buttonRef.nativeElement\n      );\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  private onClick(event: PointerEvent) {\n    this.controller?.activateTabContainerFromClick(this, event.timeStamp);\n  }\n\n  private setCurrent() {\n    if (!this.tabsList) {\n      return;\n    }\n    if (this.value == undefined) {\n      const firstEnabled = this.getFirstEnabledTab();\n      if (firstEnabled) {\n        this.value = firstEnabled.stateId;\n      } else {\n        return;\n      }\n    }\n\n    const found = this.tabsList.find((tab) => tab.stateId === this.value);\n    if (!found) {\n      const first = this.getFirstEnabledTab();\n      if (first) {\n        this.activateTab(first.stateId);\n        return;\n      } else {\n        console.error(\n          'Active tab not found.',\n          this.tabsList.toArray(),\n          this.value\n        );\n        return;\n      }\n    }\n    this.setTab(found);\n  }\n\n  private setTab(tab: RdtTabComponent) {\n    if (this.currentTab !== tab) {\n      this.solidifyTabContentSize();\n      this.currentTab = tab;\n      this.currentTemplate = tab.templateRef;\n      this.cd.markForCheck();\n      //tab.onViewWillEnter();\n    }\n\n    if (this.formAutofocus && tab.formAutofocus) {\n      // Wait until template is attached to DOM\n      timer(0)\n        .pipe(\n          takeUntilDestroyed(this.destroyRef),\n          takeUntilDestroyed(tab.destroyRef)\n        )\n        .subscribe(() => tab.focusForm());\n    }\n\n    setTimeout(() => this.releaseTabContentSize());\n  }\n\n  // Swapping template in template outlet will cause large css recalc\n  // fix size to previous tab and in case they are the same size\n  // the recalc isn't noticable\n  private solidifyTabContentSize() {\n    const el = this.tabContent.nativeElement;\n    const bb = el.getBoundingClientRect();\n    this.renderer.setStyle(el, 'width', bb.width + 'px');\n    this.renderer.setStyle(el, 'height', bb.height + 'px');\n  }\n\n  private releaseTabContentSize() {\n    const el = this.tabContent.nativeElement;\n    this.renderer.removeStyle(el, 'width');\n    this.renderer.removeStyle(el, 'height');\n  }\n\n  private getFirstEnabledTab() {\n    return this.tabsList.find((t) => !t.disabled);\n  }\n}\n","<div class=\"tab-header-panel\" *ngIf=\"tabsList\">\n  <button\n    *ngFor=\"let tab of tabsList\"\n    #headerButton\n    class=\"px-2 py-1 tab-header-button\"\n    (click)=\"activateTab(tab.stateId)\"\n    [class.active]=\"value === tab.stateId\"\n    [disabled]=\"tab.disabled\"\n    [hidden]=\"!tab.visible\"\n    role=\"tab\"\n    [attr.aria-selected]=\"value === tab.stateId\"\n    [attr.aria-controls]=\"'panel-' + tab.stateId\"\n    [attr.tabindex]=\"value === tab.stateId ? 0 : -1\"\n    [id]=\"'tab-' + tab.stateId\"\n    [class]=\"tab.buttonClass\"\n    type=\"button\"\n  >\n    {{ tab.label }}\n  </button>\n</div>\n<div\n  class=\"tab-content\"\n  role=\"tabpanel\"\n  [id]=\"'panel-' + value\"\n  [attr.aria-labelledby]=\"'tab-' + value\"\n  #tabContent\n>\n  <ng-template [ngTemplateOutlet]=\"currentTemplate\"></ng-template>\n</div>\n"]}
@@ -0,0 +1,14 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmR0LWRlc3Ryb3ktaW5hY3RpdmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vQG5ncmR0L3RhYnMvc3JjL2xpYi9kaXJlY3RpdmVzL3JkdC1kZXN0cm95LWluYWN0aXZlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSy9ELE1BQU0sT0FBTywyQkFBMkI7SUFDdEIsUUFBUSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQzt1R0FEcEMsMkJBQTJCOzJGQUEzQiwyQkFBMkI7OzJGQUEzQiwyQkFBMkI7a0JBSHZDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3JkdERlc3Ryb3lJbmFjdGl2ZV0nLFxufSlcbmV4cG9ydCBjbGFzcyBSZHREZXN0cm95SW5hY3RpdmVEaXJlY3RpdmUge1xuICBwdWJsaWMgcmVhZG9ubHkgdGVtcGxhdGUgPSBpbmplY3QoVGVtcGxhdGVSZWYpO1xufVxuIl19