@natec/mef-dev-ui-kit 15.0.0 → 16.0.0

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 (132) hide show
  1. package/esm2022/lib/markup-kit/card/card/card.component.mjs +116 -0
  2. package/esm2022/lib/markup-kit/card/card-long/card-long.component.mjs +169 -0
  3. package/esm2022/lib/markup-kit/card/card-simple/card-simple.component.mjs +50 -0
  4. package/{esm2020 → esm2022}/lib/markup-kit/card/card.module.mjs +11 -11
  5. package/esm2022/lib/markup-kit/collapse/collapse/collapse.component.mjs +149 -0
  6. package/esm2022/lib/markup-kit/collapse/collapse-set/collapse-set.component.mjs +102 -0
  7. package/{esm2020 → esm2022}/lib/markup-kit/collapse/collapse.module.mjs +5 -5
  8. package/esm2022/lib/markup-kit/modals/fill/fill.component.mjs +117 -0
  9. package/{esm2020 → esm2022}/lib/markup-kit/modals/markup-kit.module.mjs +15 -15
  10. package/esm2022/lib/markup-kit/modals/right-filter/right-filter.component.mjs +44 -0
  11. package/esm2022/lib/markup-kit/modals/slide-right/slide-right.component.mjs +113 -0
  12. package/esm2022/lib/markup-kit/modals/slide-up/slide-up.component.mjs +113 -0
  13. package/esm2022/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +51 -0
  14. package/esm2022/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.mjs +27 -0
  15. package/esm2022/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +73 -0
  16. package/{esm2020 → esm2022}/lib/markup-kit/page-layouts/page-layouts.module.mjs +13 -13
  17. package/esm2022/lib/markup-kit/page-layouts/profile/profile.component.mjs +137 -0
  18. package/esm2022/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +42 -0
  19. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +72 -0
  20. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.mjs +71 -0
  21. package/{esm2020 → esm2022}/lib/markup-kit/utils/filtered-field/filtered-field.module.mjs +7 -7
  22. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field.service.mjs +43 -0
  23. package/esm2022/lib/markup-kit/utils/filtered-field/filtred-item.model.mjs +13 -0
  24. package/esm2022/lib/markup-kit/utils/help-block/help-block.component.mjs +72 -0
  25. package/{esm2020 → esm2022}/lib/markup-kit/utils/help-block/hepl-block.module.mjs +7 -7
  26. package/esm2022/lib/pg-components/card/card.components.mjs +439 -0
  27. package/{esm2020 → esm2022}/lib/pg-components/card/card.module.mjs +5 -5
  28. package/esm2022/lib/pg-components/progress/progress.component.mjs +80 -0
  29. package/esm2022/lib/pg-components/progress/progress.config.mjs +12 -0
  30. package/{esm2020 → esm2022}/lib/pg-components/progress/progress.module.mjs +5 -5
  31. package/esm2022/lib/pg-components/select/option.component.mjs +93 -0
  32. package/{esm2020 → esm2022}/lib/pg-components/select/option.pipe.mjs +4 -4
  33. package/esm2022/lib/pg-components/select/select.component.mjs +782 -0
  34. package/{esm2020 → esm2022}/lib/pg-components/select/select.module.mjs +5 -5
  35. package/esm2022/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.mjs +36 -0
  36. package/{esm2020 → esm2022}/lib/pg-components/spec-flow-test/spec-flow-test.module.mjs +5 -5
  37. package/esm2022/lib/pg-components/switch/switch.component.mjs +293 -0
  38. package/{esm2020 → esm2022}/lib/pg-components/switch/switch.module.mjs +5 -5
  39. package/esm2022/lib/pg-components/tabs/tab-body.component.mjs +21 -0
  40. package/esm2022/lib/pg-components/tabs/tab-label.directive.mjs +45 -0
  41. package/esm2022/lib/pg-components/tabs/tab.component.mjs +102 -0
  42. package/esm2022/lib/pg-components/tabs/tabs-ink-bar.directive.mjs +81 -0
  43. package/esm2022/lib/pg-components/tabs/tabs-nav.component.mjs +298 -0
  44. package/{esm2020 → esm2022}/lib/pg-components/tabs/tabs.module.mjs +5 -5
  45. package/esm2022/lib/pg-components/tabs/tabset.component.mjs +257 -0
  46. package/fesm2022/natec-mef-dev-ui-kit.mjs +4340 -0
  47. package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -0
  48. package/lib/markup-kit/card/card/card.component.d.ts +69 -35
  49. package/lib/markup-kit/card/card-long/card-long.component.d.ts +114 -4
  50. package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +24 -1
  51. package/lib/markup-kit/collapse/collapse/collapse.component.d.ts +52 -2
  52. package/lib/markup-kit/collapse/collapse-set/collapse-set.component.d.ts +51 -1
  53. package/lib/markup-kit/modals/fill/fill.component.d.ts +59 -35
  54. package/lib/markup-kit/modals/right-filter/right-filter.component.d.ts +14 -1
  55. package/lib/markup-kit/modals/slide-right/slide-right.component.d.ts +53 -1
  56. package/lib/markup-kit/modals/slide-up/slide-up.component.d.ts +56 -4
  57. package/lib/markup-kit/page-layouts/central-page/central-page.component.d.ts +23 -1
  58. package/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.d.ts +14 -1
  59. package/lib/markup-kit/page-layouts/manage-page/manage-page.component.d.ts +47 -4
  60. package/lib/markup-kit/page-layouts/profile/profile.component.d.ts +78 -2
  61. package/lib/markup-kit/page-layouts/table-page/table-page.component.d.ts +23 -4
  62. package/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.d.ts +28 -4
  63. package/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.d.ts +43 -1
  64. package/lib/markup-kit/utils/filtered-field/filtered-field.service.d.ts +14 -0
  65. package/lib/markup-kit/utils/help-block/help-block.component.d.ts +26 -4
  66. package/lib/pg-components/card/card.components.d.ts +182 -1
  67. package/lib/pg-components/progress/progress.component.d.ts +36 -1
  68. package/lib/pg-components/select/option.component.d.ts +31 -1
  69. package/lib/pg-components/select/select.component.d.ts +1 -1
  70. package/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.d.ts +1 -1
  71. package/lib/pg-components/switch/switch.component.d.ts +151 -2
  72. package/lib/pg-components/tabs/tab-body.component.d.ts +7 -1
  73. package/lib/pg-components/tabs/tab-label.directive.d.ts +1 -1
  74. package/lib/pg-components/tabs/tab.component.d.ts +46 -1
  75. package/lib/pg-components/tabs/tabs-ink-bar.directive.d.ts +2 -2
  76. package/lib/pg-components/tabs/tabs-nav.component.d.ts +3 -3
  77. package/lib/pg-components/tabs/tabset.component.d.ts +70 -4
  78. package/package.json +9 -15
  79. package/esm2020/lib/markup-kit/card/card/card.component.mjs +0 -40
  80. package/esm2020/lib/markup-kit/card/card-long/card-long.component.mjs +0 -50
  81. package/esm2020/lib/markup-kit/card/card-simple/card-simple.component.mjs +0 -27
  82. package/esm2020/lib/markup-kit/collapse/collapse/collapse.component.mjs +0 -95
  83. package/esm2020/lib/markup-kit/collapse/collapse-set/collapse-set.component.mjs +0 -54
  84. package/esm2020/lib/markup-kit/modals/fill/fill.component.mjs +0 -91
  85. package/esm2020/lib/markup-kit/modals/right-filter/right-filter.component.mjs +0 -28
  86. package/esm2020/lib/markup-kit/modals/slide-right/slide-right.component.mjs +0 -59
  87. package/esm2020/lib/markup-kit/modals/slide-up/slide-up.component.mjs +0 -59
  88. package/esm2020/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +0 -29
  89. package/esm2020/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.mjs +0 -14
  90. package/esm2020/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +0 -29
  91. package/esm2020/lib/markup-kit/page-layouts/profile/profile.component.mjs +0 -53
  92. package/esm2020/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +0 -22
  93. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +0 -47
  94. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.mjs +0 -29
  95. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field.service.mjs +0 -30
  96. package/esm2020/lib/markup-kit/utils/filtered-field/filtred-item.model.mjs +0 -9
  97. package/esm2020/lib/markup-kit/utils/help-block/help-block.component.mjs +0 -51
  98. package/esm2020/lib/pg-components/card/card.components.mjs +0 -252
  99. package/esm2020/lib/pg-components/progress/progress.component.mjs +0 -39
  100. package/esm2020/lib/pg-components/progress/progress.config.mjs +0 -14
  101. package/esm2020/lib/pg-components/select/option.component.mjs +0 -59
  102. package/esm2020/lib/pg-components/select/select.component.mjs +0 -766
  103. package/esm2020/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.mjs +0 -24
  104. package/esm2020/lib/pg-components/switch/switch.component.mjs +0 -114
  105. package/esm2020/lib/pg-components/tabs/tab-body.component.mjs +0 -14
  106. package/esm2020/lib/pg-components/tabs/tab-label.directive.mjs +0 -44
  107. package/esm2020/lib/pg-components/tabs/tab.component.mjs +0 -53
  108. package/esm2020/lib/pg-components/tabs/tabs-ink-bar.directive.mjs +0 -78
  109. package/esm2020/lib/pg-components/tabs/tabs-nav.component.mjs +0 -287
  110. package/esm2020/lib/pg-components/tabs/tabset.component.mjs +0 -179
  111. package/fesm2015/natec-mef-dev-ui-kit.mjs +0 -2973
  112. package/fesm2015/natec-mef-dev-ui-kit.mjs.map +0 -1
  113. package/fesm2020/natec-mef-dev-ui-kit.mjs +0 -2966
  114. package/fesm2020/natec-mef-dev-ui-kit.mjs.map +0 -1
  115. /package/{esm2020 → esm2022}/lib/markup-kit/card/card-long/cart-type-colors.enum.mjs +0 -0
  116. /package/{esm2020 → esm2022}/lib/markup-kit/card/index.mjs +0 -0
  117. /package/{esm2020 → esm2022}/lib/markup-kit/collapse/index.mjs +0 -0
  118. /package/{esm2020 → esm2022}/lib/markup-kit/modals/index.mjs +0 -0
  119. /package/{esm2020 → esm2022}/lib/markup-kit/modals/modal-size.enum.mjs +0 -0
  120. /package/{esm2020 → esm2022}/lib/markup-kit/page-layouts/index.mjs +0 -0
  121. /package/{esm2020 → esm2022}/lib/markup-kit/utils/filtered-field/index.mjs +0 -0
  122. /package/{esm2020 → esm2022}/lib/markup-kit/utils/help-block/index.mjs +0 -0
  123. /package/{esm2020 → esm2022}/lib/pg-components/card/index.mjs +0 -0
  124. /package/{esm2020 → esm2022}/lib/pg-components/progress/index.mjs +0 -0
  125. /package/{esm2020 → esm2022}/lib/pg-components/select/index.mjs +0 -0
  126. /package/{esm2020 → esm2022}/lib/pg-components/spec-flow-test/index.mjs +0 -0
  127. /package/{esm2020 → esm2022}/lib/pg-components/switch/index.mjs +0 -0
  128. /package/{esm2020 → esm2022}/lib/pg-components/tabs/index.mjs +0 -0
  129. /package/{esm2020 → esm2022}/lib/pg-components/util/convert.mjs +0 -0
  130. /package/{esm2020 → esm2022}/lib/pg-components/util/request-animation.mjs +0 -0
  131. /package/{esm2020 → esm2022}/natec-mef-dev-ui-kit.mjs +0 -0
  132. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -1,287 +0,0 @@
