@festo-ui/angular 5.1.0 → 6.0.0-dev.198

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 (156) hide show
  1. package/{esm2020 → esm2022}/lib/components/accordion/accordion-header/accordion-header.component.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/components/accordion/accordion-item/accordion-item-body/accordion-item-body.component.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/components/accordion/accordion-item/accordion-item-header/accordion-item-header.component.mjs +4 -4
  4. package/esm2022/lib/components/accordion/accordion-item/accordion-item.component.mjs +148 -0
  5. package/esm2022/lib/components/accordion/accordion.component.mjs +59 -0
  6. package/{esm2020 → esm2022}/lib/components/breadcrumb/breadcrumb.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/components/buttons/button/button.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/components/buttons/link-button/link-button.component.mjs +4 -4
  9. package/{esm2020 → esm2022}/lib/components/chips/chip/chip.component.mjs +4 -4
  10. package/{esm2020 → esm2022}/lib/components/chips/chip-container/chip-container.component.mjs +4 -4
  11. package/esm2022/lib/components/components.module.mjs +207 -0
  12. package/{esm2020 → esm2022}/lib/components/loading-indicator/loading-indicator.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.mjs +6 -6
  14. package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.mjs +4 -4
  15. package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout.component.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/components/pagination/pagination.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/components/popovers/legend/legend.component.mjs +5 -5
  18. package/{esm2020 → esm2022}/lib/components/popovers/legend/legend.directive.mjs +5 -5
  19. package/{esm2020 → esm2022}/lib/components/popovers/popover/popover.component.mjs +5 -5
  20. package/{esm2020 → esm2022}/lib/components/popovers/popover-content/popover-content.component.mjs +5 -5
  21. package/{esm2020 → esm2022}/lib/components/popovers/popover-content/popover-content.directive.mjs +5 -5
  22. package/{esm2020 → esm2022}/lib/components/popovers/popover-menu/popover-menu.component.mjs +5 -5
  23. package/{esm2020 → esm2022}/lib/components/popovers/popover.service.mjs +5 -5
  24. package/{esm2020 → esm2022}/lib/components/popovers/tooltip/tooltip.directive.mjs +5 -5
  25. package/{esm2020 → esm2022}/lib/components/progress/progress.component.mjs +4 -4
  26. package/{esm2020 → esm2022}/lib/components/scroll/scrollable.directive.mjs +5 -5
  27. package/{esm2020 → esm2022}/lib/components/search-input/search-input.component.mjs +4 -4
  28. package/esm2022/lib/components/sidebar-overlay/sidebar-overlay.component.mjs +59 -0
  29. package/{esm2020 → esm2022}/lib/components/snackbar/snackbar-container.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/lib/components/snackbar/snackbar-container.directive.mjs +5 -5
  31. package/esm2022/lib/components/snackbar/snackbar.component.mjs +81 -0
  32. package/esm2022/lib/components/snackbar/snackbar.module.mjs +24 -0
  33. package/{esm2020 → esm2022}/lib/components/snackbar/snackbar.service.mjs +5 -5
  34. package/{esm2020 → esm2022}/lib/components/stepper-horizontal/step-horizontal/step-horizontal.component.mjs +4 -4
  35. package/{esm2020 → esm2022}/lib/components/stepper-horizontal/stepper-horizontal.component.mjs +4 -4
  36. package/{esm2020 → esm2022}/lib/components/stepper-vertical/step-vertical/step-vertical.component.mjs +4 -4
  37. package/{esm2020 → esm2022}/lib/components/stepper-vertical/stepper-vertical.component.mjs +4 -4
  38. package/{esm2020 → esm2022}/lib/components/table-header-cell/table-header-cell.directive.mjs +4 -4
  39. package/esm2022/lib/components/tabs/tab-pane/tab-pane.component.mjs +34 -0
  40. package/esm2022/lib/components/tabs/tabs.component.mjs +459 -0
  41. package/{esm2020 → esm2022}/lib/directives/click-outside.directive.mjs +5 -5
  42. package/{esm2020 → esm2022}/lib/festo-angular.module.mjs +5 -5
  43. package/esm2022/lib/forms/checkbox/checkbox.component.mjs +154 -0
  44. package/{esm2020 → esm2022}/lib/forms/color-indicator/color-indicator.component.mjs +4 -4
  45. package/esm2022/lib/forms/color-picker/color-picker.component.mjs +292 -0
  46. package/{esm2020 → esm2022}/lib/forms/date-picker/date-picker.component.mjs +12 -12
  47. package/{esm2020 → esm2022}/lib/forms/date-range-picker/date-range-picker.component.mjs +12 -12
  48. package/{esm2020 → esm2022}/lib/forms/flatpickr/flatpickr.component.mjs +4 -4
  49. package/{esm2020 → esm2022}/lib/forms/forms.module.mjs +62 -62
  50. package/esm2022/lib/forms/radio/radio.component.mjs +350 -0
  51. package/{esm2020 → esm2022}/lib/forms/segment/segment-control/segment-control.component.mjs +4 -4
  52. package/{esm2020 → esm2022}/lib/forms/segment/segment.component.mjs +11 -11
  53. package/{esm2020 → esm2022}/lib/forms/select/chip-text.pipe.mjs +4 -4
  54. package/{esm2020 → esm2022}/lib/forms/select/select-option/select-option.component.mjs +4 -4
  55. package/esm2022/lib/forms/select/select.component.mjs +275 -0
  56. package/esm2022/lib/forms/slider/slider.component.mjs +113 -0
  57. package/esm2022/lib/forms/switch/switch.component.mjs +121 -0
  58. package/esm2022/lib/forms/text-area/text-area.component.mjs +187 -0
  59. package/esm2022/lib/forms/text-editor/text-editor.component.mjs +308 -0
  60. package/esm2022/lib/forms/text-input/text-input.component.mjs +208 -0
  61. package/{esm2020 → esm2022}/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.mjs +4 -4
  62. package/{esm2020 → esm2022}/lib/forms/time-picker/time-picker.component.mjs +11 -11
  63. package/{esm2020 → esm2022}/lib/forms/unique-selection-dispatcher.mjs +4 -4
  64. package/{esm2020 → esm2022}/lib/forms/value-accessor-base.mjs +4 -4
  65. package/{esm2020 → esm2022}/lib/modals/alert/alert.component.mjs +4 -4
  66. package/{esm2020 → esm2022}/lib/modals/confirm/confirm.component.mjs +5 -5
  67. package/{esm2020 → esm2022}/lib/modals/custom-modal/custom-modal.component.mjs +4 -4
  68. package/{esm2020 → esm2022}/lib/modals/image-gallery/image-gallery.component.mjs +5 -5
  69. package/{esm2020 → esm2022}/lib/modals/modal.service.mjs +5 -5
  70. package/{esm2020 → esm2022}/lib/modals/modals.module.mjs +5 -5
  71. package/{esm2020 → esm2022}/lib/modals/prompt/prompt.component.mjs +5 -5
  72. package/{esm2020 → esm2022}/lib/pipes/safe-html.pipe.mjs +5 -5
  73. package/{fesm2020 → fesm2022}/festo-ui-angular.mjs +512 -520
  74. package/{fesm2020 → fesm2022}/festo-ui-angular.mjs.map +1 -1
  75. package/lib/components/accordion/accordion.component.d.ts +1 -1
  76. package/lib/components/breadcrumb/breadcrumb.component.d.ts +1 -1
  77. package/lib/components/buttons/button/button.component.d.ts +1 -1
  78. package/lib/components/buttons/link-button/link-button.component.d.ts +1 -1
  79. package/lib/components/chips/chip/chip.component.d.ts +1 -1
  80. package/lib/components/chips/chip-container/chip-container.component.d.ts +1 -1
  81. package/lib/components/loading-indicator/loading-indicator.component.d.ts +1 -1
  82. package/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.d.ts +1 -1
  83. package/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.d.ts +1 -1
  84. package/lib/components/pagination/pagination.component.d.ts +1 -1
  85. package/lib/components/popovers/legend/legend.component.d.ts +1 -1
  86. package/lib/components/popovers/popover-content/popover-content.component.d.ts +1 -1
  87. package/lib/components/popovers/popover-menu/popover-menu.component.d.ts +1 -1
  88. package/lib/components/popovers/tooltip/tooltip.directive.d.ts +1 -1
  89. package/lib/components/progress/progress.component.d.ts +1 -1
  90. package/lib/components/scroll/scrollable.directive.d.ts +1 -1
  91. package/lib/components/search-input/search-input.component.d.ts +1 -1
  92. package/lib/components/sidebar-overlay/sidebar-overlay.component.d.ts +1 -1
  93. package/lib/components/snackbar/snackbar-container.component.d.ts +1 -1
  94. package/lib/components/snackbar/snackbar-container.directive.d.ts +1 -1
  95. package/lib/components/snackbar/snackbar.component.d.ts +1 -1
  96. package/lib/components/stepper-horizontal/step-horizontal/step-horizontal.component.d.ts +1 -1
  97. package/lib/components/stepper-horizontal/stepper-horizontal.component.d.ts +1 -1
  98. package/lib/components/stepper-vertical/step-vertical/step-vertical.component.d.ts +1 -1
  99. package/lib/components/stepper-vertical/stepper-vertical.component.d.ts +1 -1
  100. package/lib/components/table-header-cell/table-header-cell.directive.d.ts +1 -1
  101. package/lib/components/tabs/tab-pane/tab-pane.component.d.ts +1 -1
  102. package/lib/components/tabs/tabs.component.d.ts +1 -1
  103. package/lib/forms/checkbox/checkbox.component.d.ts +1 -1
  104. package/lib/forms/color-indicator/color-indicator.component.d.ts +1 -1
  105. package/lib/forms/color-picker/color-picker.component.d.ts +1 -1
  106. package/lib/forms/date-picker/date-picker.component.d.ts +1 -1
  107. package/lib/forms/date-range-picker/date-range-picker.component.d.ts +1 -1
  108. package/lib/forms/flatpickr/flatpickr.component.d.ts +1 -1
  109. package/lib/forms/radio/radio.component.d.ts +6 -6
  110. package/lib/forms/segment/segment-control/segment-control.component.d.ts +1 -1
  111. package/lib/forms/segment/segment.component.d.ts +1 -1
  112. package/lib/forms/select/select-option/select-option.component.d.ts +1 -1
  113. package/lib/forms/select/select.component.d.ts +6 -5
  114. package/lib/forms/slider/slider.component.d.ts +1 -1
  115. package/lib/forms/switch/switch.component.d.ts +1 -1
  116. package/lib/forms/text-area/text-area.component.d.ts +1 -1
  117. package/lib/forms/text-editor/text-editor.component.d.ts +1 -1
  118. package/lib/forms/text-input/text-input.component.d.ts +1 -1
  119. package/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.d.ts +1 -1
  120. package/lib/forms/time-picker/time-picker.component.d.ts +1 -1
  121. package/lib/forms/value-accessor-base.d.ts +1 -1
  122. package/lib/modals/alert/alert.component.d.ts +1 -1
  123. package/lib/modals/confirm/confirm.component.d.ts +1 -1
  124. package/lib/modals/custom-modal/custom-modal.component.d.ts +1 -1
  125. package/lib/modals/image-gallery/image-gallery.component.d.ts +1 -1
  126. package/lib/modals/prompt/prompt.component.d.ts +1 -1
  127. package/package.json +17 -23
  128. package/esm2020/lib/components/accordion/accordion-item/accordion-item.component.mjs +0 -148
  129. package/esm2020/lib/components/accordion/accordion.component.mjs +0 -59
  130. package/esm2020/lib/components/components.module.mjs +0 -218
  131. package/esm2020/lib/components/sidebar-overlay/sidebar-overlay.component.mjs +0 -59
  132. package/esm2020/lib/components/snackbar/snackbar.component.mjs +0 -81
  133. package/esm2020/lib/components/snackbar/snackbar.module.mjs +0 -24
  134. package/esm2020/lib/components/tabs/tab-pane/tab-pane.component.mjs +0 -34
  135. package/esm2020/lib/components/tabs/tabs.component.mjs +0 -459
  136. package/esm2020/lib/forms/checkbox/checkbox.component.mjs +0 -154
  137. package/esm2020/lib/forms/color-picker/color-picker.component.mjs +0 -292
  138. package/esm2020/lib/forms/radio/radio.component.mjs +0 -350
  139. package/esm2020/lib/forms/select/select.component.mjs +0 -273
  140. package/esm2020/lib/forms/slider/slider.component.mjs +0 -113
  141. package/esm2020/lib/forms/switch/switch.component.mjs +0 -121
  142. package/esm2020/lib/forms/text-area/text-area.component.mjs +0 -187
  143. package/esm2020/lib/forms/text-editor/text-editor.component.mjs +0 -308
  144. package/esm2020/lib/forms/text-input/text-input.component.mjs +0 -208
  145. package/fesm2015/festo-ui-angular.mjs +0 -6504
  146. package/fesm2015/festo-ui-angular.mjs.map +0 -1
  147. /package/{esm2020 → esm2022}/festo-ui-angular.mjs +0 -0
  148. /package/{esm2020 → esm2022}/lib/components/accordion/index.mjs +0 -0
  149. /package/{esm2020 → esm2022}/lib/components/popovers/popover-ref.mjs +0 -0
  150. /package/{esm2020 → esm2022}/lib/components/popovers/popover.defaults.mjs +0 -0
  151. /package/{esm2020 → esm2022}/lib/components/popovers/popover.models.mjs +0 -0
  152. /package/{esm2020 → esm2022}/lib/components/scroll/index.mjs +0 -0
  153. /package/{esm2020 → esm2022}/lib/components/snackbar/snackbar.models.mjs +0 -0
  154. /package/{esm2020 → esm2022}/lib/forms/color-picker/color-helper.mjs +0 -0
  155. /package/{esm2020 → esm2022}/lib/modals/index.mjs +0 -0
  156. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -0,0 +1,459 @@