1
- import { Component, ContentChild, ContentChildren, Input, Optional, ViewChild, ViewEncapsulation } from '@angular/core';
2
- import { fromEvent, merge, of as observableOf } from 'rxjs';
3
- import { auditTime, startWith } from 'rxjs/operators';
4
- import { toBoolean } from '../util/convert';
5
- import { MefDevTabLabelDirective } from './tab-label.directive';
6
- import { MefDevTabsInkBarDirective } from './tabs-ink-bar.directive';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/cdk/bidi";
9
- import * as i2 from "./tabs-ink-bar.directive";
10
- const EXAGGERATED_OVERSCROLL = 64;
11
- export class MefDevTabsNavComponent {
12
- constructor(_elementRef, _ngZone, _renderer, _dir) {
13
- this._elementRef = _elementRef;
14
- this._ngZone = _ngZone;
15
- this._renderer = _renderer;
16
- this._dir = _dir;
17
- this._animated = true;
18
- this._hideBar = false;
19
- this._showPagination = true;
20
- this._showPaginationControls = false;
21
- this._disableScrollAfter = true;
22
- this._disableScrollBefore = true;
23
- this._scrollDistance = 0;
24
- this._selectedIndexChanged = false;
25
- this._realignInkBar = null;
26
- this._selectedIndex = 0;
27
- this._tabPositionMode = 'horizontal';
28
- this._tabPosition = 'top';
29
- this.Size = 'default';
30
- this._type = 'line';
31
- }
32
- set Animated(value) {
33
- this._animated = toBoolean(value);
34
- }
35
- get Animated() {
36
- return this._animated;
37
- }
38
- set Position(value) {
39
- this._tabPosition = value;
40
- }
41
- get Position() {
42
- return this._tabPosition;
43
- }
44
- set HideBar(value) {
45
- this._hideBar = toBoolean(value);
46
- }
47
- get HideBar() {
48
- return this._hideBar;
49
- }
50
- set Type(value) {
51
- this._type = value;
52
- }
53
- get Type() {
54
- return this._type;
55
- }
56
- set ShowPagination(value) {
57
- this._showPagination = toBoolean(value);
58
- }
59
- get ShowPagination() {
60
- return this._showPagination;
61
- }
62
- set PositionMode(value) {
63
- this._tabPositionMode = value;
64
- this._alignInkBarToSelectedTab();
65
- if (this.ShowPagination) {
66
- this._updatePagination();
67
- }
68
- }
69
- get PositionMode() {
70
- return this._tabPositionMode;
71
- }
72
- set selectedIndex(value) {
73
- this._selectedIndexChanged = this._selectedIndex !== value;
74
- this._selectedIndex = value;
75
- }
76
- get selectedIndex() {
77
- return this._selectedIndex;
78
- }
79
- _onContentChanges() {
80
- if (this.ShowPagination) {
81
- this._updatePagination();
82
- }
83
- this._alignInkBarToSelectedTab();
84
- }
85
- _scrollHeader(scrollDir) {
86
- // Move the scroll distance one-third the length of the tab list's viewport.
87
- this.scrollDistance += ((scrollDir === 'before' ? -1 : 1) * this.viewWidthHeightPix) / 3;
88
- }
89
- ngAfterContentChecked() {
90
- if (this._tabLabelCount !== this._labelWrappers.length) {
91
- if (this.ShowPagination) {
92
- this._updatePagination();
93
- }
94
- this._tabLabelCount = this._labelWrappers.length;
95
- }
96
- if (this._selectedIndexChanged) {
97
- this._scrollToLabel(this._selectedIndex);
98
- if (this.ShowPagination) {
99
- this._checkScrollingControls();
100
- }
101
- this._alignInkBarToSelectedTab();
102
- this._selectedIndexChanged = false;
103
- }
104
- if (this._scrollDistanceChanged) {
105
- if (this.ShowPagination) {
106
- this._updateTabScrollPosition();
107
- }
108
- this._scrollDistanceChanged = false;
109
- }
110
- }
111
- ngAfterContentInit() {
112
- this._realignInkBar = this._ngZone.runOutsideAngular(() => {
113
- const dirChange = this._dir ? this._dir.change : observableOf(null);
114
- const resize = typeof window !== 'undefined' ? fromEvent(window, 'resize').pipe(auditTime(10)) : observableOf(null);
115
- //@ts-ignore
116
- return merge(dirChange, resize)
117
- .pipe(startWith(null))
118
- .subscribe(() => {
119
- if (this.ShowPagination) {
120
- this._updatePagination();
121
- }
122
- this._alignInkBarToSelectedTab();
123
- });
124
- });
125
- }
126
- _updateTabScrollPosition() {
127
- const scrollDistance = this.scrollDistance;
128
- if (this.PositionMode === 'horizontal') {
129
- const translateX = this._getLayoutDirection() === 'ltr' ? -scrollDistance : scrollDistance;
130
- this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(${translateX}px, 0, 0)`);
131
- }
132
- else {
133
- this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(0,${-scrollDistance}px, 0)`);
134
- }
135
- }
136
- _updatePagination() {
137
- this._checkPaginationEnabled();
138
- this._checkScrollingControls();
139
- this._updateTabScrollPosition();
140
- }
141
- _checkPaginationEnabled() {
142
- this._showPaginationControls = this.tabListScrollWidthHeightPix > this.elementRefOffSetWidthHeight;
143
- if (!this._showPaginationControls) {
144
- this.scrollDistance = 0;
145
- }
146
- }
147
- _scrollToLabel(labelIndex) {
148
- const selectedLabel = this._labelWrappers ? this._labelWrappers.toArray()[labelIndex] : null;
149
- if (!selectedLabel) {
150
- return;
151
- }
152
- // The view length is the visible width of the tab labels.
153
- let labelBeforePos;
154
- let labelAfterPos;
155
- if (this.PositionMode === 'horizontal') {
156
- if (this._getLayoutDirection() === 'ltr') {
157
- labelBeforePos = selectedLabel.getOffsetLeft();
158
- labelAfterPos = labelBeforePos + selectedLabel.getOffsetWidth();
159
- }
160
- else {
161
- labelAfterPos = this._tabList.nativeElement.offsetWidth - selectedLabel.getOffsetLeft();
162
- labelBeforePos = labelAfterPos - selectedLabel.getOffsetWidth();
163
- }
164
- }
165
- else {
166
- labelBeforePos = selectedLabel.getOffsetTop();
167
- labelAfterPos = labelBeforePos + selectedLabel.getOffsetHeight();
168
- }
169
- const beforeVisiblePos = this.scrollDistance;
170
- const afterVisiblePos = this.scrollDistance + this.viewWidthHeightPix;
171
- if (labelBeforePos < beforeVisiblePos) {
172
- // Scroll header to move label to the before direction
173
- this.scrollDistance -= beforeVisiblePos - labelBeforePos + EXAGGERATED_OVERSCROLL;
174
- }
175
- else if (labelAfterPos > afterVisiblePos) {
176
- // Scroll header to move label to the after direction
177
- this.scrollDistance += labelAfterPos - afterVisiblePos + EXAGGERATED_OVERSCROLL;
178
- }
179
- }
180
- _checkScrollingControls() {
181
- // Check if the pagination arrows should be activated.
182
- this._disableScrollBefore = this.scrollDistance === 0;
183
- this._disableScrollAfter = this.scrollDistance === this._getMaxScrollDistance();
184
- }
185
- /**
186
- * Determines what is the maximum length in pixels that can be set for the scroll distance. This
187
- * is equal to the difference in width between the tab list container and tab header container.
188
- *
189
- * This is an expensive call that forces a layout reflow to compute box and scroll metrics and
190
- * should be called sparingly.
191
- */
192
- _getMaxScrollDistance() {
193
- return this.tabListScrollWidthHeightPix - this.viewWidthHeightPix || 0;
194
- }
195
- /** Sets the distance in pixels that the tab header should be transformed in the X-axis. */
196
- set scrollDistance(v) {
197
- this._scrollDistance = Math.max(0, Math.min(this._getMaxScrollDistance(), v));
198
- // Mark that the scroll distance has changed so that after the view is checked, the CSS
199
- // transformation can move the header.
200
- this._scrollDistanceChanged = true;
201
- this._checkScrollingControls();
202
- }
203
- get scrollDistance() {
204
- return this._scrollDistance;
205
- }
206
- get viewWidthHeightPix() {
207
- let PAGINATION_PIX = 0;
208
- if (this._showPaginationControls) {
209
- PAGINATION_PIX = 64;
210
- }
211
- if (this.PositionMode === 'horizontal') {
212
- return this._tabListContainer.nativeElement.offsetWidth - PAGINATION_PIX;
213
- }
214
- else {
215
- return this._tabListContainer.nativeElement.offsetHeight - PAGINATION_PIX;
216
- }
217
- }
218
- get tabListScrollWidthHeightPix() {
219
- if (this.PositionMode === 'horizontal') {
220
- return this._tabList.nativeElement.scrollWidth;
221
- }
222
- else {
223
- return this._tabList.nativeElement.scrollHeight;
224
- }
225
- }
226
- get elementRefOffSetWidthHeight() {
227
- if (this.PositionMode === 'horizontal') {
228
- return this._elementRef.nativeElement.offsetWidth;
229
- }
230
- else {
231
- return this._elementRef.nativeElement.offsetHeight;
232
- }
233
- }
234
- _getLayoutDirection() {
235
- return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';
236
- }
237
- _alignInkBarToSelectedTab() {
238
- if (this.Type !== 'fillup') {
239
- const selectedLabelWrapper = this._labelWrappers && this._labelWrappers.length
240
- ? this._labelWrappers.toArray()[this.selectedIndex].elementRef.nativeElement
241
- : null;
242
- if (this._inkBar) {
243
- this._inkBar.alignToElement(selectedLabelWrapper);
244
- }
245
- }
246
- }
247
- }
248
- MefDevTabsNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MefDevTabsNavComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i1.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Component });
249
- MefDevTabsNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: MefDevTabsNavComponent, selector: "mefdev-tabs-nav", inputs: { Size: "Size", Animated: "Animated", Position: "Position", HideBar: "HideBar", Type: "Type", ShowPagination: "ShowPagination", PositionMode: "PositionMode", selectedIndex: "selectedIndex" }, queries: [{ propertyName: "_tabBarExtraContent", first: true, predicate: ["tabBarExtraContent"], descendants: true, static: true }, { propertyName: "_labelWrappers", predicate: MefDevTabLabelDirective }], viewQueries: [{ propertyName: "_inkBar", first: true, predicate: MefDevTabsInkBarDirective, descendants: true, static: true }, { propertyName: "_tabListContainer", first: true, predicate: ["tabListContainer"], descendants: true, static: true }, { propertyName: "_tabList", first: true, predicate: ["tabList"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"nav-tabs-wrapper\" [class.scrolling]=\"_showPaginationControls\" #tabListContainer>\r\n <div class=\"nav-wrap\">\r\n <ul\r\n class=\"nav nav-tabs nav-tabs-{{ _type }} nav-tabs-{{ _tabPosition }}\"\r\n [class.tabs-nav-animated]=\"Animated\"\r\n #tabList\r\n (cdkObserveContent)=\"_onContentChanges()\"\r\n >\r\n <div\r\n class=\"active-bar\"\r\n pg-tabs-ink-bar\r\n [hidden]=\"HideBar\"\r\n [Animated]=\"Animated\"\r\n [PositionMode]=\"PositionMode\"\r\n style=\"display: block;\"\r\n ></div>\r\n <ng-content></ng-content>\r\n </ul>\r\n </div>\r\n </div>", dependencies: [{ kind: "directive", type: i2.MefDevTabsInkBarDirective, selector: "[pg-tabs-ink-bar]", inputs: ["Animated", "PositionMode"] }], encapsulation: i0.ViewEncapsulation.None });
250
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MefDevTabsNavComponent, decorators: [{
251
- type: Component,
252
- args: [{ selector: 'mefdev-tabs-nav', encapsulation: ViewEncapsulation.None, template: "<div class=\"nav-tabs-wrapper\" [class.scrolling]=\"_showPaginationControls\" #tabListContainer>\r\n <div class=\"nav-wrap\">\r\n <ul\r\n class=\"nav nav-tabs nav-tabs-{{ _type }} nav-tabs-{{ _tabPosition }}\"\r\n [class.tabs-nav-animated]=\"Animated\"\r\n #tabList\r\n (cdkObserveContent)=\"_onContentChanges()\"\r\n >\r\n <div\r\n class=\"active-bar\"\r\n pg-tabs-ink-bar\r\n [hidden]=\"HideBar\"\r\n [Animated]=\"Animated\"\r\n [PositionMode]=\"PositionMode\"\r\n style=\"display: block;\"\r\n ></div>\r\n <ng-content></ng-content>\r\n </ul>\r\n </div>\r\n </div>" }]
253
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i1.Directionality, decorators: [{
254
- type: Optional
255
- }] }]; }, propDecorators: { Size: [{
256
- type: Input
257
- }], Animated: [{
258
- type: Input
259
- }], Position: [{
260
- type: Input
261
- }], HideBar: [{
262
- type: Input
263
- }], Type: [{
264
- type: Input
265
- }], _tabBarExtraContent: [{
266
- type: ContentChild,
267
- args: ['tabBarExtraContent', { static: true }]
268
- }], _labelWrappers: [{
269
- type: ContentChildren,
270
- args: [MefDevTabLabelDirective]
271
- }], _inkBar: [{
272
- type: ViewChild,
273
- args: [MefDevTabsInkBarDirective, { static: true }]
274
- }], _tabListContainer: [{
275
- type: ViewChild,
276
- args: ['tabListContainer', { static: true }]
277
- }], _tabList: [{
278
- type: ViewChild,
279
- args: ['tabList', { static: true }]
280
- }], ShowPagination: [{
281
- type: Input
282
- }], PositionMode: [{
283
- type: Input
284
- }], selectedIndex: [{
285
- type: Input
286
- }] } });
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-nav.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit-lib/src/lib/pg-components/tabs/tabs-nav.component.ts","../../../../../../projects/ui-kit-lib/src/lib/pg-components/tabs/tabs-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["/** code from https://github.com/angular/material2 */\r\nimport { Direction, Directionality } from '@angular/cdk/bidi';\r\nimport {\r\n  AfterContentChecked,\r\n  AfterContentInit,\r\n  Component,\r\n  ContentChild,\r\n  ContentChildren,\r\n  ElementRef,\r\n  HostBinding,\r\n  Input,\r\n  NgZone,\r\n  Optional,\r\n  QueryList,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { Subscription, fromEvent, merge, of as observableOf } from 'rxjs';\r\nimport { auditTime, startWith } from 'rxjs/operators';\r\nimport { toBoolean } from '../util/convert';\r\nimport { MefDevTabLabelDirective } from './tab-label.directive';\r\nimport { MefDevTabsInkBarDirective } from './tabs-ink-bar.directive';\r\n\r\nconst EXAGGERATED_OVERSCROLL = 64;\r\nexport type ScrollDirection = 'after' | 'before';\r\n\r\n/** duplicated defined https://github.com/angular/angular-cli/issues/2034 **/\r\nexport type TabPositionMode = 'horizontal' | 'vertical';\r\n\r\n@Component({\r\n  selector: 'mefdev-tabs-nav',\r\n  encapsulation: ViewEncapsulation.None,\r\n  templateUrl: \"./tabs-nav.component.html\"\r\n})\r\nexport class MefDevTabsNavComponent implements AfterContentChecked, AfterContentInit {\r\n  private _animated = true;\r\n  private _hideBar = false;\r\n  private _showPagination = true;\r\n\r\n  _showPaginationControls = false;\r\n  _disableScrollAfter = true;\r\n  _disableScrollBefore = true;\r\n  _scrollDistance = 0;\r\n  _selectedIndexChanged = false;\r\n  _realignInkBar: Subscription | null = null;\r\n  _tabLabelCount: number;\r\n  _scrollDistanceChanged: boolean;\r\n  _selectedIndex = 0;\r\n  _tabPositionMode: TabPositionMode = 'horizontal';\r\n  _tabPosition = 'top';\r\n  @Input() Size = 'default';\r\n  _type = 'line';\r\n\r\n  @Input()\r\n  set Animated(value: boolean) {\r\n    this._animated = toBoolean(value);\r\n  }\r\n\r\n  get Animated(): boolean {\r\n    return this._animated;\r\n  }\r\n\r\n  @Input()\r\n  set Position(value: string) {\r\n    this._tabPosition = value;\r\n  }\r\n\r\n  get Position(): string {\r\n    return this._tabPosition;\r\n  }\r\n\r\n  @Input()\r\n  set HideBar(value: boolean) {\r\n    this._hideBar = toBoolean(value);\r\n  }\r\n\r\n  get HideBar(): boolean {\r\n    return this._hideBar;\r\n  }\r\n\r\n  @Input()\r\n  set Type(value: string) {\r\n    this._type = value;\r\n  }\r\n\r\n  get Type(): string {\r\n    return this._type;\r\n  }\r\n\r\n  @ContentChild('tabBarExtraContent', { static: true }) _tabBarExtraContent: TemplateRef<void>;\r\n  @ContentChildren(MefDevTabLabelDirective) _labelWrappers: QueryList<MefDevTabLabelDirective>;\r\n  @ViewChild(MefDevTabsInkBarDirective, { static: true }) _inkBar: MefDevTabsInkBarDirective;\r\n  @ViewChild('tabListContainer', { static: true }) _tabListContainer: ElementRef;\r\n  @ViewChild('tabList', { static: true }) _tabList: ElementRef;\r\n\r\n  @Input()\r\n  set ShowPagination(value: boolean) {\r\n    this._showPagination = toBoolean(value);\r\n  }\r\n\r\n  get ShowPagination(): boolean {\r\n    return this._showPagination;\r\n  }\r\n\r\n  @Input()\r\n  set PositionMode(value: TabPositionMode) {\r\n    this._tabPositionMode = value;\r\n    this._alignInkBarToSelectedTab();\r\n    if (this.ShowPagination) {\r\n      this._updatePagination();\r\n    }\r\n  }\r\n\r\n  get PositionMode(): TabPositionMode {\r\n    return this._tabPositionMode;\r\n  }\r\n\r\n  @Input()\r\n  set selectedIndex(value: number) {\r\n    this._selectedIndexChanged = this._selectedIndex !== value;\r\n\r\n    this._selectedIndex = value;\r\n  }\r\n\r\n  get selectedIndex(): number {\r\n    return this._selectedIndex;\r\n  }\r\n\r\n  constructor(\r\n    public _elementRef: ElementRef,\r\n    private _ngZone: NgZone,\r\n    private _renderer: Renderer2,\r\n    @Optional() private _dir: Directionality\r\n  ) {}\r\n\r\n  _onContentChanges(): void {\r\n    if (this.ShowPagination) {\r\n      this._updatePagination();\r\n    }\r\n    this._alignInkBarToSelectedTab();\r\n  }\r\n\r\n  _scrollHeader(scrollDir: ScrollDirection): void {\r\n    // Move the scroll distance one-third the length of the tab list's viewport.\r\n    this.scrollDistance += ((scrollDir === 'before' ? -1 : 1) * this.viewWidthHeightPix) / 3;\r\n  }\r\n\r\n  ngAfterContentChecked(): void {\r\n    if (this._tabLabelCount !== this._labelWrappers.length) {\r\n      if (this.ShowPagination) {\r\n        this._updatePagination();\r\n      }\r\n      this._tabLabelCount = this._labelWrappers.length;\r\n    }\r\n    if (this._selectedIndexChanged) {\r\n      this._scrollToLabel(this._selectedIndex);\r\n      if (this.ShowPagination) {\r\n        this._checkScrollingControls();\r\n      }\r\n      this._alignInkBarToSelectedTab();\r\n      this._selectedIndexChanged = false;\r\n    }\r\n    if (this._scrollDistanceChanged) {\r\n      if (this.ShowPagination) {\r\n        this._updateTabScrollPosition();\r\n      }\r\n      this._scrollDistanceChanged = false;\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    this._realignInkBar = this._ngZone.runOutsideAngular(() => {\r\n      const dirChange = this._dir ? this._dir.change : observableOf(null);\r\n      const resize = typeof window !== 'undefined' ? fromEvent(window, 'resize').pipe(auditTime(10)) : observableOf(null);\r\n      //@ts-ignore\r\n      return merge(dirChange, resize)\r\n        .pipe(startWith(null))\r\n        .subscribe(() => {\r\n          if (this.ShowPagination) {\r\n            this._updatePagination();\r\n          }\r\n          this._alignInkBarToSelectedTab();\r\n        });\r\n    });\r\n  }\r\n\r\n  _updateTabScrollPosition(): void {\r\n    const scrollDistance = this.scrollDistance;\r\n    if (this.PositionMode === 'horizontal') {\r\n      const translateX = this._getLayoutDirection() === 'ltr' ? -scrollDistance : scrollDistance;\r\n      this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(${translateX}px, 0, 0)`);\r\n    } else {\r\n      this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(0,${-scrollDistance}px, 0)`);\r\n    }\r\n  }\r\n\r\n  _updatePagination(): void {\r\n    this._checkPaginationEnabled();\r\n    this._checkScrollingControls();\r\n    this._updateTabScrollPosition();\r\n  }\r\n\r\n  _checkPaginationEnabled(): void {\r\n    this._showPaginationControls = this.tabListScrollWidthHeightPix > this.elementRefOffSetWidthHeight;\r\n\r\n    if (!this._showPaginationControls) {\r\n      this.scrollDistance = 0;\r\n    }\r\n  }\r\n\r\n  _scrollToLabel(labelIndex: number): void {\r\n    const selectedLabel = this._labelWrappers ? this._labelWrappers.toArray()[labelIndex] : null;\r\n\r\n    if (!selectedLabel) {\r\n      return;\r\n    }\r\n\r\n    // The view length is the visible width of the tab labels.\r\n\r\n    let labelBeforePos: number;\r\n    let labelAfterPos: number;\r\n    if (this.PositionMode === 'horizontal') {\r\n      if (this._getLayoutDirection() === 'ltr') {\r\n        labelBeforePos = selectedLabel.getOffsetLeft();\r\n        labelAfterPos = labelBeforePos + selectedLabel.getOffsetWidth();\r\n      } else {\r\n        labelAfterPos = this._tabList.nativeElement.offsetWidth - selectedLabel.getOffsetLeft();\r\n        labelBeforePos = labelAfterPos - selectedLabel.getOffsetWidth();\r\n      }\r\n    } else {\r\n      labelBeforePos = selectedLabel.getOffsetTop();\r\n      labelAfterPos = labelBeforePos + selectedLabel.getOffsetHeight();\r\n    }\r\n    const beforeVisiblePos = this.scrollDistance;\r\n    const afterVisiblePos = this.scrollDistance + this.viewWidthHeightPix;\r\n\r\n    if (labelBeforePos < beforeVisiblePos) {\r\n      // Scroll header to move label to the before direction\r\n      this.scrollDistance -= beforeVisiblePos - labelBeforePos + EXAGGERATED_OVERSCROLL;\r\n    } else if (labelAfterPos > afterVisiblePos) {\r\n      // Scroll header to move label to the after direction\r\n      this.scrollDistance += labelAfterPos - afterVisiblePos + EXAGGERATED_OVERSCROLL;\r\n    }\r\n  }\r\n\r\n  _checkScrollingControls(): void {\r\n    // Check if the pagination arrows should be activated.\r\n    this._disableScrollBefore = this.scrollDistance === 0;\r\n    this._disableScrollAfter = this.scrollDistance === this._getMaxScrollDistance();\r\n  }\r\n\r\n  /**\r\n   * Determines what is the maximum length in pixels that can be set for the scroll distance. This\r\n   * is equal to the difference in width between the tab list container and tab header container.\r\n   *\r\n   * This is an expensive call that forces a layout reflow to compute box and scroll metrics and\r\n   * should be called sparingly.\r\n   */\r\n  _getMaxScrollDistance(): number {\r\n    return this.tabListScrollWidthHeightPix - this.viewWidthHeightPix || 0;\r\n  }\r\n\r\n  /** Sets the distance in pixels that the tab header should be transformed in the X-axis. */\r\n  set scrollDistance(v: number) {\r\n    this._scrollDistance = Math.max(0, Math.min(this._getMaxScrollDistance(), v));\r\n\r\n    // Mark that the scroll distance has changed so that after the view is checked, the CSS\r\n    // transformation can move the header.\r\n    this._scrollDistanceChanged = true;\r\n\r\n    this._checkScrollingControls();\r\n  }\r\n\r\n  get scrollDistance(): number {\r\n    return this._scrollDistance;\r\n  }\r\n\r\n  get viewWidthHeightPix(): number {\r\n    let PAGINATION_PIX = 0;\r\n    if (this._showPaginationControls) {\r\n      PAGINATION_PIX = 64;\r\n    }\r\n    if (this.PositionMode === 'horizontal') {\r\n      return this._tabListContainer.nativeElement.offsetWidth - PAGINATION_PIX;\r\n    } else {\r\n      return this._tabListContainer.nativeElement.offsetHeight - PAGINATION_PIX;\r\n    }\r\n  }\r\n\r\n  get tabListScrollWidthHeightPix(): number {\r\n    if (this.PositionMode === 'horizontal') {\r\n      return this._tabList.nativeElement.scrollWidth;\r\n    } else {\r\n      return this._tabList.nativeElement.scrollHeight;\r\n    }\r\n  }\r\n\r\n  get elementRefOffSetWidthHeight(): number {\r\n    if (this.PositionMode === 'horizontal') {\r\n      return this._elementRef.nativeElement.offsetWidth;\r\n    } else {\r\n      return this._elementRef.nativeElement.offsetHeight;\r\n    }\r\n  }\r\n\r\n  _getLayoutDirection(): Direction {\r\n    return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';\r\n  }\r\n\r\n  _alignInkBarToSelectedTab(): void {\r\n    if (this.Type !== 'fillup') {\r\n      const selectedLabelWrapper =\r\n        this._labelWrappers && this._labelWrappers.length\r\n          ? this._labelWrappers.toArray()[this.selectedIndex].elementRef.nativeElement\r\n          : null;\r\n      if (this._inkBar) {\r\n        this._inkBar.alignToElement(selectedLabelWrapper);\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div class=\"nav-tabs-wrapper\" [class.scrolling]=\"_showPaginationControls\" #tabListContainer>\r\n    <div class=\"nav-wrap\">\r\n      <ul\r\n        class=\"nav nav-tabs nav-tabs-{{ _type }} nav-tabs-{{ _tabPosition }}\"\r\n        [class.tabs-nav-animated]=\"Animated\"\r\n        #tabList\r\n        (cdkObserveContent)=\"_onContentChanges()\"\r\n      >\r\n        <div\r\n          class=\"active-bar\"\r\n          pg-tabs-ink-bar\r\n          [hidden]=\"HideBar\"\r\n          [Animated]=\"Animated\"\r\n          [PositionMode]=\"PositionMode\"\r\n          style=\"display: block;\"\r\n        ></div>\r\n        <ng-content></ng-content>\r\n      </ul>\r\n    </div>\r\n  </div>"]}
@@ -1,179 +0,0 @@
1
- /** code from https://github.com/angular/material2 */
2
- import { Component, ContentChild, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
3
- import { map } from 'rxjs/operators';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common";
6
- import * as i2 from "./tabs-nav.component";
7
- import * as i3 from "./tab-label.directive";
8
- import * as i4 from "./tab-body.component";
9
- export class TabChangeEvent {
10
- }
11
- /**
12
- * Example of usage:
13
- * <example-url>https://mef.dev/ui_kit_demo/view/tabset</example-url>
14
- */
15
- export class MefDevTabSetComponent {
16
- constructor(_renderer) {
17
- this._renderer = _renderer;
18
- this._prefixCls = 'nav-tabs';
19
- this._tabPosition = 'top';
20
- this._tabPositionMode = 'horizontal';
21
- this._indexToSelect = 0;
22
- this._selectedIndex = null;
23
- this._isViewInit = false;
24
- this._tabs = [];
25
- this._tabAnimation = '';
26
- this._extra_tab_class = '';
27
- this._extra_tabcontent_class = '';
28
- this.Animated = true;
29
- this.ShowPagination = true;
30
- this.Hide = false;
31
- this.SelectChange = new EventEmitter(true);
32
- this.Size = 'default';
33
- this._type = 'line';
34
- this.tabs = [];
35
- }
36
- set SelectedIndex(value) {
37
- this._indexToSelect = value;
38
- }
39
- get SelectedIndex() {
40
- return this._selectedIndex;
41
- }
42
- get SelectedIndexChange() {
43
- //@ts-ignore
44
- return this.SelectChange.pipe(map((event) => event.index));
45
- }
46
- set TabPosition(value) {
47
- this._tabPosition = value;
48
- if (this._tabPosition === 'top' || this._tabPosition === 'bottom') {
49
- this._tabPositionMode = 'horizontal';
50
- }
51
- else {
52
- this._tabPositionMode = 'vertical';
53
- }
54
- }
55
- get TabPosition() {
56
- return this._tabPosition;
57
- }
58
- set extraTabClass(value) {
59
- this._extra_tab_class = value;
60
- }
61
- set extraTabContentClass(value) {
62
- this._extra_tabcontent_class = value;
63
- }
64
- set Type(value) {
65
- if (this._type === value) {
66
- return;
67
- }
68
- this._type = value;
69
- this._setClassMap();
70
- }
71
- set tabAnimation(value) {
72
- this._tabAnimation = value;
73
- }
74
- get Type() {
75
- return this._type;
76
- }
77
- _setPosition(value) { }
78
- _setClassMap() { }
79
- clickLabel(index) {
80
- if (this._tabs[index].Disabled) {
81
- }
82
- else {
83
- this.SelectedIndex = index;
84
- this._tabs[index].pgClick.emit();
85
- }
86
- }
87
- ngOnInit() {
88
- this._setClassMap();
89
- }
90
- ngAfterContentChecked() {
91
- // Clamp the next selected index to the bounds of 0 and the tabs length. Note the `|| 0`, which
92
- // ensures that values like NaN can't get through and which would otherwise throw the
93
- // component into an infinite loop (since Math.max(NaN, 0) === NaN).
94
- const indexToSelect = (this._indexToSelect = Math.min(this._tabs.length - 1, Math.max(this._indexToSelect || 0, 0)));
95
- // If there is a change in selected index, emit a change event. Should not trigger if
96
- // the selected index has not yet been initialized.
97
- if (this._selectedIndex !== indexToSelect && this._selectedIndex != null) {
98
- this.SelectChange.emit(this._createChangeEvent(indexToSelect));
99
- }
100
- // Setup the position for each tab and optionally setup an origin on the next selected tab.
101
- this._tabs.forEach((tab, index) => {
102
- tab.position = index - indexToSelect;
103
- // If there is already a selected tab, then set up an origin for the next selected tab
104
- // if it doesn't have one already.
105
- if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {
106
- tab.origin = indexToSelect - this._selectedIndex;
107
- }
108
- });
109
- this._selectedIndex = indexToSelect;
110
- }
111
- ngAfterViewInit() {
112
- this._isViewInit = true;
113
- }
114
- _createChangeEvent(index) {
115
- const event = new TabChangeEvent();
116
- event.index = index;
117
- if (this._tabs && this._tabs.length) {
118
- event.tab = this._tabs[index];
119
- this._tabs.forEach((item, i) => {
120
- if (i !== index) {
121
- item.pgDeselect.emit();
122
- }
123
- });
124
- event.tab.pgSelect.emit();
125
- }
126
- return event;
127
- }
128
- get inkBarAnimated() {
129
- return this.Animated === true || this.Animated.inkBar === true;
130
- }
131
- get tabPaneAnimated() {
132
- return this.Animated === true || this.Animated.tabPane === true;
133
- }
134
- }
135
- MefDevTabSetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MefDevTabSetComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
136
- MefDevTabSetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: MefDevTabSetComponent, selector: "mefdev-tabset", inputs: { TabBarExtraTemplate: "TabBarExtraTemplate", Animated: "Animated", ShowPagination: "ShowPagination", Hide: "Hide", SelectedIndex: "SelectedIndex", Size: "Size", TabPosition: "TabPosition", extraTabClass: "extraTabClass", extraTabContentClass: "extraTabContentClass", Type: "Type", tabAnimation: "tabAnimation" }, outputs: { SelectedIndexChange: "SelectedIndexChange", SelectChange: "SelectChange" }, queries: [{ propertyName: "TabBarExtraContent", first: true, predicate: ["TabBarExtraContent"], descendants: true, static: true }], viewQueries: [{ propertyName: "_tabNav", first: true, predicate: ["tabNav"], descendants: true, static: true }, { propertyName: "_tabContent", first: true, predicate: ["tabContent"], descendants: true, static: true }, { propertyName: "_hostContent", first: true, predicate: ["hostContent"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"tab-wrapper tab-{{ _tabPositionMode }} {{ _tabPosition }} {{ _type }} {{ _extra_tab_class }}\" #hostContent>\r\n <mefdev-tabs-nav\r\n #tabNav\r\n [Size]=\"Size\"\r\n [Type]=\"Type\"\r\n [ShowPagination]=\"ShowPagination\"\r\n [PositionMode]=\"_tabPositionMode\"\r\n [Position]=\"_tabPosition\"\r\n [Animated]=\"inkBarAnimated\"\r\n [HideBar]=\"Hide\"\r\n [selectedIndex]=\"SelectedIndex\"\r\n >\r\n <ng-template #tabBarExtraContent>\r\n <ng-template [ngTemplateOutlet]=\"TabBarExtraTemplate || TabBarExtraContent\"></ng-template>\r\n </ng-template>\r\n <li pg-tab-label [disabled]=\"tab.disabled\" (click)=\"clickLabel(i)\" *ngFor=\"let tab of _tabs; let i = index\">\r\n <a href=\"javascript:void(0);\" class=\"\" [class.active]=\"SelectedIndex == i && !Hide\">\r\n <ng-template [ngTemplateOutlet]=\"tab._tabHeading\"></ng-template>\r\n </a>\r\n </mefdev-tabs-nav>\r\n <div class=\"tab-content-wrapper {{ _extra_tabcontent_class }}\">\r\n <div\r\n class=\"tab-content {{ _tabAnimation }}\"\r\n #tabContent\r\n [class.animated]=\"tabPaneAnimated\"\r\n [class.not-animated]=\"!tabPaneAnimated\"\r\n [style.margin-left.%]=\"tabPaneAnimated && -(SelectedIndex ?? -1) * 100\"\r\n >\r\n <mefdev-tab-body\r\n class=\"tab-pane\"\r\n [class.active]=\"SelectedIndex == i && !Hide\"\r\n [class.inactive]=\"SelectedIndex != i || Hide\"\r\n [content]=\"tab.content\"\r\n *ngFor=\"let tab of _tabs; let i = index\"\r\n >\r\n </mefdev-tab-body>\r\n </div>\r\n </div>\r\n </div>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MefDevTabsNavComponent, selector: "mefdev-tabs-nav", inputs: ["Size", "Animated", "Position", "HideBar", "Type", "ShowPagination", "PositionMode", "selectedIndex"] }, { kind: "directive", type: i3.MefDevTabLabelDirective, selector: "[pg-tab-label]", inputs: ["disabled"] }, { kind: "component", type: i4.MefDevTabBodyComponent, selector: "mefdev-tab-body", inputs: ["content"] }], encapsulation: i0.ViewEncapsulation.None });
137
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MefDevTabSetComponent, decorators: [{
138
- type: Component,
139
- args: [{ selector: 'mefdev-tabset', encapsulation: ViewEncapsulation.None, template: "<div class=\"tab-wrapper tab-{{ _tabPositionMode }} {{ _tabPosition }} {{ _type }} {{ _extra_tab_class }}\" #hostContent>\r\n <mefdev-tabs-nav\r\n #tabNav\r\n [Size]=\"Size\"\r\n [Type]=\"Type\"\r\n [ShowPagination]=\"ShowPagination\"\r\n [PositionMode]=\"_tabPositionMode\"\r\n [Position]=\"_tabPosition\"\r\n [Animated]=\"inkBarAnimated\"\r\n [HideBar]=\"Hide\"\r\n [selectedIndex]=\"SelectedIndex\"\r\n >\r\n <ng-template #tabBarExtraContent>\r\n <ng-template [ngTemplateOutlet]=\"TabBarExtraTemplate || TabBarExtraContent\"></ng-template>\r\n </ng-template>\r\n <li pg-tab-label [disabled]=\"tab.disabled\" (click)=\"clickLabel(i)\" *ngFor=\"let tab of _tabs; let i = index\">\r\n <a href=\"javascript:void(0);\" class=\"\" [class.active]=\"SelectedIndex == i && !Hide\">\r\n <ng-template [ngTemplateOutlet]=\"tab._tabHeading\"></ng-template>\r\n </a>\r\n </mefdev-tabs-nav>\r\n <div class=\"tab-content-wrapper {{ _extra_tabcontent_class }}\">\r\n <div\r\n class=\"tab-content {{ _tabAnimation }}\"\r\n #tabContent\r\n [class.animated]=\"tabPaneAnimated\"\r\n [class.not-animated]=\"!tabPaneAnimated\"\r\n [style.margin-left.%]=\"tabPaneAnimated && -(SelectedIndex ?? -1) * 100\"\r\n >\r\n <mefdev-tab-body\r\n class=\"tab-pane\"\r\n [class.active]=\"SelectedIndex == i && !Hide\"\r\n [class.inactive]=\"SelectedIndex != i || Hide\"\r\n [content]=\"tab.content\"\r\n *ngFor=\"let tab of _tabs; let i = index\"\r\n >\r\n </mefdev-tab-body>\r\n </div>\r\n </div>\r\n </div>" }]
140
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { TabBarExtraTemplate: [{
141
- type: Input
142
- }], TabBarExtraContent: [{
143
- type: ContentChild,
144
- args: ['TabBarExtraContent', { static: true }]
145
- }], _tabNav: [{
146
- type: ViewChild,
147
- args: ['tabNav', { static: true }]
148
- }], _tabContent: [{
149
- type: ViewChild,
150
- args: ['tabContent', { static: true }]
151
- }], _hostContent: [{
152
- type: ViewChild,
153
- args: ['hostContent', { static: true }]
154
- }], Animated: [{
155
- type: Input
156
- }], ShowPagination: [{
157
- type: Input
158
- }], Hide: [{
159
- type: Input
160
- }], SelectedIndex: [{
161
- type: Input
162
- }], SelectedIndexChange: [{
163
- type: Output
164
- }], SelectChange: [{
165
- type: Output
166
- }], Size: [{
167
- type: Input
168
- }], TabPosition: [{
169
- type: Input
170
- }], extraTabClass: [{
171
- type: Input
172
- }], extraTabContentClass: [{
173
- type: Input
174
- }], Type: [{
175
- type: Input
176
- }], tabAnimation: [{
177
- type: Input
178
- }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabset.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-kit-lib/src/lib/pg-components/tabs/tabset.component.ts","../../../../../../projects/ui-kit-lib/src/lib/pg-components/tabs/tabset.component.html"],"names":[],"mappings":"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","sourcesContent":["/** code from https://github.com/angular/material2 */\r\n\r\nimport {\r\n  AfterContentChecked,\r\n  AfterViewInit,\r\n  Component,\r\n  ContentChild,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { toBoolean } from '../util/convert';\r\nimport { MefDevTabComponent } from './tab.component';\r\nimport { MefDevTabsNavComponent } from './tabs-nav.component';\r\n\r\nexport interface AnimatedInterface {\r\n  inkBar: boolean;\r\n  tabPane: boolean;\r\n}\r\n\r\nexport class TabChangeEvent {\r\n  index: number;\r\n  tab: MefDevTabComponent;\r\n}\r\n\r\nexport type TabPosition = 'top' | 'bottom' | 'left' | 'right';\r\nexport type TabPositionMode = 'horizontal' | 'vertical';\r\nexport type TabType = 'line' | 'fillup' | 'linetriangle';\r\n\r\n\r\n/**\r\n  * Example of usage:\r\n  * <example-url>https://mef.dev/ui_kit_demo/view/tabset</example-url>\r\n  */\r\n@Component({\r\n  selector: 'mefdev-tabset',\r\n  encapsulation: ViewEncapsulation.None,\r\n  templateUrl: \"./tabset.component.html\",\r\n})\r\nexport class MefDevTabSetComponent implements AfterContentChecked, OnInit, AfterViewInit {\r\n  _el:any;\r\n  _classMap:any;\r\n  _prefixCls = 'nav-tabs';\r\n  _width:any;\r\n  _tabPosition: TabPosition = 'top';\r\n  _tabPositionMode: TabPositionMode = 'horizontal';\r\n  _indexToSelect: number | null = 0;\r\n  _selectedIndex: number | null = null;\r\n  _isViewInit = false;\r\n  _tabs: MefDevTabComponent[] = [];\r\n  _tabAnimation = '';\r\n  _extra_tab_class = '';\r\n  _extra_tabcontent_class = '';\r\n\r\n  @Input() TabBarExtraTemplate: TemplateRef<void>;\r\n  @ContentChild('TabBarExtraContent', { static: true }) TabBarExtraContent: TemplateRef<void>;\r\n  @ViewChild('tabNav', { static: true }) _tabNav: MefDevTabsNavComponent;\r\n  @ViewChild('tabContent', { static: true }) _tabContent: ElementRef;\r\n  @ViewChild('hostContent', { static: true }) _hostContent: ElementRef;\r\n  @Input() Animated: AnimatedInterface | boolean = true;\r\n  @Input() ShowPagination = true;\r\n  @Input() Hide = false;\r\n\r\n  @Input()\r\n  set SelectedIndex(value: number | null) {\r\n    this._indexToSelect = value;\r\n  }\r\n\r\n  get SelectedIndex(): number | null {\r\n    return this._selectedIndex;\r\n  }\r\n\r\n  @Output()\r\n  get SelectedIndexChange(): Observable<number> {\r\n    //@ts-ignore\r\n    return this.SelectChange.pipe(map((event:any) => event.index));\r\n  }\r\n\r\n  @Output() SelectChange: EventEmitter<TabChangeEvent> = new EventEmitter<TabChangeEvent>(true);\r\n\r\n  @Input() Size = 'default';\r\n  _type: TabType = 'line';\r\n  tabs: MefDevTabComponent[] = [];\r\n\r\n  @Input()\r\n  set TabPosition(value: TabPosition) {\r\n    this._tabPosition = value;\r\n    if (this._tabPosition === 'top' || this._tabPosition === 'bottom') {\r\n      this._tabPositionMode = 'horizontal';\r\n    } else {\r\n      this._tabPositionMode = 'vertical';\r\n    }\r\n  }\r\n\r\n  get TabPosition(): TabPosition {\r\n    return this._tabPosition;\r\n  }\r\n\r\n  @Input()\r\n  set extraTabClass(value: string) {\r\n    this._extra_tab_class = value;\r\n  }\r\n  @Input()\r\n  set extraTabContentClass(value: string) {\r\n    this._extra_tabcontent_class = value;\r\n  }\r\n\r\n  @Input()\r\n  set Type(value: TabType) {\r\n    if (this._type === value) {\r\n      return;\r\n    }\r\n    this._type = value;\r\n    this._setClassMap();\r\n  }\r\n\r\n  @Input()\r\n  set tabAnimation(value: string) {\r\n    this._tabAnimation = value;\r\n  }\r\n\r\n  get Type(): TabType {\r\n    return this._type;\r\n  }\r\n\r\n  _setPosition(value: TabPosition): void {}\r\n\r\n  _setClassMap(): void {}\r\n\r\n  clickLabel(index: number): void {\r\n    if (this._tabs[index].Disabled) {\r\n    } else {\r\n      this.SelectedIndex = index;\r\n      this._tabs[index].pgClick.emit();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this._setClassMap();\r\n  }\r\n\r\n  ngAfterContentChecked(): void {\r\n    // Clamp the next selected index to the bounds of 0 and the tabs length. Note the `|| 0`, which\r\n    // ensures that values like NaN can't get through and which would otherwise throw the\r\n    // component into an infinite loop (since Math.max(NaN, 0) === NaN).\r\n    const indexToSelect = (this._indexToSelect = Math.min(this._tabs.length - 1, Math.max(this._indexToSelect || 0, 0)));\r\n\r\n    // If there is a change in selected index, emit a change event. Should not trigger if\r\n    // the selected index has not yet been initialized.\r\n    if (this._selectedIndex !== indexToSelect && this._selectedIndex != null) {\r\n      this.SelectChange.emit(this._createChangeEvent(indexToSelect));\r\n    }\r\n\r\n    // Setup the position for each tab and optionally setup an origin on the next selected tab.\r\n    this._tabs.forEach((tab: MefDevTabComponent, index: number) => {\r\n      tab.position = index - indexToSelect;\r\n      // If there is already a selected tab, then set up an origin for the next selected tab\r\n      // if it doesn't have one already.\r\n      if (this._selectedIndex != null && tab.position === 0 && !tab.origin) {\r\n        tab.origin = indexToSelect - this._selectedIndex;\r\n      }\r\n    });\r\n    this._selectedIndex = indexToSelect;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this._isViewInit = true;\r\n  }\r\n\r\n  private _createChangeEvent(index: number): TabChangeEvent {\r\n    const event = new TabChangeEvent();\r\n    event.index = index;\r\n    if (this._tabs && this._tabs.length) {\r\n      event.tab = this._tabs[index];\r\n      this._tabs.forEach((item, i) => {\r\n        if (i !== index) {\r\n          item.pgDeselect.emit();\r\n        }\r\n      });\r\n      event.tab.pgSelect.emit();\r\n    }\r\n    return event;\r\n  }\r\n\r\n  get inkBarAnimated(): boolean {\r\n    return this.Animated === true || (this.Animated as AnimatedInterface).inkBar === true;\r\n  }\r\n\r\n  get tabPaneAnimated(): boolean {\r\n    return this.Animated === true || (this.Animated as AnimatedInterface).tabPane === true;\r\n  }\r\n\r\n  constructor(private _renderer: Renderer2) {}\r\n}\r\n","<div class=\"tab-wrapper tab-{{ _tabPositionMode }} {{ _tabPosition }} {{ _type }} {{ _extra_tab_class }}\" #hostContent>\r\n    <mefdev-tabs-nav\r\n      #tabNav\r\n      [Size]=\"Size\"\r\n      [Type]=\"Type\"\r\n      [ShowPagination]=\"ShowPagination\"\r\n      [PositionMode]=\"_tabPositionMode\"\r\n      [Position]=\"_tabPosition\"\r\n      [Animated]=\"inkBarAnimated\"\r\n      [HideBar]=\"Hide\"\r\n      [selectedIndex]=\"SelectedIndex\"\r\n    >\r\n      <ng-template #tabBarExtraContent>\r\n        <ng-template [ngTemplateOutlet]=\"TabBarExtraTemplate || TabBarExtraContent\"></ng-template>\r\n      </ng-template>\r\n      <li pg-tab-label [disabled]=\"tab.disabled\" (click)=\"clickLabel(i)\" *ngFor=\"let tab of _tabs; let i = index\">\r\n        <a href=\"javascript:void(0);\" class=\"\" [class.active]=\"SelectedIndex == i && !Hide\">\r\n          <ng-template [ngTemplateOutlet]=\"tab._tabHeading\"></ng-template>\r\n        </a>\r\n      </mefdev-tabs-nav>\r\n    <div class=\"tab-content-wrapper {{ _extra_tabcontent_class }}\">\r\n      <div\r\n        class=\"tab-content {{ _tabAnimation }}\"\r\n        #tabContent\r\n        [class.animated]=\"tabPaneAnimated\"\r\n        [class.not-animated]=\"!tabPaneAnimated\"\r\n        [style.margin-left.%]=\"tabPaneAnimated && -(SelectedIndex ?? -1) * 100\"\r\n      >\r\n        <mefdev-tab-body\r\n          class=\"tab-pane\"\r\n          [class.active]=\"SelectedIndex == i && !Hide\"\r\n          [class.inactive]=\"SelectedIndex != i || Hide\"\r\n          [content]=\"tab.content\"\r\n          *ngFor=\"let tab of _tabs; let i = index\"\r\n        >\r\n        </mefdev-tab-body>\r\n      </div>\r\n    </div>\r\n  </div>"]}