1
+ import { CommonModule, DOCUMENT } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, Output, ViewChild } from '@angular/core';
3
+ import { noop, Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import { FngTabPaneComponent } from './tab-pane/tab-pane.component';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ export class FngTabsComponent {
9
+ static { this.nextId = 0; }
10
+ constructor(elRef, document, renderer, cd) {
11
+ this.elRef = elRef;
12
+ this.document = document;
13
+ this.renderer = renderer;
14
+ this.cd = cd;
15
+ this.viewType = 'responsive';
16
+ this.showDivider = false;
17
+ this.config = null;
18
+ this.fngBeforeTabChange = new EventEmitter();
19
+ this.fngTabChange = new EventEmitter();
20
+ this.componentId = `tabs-${++FngTabsComponent.nextId}`;
21
+ this.tabs = [];
22
+ this.useCompactDensity = true;
23
+ this.activeTab = undefined;
24
+ this.complete = new Subject();
25
+ this.injectedWindow = this.document.defaultView;
26
+ }
27
+ ngAfterContentInit() {
28
+ this.initTabs();
29
+ if (null == this.activeTab) {
30
+ this.panes?.map((pane, i) => {
31
+ if (0 === i) {
32
+ pane.isVisible = true;
33
+ }
34
+ });
35
+ }
36
+ else {
37
+ const pane = this.panes?.find(pane => {
38
+ if (this.activeTab) {
39
+ return this.activeTab.paneId != null && pane.tabPaneId === this.activeTab.paneId;
40
+ }
41
+ else {
42
+ return false;
43
+ }
44
+ });
45
+ if (pane) {
46
+ pane.isVisible = true;
47
+ }
48
+ }
49
+ }
50
+ ngAfterViewInit() {
51
+ this.elemScroller = this.scroller?.nativeElement;
52
+ this.elemScrollArea = this.scrollAera?.nativeElement;
53
+ this.elemScrollContent = this.scrollContent?.nativeElement;
54
+ if (this.elemScroller == null || this.elemScrollArea == null || this.elemScrollContent == null) {
55
+ return;
56
+ }
57
+ const initialWidth = this.elemScrollArea.offsetWidth;
58
+ if (initialWidth != null && initialWidth > 768) {
59
+ this.useCompactDensity = false;
60
+ this.cd.detectChanges();
61
+ }
62
+ this.resizeObserver = new ResizeObserver(() => {
63
+ if (this.elemScrollArea == null) {
64
+ return;
65
+ }
66
+ const width = this.elemScrollArea.offsetWidth;
67
+ if (width != null && width > 768 && this.useCompactDensity === true) {
68
+ this.useCompactDensity = false;
69
+ this.cd.detectChanges();
70
+ }
71
+ else if (width != null && width <= 768 && this.useCompactDensity === false) {
72
+ this.useCompactDensity = true;
73
+ this.cd.detectChanges();
74
+ }
75
+ });
76
+ if (this.elemScrollArea != null) {
77
+ this.resizeObserver.observe(this.elemScrollArea);
78
+ }
79
+ this.handleTabPaneChanges();
80
+ }
81
+ ngOnDestroy() {
82
+ this.complete.next(true);
83
+ this.complete.unsubscribe();
84
+ }
85
+ showTabPane(id) {
86
+ if (id == null) {
87
+ return;
88
+ }
89
+ const pane = this.panes?.find(p => p.tabPaneId === id);
90
+ const handleTabChange = (id) => {
91
+ if (pane != null && pane.disabled !== true) {
92
+ this.panes?.map(p => {
93
+ p.isVisible = false;
94
+ });
95
+ pane.isVisible = true;
96
+ this.tabs.map(tab => {
97
+ if (tab.paneId !== pane.tabPaneId) {
98
+ tab.active = false;
99
+ }
100
+ else {
101
+ tab.active = true;
102
+ }
103
+ });
104
+ this.fngTabChange.emit({
105
+ previous: this.activeTab?.paneId || '',
106
+ current: id
107
+ });
108
+ this.activeTab = this.tabs.find(tab => !!tab.active);
109
+ this.cd.detectChanges();
110
+ }
111
+ };
112
+ if (this.fngBeforeTabChange?.observers?.length > 0 && pane?.disabled !== true) {
113
+ this.fngBeforeTabChange.emit({
114
+ ok: () => {
115
+ handleTabChange(id);
116
+ },
117
+ cancel: () => {
118
+ noop();
119
+ }
120
+ });
121
+ }
122
+ else {
123
+ handleTabChange(id);
124
+ }
125
+ }
126
+ handleTabScroll(event, index) {
127
+ if (this.elemScrollContent == null || this.elemScrollArea == null) {
128
+ return;
129
+ }
130
+ const scrollContentWidth = this.elemScrollContent.offsetWidth;
131
+ const scrollAreaWidth = this.elemScrollArea.offsetWidth;
132
+ // check if no scroll is needed
133
+ if (scrollAreaWidth > scrollContentWidth) {
134
+ return;
135
+ }
136
+ // check index
137
+ if (!this.indexIsInRange(index)) {
138
+ return;
139
+ }
140
+ // always scroll to 0 if scrolling to the first tab
141
+ if (index === 0) {
142
+ this.scrollTo(0);
143
+ return;
144
+ }
145
+ // always scroll to the max value if scrolling to the last tab
146
+ if (index === this.tabs.length - 1) {
147
+ this.scrollTo(this.elemScrollContent.offsetWidth);
148
+ return;
149
+ }
150
+ const currentTab = event.target;
151
+ this.scrollIntoView(index, currentTab);
152
+ }
153
+ initTabs() {
154
+ this.tabs = [];
155
+ this.panes?.map((pane, i) => {
156
+ pane.tabId = this.componentId + '-tab-' + i;
157
+ const tab = {
158
+ name: null != pane.name ? pane.name : '',
159
+ paneId: null != pane.tabPaneId ? pane.tabPaneId : null,
160
+ icon: null != pane.icon ? pane.icon : null,
161
+ active: null != pane.active ? pane.active : false,
162
+ disabled: null != pane.disabled ? pane.disabled : false
163
+ };
164
+ this.tabs.push(tab);
165
+ });
166
+ this.initActiveTab();
167
+ this.cd.detectChanges();
168
+ }
169
+ initActiveTab() {
170
+ const activeTab = this.tabs.find((tab) => !!tab.active);
171
+ if (!activeTab && 0 < this.tabs.length) {
172
+ this.tabs[0] = { ...this.tabs[0], active: true };
173
+ this.activeTab = this.tabs[0];
174
+ }
175
+ else {
176
+ this.activeTab = activeTab;
177
+ }
178
+ }
179
+ handleTabPaneChanges() {
180
+ // first subscribe to any changes in tab pane, so that the tabs in this view wiil be updated
181
+ this.panes?.forEach(pane => {
182
+ pane.changes$.pipe(takeUntil(this.complete)).subscribe(() => {
183
+ // on changes in a tab pane, we init the tabs again
184
+ this.initTabs();
185
+ });
186
+ });
187
+ }
188
+ scrollTo(scrollX) {
189
+ if (scrollX == null) {
190
+ return;
191
+ }
192
+ const currentScrollX = this.getScrollPosition();
193
+ const safeScrollX = this.clampScrollValue(scrollX);
194
+ if (safeScrollX == null || currentScrollX == null) {
195
+ return;
196
+ }
197
+ const scrollDelta = safeScrollX - currentScrollX;
198
+ this.animate({
199
+ finalScrollPosition: safeScrollX,
200
+ scrollDelta
201
+ });
202
+ }
203
+ scrollIntoView(index, tab) {
204
+ if (this.elemScrollArea == null) {
205
+ return;
206
+ }
207
+ const scrollPosition = this.getScrollPosition();
208
+ const barWidth = this.elemScrollArea.offsetWidth;
209
+ if (barWidth == null || scrollPosition == null) {
210
+ return;
211
+ }
212
+ const tabDimensions = this.computeDimensions(tab);
213
+ if (tabDimensions == null) {
214
+ return;
215
+ }
216
+ const nextIndex = this.findAdjacentTabIndexClosestToEdge(index, tabDimensions, scrollPosition, barWidth);
217
+ if (!this.indexIsInRange(nextIndex)) {
218
+ return;
219
+ }
220
+ const scrollIncrement = this.calculateScrollIncrement(index, nextIndex, scrollPosition, barWidth);
221
+ if (scrollIncrement == null) {
222
+ return;
223
+ }
224
+ this.incrementScroll(scrollIncrement);
225
+ }
226
+ incrementScroll(scrollXIncrement) {
227
+ // no scroll needed
228
+ if (scrollXIncrement === 0) {
229
+ return;
230
+ }
231
+ const scrollOperation = this.getIncrementScrollOperation(scrollXIncrement);
232
+ if (scrollOperation == null) {
233
+ return;
234
+ }
235
+ this.animate(scrollOperation);
236
+ }
237
+ animate(animation) {
238
+ // no animation needed
239
+ if (animation.scrollDelta === 0) {
240
+ return;
241
+ }
242
+ // no animation possible
243
+ if (this.elemScrollArea == null) {
244
+ return;
245
+ }
246
+ this.stopScrollAnimation();
247
+ // this animation uses the flip approach
248
+ // https://aerotwist.com/blog/flip-your-animations/
249
+ // https://css-tricks.com/animating-layouts-with-the-flip-technique/
250
+ this.elemScrollArea.scrollLeft = animation.finalScrollPosition;
251
+ this.setScrollContentStyleProperty('transform', `translateX(${animation.scrollDelta}px)`);
252
+ // force repaint
253
+ this.elemScrollArea.getBoundingClientRect();
254
+ requestAnimationFrame(() => {
255
+ this.renderer.addClass(this.elemScroller, 'fng-tab-scroller--animating');
256
+ this.setScrollContentStyleProperty('transform', 'none');
257
+ });
258
+ }
259
+ stopScrollAnimation() {
260
+ if (this.elemScrollArea == null) {
261
+ return;
262
+ }
263
+ const currentScrollPosition = this.getAnimatingScrollPosition();
264
+ if (currentScrollPosition == null) {
265
+ return;
266
+ }
267
+ this.renderer.removeClass(this.elemScroller, 'fng-tab-scroller--animating');
268
+ this.setScrollContentStyleProperty('transform', 'translateX(0px)');
269
+ this.elemScrollArea.scrollLeft = currentScrollPosition;
270
+ }
271
+ getAnimatingScrollPosition() {
272
+ if (this.elemScrollArea == null) {
273
+ return null;
274
+ }
275
+ const currentTranslateX = this.calculateCurrentTranslateX();
276
+ const scrollLeft = this.elemScrollArea.scrollLeft;
277
+ return scrollLeft - currentTranslateX;
278
+ }
279
+ getIncrementScrollOperation(scrollX) {
280
+ const currentScrollX = this.getScrollPosition();
281
+ if (currentScrollX == null) {
282
+ return null;
283
+ }
284
+ const targetScrollX = scrollX + currentScrollX;
285
+ const safeScrollX = this.clampScrollValue(targetScrollX);
286
+ if (safeScrollX == null) {
287
+ return null;
288
+ }
289
+ const scrollDelta = safeScrollX - currentScrollX;
290
+ return {
291
+ finalScrollPosition: safeScrollX,
292
+ scrollDelta
293
+ };
294
+ }
295
+ clampScrollValue(scrollX) {
296
+ const edges = this.calculateScrollEdges();
297
+ if (edges == null) {
298
+ return null;
299
+ }
300
+ return Math.min(Math.max(edges.left, scrollX), edges.right);
301
+ }
302
+ calculateScrollEdges() {
303
+ if (this.elemScrollArea == null || this.elemScrollContent == null) {
304
+ return null;
305
+ }
306
+ const scrollContentWidth = this.elemScrollContent.offsetWidth;
307
+ const scrollAreaWidth = this.elemScrollArea.offsetWidth;
308
+ return {
309
+ left: 0,
310
+ right: scrollContentWidth - scrollAreaWidth
311
+ };
312
+ }
313
+ computeDimensions(tab) {
314
+ const rootWidth = tab.offsetWidth;
315
+ const rootLeft = tab.offsetLeft;
316
+ const tabContent = tab.querySelector('.fng-tab-content');
317
+ if (tabContent == null) {
318
+ return null;
319
+ }
320
+ const contentWidth = tabContent.offsetWidth;
321
+ const contentLeft = tabContent.offsetLeft;
322
+ return {
323
+ contentLeft: rootLeft + contentLeft,
324
+ contentRight: rootLeft + contentLeft + contentWidth,
325
+ rootLeft,
326
+ rootRight: rootLeft + rootWidth
327
+ };
328
+ }
329
+ calculateScrollIncrement(index, nextIndex, scrollPosition, barWidth) {
330
+ const nextTab = this.elRef.nativeElement.querySelector(`#${this.componentId}-tab-${nextIndex}`);
331
+ if (nextTab == null) {
332
+ return null;
333
+ }
334
+ const nextTabDimensions = this.computeDimensions(nextTab);
335
+ if (nextTabDimensions == null) {
336
+ return null;
337
+ }
338
+ const relativeContentLeft = nextTabDimensions.contentLeft - scrollPosition - barWidth;
339
+ const relativeContentRight = nextTabDimensions.contentRight - scrollPosition;
340
+ const leftIncrement = relativeContentRight - 48;
341
+ const rightIncrement = relativeContentLeft + 48;
342
+ if (nextIndex < index) {
343
+ return Math.min(leftIncrement, 0);
344
+ }
345
+ return Math.max(rightIncrement, 0);
346
+ }
347
+ indexIsInRange(index) {
348
+ return index >= 0 && index < this.tabs.length;
349
+ }
350
+ getScrollPosition() {
351
+ if (this.elemScrollArea == null) {
352
+ return null;
353
+ }
354
+ const currentTranslateX = this.calculateCurrentTranslateX();
355
+ const scrollLeft = this.elemScrollArea.scrollLeft;
356
+ return scrollLeft - currentTranslateX;
357
+ }
358
+ calculateCurrentTranslateX() {
359
+ const transformValue = this.getScrollContentStyleValue('transform');
360
+ if (transformValue == null) {
361
+ return 0;
362
+ }
363
+ if (transformValue === 'none') {
364
+ return 0;
365
+ }
366
+ // the transform value is in form of 'matrix(a, b, c, d, tx, ty)'
367
+ // get all the parenthesized values
368
+ const match = /\((.+?)\)/.exec(transformValue);
369
+ if (!match) {
370
+ return 0;
371
+ }
372
+ const matrixParams = match[1];
373
+ // we need value of tx -> translateX
374
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
375
+ const [a, b, c, d, tx, ty] = matrixParams.split(',');
376
+ return parseFloat(tx);
377
+ }
378
+ getScrollContentStyleValue(propName) {
379
+ if (this.elemScrollContent == null) {
380
+ return;
381
+ }
382
+ return this.injectedWindow?.getComputedStyle(this.elemScrollContent).getPropertyValue(propName);
383
+ }
384
+ setScrollContentStyleProperty(propName, value) {
385
+ this.renderer.setStyle(this.elemScrollContent, propName, value);
386
+ }
387
+ findAdjacentTabIndexClosestToEdge(index, tabDimensions, scrollPosition, barWidth) {
388
+ /**
389
+ * tabs are laid out in the tab scroller like this:
390
+ *
391
+ * scroll position
392
+ * +---+
393
+ * | | bar width
394
+ * | +-----------------------------------+
395
+ * | | |
396
+ * | v v
397
+ * | +-----------------------------------+
398
+ * v | tab scroller |
399
+ * +------------+--------------+-------------------+
400
+ * | tab | tab | tab |
401
+ * +------------+--------------+-------------------+
402
+ * | |
403
+ * +-----------------------------------+
404
+ *
405
+ * to determine the next adjacent index, we look at the tab root left and
406
+ * tab root right, both relative to the scroll position. if the tab root
407
+ * left is less than 0, then we know it's out of view to the left. if the
408
+ * tab root right minus the bar width is greater than 0, we know the tab is
409
+ * out of view to the right. from there, we either increment or decrement
410
+ * the index.
411
+ */
412
+ const relativeRootLeft = tabDimensions.rootLeft - scrollPosition;
413
+ const relativeRootRight = tabDimensions.rootRight - scrollPosition - barWidth;
414
+ const relativeRootDelta = relativeRootLeft + relativeRootRight;
415
+ const leftEdgeIsCloser = relativeRootLeft < 0 || relativeRootDelta < 0;
416
+ const rightEdgeIsCloser = relativeRootRight > 0 || relativeRootDelta > 0;
417
+ if (leftEdgeIsCloser) {
418
+ return index - 1;
419
+ }
420
+ if (rightEdgeIsCloser) {
421
+ return index + 1;
422
+ }
423
+ return -1;
424
+ }
425
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTabsComponent, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
426
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngTabsComponent, isStandalone: true, selector: "fng-tabs", inputs: { viewType: ["fngTabsViewType", "viewType"], showDivider: ["fngTabsUseBottomDivider", "showDivider"], config: "config" }, outputs: { fngBeforeTabChange: "fngBeforeTabChange", fngTabChange: "fngTabChange" }, queries: [{ propertyName: "panes", predicate: FngTabPaneComponent }], viewQueries: [{ propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true }, { propertyName: "scrollAera", first: true, predicate: ["scrollAera"], descendants: true }, { propertyName: "scrollContent", first: true, predicate: ["scrollContent"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"viewType === 'legacy'\">\r\n <div class=\"fwe-legacy-tabs\">\r\n <ul\r\n role=\"tablist\"\r\n class=\"fwe-legacy-tab-bar\"\r\n [class.fwe-legacy-tab-bar-full-width]=\"config?.tabBar?.fullWidth\"\r\n [class.fwe-legacy-tab-items-equal-width]=\"'equal' === config?.tabItems?.appearance\"\r\n [class.fwe-legacy-tab-items-fill]=\"'fill' === config?.tabItems?.appearance\"\r\n >\r\n <li\r\n *ngFor=\"let tab of tabs; let i = index\"\r\n class=\"fwe-legacy-tab-item\"\r\n [ngClass]=\"{ 'fwe-active': tab?.active, 'fwe-disabled': tab?.disabled }\"\r\n >\r\n <ng-container *ngIf=\"null == tab?.icon\">\r\n <a\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n role=\"tab\"\r\n class=\"fwe-legacy-tab-link\"\r\n (click)=\"showTabPane(tab.paneId)\"\r\n >{{ tab.name }}</a\r\n >\r\n </ng-container>\r\n <ng-container *ngIf=\"null != tab?.icon\">\r\n <a\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n role=\"tab\"\r\n class=\"fwe-legacy-tab-link\"\r\n (click)=\"showTabPane(tab.paneId)\"\r\n [class.fwe-can-swap-icon]=\"2 === tabs.length && 1 === i\"\r\n >\r\n <i [class]=\"'fwe-icon ' + tab.icon\"></i>\r\n <span>{{ tab.name }}</span>\r\n </a>\r\n </ng-container>\r\n </li>\r\n </ul>\r\n <div class=\"fwe-legacy-tab-panel-content\">\r\n <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"viewType !== 'legacy'\">\r\n <div class=\"fng-tab-bar\" role=\"tablist\">\r\n <div class=\"fng-tab-scroller\" #scroller>\r\n <div\r\n class=\"fng-tab-scroller-scroll-area fng-tab-scroller-scroll-area--scroll\"\r\n [class.fng-tab-scroller-scroll-area--compact]=\"useCompactDensity\"\r\n #scrollAera\r\n >\r\n <div class=\"fng-tab-scroller-scroll-content\" [class.fng-tab-scroller-scroll-content--with-divider]=\"showDivider\" #scrollContent>\r\n <button\r\n *ngFor=\"let tab of tabs; let i = index\"\r\n role=\"tab\"\r\n class=\"fng-tab\"\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [tabindex]=\"i === 0 ? 0 : -1\"\r\n [class.fng-tab--active]=\"tab?.active\"\r\n [class.fng-tab--disabled]=\"tab?.disabled\"\r\n (click)=\"handleTabScroll($event, i); showTabPane(tab.paneId)\"\r\n >\r\n <span class=\"fng-tab-content\">\r\n <span class=\"fng-tab-text-label\">{{ tab.name }}</span>\r\n </span>\r\n <span class=\"fng-tab-indicator\" [class.fng-tab-indicator--active]=\"tab?.active\">\r\n <span class=\"fng-tab-indicator-content fng-tab-indicator-content--underline\"></span>\r\n </span>\r\n </button>\r\n <div class=\"fng-tab-scroller-divider-line\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"fng-tab-panel-content\">\r\n <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-template #tabPanelContent>\r\n <ng-content></ng-content>\r\n</ng-template>\r\n", styles: [".fwe-legacy-tabs{margin:48px 0;width:100%;height:100%}.fwe-legacy-tab-bar{display:flex;flex-wrap:nowrap;width:75%;padding-left:0;margin-bottom:0;margin-top:0;list-style:none;font-size:var(--fwe-font-size-base)}.fwe-legacy-tab-bar.fwe-legacy-tab-bar-full-width{width:100%}.fwe-legacy-tab-bar.fwe-legacy-tab-items-fill .fwe-legacy-tab-item{flex:1 1 auto}.fwe-legacy-tab-bar.fwe-legacy-tab-items-equal-width .fwe-legacy-tab-item{flex:1 1 0}.fwe-legacy-tab-item{height:48px;max-height:48px;background-color:var(--fwe-gray-300);border-right:2px solid var(--fwe-gray-100);text-align:center}.fwe-legacy-tab-item:last-child{border-right:none}.fwe-legacy-tab-item.fwe-active{background-color:var(--fwe-white)}.fwe-legacy-tab-item.fwe-active .fwe-legacy-tab-link{color:var(--fwe-caerul)}.fwe-legacy-tab-item.fwe-disabled{background-color:var(--fwe-control-disabled)}.fwe-legacy-tab-item.fwe-disabled .fwe-legacy-tab-link{color:var(--fwe-text-disabled)}.fwe-legacy-tab-item:not(.fwe-active){border-bottom:2px solid var(--fwe-gray-100)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link{padding:11px 16px}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link:hover{color:var(--fwe-btn-text);background-color:var(--fwe-btn-hover)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link:active{background-color:var(--fwe-btn-active)}.fwe-legacy-tab-link{display:inline-block;width:100%;height:46px;padding:11px 16px 13px;line-height:24px;cursor:pointer;color:var(--fwe-black);white-space:nowrap}.fwe-legacy-tab-link i.fwe-icon{padding-right:8px;vertical-align:initial}.fwe-legacy-tab-link i.fwe-icon.fwe-icon-lg{position:relative;top:3px}.fwe-legacy-tab-panel-content{padding:48px 24px;background-color:var(--fwe-white);height:100%;overflow:auto}@media (max-width: 375px){.fwe-legacy-tab-bar{justify-content:space-between;background-color:var(--fwe-white);width:100%}.fwe-legacy-tab-item{background-color:var(--fwe-white);border-right:2px solid var(--fwe-white)}.fwe-legacy-tab-item:not(.fwe-active){border-bottom:2px solid var(--fwe-white)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link{color:var(--fwe-icon-gray)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link i.fwe-icon{color:var(--fwe-icon-gray)}.fwe-legacy-tab-link.fwe-can-swap-icon{direction:rtl}.fwe-legacy-tab-link.fwe-can-swap-icon i.fwe-icon{padding-left:8px;padding-right:0}}.fng-tab-panel-content{padding:48px 24px;background-color:var(--fwe-white);height:100%;overflow:auto}.fng-tab-bar{width:100%}.fng-tab-scroller{overflow-y:hidden}.fng-tab-scroller-scroll-area{position:relative;display:flex;overflow-x:hidden}.fng-tab-scroller-scroll-area::-webkit-scrollbar{display:none}.fng-tab-scroller-scroll-area--scroll{overflow-x:scroll}.fng-tab-scroller-scroll-content{position:relative;display:flex;flex:1 0 auto;transform:none;will-change:transform;padding:0 17px 0 16px}.fng-tab-scroller-scroll-content--with-divider .fng-tab-scroller-divider-line{display:block}.fng-tab-scroller--animating .fng-tab-scroller-scroll-content{transition:.25s transform cubic-bezier(.4,0,.2,1)}.fng-tab-scroller-divider-line{display:none;position:absolute;inset:0;border-bottom:1px solid var(--fwe-control)}.fng-tab-indicator{display:flex;position:absolute;top:0;left:0;justify-content:center;width:100%;height:100%;pointer-events:none;z-index:1}.fng-tab-indicator-content{transform-origin:left;opacity:0}.fng-tab-indicator-content--underline{align-self:flex-end;box-sizing:border-box;width:100%;border-top-style:solid}.fng-tab-indicator .fng-tab-indicator-content{transition:.25s transform cubic-bezier(.4,0,.2,1)}.fng-tab-indicator .fng-tab-indicator-content--underline{border-top:4px solid var(--fwe-caerul)}.fng-tab-indicator--active .fng-tab-indicator-content{opacity:1}.fng-tab{position:relative;display:flex;flex:1 0 auto;justify-content:center;padding:0;margin:0;border:none;outline:none;background:none;text-align:center;white-space:nowrap;cursor:pointer;-webkit-appearance:none;z-index:1;height:36px}.fng-tab:hover .fng-tab-text-label{color:var(--fwe-caerul)}.fng-tab:active .fng-tab-text-label{color:var(--fwe-btn-hero-active)}.fng-tab:not(:last-child){margin-right:32px}.fng-tab::-moz-focus-inner{padding:0;border:0}.fng-tab .fng-tab-text-label{color:var(--fwe-text)}.fng-tab--active .fng-tab-text-label{color:var(--fwe-caerul)}.fng-tab--disabled .fng-tab-text-label{color:var(--fwe-text-disabled)}.fng-tab-content{position:relative;display:flex;align-items:flex-start;justify-content:center;height:inherit;pointer-events:none}.fng-tab-text-label{display:inline-block;z-index:2}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab{flex:none}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab:not(:last-child){margin-right:64px}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab-scroller-scroll-content{padding:0 32px}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab-scroller-divider-line{padding-right:64px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
427
+ }
428
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngTabsComponent, decorators: [{
429
+ type: Component,
430
+ args: [{ standalone: true, imports: [CommonModule], selector: 'fng-tabs', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"viewType === 'legacy'\">\r\n <div class=\"fwe-legacy-tabs\">\r\n <ul\r\n role=\"tablist\"\r\n class=\"fwe-legacy-tab-bar\"\r\n [class.fwe-legacy-tab-bar-full-width]=\"config?.tabBar?.fullWidth\"\r\n [class.fwe-legacy-tab-items-equal-width]=\"'equal' === config?.tabItems?.appearance\"\r\n [class.fwe-legacy-tab-items-fill]=\"'fill' === config?.tabItems?.appearance\"\r\n >\r\n <li\r\n *ngFor=\"let tab of tabs; let i = index\"\r\n class=\"fwe-legacy-tab-item\"\r\n [ngClass]=\"{ 'fwe-active': tab?.active, 'fwe-disabled': tab?.disabled }\"\r\n >\r\n <ng-container *ngIf=\"null == tab?.icon\">\r\n <a\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n role=\"tab\"\r\n class=\"fwe-legacy-tab-link\"\r\n (click)=\"showTabPane(tab.paneId)\"\r\n >{{ tab.name }}</a\r\n >\r\n </ng-container>\r\n <ng-container *ngIf=\"null != tab?.icon\">\r\n <a\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n role=\"tab\"\r\n class=\"fwe-legacy-tab-link\"\r\n (click)=\"showTabPane(tab.paneId)\"\r\n [class.fwe-can-swap-icon]=\"2 === tabs.length && 1 === i\"\r\n >\r\n <i [class]=\"'fwe-icon ' + tab.icon\"></i>\r\n <span>{{ tab.name }}</span>\r\n </a>\r\n </ng-container>\r\n </li>\r\n </ul>\r\n <div class=\"fwe-legacy-tab-panel-content\">\r\n <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"viewType !== 'legacy'\">\r\n <div class=\"fng-tab-bar\" role=\"tablist\">\r\n <div class=\"fng-tab-scroller\" #scroller>\r\n <div\r\n class=\"fng-tab-scroller-scroll-area fng-tab-scroller-scroll-area--scroll\"\r\n [class.fng-tab-scroller-scroll-area--compact]=\"useCompactDensity\"\r\n #scrollAera\r\n >\r\n <div class=\"fng-tab-scroller-scroll-content\" [class.fng-tab-scroller-scroll-content--with-divider]=\"showDivider\" #scrollContent>\r\n <button\r\n *ngFor=\"let tab of tabs; let i = index\"\r\n role=\"tab\"\r\n class=\"fng-tab\"\r\n [id]=\"componentId + '-tab-' + i\"\r\n [attr.aria-controls]=\"tab.paneId\"\r\n [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n [tabindex]=\"i === 0 ? 0 : -1\"\r\n [class.fng-tab--active]=\"tab?.active\"\r\n [class.fng-tab--disabled]=\"tab?.disabled\"\r\n (click)=\"handleTabScroll($event, i); showTabPane(tab.paneId)\"\r\n >\r\n <span class=\"fng-tab-content\">\r\n <span class=\"fng-tab-text-label\">{{ tab.name }}</span>\r\n </span>\r\n <span class=\"fng-tab-indicator\" [class.fng-tab-indicator--active]=\"tab?.active\">\r\n <span class=\"fng-tab-indicator-content fng-tab-indicator-content--underline\"></span>\r\n </span>\r\n </button>\r\n <div class=\"fng-tab-scroller-divider-line\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"fng-tab-panel-content\">\r\n <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n </div>\r\n </div>\r\n</ng-container>\r\n\r\n<ng-template #tabPanelContent>\r\n <ng-content></ng-content>\r\n</ng-template>\r\n", styles: [".fwe-legacy-tabs{margin:48px 0;width:100%;height:100%}.fwe-legacy-tab-bar{display:flex;flex-wrap:nowrap;width:75%;padding-left:0;margin-bottom:0;margin-top:0;list-style:none;font-size:var(--fwe-font-size-base)}.fwe-legacy-tab-bar.fwe-legacy-tab-bar-full-width{width:100%}.fwe-legacy-tab-bar.fwe-legacy-tab-items-fill .fwe-legacy-tab-item{flex:1 1 auto}.fwe-legacy-tab-bar.fwe-legacy-tab-items-equal-width .fwe-legacy-tab-item{flex:1 1 0}.fwe-legacy-tab-item{height:48px;max-height:48px;background-color:var(--fwe-gray-300);border-right:2px solid var(--fwe-gray-100);text-align:center}.fwe-legacy-tab-item:last-child{border-right:none}.fwe-legacy-tab-item.fwe-active{background-color:var(--fwe-white)}.fwe-legacy-tab-item.fwe-active .fwe-legacy-tab-link{color:var(--fwe-caerul)}.fwe-legacy-tab-item.fwe-disabled{background-color:var(--fwe-control-disabled)}.fwe-legacy-tab-item.fwe-disabled .fwe-legacy-tab-link{color:var(--fwe-text-disabled)}.fwe-legacy-tab-item:not(.fwe-active){border-bottom:2px solid var(--fwe-gray-100)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link{padding:11px 16px}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link:hover{color:var(--fwe-btn-text);background-color:var(--fwe-btn-hover)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link:active{background-color:var(--fwe-btn-active)}.fwe-legacy-tab-link{display:inline-block;width:100%;height:46px;padding:11px 16px 13px;line-height:24px;cursor:pointer;color:var(--fwe-black);white-space:nowrap}.fwe-legacy-tab-link i.fwe-icon{padding-right:8px;vertical-align:initial}.fwe-legacy-tab-link i.fwe-icon.fwe-icon-lg{position:relative;top:3px}.fwe-legacy-tab-panel-content{padding:48px 24px;background-color:var(--fwe-white);height:100%;overflow:auto}@media (max-width: 375px){.fwe-legacy-tab-bar{justify-content:space-between;background-color:var(--fwe-white);width:100%}.fwe-legacy-tab-item{background-color:var(--fwe-white);border-right:2px solid var(--fwe-white)}.fwe-legacy-tab-item:not(.fwe-active){border-bottom:2px solid var(--fwe-white)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link{color:var(--fwe-icon-gray)}.fwe-legacy-tab-item:not(.fwe-active) .fwe-legacy-tab-link i.fwe-icon{color:var(--fwe-icon-gray)}.fwe-legacy-tab-link.fwe-can-swap-icon{direction:rtl}.fwe-legacy-tab-link.fwe-can-swap-icon i.fwe-icon{padding-left:8px;padding-right:0}}.fng-tab-panel-content{padding:48px 24px;background-color:var(--fwe-white);height:100%;overflow:auto}.fng-tab-bar{width:100%}.fng-tab-scroller{overflow-y:hidden}.fng-tab-scroller-scroll-area{position:relative;display:flex;overflow-x:hidden}.fng-tab-scroller-scroll-area::-webkit-scrollbar{display:none}.fng-tab-scroller-scroll-area--scroll{overflow-x:scroll}.fng-tab-scroller-scroll-content{position:relative;display:flex;flex:1 0 auto;transform:none;will-change:transform;padding:0 17px 0 16px}.fng-tab-scroller-scroll-content--with-divider .fng-tab-scroller-divider-line{display:block}.fng-tab-scroller--animating .fng-tab-scroller-scroll-content{transition:.25s transform cubic-bezier(.4,0,.2,1)}.fng-tab-scroller-divider-line{display:none;position:absolute;inset:0;border-bottom:1px solid var(--fwe-control)}.fng-tab-indicator{display:flex;position:absolute;top:0;left:0;justify-content:center;width:100%;height:100%;pointer-events:none;z-index:1}.fng-tab-indicator-content{transform-origin:left;opacity:0}.fng-tab-indicator-content--underline{align-self:flex-end;box-sizing:border-box;width:100%;border-top-style:solid}.fng-tab-indicator .fng-tab-indicator-content{transition:.25s transform cubic-bezier(.4,0,.2,1)}.fng-tab-indicator .fng-tab-indicator-content--underline{border-top:4px solid var(--fwe-caerul)}.fng-tab-indicator--active .fng-tab-indicator-content{opacity:1}.fng-tab{position:relative;display:flex;flex:1 0 auto;justify-content:center;padding:0;margin:0;border:none;outline:none;background:none;text-align:center;white-space:nowrap;cursor:pointer;-webkit-appearance:none;z-index:1;height:36px}.fng-tab:hover .fng-tab-text-label{color:var(--fwe-caerul)}.fng-tab:active .fng-tab-text-label{color:var(--fwe-btn-hero-active)}.fng-tab:not(:last-child){margin-right:32px}.fng-tab::-moz-focus-inner{padding:0;border:0}.fng-tab .fng-tab-text-label{color:var(--fwe-text)}.fng-tab--active .fng-tab-text-label{color:var(--fwe-caerul)}.fng-tab--disabled .fng-tab-text-label{color:var(--fwe-text-disabled)}.fng-tab-content{position:relative;display:flex;align-items:flex-start;justify-content:center;height:inherit;pointer-events:none}.fng-tab-text-label{display:inline-block;z-index:2}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab{flex:none}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab:not(:last-child){margin-right:64px}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab-scroller-scroll-content{padding:0 32px}.fng-tab-scroller-scroll-area:not(.fng-tab-scroller-scroll-area--compact) .fng-tab-scroller-divider-line{padding-right:64px}\n"] }]
431
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: Document, decorators: [{
432
+ type: Inject,
433
+ args: [DOCUMENT]
434
+ }] }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { viewType: [{
435
+ type: Input,
436
+ args: ['fngTabsViewType']
437
+ }], showDivider: [{
438
+ type: Input,
439
+ args: ['fngTabsUseBottomDivider']
440
+ }], config: [{
441
+ type: Input
442
+ }], fngBeforeTabChange: [{
443
+ type: Output
444
+ }], fngTabChange: [{
445
+ type: Output
446
+ }], panes: [{
447
+ type: ContentChildren,
448
+ args: [FngTabPaneComponent]
449
+ }], scroller: [{
450
+ type: ViewChild,
451
+ args: ['scroller']
452
+ }], scrollAera: [{
453
+ type: ViewChild,
454
+ args: ['scrollAera']
455
+ }], scrollContent: [{
456
+ type: ViewChild,
457
+ args: ['scrollContent']
458
+ }] } });
459
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/components/tabs/tabs.component.ts","../../../../../../projects/angular/src/lib/components/tabs/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\r\nimport {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { noop, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FngTabPaneComponent } from './tab-pane/tab-pane.component';\r\n\r\nexport interface FngTab {\r\n  name: string;\r\n  paneId: string | null;\r\n  active?: boolean;\r\n  icon?: string | null;\r\n  disabled?: boolean;\r\n}\r\n\r\n// fill: use the remaining space and add in same proportion to every tab item\r\n// equal: make all tab items same width (as the one with largest content)\r\nexport type FngTabItemAppearance = 'fill' | 'equal' | 'default';\r\n\r\n// legacy: recommended for desktop only applications\r\n// responsive: desktop, tablet, mobile with scrollable tabs\r\nexport type FngTabViewType = 'legacy' | 'responsive';\r\n\r\n// configuration options for legacy tab view type\r\nexport interface FngTabsConfiguration {\r\n  tabBar?: {\r\n    fullWidth?: boolean;\r\n  };\r\n  tabItems?: {\r\n    appearance: FngTabItemAppearance;\r\n  };\r\n}\r\n\r\n// provides details about the left and right edges of the tab element and the tab content element\r\n// these values are used to determine the visual position of the tab with respect of its parent container\r\nexport interface FngTabDimensions {\r\n  rootLeft: number;\r\n  rootRight: number;\r\n  contentLeft: number;\r\n  contentRight: number;\r\n}\r\n\r\nexport interface FngTabScrollAnimation {\r\n  finalScrollPosition: number;\r\n  scrollDelta: number;\r\n}\r\n\r\nexport interface FngTabScrollHorizontalEdges {\r\n  left: number;\r\n  right: number;\r\n}\r\n\r\nexport interface FngBeforeTabChangeEvent {\r\n  ok: () => void;\r\n  cancel: () => void;\r\n}\r\n\r\n@Component({\r\n  standalone: true,\r\n  imports: [CommonModule],\r\n  selector: 'fng-tabs',\r\n  templateUrl: './tabs.component.html',\r\n  styleUrls: ['./tabs.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FngTabsComponent implements AfterContentInit, AfterViewInit, OnDestroy {\r\n  static nextId = 0;\r\n  @Input('fngTabsViewType') viewType: FngTabViewType = 'responsive';\r\n  @Input('fngTabsUseBottomDivider') showDivider: boolean = false;\r\n\r\n  @Input() config: FngTabsConfiguration | null = null;\r\n  @Output() fngBeforeTabChange = new EventEmitter<FngBeforeTabChangeEvent>();\r\n  @Output() fngTabChange = new EventEmitter<{ previous: string; current: string }>();\r\n\r\n  @ContentChildren(FngTabPaneComponent) panes: QueryList<FngTabPaneComponent> | undefined;\r\n  @ViewChild('scroller') scroller: ElementRef | undefined;\r\n  @ViewChild('scrollAera') scrollAera: ElementRef | undefined;\r\n  @ViewChild('scrollContent') scrollContent: ElementRef | undefined;\r\n\r\n  componentId = `tabs-${++FngTabsComponent.nextId}`;\r\n  tabs: FngTab[] = [];\r\n  useCompactDensity: boolean = true;\r\n  private activeTab: FngTab | undefined = undefined;\r\n  private elemScroller: HTMLElement | undefined;\r\n  private elemScrollArea: HTMLElement | undefined;\r\n  private elemScrollContent: HTMLElement | undefined;\r\n  private readonly injectedWindow: Window | null;\r\n  private resizeObserver!: ResizeObserver;\r\n  private complete: Subject<boolean> = new Subject();\r\n\r\n  constructor(\r\n    private elRef: ElementRef,\r\n    @Inject(DOCUMENT) private document: Document,\r\n    private renderer: Renderer2,\r\n    private cd: ChangeDetectorRef\r\n  ) {\r\n    this.injectedWindow = this.document.defaultView;\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.initTabs();\r\n    if (null == this.activeTab) {\r\n      this.panes?.map((pane, i) => {\r\n        if (0 === i) {\r\n          pane.isVisible = true;\r\n        }\r\n      });\r\n    } else {\r\n      const pane = this.panes?.find(pane => {\r\n        if (this.activeTab) {\r\n          return this.activeTab.paneId != null && pane.tabPaneId === this.activeTab.paneId;\r\n        } else {\r\n          return false;\r\n        }\r\n      });\r\n      if (pane) {\r\n        pane.isVisible = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.elemScroller = this.scroller?.nativeElement;\r\n    this.elemScrollArea = this.scrollAera?.nativeElement;\r\n    this.elemScrollContent = this.scrollContent?.nativeElement;\r\n    if (this.elemScroller == null || this.elemScrollArea == null || this.elemScrollContent == null) {\r\n      return;\r\n    }\r\n    const initialWidth = this.elemScrollArea.offsetWidth;\r\n    if (initialWidth != null && initialWidth > 768) {\r\n      this.useCompactDensity = false;\r\n      this.cd.detectChanges();\r\n    }\r\n\r\n    this.resizeObserver = new ResizeObserver(() => {\r\n      if (this.elemScrollArea == null) {\r\n        return;\r\n      }\r\n      const width = this.elemScrollArea.offsetWidth;\r\n      if (width != null && width > 768 && this.useCompactDensity === true) {\r\n        this.useCompactDensity = false;\r\n        this.cd.detectChanges();\r\n      } else if (width != null && width <= 768 && this.useCompactDensity === false) {\r\n        this.useCompactDensity = true;\r\n        this.cd.detectChanges();\r\n      }\r\n    });\r\n\r\n    if (this.elemScrollArea != null) {\r\n      this.resizeObserver.observe(this.elemScrollArea);\r\n    }\r\n\r\n    this.handleTabPaneChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.complete.next(true);\r\n    this.complete.unsubscribe();\r\n  }\r\n\r\n  showTabPane(id: string | null) {\r\n    if (id == null) {\r\n      return;\r\n    }\r\n\r\n    const pane = this.panes?.find(p => p.tabPaneId === id);\r\n    const handleTabChange = (id: string) => {\r\n      if (pane != null && pane.disabled !== true) {\r\n        this.panes?.map(p => {\r\n          p.isVisible = false;\r\n        });\r\n        pane.isVisible = true;\r\n\r\n        this.tabs.map(tab => {\r\n          if (tab.paneId !== pane.tabPaneId) {\r\n            tab.active = false;\r\n          } else {\r\n            tab.active = true;\r\n          }\r\n        });\r\n        this.fngTabChange.emit({\r\n          previous: this.activeTab?.paneId || '',\r\n          current: id\r\n        });\r\n        this.activeTab = this.tabs.find(tab => !!tab.active);\r\n        this.cd.detectChanges();\r\n      }\r\n    };\r\n\r\n    if (this.fngBeforeTabChange?.observers?.length > 0 && pane?.disabled !== true) {\r\n      this.fngBeforeTabChange.emit({\r\n        ok: () => {\r\n          handleTabChange(id);\r\n        },\r\n        cancel: () => {\r\n          noop();\r\n        }\r\n      });\r\n    } else {\r\n      handleTabChange(id);\r\n    }\r\n  }\r\n\r\n  handleTabScroll(event: any, index: number) {\r\n    if (this.elemScrollContent == null || this.elemScrollArea == null) {\r\n      return;\r\n    }\r\n    const scrollContentWidth = this.elemScrollContent.offsetWidth;\r\n    const scrollAreaWidth = this.elemScrollArea.offsetWidth;\r\n\r\n    // check if no scroll is needed\r\n    if (scrollAreaWidth > scrollContentWidth) {\r\n      return;\r\n    }\r\n\r\n    // check index\r\n    if (!this.indexIsInRange(index)) {\r\n      return;\r\n    }\r\n\r\n    // always scroll to 0 if scrolling to the first tab\r\n    if (index === 0) {\r\n      this.scrollTo(0);\r\n      return;\r\n    }\r\n\r\n    // always scroll to the max value if scrolling to the last tab\r\n    if (index === this.tabs.length - 1) {\r\n      this.scrollTo(this.elemScrollContent.offsetWidth);\r\n      return;\r\n    }\r\n\r\n    const currentTab: HTMLElement = event.target;\r\n    this.scrollIntoView(index, currentTab);\r\n  }\r\n\r\n  private initTabs() {\r\n    this.tabs = [];\r\n    this.panes?.map((pane, i) => {\r\n      pane.tabId = this.componentId + '-tab-' + i;\r\n      const tab: FngTab = {\r\n        name: null != pane.name ? pane.name : '',\r\n        paneId: null != pane.tabPaneId ? pane.tabPaneId : null,\r\n        icon: null != pane.icon ? pane.icon : null,\r\n        active: null != pane.active ? pane.active : false,\r\n        disabled: null != pane.disabled ? pane.disabled : false\r\n      };\r\n      this.tabs.push(tab);\r\n    });\r\n\r\n    this.initActiveTab();\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  private initActiveTab() {\r\n    const activeTab: FngTab | undefined = this.tabs.find((tab: FngTab) => !!tab.active);\r\n    if (!activeTab && 0 < this.tabs.length) {\r\n      this.tabs[0] = { ...this.tabs[0], active: true };\r\n      this.activeTab = this.tabs[0];\r\n    } else {\r\n      this.activeTab = activeTab;\r\n    }\r\n  }\r\n\r\n  private handleTabPaneChanges() {\r\n    // first subscribe to any changes in tab pane, so that the tabs in this view wiil be updated\r\n    this.panes?.forEach(pane => {\r\n      pane.changes$.pipe(takeUntil(this.complete)).subscribe(() => {\r\n        // on changes in a tab pane, we init the tabs again\r\n        this.initTabs();\r\n      });\r\n    });\r\n  }\r\n\r\n  private scrollTo(scrollX: number | undefined) {\r\n    if (scrollX == null) {\r\n      return;\r\n    }\r\n    const currentScrollX = this.getScrollPosition();\r\n    const safeScrollX = this.clampScrollValue(scrollX);\r\n    if (safeScrollX == null || currentScrollX == null) {\r\n      return;\r\n    }\r\n    const scrollDelta = safeScrollX - currentScrollX;\r\n    this.animate({\r\n      finalScrollPosition: safeScrollX,\r\n      scrollDelta\r\n    });\r\n  }\r\n\r\n  private scrollIntoView(index: number, tab: HTMLElement) {\r\n    if (this.elemScrollArea == null) {\r\n      return;\r\n    }\r\n\r\n    const scrollPosition = this.getScrollPosition();\r\n    const barWidth = this.elemScrollArea.offsetWidth;\r\n    if (barWidth == null || scrollPosition == null) {\r\n      return;\r\n    }\r\n\r\n    const tabDimensions = this.computeDimensions(tab);\r\n    if (tabDimensions == null) {\r\n      return;\r\n    }\r\n\r\n    const nextIndex = this.findAdjacentTabIndexClosestToEdge(index, tabDimensions, scrollPosition, barWidth);\r\n    if (!this.indexIsInRange(nextIndex)) {\r\n      return;\r\n    }\r\n\r\n    const scrollIncrement = this.calculateScrollIncrement(index, nextIndex, scrollPosition, barWidth);\r\n    if (scrollIncrement == null) {\r\n      return;\r\n    }\r\n\r\n    this.incrementScroll(scrollIncrement);\r\n  }\r\n\r\n  private incrementScroll(scrollXIncrement: number) {\r\n    // no scroll needed\r\n    if (scrollXIncrement === 0) {\r\n      return;\r\n    }\r\n    const scrollOperation = this.getIncrementScrollOperation(scrollXIncrement);\r\n    if (scrollOperation == null) {\r\n      return;\r\n    }\r\n    this.animate(scrollOperation);\r\n  }\r\n\r\n  private animate(animation: FngTabScrollAnimation) {\r\n    // no animation needed\r\n    if (animation.scrollDelta === 0) {\r\n      return;\r\n    }\r\n\r\n    // no animation possible\r\n    if (this.elemScrollArea == null) {\r\n      return;\r\n    }\r\n\r\n    this.stopScrollAnimation();\r\n\r\n    // this animation uses the flip approach\r\n    // https://aerotwist.com/blog/flip-your-animations/\r\n    // https://css-tricks.com/animating-layouts-with-the-flip-technique/\r\n    this.elemScrollArea.scrollLeft = animation.finalScrollPosition;\r\n    this.setScrollContentStyleProperty('transform', `translateX(${animation.scrollDelta}px)`);\r\n    // force repaint\r\n    this.elemScrollArea.getBoundingClientRect();\r\n\r\n    requestAnimationFrame(() => {\r\n      this.renderer.addClass(this.elemScroller, 'fng-tab-scroller--animating');\r\n      this.setScrollContentStyleProperty('transform', 'none');\r\n    });\r\n  }\r\n\r\n  private stopScrollAnimation() {\r\n    if (this.elemScrollArea == null) {\r\n      return;\r\n    }\r\n    const currentScrollPosition = this.getAnimatingScrollPosition();\r\n    if (currentScrollPosition == null) {\r\n      return;\r\n    }\r\n\r\n    this.renderer.removeClass(this.elemScroller, 'fng-tab-scroller--animating');\r\n    this.setScrollContentStyleProperty('transform', 'translateX(0px)');\r\n    this.elemScrollArea.scrollLeft = currentScrollPosition;\r\n  }\r\n\r\n  private getAnimatingScrollPosition(): number | null {\r\n    if (this.elemScrollArea == null) {\r\n      return null;\r\n    }\r\n    const currentTranslateX = this.calculateCurrentTranslateX();\r\n    const scrollLeft = this.elemScrollArea.scrollLeft;\r\n    return scrollLeft - currentTranslateX;\r\n  }\r\n\r\n  private getIncrementScrollOperation(scrollX: number): FngTabScrollAnimation | null {\r\n    const currentScrollX = this.getScrollPosition();\r\n    if (currentScrollX == null) {\r\n      return null;\r\n    }\r\n\r\n    const targetScrollX = scrollX + currentScrollX;\r\n    const safeScrollX = this.clampScrollValue(targetScrollX);\r\n    if (safeScrollX == null) {\r\n      return null;\r\n    }\r\n    const scrollDelta = safeScrollX - currentScrollX;\r\n    return {\r\n      finalScrollPosition: safeScrollX,\r\n      scrollDelta\r\n    };\r\n  }\r\n\r\n  private clampScrollValue(scrollX: number): number | null {\r\n    const edges = this.calculateScrollEdges();\r\n    if (edges == null) {\r\n      return null;\r\n    }\r\n    return Math.min(Math.max(edges.left, scrollX), edges.right);\r\n  }\r\n\r\n  private calculateScrollEdges(): FngTabScrollHorizontalEdges | null {\r\n    if (this.elemScrollArea == null || this.elemScrollContent == null) {\r\n      return null;\r\n    }\r\n    const scrollContentWidth = this.elemScrollContent.offsetWidth;\r\n    const scrollAreaWidth = this.elemScrollArea.offsetWidth;\r\n    return {\r\n      left: 0,\r\n      right: scrollContentWidth - scrollAreaWidth\r\n    };\r\n  }\r\n\r\n  private computeDimensions(tab: HTMLElement): FngTabDimensions | null {\r\n    const rootWidth = tab.offsetWidth;\r\n    const rootLeft = tab.offsetLeft;\r\n\r\n    const tabContent: HTMLElement | null = tab.querySelector<HTMLElement>('.fng-tab-content');\r\n    if (tabContent == null) {\r\n      return null;\r\n    }\r\n\r\n    const contentWidth = tabContent.offsetWidth;\r\n    const contentLeft = tabContent.offsetLeft;\r\n\r\n    return {\r\n      contentLeft: rootLeft + contentLeft,\r\n      contentRight: rootLeft + contentLeft + contentWidth,\r\n      rootLeft,\r\n      rootRight: rootLeft + rootWidth\r\n    };\r\n  }\r\n\r\n  private calculateScrollIncrement(index: number, nextIndex: number, scrollPosition: number, barWidth: number): number | null {\r\n    const nextTab: HTMLElement | null = (this.elRef.nativeElement as HTMLElement).querySelector<HTMLElement>(\r\n      `#${this.componentId}-tab-${nextIndex}`\r\n    );\r\n\r\n    if (nextTab == null) {\r\n      return null;\r\n    }\r\n\r\n    const nextTabDimensions = this.computeDimensions(nextTab);\r\n\r\n    if (nextTabDimensions == null) {\r\n      return null;\r\n    }\r\n\r\n    const relativeContentLeft = nextTabDimensions.contentLeft - scrollPosition - barWidth;\r\n    const relativeContentRight = nextTabDimensions.contentRight - scrollPosition;\r\n    const leftIncrement = relativeContentRight - 48;\r\n    const rightIncrement = relativeContentLeft + 48;\r\n\r\n    if (nextIndex < index) {\r\n      return Math.min(leftIncrement, 0);\r\n    }\r\n\r\n    return Math.max(rightIncrement, 0);\r\n  }\r\n\r\n  private indexIsInRange(index: number) {\r\n    return index >= 0 && index < this.tabs.length;\r\n  }\r\n\r\n  private getScrollPosition(): number | null {\r\n    if (this.elemScrollArea == null) {\r\n      return null;\r\n    }\r\n    const currentTranslateX = this.calculateCurrentTranslateX();\r\n    const scrollLeft = this.elemScrollArea.scrollLeft;\r\n\r\n    return scrollLeft - currentTranslateX;\r\n  }\r\n\r\n  private calculateCurrentTranslateX(): number {\r\n    const transformValue = this.getScrollContentStyleValue('transform');\r\n    if (transformValue == null) {\r\n      return 0;\r\n    }\r\n\r\n    if (transformValue === 'none') {\r\n      return 0;\r\n    }\r\n\r\n    // the transform value is in form of 'matrix(a, b, c, d, tx, ty)'\r\n    // get all the parenthesized values\r\n    const match = /\\((.+?)\\)/.exec(transformValue);\r\n    if (!match) {\r\n      return 0;\r\n    }\r\n\r\n    const matrixParams = match[1];\r\n    // we need value of tx -> translateX\r\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n    const [a, b, c, d, tx, ty] = matrixParams.split(',');\r\n    return parseFloat(tx);\r\n  }\r\n\r\n  private getScrollContentStyleValue(propName: string) {\r\n    if (this.elemScrollContent == null) {\r\n      return;\r\n    }\r\n    return this.injectedWindow?.getComputedStyle(this.elemScrollContent).getPropertyValue(propName);\r\n  }\r\n\r\n  private setScrollContentStyleProperty(propName: string, value: any) {\r\n    this.renderer.setStyle(this.elemScrollContent, propName, value);\r\n  }\r\n\r\n  private findAdjacentTabIndexClosestToEdge(index: number, tabDimensions: FngTabDimensions, scrollPosition: number, barWidth: number): number {\r\n    /**\r\n     * tabs are laid out in the tab scroller like this:\r\n     *\r\n     *    scroll position\r\n     *    +---+\r\n     *    |   |   bar width\r\n     *    |   +-----------------------------------+\r\n     *    |   |                                   |\r\n     *    |   v                                   v\r\n     *    |   +-----------------------------------+\r\n     *    v   |             tab scroller          |\r\n     *    +------------+--------------+-------------------+\r\n     *    |    tab     |      tab     |        tab        |\r\n     *    +------------+--------------+-------------------+\r\n     *        |                                   |\r\n     *        +-----------------------------------+\r\n     *\r\n     * to determine the next adjacent index, we look at the tab root left and\r\n     * tab root right, both relative to the scroll position. if the tab root\r\n     * left is less than 0, then we know it's out of view to the left. if the\r\n     * tab root right minus the bar width is greater than 0, we know the tab is\r\n     * out of view to the right. from there, we either increment or decrement\r\n     * the index.\r\n     */\r\n    const relativeRootLeft = tabDimensions.rootLeft - scrollPosition;\r\n    const relativeRootRight = tabDimensions.rootRight - scrollPosition - barWidth;\r\n    const relativeRootDelta = relativeRootLeft + relativeRootRight;\r\n    const leftEdgeIsCloser = relativeRootLeft < 0 || relativeRootDelta < 0;\r\n    const rightEdgeIsCloser = relativeRootRight > 0 || relativeRootDelta > 0;\r\n\r\n    if (leftEdgeIsCloser) {\r\n      return index - 1;\r\n    }\r\n\r\n    if (rightEdgeIsCloser) {\r\n      return index + 1;\r\n    }\r\n\r\n    return -1;\r\n  }\r\n}\r\n","<ng-container *ngIf=\"viewType === 'legacy'\">\r\n  <div class=\"fwe-legacy-tabs\">\r\n    <ul\r\n      role=\"tablist\"\r\n      class=\"fwe-legacy-tab-bar\"\r\n      [class.fwe-legacy-tab-bar-full-width]=\"config?.tabBar?.fullWidth\"\r\n      [class.fwe-legacy-tab-items-equal-width]=\"'equal' === config?.tabItems?.appearance\"\r\n      [class.fwe-legacy-tab-items-fill]=\"'fill' === config?.tabItems?.appearance\"\r\n    >\r\n      <li\r\n        *ngFor=\"let tab of tabs; let i = index\"\r\n        class=\"fwe-legacy-tab-item\"\r\n        [ngClass]=\"{ 'fwe-active': tab?.active, 'fwe-disabled': tab?.disabled }\"\r\n      >\r\n        <ng-container *ngIf=\"null == tab?.icon\">\r\n          <a\r\n            [id]=\"componentId + '-tab-' + i\"\r\n            [attr.aria-controls]=\"tab.paneId\"\r\n            [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n            [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n            role=\"tab\"\r\n            class=\"fwe-legacy-tab-link\"\r\n            (click)=\"showTabPane(tab.paneId)\"\r\n            >{{ tab.name }}</a\r\n          >\r\n        </ng-container>\r\n        <ng-container *ngIf=\"null != tab?.icon\">\r\n          <a\r\n            [id]=\"componentId + '-tab-' + i\"\r\n            [attr.aria-controls]=\"tab.paneId\"\r\n            [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n            [attr.aria-disabled]=\"true === tab?.disabled ? true : false\"\r\n            role=\"tab\"\r\n            class=\"fwe-legacy-tab-link\"\r\n            (click)=\"showTabPane(tab.paneId)\"\r\n            [class.fwe-can-swap-icon]=\"2 === tabs.length && 1 === i\"\r\n          >\r\n            <i [class]=\"'fwe-icon ' + tab.icon\"></i>\r\n            <span>{{ tab.name }}</span>\r\n          </a>\r\n        </ng-container>\r\n      </li>\r\n    </ul>\r\n    <div class=\"fwe-legacy-tab-panel-content\">\r\n      <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"viewType !== 'legacy'\">\r\n  <div class=\"fng-tab-bar\" role=\"tablist\">\r\n    <div class=\"fng-tab-scroller\" #scroller>\r\n      <div\r\n        class=\"fng-tab-scroller-scroll-area fng-tab-scroller-scroll-area--scroll\"\r\n        [class.fng-tab-scroller-scroll-area--compact]=\"useCompactDensity\"\r\n        #scrollAera\r\n      >\r\n        <div class=\"fng-tab-scroller-scroll-content\" [class.fng-tab-scroller-scroll-content--with-divider]=\"showDivider\" #scrollContent>\r\n          <button\r\n            *ngFor=\"let tab of tabs; let i = index\"\r\n            role=\"tab\"\r\n            class=\"fng-tab\"\r\n            [id]=\"componentId + '-tab-' + i\"\r\n            [attr.aria-controls]=\"tab.paneId\"\r\n            [attr.aria-selected]=\"true === tab?.active ? true : false\"\r\n            [tabindex]=\"i === 0 ? 0 : -1\"\r\n            [class.fng-tab--active]=\"tab?.active\"\r\n            [class.fng-tab--disabled]=\"tab?.disabled\"\r\n            (click)=\"handleTabScroll($event, i); showTabPane(tab.paneId)\"\r\n          >\r\n            <span class=\"fng-tab-content\">\r\n              <span class=\"fng-tab-text-label\">{{ tab.name }}</span>\r\n            </span>\r\n            <span class=\"fng-tab-indicator\" [class.fng-tab-indicator--active]=\"tab?.active\">\r\n              <span class=\"fng-tab-indicator-content fng-tab-indicator-content--underline\"></span>\r\n            </span>\r\n          </button>\r\n          <div class=\"fng-tab-scroller-divider-line\"></div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"fng-tab-panel-content\">\r\n      <ng-container *ngTemplateOutlet=\"tabPanelContent\"></ng-container>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n\r\n<ng-template #tabPanelContent>\r\n  <ng-content></ng-content>\r\n</ng-template>\r\n"]}
@@ -11,19 +11,19 @@ export class FngClickOutsideDirective {
11
11
  this.clickOutside.emit(null);
12
12
  }
13
13
  }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngClickOutsideDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
15
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: FngClickOutsideDirective, isStandalone: true, selector: "[fngClickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event.target)" } }, ngImport: i0 }); }
14
16
  }
15
- FngClickOutsideDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: FngClickOutsideDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
16
- FngClickOutsideDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: FngClickOutsideDirective, isStandalone: true, selector: "[fngClickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event.target)" } }, ngImport: i0 });
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: FngClickOutsideDirective, decorators: [{
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngClickOutsideDirective, decorators: [{
18
18
  type: Directive,
19
19
  args: [{
20
20
  standalone: true,
21
21
  selector: '[fngClickOutside]'
22
22
  }]
23
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { clickOutside: [{
23
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { clickOutside: [{
24
24
  type: Output
25
25
  }], onClick: [{
26
26
  type: HostListener,
27
27
  args: ['document:click', ['$event.target']]
28
28
  }] } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy9saWIvZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0xRixNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLFlBQW9CLEtBQWlCO1FBQWpCLFVBQUssR0FBTCxLQUFLLENBQVk7UUFHOUIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBSEQsQ0FBQztJQU1sQyxPQUFPLENBQUMsYUFBMEI7UUFDdkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUM5QjtJQUNILENBQUM7O3FIQVpVLHdCQUF3Qjt5R0FBeEIsd0JBQXdCOzJGQUF4Qix3QkFBd0I7a0JBSnBDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCO2lHQUtRLFlBQVk7c0JBRGxCLE1BQU07Z0JBSUEsT0FBTztzQkFEYixZQUFZO3VCQUFDLGdCQUFnQixFQUFFLENBQUMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1tmbmdDbGlja091dHNpZGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBGbmdDbGlja091dHNpZGVEaXJlY3RpdmUge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsUmVmOiBFbGVtZW50UmVmKSB7fVxuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgY2xpY2tPdXRzaWRlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmNsaWNrJywgWyckZXZlbnQudGFyZ2V0J10pXG4gIHB1YmxpYyBvbkNsaWNrKHRhcmdldEVsZW1lbnQ6IEhUTUxFbGVtZW50KSB7XG4gICAgY29uc3QgaW5zaWRlID0gdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKHRhcmdldEVsZW1lbnQpO1xuICAgIGlmICghaW5zaWRlKSB7XG4gICAgICB0aGlzLmNsaWNrT3V0c2lkZS5lbWl0KG51bGwpO1xuICAgIH1cbiAgfVxufVxuIl19
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyL3NyYy9saWIvZGlyZWN0aXZlcy9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU0xRixNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLFlBQW9CLEtBQWlCO1FBQWpCLFVBQUssR0FBTCxLQUFLLENBQVk7UUFHOUIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBSEQsQ0FBQztJQU1sQyxPQUFPLENBQUMsYUFBMEI7UUFDdkMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2hFLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDWCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUM5QjtJQUNILENBQUM7OEdBWlUsd0JBQXdCO2tHQUF4Qix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBSnBDLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtQkFBbUI7aUJBQzlCOytFQUtRLFlBQVk7c0JBRGxCLE1BQU07Z0JBSUEsT0FBTztzQkFEYixZQUFZO3VCQUFDLGdCQUFnQixFQUFFLENBQUMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBPdXRwdXQsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ1tmbmdDbGlja091dHNpZGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBGbmdDbGlja091dHNpZGVEaXJlY3RpdmUge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsUmVmOiBFbGVtZW50UmVmKSB7fVxuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgY2xpY2tPdXRzaWRlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OmNsaWNrJywgWyckZXZlbnQudGFyZ2V0J10pXG4gIHB1YmxpYyBvbkNsaWNrKHRhcmdldEVsZW1lbnQ6IEhUTUxFbGVtZW50KSB7XG4gICAgY29uc3QgaW5zaWRlID0gdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKHRhcmdldEVsZW1lbnQpO1xuICAgIGlmICghaW5zaWRlKSB7XG4gICAgICB0aGlzLmNsaWNrT3V0c2lkZS5lbWl0KG51bGwpO1xuICAgIH1cbiAgfVxufVxuIl19