@natec/mef-dev-ui-kit 0.0.1

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 (144) hide show
  1. package/README.md +24 -0
  2. package/esm2020/lib/markup-kit/card/card/card.component.mjs +37 -0
  3. package/esm2020/lib/markup-kit/card/card-long/card-long.component.mjs +46 -0
  4. package/esm2020/lib/markup-kit/card/card-long/cart-type-colors.enum.mjs +7 -0
  5. package/esm2020/lib/markup-kit/card/card-simple/card-simple.component.mjs +23 -0
  6. package/esm2020/lib/markup-kit/card/card.module.mjs +45 -0
  7. package/esm2020/lib/markup-kit/card/index.mjs +5 -0
  8. package/esm2020/lib/markup-kit/collapse/collapse/collapse.component.mjs +87 -0
  9. package/esm2020/lib/markup-kit/collapse/collapse-set/collapse-set.component.mjs +54 -0
  10. package/esm2020/lib/markup-kit/collapse/collapse.module.mjs +25 -0
  11. package/esm2020/lib/markup-kit/collapse/index.mjs +4 -0
  12. package/esm2020/lib/markup-kit/modals/fill/fill.component.mjs +52 -0
  13. package/esm2020/lib/markup-kit/modals/index.mjs +7 -0
  14. package/esm2020/lib/markup-kit/modals/markup-kit.module.mjs +49 -0
  15. package/esm2020/lib/markup-kit/modals/modal-size.enum.mjs +2 -0
  16. package/esm2020/lib/markup-kit/modals/right-filter/right-filter.component.mjs +28 -0
  17. package/esm2020/lib/markup-kit/modals/slide-right/slide-right.component.mjs +55 -0
  18. package/esm2020/lib/markup-kit/modals/slide-up/slide-up.component.mjs +55 -0
  19. package/esm2020/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +25 -0
  20. package/esm2020/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.mjs +14 -0
  21. package/esm2020/lib/markup-kit/page-layouts/index.mjs +7 -0
  22. package/esm2020/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +25 -0
  23. package/esm2020/lib/markup-kit/page-layouts/page-layouts.module.mjs +49 -0
  24. package/esm2020/lib/markup-kit/page-layouts/profile/profile.component.mjs +49 -0
  25. package/esm2020/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +18 -0
  26. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +40 -0
  27. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.mjs +29 -0
  28. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field.module.mjs +31 -0
  29. package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field.service.mjs +30 -0
  30. package/esm2020/lib/markup-kit/utils/filtered-field/filtred-item.model.mjs +9 -0
  31. package/esm2020/lib/markup-kit/utils/filtered-field/index.mjs +5 -0
  32. package/esm2020/lib/markup-kit/utils/help-block/help-block.component.mjs +44 -0
  33. package/esm2020/lib/markup-kit/utils/help-block/hepl-block.module.mjs +30 -0
  34. package/esm2020/lib/markup-kit/utils/help-block/index.mjs +3 -0
  35. package/esm2020/lib/markup-kit/utils/loader/index.mjs +5 -0
  36. package/esm2020/lib/markup-kit/utils/loader/loader/loader.component.mjs +27 -0
  37. package/esm2020/lib/markup-kit/utils/loader/loader.module.mjs +58 -0
  38. package/esm2020/lib/markup-kit/utils/loader/loader.service.mjs +50 -0
  39. package/esm2020/lib/markup-kit/utils/loader/request-event.enum.mjs +7 -0
  40. package/esm2020/lib/pg-components/card/card.components.mjs +253 -0
  41. package/esm2020/lib/pg-components/card/card.module.mjs +25 -0
  42. package/esm2020/lib/pg-components/card/index.mjs +3 -0
  43. package/esm2020/lib/pg-components/progress/index.mjs +4 -0
  44. package/esm2020/lib/pg-components/progress/progress.component.mjs +39 -0
  45. package/esm2020/lib/pg-components/progress/progress.config.mjs +14 -0
  46. package/esm2020/lib/pg-components/progress/progress.module.mjs +22 -0
  47. package/esm2020/lib/pg-components/select/index.mjs +5 -0
  48. package/esm2020/lib/pg-components/select/option.component.mjs +60 -0
  49. package/esm2020/lib/pg-components/select/option.pipe.mjs +42 -0
  50. package/esm2020/lib/pg-components/select/select.component.mjs +762 -0
  51. package/esm2020/lib/pg-components/select/select.module.mjs +22 -0
  52. package/esm2020/lib/pg-components/spec-flow-test/index.mjs +3 -0
  53. package/esm2020/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.mjs +24 -0
  54. package/esm2020/lib/pg-components/spec-flow-test/spec-flow-test.module.mjs +27 -0
  55. package/esm2020/lib/pg-components/switch/index.mjs +3 -0
  56. package/esm2020/lib/pg-components/switch/switch.component.mjs +130 -0
  57. package/esm2020/lib/pg-components/switch/switch.module.mjs +18 -0
  58. package/esm2020/lib/pg-components/tabs/index.mjs +8 -0
  59. package/esm2020/lib/pg-components/tabs/tab-body.component.mjs +22 -0
  60. package/esm2020/lib/pg-components/tabs/tab-label.directive.mjs +44 -0
  61. package/esm2020/lib/pg-components/tabs/tab.component.mjs +66 -0
  62. package/esm2020/lib/pg-components/tabs/tabs-ink-bar.directive.mjs +78 -0
  63. package/esm2020/lib/pg-components/tabs/tabs-nav.component.mjs +335 -0
  64. package/esm2020/lib/pg-components/tabs/tabs.module.mjs +24 -0
  65. package/esm2020/lib/pg-components/tabs/tabset.component.mjs +260 -0
  66. package/esm2020/lib/pg-components/util/convert.mjs +4 -0
  67. package/esm2020/lib/pg-components/util/request-animation.mjs +26 -0
  68. package/esm2020/mef-dev-ui-kit.mjs +5 -0
  69. package/esm2020/public-api.mjs +16 -0
  70. package/fesm2015/mef-dev-ui-kit.mjs +3190 -0
  71. package/fesm2015/mef-dev-ui-kit.mjs.map +1 -0
  72. package/fesm2020/mef-dev-ui-kit.mjs +3183 -0
  73. package/fesm2020/mef-dev-ui-kit.mjs.map +1 -0
  74. package/lib/markup-kit/card/card/card.component.d.ts +17 -0
  75. package/lib/markup-kit/card/card-long/card-long.component.d.ts +21 -0
  76. package/lib/markup-kit/card/card-long/cart-type-colors.enum.d.ts +5 -0
  77. package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +10 -0
  78. package/lib/markup-kit/card/card.module.d.ts +18 -0
  79. package/lib/markup-kit/card/index.d.ts +4 -0
  80. package/lib/markup-kit/collapse/collapse/collapse.component.d.ts +19 -0
  81. package/lib/markup-kit/collapse/collapse-set/collapse-set.component.d.ts +18 -0
  82. package/lib/markup-kit/collapse/collapse.module.d.ts +14 -0
  83. package/lib/markup-kit/collapse/index.d.ts +3 -0
  84. package/lib/markup-kit/modals/fill/fill.component.d.ts +17 -0
  85. package/lib/markup-kit/modals/index.d.ts +6 -0
  86. package/lib/markup-kit/modals/markup-kit.module.d.ts +14 -0
  87. package/lib/markup-kit/modals/modal-size.enum.d.ts +5 -0
  88. package/lib/markup-kit/modals/right-filter/right-filter.component.d.ts +13 -0
  89. package/lib/markup-kit/modals/slide-right/slide-right.component.d.ts +19 -0
  90. package/lib/markup-kit/modals/slide-up/slide-up.component.d.ts +19 -0
  91. package/lib/markup-kit/page-layouts/central-page/central-page.component.d.ts +11 -0
  92. package/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.d.ts +8 -0
  93. package/lib/markup-kit/page-layouts/index.d.ts +6 -0
  94. package/lib/markup-kit/page-layouts/manage-page/manage-page.component.d.ts +11 -0
  95. package/lib/markup-kit/page-layouts/page-layouts.module.d.ts +14 -0
  96. package/lib/markup-kit/page-layouts/profile/profile.component.d.ts +27 -0
  97. package/lib/markup-kit/page-layouts/table-page/table-page.component.d.ts +9 -0
  98. package/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.d.ts +14 -0
  99. package/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.d.ts +14 -0
  100. package/lib/markup-kit/utils/filtered-field/filtered-field.module.d.ts +9 -0
  101. package/lib/markup-kit/utils/filtered-field/filtered-field.service.d.ts +14 -0
  102. package/lib/markup-kit/utils/filtered-field/filtred-item.model.d.ts +7 -0
  103. package/lib/markup-kit/utils/filtered-field/index.d.ts +4 -0
  104. package/lib/markup-kit/utils/help-block/help-block.component.d.ts +10 -0
  105. package/lib/markup-kit/utils/help-block/hepl-block.module.d.ts +10 -0
  106. package/lib/markup-kit/utils/help-block/index.d.ts +2 -0
  107. package/lib/markup-kit/utils/loader/index.d.ts +4 -0
  108. package/lib/markup-kit/utils/loader/loader/loader.component.d.ts +12 -0
  109. package/lib/markup-kit/utils/loader/loader.module.d.ts +9 -0
  110. package/lib/markup-kit/utils/loader/loader.service.d.ts +15 -0
  111. package/lib/markup-kit/utils/loader/request-event.enum.d.ts +5 -0
  112. package/lib/pg-components/card/card.components.d.ts +60 -0
  113. package/lib/pg-components/card/card.module.d.ts +12 -0
  114. package/lib/pg-components/card/index.d.ts +2 -0
  115. package/lib/pg-components/progress/index.d.ts +3 -0
  116. package/lib/pg-components/progress/progress.component.d.ts +15 -0
  117. package/lib/pg-components/progress/progress.config.d.ts +7 -0
  118. package/lib/pg-components/progress/progress.module.d.ts +10 -0
  119. package/lib/pg-components/select/index.d.ts +4 -0
  120. package/lib/pg-components/select/option.component.d.ts +21 -0
  121. package/lib/pg-components/select/option.pipe.d.ts +8 -0
  122. package/lib/pg-components/select/select.component.d.ts +135 -0
  123. package/lib/pg-components/select/select.module.d.ts +12 -0
  124. package/lib/pg-components/spec-flow-test/index.d.ts +2 -0
  125. package/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.d.ts +22 -0
  126. package/lib/pg-components/spec-flow-test/spec-flow-test.module.d.ts +10 -0
  127. package/lib/pg-components/switch/index.d.ts +2 -0
  128. package/lib/pg-components/switch/switch.component.d.ts +29 -0
  129. package/lib/pg-components/switch/switch.module.d.ts +8 -0
  130. package/lib/pg-components/tabs/index.d.ts +7 -0
  131. package/lib/pg-components/tabs/tab-body.component.d.ts +7 -0
  132. package/lib/pg-components/tabs/tab-label.directive.d.ts +15 -0
  133. package/lib/pg-components/tabs/tab.component.d.ts +22 -0
  134. package/lib/pg-components/tabs/tabs-ink-bar.directive.d.ts +23 -0
  135. package/lib/pg-components/tabs/tabs-nav.component.d.ts +79 -0
  136. package/lib/pg-components/tabs/tabs.module.d.ts +14 -0
  137. package/lib/pg-components/tabs/tabset.component.d.ts +67 -0
  138. package/lib/pg-components/util/convert.d.ts +1 -0
  139. package/lib/pg-components/util/request-animation.d.ts +1 -0
  140. package/mef-dev-ui-kit.d.ts +5 -0
  141. package/package.json +44 -0
  142. package/public-api.d.ts +14 -0
  143. package/src/lib/styles/designe-colors.scss +68 -0
  144. package/src/lib/styles/fonts.scss +90 -0
@@ -0,0 +1,335 @@
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 { pgTabLabelDirective } from './tab-label.directive';
6
+ import { pgTabsInkBarDirective } 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 "@angular/cdk/observers";
10
+ import * as i3 from "./tabs-ink-bar.directive";
11
+ const EXAGGERATED_OVERSCROLL = 64;
12
+ export class pgTabsNavComponent {
13
+ constructor(_elementRef, _ngZone, _renderer, _dir) {
14
+ this._elementRef = _elementRef;
15
+ this._ngZone = _ngZone;
16
+ this._renderer = _renderer;
17
+ this._dir = _dir;
18
+ this._animated = true;
19
+ this._hideBar = false;
20
+ this._showPagination = true;
21
+ this._showPaginationControls = false;
22
+ this._disableScrollAfter = true;
23
+ this._disableScrollBefore = true;
24
+ this._scrollDistance = 0;
25
+ this._selectedIndexChanged = false;
26
+ this._realignInkBar = null;
27
+ this._selectedIndex = 0;
28
+ this._tabPositionMode = 'horizontal';
29
+ this._tabPosition = 'top';
30
+ this.Size = 'default';
31
+ this._type = 'line';
32
+ }
33
+ set Animated(value) {
34
+ this._animated = toBoolean(value);
35
+ }
36
+ get Animated() {
37
+ return this._animated;
38
+ }
39
+ set Position(value) {
40
+ this._tabPosition = value;
41
+ }
42
+ get Position() {
43
+ return this._tabPosition;
44
+ }
45
+ set HideBar(value) {
46
+ this._hideBar = toBoolean(value);
47
+ }
48
+ get HideBar() {
49
+ return this._hideBar;
50
+ }
51
+ set Type(value) {
52
+ this._type = value;
53
+ }
54
+ get Type() {
55
+ return this._type;
56
+ }
57
+ set ShowPagination(value) {
58
+ this._showPagination = toBoolean(value);
59
+ }
60
+ get ShowPagination() {
61
+ return this._showPagination;
62
+ }
63
+ set PositionMode(value) {
64
+ this._tabPositionMode = value;
65
+ this._alignInkBarToSelectedTab();
66
+ if (this.ShowPagination) {
67
+ this._updatePagination();
68
+ }
69
+ }
70
+ get PositionMode() {
71
+ return this._tabPositionMode;
72
+ }
73
+ set selectedIndex(value) {
74
+ this._selectedIndexChanged = this._selectedIndex !== value;
75
+ this._selectedIndex = value;
76
+ }
77
+ get selectedIndex() {
78
+ return this._selectedIndex;
79
+ }
80
+ _onContentChanges() {
81
+ if (this.ShowPagination) {
82
+ this._updatePagination();
83
+ }
84
+ this._alignInkBarToSelectedTab();
85
+ }
86
+ _scrollHeader(scrollDir) {
87
+ // Move the scroll distance one-third the length of the tab list's viewport.
88
+ this.scrollDistance += ((scrollDir === 'before' ? -1 : 1) * this.viewWidthHeightPix) / 3;
89
+ }
90
+ ngAfterContentChecked() {
91
+ if (this._tabLabelCount !== this._labelWrappers.length) {
92
+ if (this.ShowPagination) {
93
+ this._updatePagination();
94
+ }
95
+ this._tabLabelCount = this._labelWrappers.length;
96
+ }
97
+ if (this._selectedIndexChanged) {
98
+ this._scrollToLabel(this._selectedIndex);
99
+ if (this.ShowPagination) {
100
+ this._checkScrollingControls();
101
+ }
102
+ this._alignInkBarToSelectedTab();
103
+ this._selectedIndexChanged = false;
104
+ }
105
+ if (this._scrollDistanceChanged) {
106
+ if (this.ShowPagination) {
107
+ this._updateTabScrollPosition();
108
+ }
109
+ this._scrollDistanceChanged = false;
110
+ }
111
+ }
112
+ ngAfterContentInit() {
113
+ this._realignInkBar = this._ngZone.runOutsideAngular(() => {
114
+ const dirChange = this._dir ? this._dir.change : observableOf(null);
115
+ const resize = typeof window !== 'undefined' ? fromEvent(window, 'resize').pipe(auditTime(10)) : observableOf(null);
116
+ //@ts-ignore
117
+ return merge(dirChange, resize)
118
+ .pipe(startWith(null))
119
+ .subscribe(() => {
120
+ if (this.ShowPagination) {
121
+ this._updatePagination();
122
+ }
123
+ this._alignInkBarToSelectedTab();
124
+ });
125
+ });
126
+ }
127
+ _updateTabScrollPosition() {
128
+ const scrollDistance = this.scrollDistance;
129
+ if (this.PositionMode === 'horizontal') {
130
+ const translateX = this._getLayoutDirection() === 'ltr' ? -scrollDistance : scrollDistance;
131
+ this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(${translateX}px, 0, 0)`);
132
+ }
133
+ else {
134
+ this._renderer.setStyle(this._tabList.nativeElement, 'transform', `translate3d(0,${-scrollDistance}px, 0)`);
135
+ }
136
+ }
137
+ _updatePagination() {
138
+ this._checkPaginationEnabled();
139
+ this._checkScrollingControls();
140
+ this._updateTabScrollPosition();
141
+ }
142
+ _checkPaginationEnabled() {
143
+ this._showPaginationControls = this.tabListScrollWidthHeightPix > this.elementRefOffSetWidthHeight;
144
+ if (!this._showPaginationControls) {
145
+ this.scrollDistance = 0;
146
+ }
147
+ }
148
+ _scrollToLabel(labelIndex) {
149
+ const selectedLabel = this._labelWrappers ? this._labelWrappers.toArray()[labelIndex] : null;
150
+ if (!selectedLabel) {
151
+ return;
152
+ }
153
+ // The view length is the visible width of the tab labels.
154
+ let labelBeforePos;
155
+ let labelAfterPos;
156
+ if (this.PositionMode === 'horizontal') {
157
+ if (this._getLayoutDirection() === 'ltr') {
158
+ labelBeforePos = selectedLabel.getOffsetLeft();
159
+ labelAfterPos = labelBeforePos + selectedLabel.getOffsetWidth();
160
+ }
161
+ else {
162
+ labelAfterPos = this._tabList.nativeElement.offsetWidth - selectedLabel.getOffsetLeft();
163
+ labelBeforePos = labelAfterPos - selectedLabel.getOffsetWidth();
164
+ }
165
+ }
166
+ else {
167
+ labelBeforePos = selectedLabel.getOffsetTop();
168
+ labelAfterPos = labelBeforePos + selectedLabel.getOffsetHeight();
169
+ }
170
+ const beforeVisiblePos = this.scrollDistance;
171
+ const afterVisiblePos = this.scrollDistance + this.viewWidthHeightPix;
172
+ if (labelBeforePos < beforeVisiblePos) {
173
+ // Scroll header to move label to the before direction
174
+ this.scrollDistance -= beforeVisiblePos - labelBeforePos + EXAGGERATED_OVERSCROLL;
175
+ }
176
+ else if (labelAfterPos > afterVisiblePos) {
177
+ // Scroll header to move label to the after direction
178
+ this.scrollDistance += labelAfterPos - afterVisiblePos + EXAGGERATED_OVERSCROLL;
179
+ }
180
+ }
181
+ _checkScrollingControls() {
182
+ // Check if the pagination arrows should be activated.
183
+ this._disableScrollBefore = this.scrollDistance === 0;
184
+ this._disableScrollAfter = this.scrollDistance === this._getMaxScrollDistance();
185
+ }
186
+ /**
187
+ * Determines what is the maximum length in pixels that can be set for the scroll distance. This
188
+ * is equal to the difference in width between the tab list container and tab header container.
189
+ *
190
+ * This is an expensive call that forces a layout reflow to compute box and scroll metrics and
191
+ * should be called sparingly.
192
+ */
193
+ _getMaxScrollDistance() {
194
+ return this.tabListScrollWidthHeightPix - this.viewWidthHeightPix || 0;
195
+ }
196
+ /** Sets the distance in pixels that the tab header should be transformed in the X-axis. */
197
+ set scrollDistance(v) {
198
+ this._scrollDistance = Math.max(0, Math.min(this._getMaxScrollDistance(), v));
199
+ // Mark that the scroll distance has changed so that after the view is checked, the CSS
200
+ // transformation can move the header.
201
+ this._scrollDistanceChanged = true;
202
+ this._checkScrollingControls();
203
+ }
204
+ get scrollDistance() {
205
+ return this._scrollDistance;
206
+ }
207
+ get viewWidthHeightPix() {
208
+ let PAGINATION_PIX = 0;
209
+ if (this._showPaginationControls) {
210
+ PAGINATION_PIX = 64;
211
+ }
212
+ if (this.PositionMode === 'horizontal') {
213
+ return this._tabListContainer.nativeElement.offsetWidth - PAGINATION_PIX;
214
+ }
215
+ else {
216
+ return this._tabListContainer.nativeElement.offsetHeight - PAGINATION_PIX;
217
+ }
218
+ }
219
+ get tabListScrollWidthHeightPix() {
220
+ if (this.PositionMode === 'horizontal') {
221
+ return this._tabList.nativeElement.scrollWidth;
222
+ }
223
+ else {
224
+ return this._tabList.nativeElement.scrollHeight;
225
+ }
226
+ }
227
+ get elementRefOffSetWidthHeight() {
228
+ if (this.PositionMode === 'horizontal') {
229
+ return this._elementRef.nativeElement.offsetWidth;
230
+ }
231
+ else {
232
+ return this._elementRef.nativeElement.offsetHeight;
233
+ }
234
+ }
235
+ _getLayoutDirection() {
236
+ return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';
237
+ }
238
+ _alignInkBarToSelectedTab() {
239
+ if (this.Type !== 'fillup') {
240
+ const selectedLabelWrapper = this._labelWrappers && this._labelWrappers.length
241
+ ? this._labelWrappers.toArray()[this.selectedIndex].elementRef.nativeElement
242
+ : null;
243
+ if (this._inkBar) {
244
+ this._inkBar.alignToElement(selectedLabelWrapper);
245
+ }
246
+ }
247
+ }
248
+ }
249
+ pgTabsNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsNavComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.Renderer2 }, { token: i1.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Component });
250
+ pgTabsNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: pgTabsNavComponent, selector: "pg-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: pgTabLabelDirective }], viewQueries: [{ propertyName: "_inkBar", first: true, predicate: pgTabsInkBarDirective, 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: `
251
+ <div class="nav-tabs-wrapper" [class.scrolling]="_showPaginationControls" #tabListContainer>
252
+ <div class="nav-wrap">
253
+ <ul
254
+ class="nav nav-tabs nav-tabs-{{ _type }} nav-tabs-{{ _tabPosition }}"
255
+ [class.tabs-nav-animated]="Animated"
256
+ #tabList
257
+ (cdkObserveContent)="_onContentChanges()"
258
+ >
259
+ <div
260
+ class="active-bar"
261
+ pg-tabs-ink-bar
262
+ [hidden]="HideBar"
263
+ [Animated]="Animated"
264
+ [PositionMode]="PositionMode"
265
+ style="display: block;"
266
+ ></div>
267
+ <ng-content></ng-content>
268
+ </ul>
269
+ </div>
270
+ </div>
271
+ `, isInline: true, directives: [{ type: i2.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }, { type: i3.pgTabsInkBarDirective, selector: "[pg-tabs-ink-bar]", inputs: ["Animated", "PositionMode"] }], encapsulation: i0.ViewEncapsulation.None });
272
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsNavComponent, decorators: [{
273
+ type: Component,
274
+ args: [{
275
+ selector: 'pg-tabs-nav',
276
+ encapsulation: ViewEncapsulation.None,
277
+ template: `
278
+ <div class="nav-tabs-wrapper" [class.scrolling]="_showPaginationControls" #tabListContainer>
279
+ <div class="nav-wrap">
280
+ <ul
281
+ class="nav nav-tabs nav-tabs-{{ _type }} nav-tabs-{{ _tabPosition }}"
282
+ [class.tabs-nav-animated]="Animated"
283
+ #tabList
284
+ (cdkObserveContent)="_onContentChanges()"
285
+ >
286
+ <div
287
+ class="active-bar"
288
+ pg-tabs-ink-bar
289
+ [hidden]="HideBar"
290
+ [Animated]="Animated"
291
+ [PositionMode]="PositionMode"
292
+ style="display: block;"
293
+ ></div>
294
+ <ng-content></ng-content>
295
+ </ul>
296
+ </div>
297
+ </div>
298
+ `,
299
+ host: {}
300
+ }]
301
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.Renderer2 }, { type: i1.Directionality, decorators: [{
302
+ type: Optional
303
+ }] }]; }, propDecorators: { Size: [{
304
+ type: Input
305
+ }], Animated: [{
306
+ type: Input
307
+ }], Position: [{
308
+ type: Input
309
+ }], HideBar: [{
310
+ type: Input
311
+ }], Type: [{
312
+ type: Input
313
+ }], _tabBarExtraContent: [{
314
+ type: ContentChild,
315
+ args: ['tabBarExtraContent', { static: true }]
316
+ }], _labelWrappers: [{
317
+ type: ContentChildren,
318
+ args: [pgTabLabelDirective]
319
+ }], _inkBar: [{
320
+ type: ViewChild,
321
+ args: [pgTabsInkBarDirective, { static: true }]
322
+ }], _tabListContainer: [{
323
+ type: ViewChild,
324
+ args: ['tabListContainer', { static: true }]
325
+ }], _tabList: [{
326
+ type: ViewChild,
327
+ args: ['tabList', { static: true }]
328
+ }], ShowPagination: [{
329
+ type: Input
330
+ }], PositionMode: [{
331
+ type: Input
332
+ }], selectedIndex: [{
333
+ type: Input
334
+ }] } });
335
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-nav.component.js","sourceRoot":"","sources":["../../../../../../projects/mef-dev-ui-tool-kit/src/lib/pg-components/tabs/tabs-nav.component.ts"],"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 { pgTabLabelDirective } from './tab-label.directive';\r\nimport { pgTabsInkBarDirective } 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: 'pg-tabs-nav',\r\n  encapsulation: ViewEncapsulation.None,\r\n  template: `\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>\r\n  `,\r\n  host: {}\r\n})\r\nexport class pgTabsNavComponent 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(pgTabLabelDirective) _labelWrappers: QueryList<pgTabLabelDirective>;\r\n  @ViewChild(pgTabsInkBarDirective, { static: true }) _inkBar: pgTabsInkBarDirective;\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"]}
@@ -0,0 +1,24 @@
1
+ import { ObserversModule } from '@angular/cdk/observers';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NgModule } from '@angular/core';
4
+ import { pgTabBodyComponent } from './tab-body.component';
5
+ import { pgTabLabelDirective } from './tab-label.directive';
6
+ import { pgTabComponent } from './tab.component';
7
+ import { pgTabsInkBarDirective } from './tabs-ink-bar.directive';
8
+ import { pgTabsNavComponent } from './tabs-nav.component';
9
+ import { pgTabSetComponent } from './tabset.component';
10
+ import * as i0 from "@angular/core";
11
+ export class pgTabsModule {
12
+ }
13
+ pgTabsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
14
+ pgTabsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsModule, declarations: [pgTabComponent, pgTabSetComponent, pgTabsNavComponent, pgTabLabelDirective, pgTabsInkBarDirective, pgTabBodyComponent], imports: [CommonModule, ObserversModule], exports: [pgTabComponent, pgTabSetComponent, pgTabsNavComponent, pgTabLabelDirective, pgTabsInkBarDirective, pgTabBodyComponent] });
15
+ pgTabsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsModule, imports: [[CommonModule, ObserversModule]] });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: pgTabsModule, decorators: [{
17
+ type: NgModule,
18
+ args: [{
19
+ declarations: [pgTabComponent, pgTabSetComponent, pgTabsNavComponent, pgTabLabelDirective, pgTabsInkBarDirective, pgTabBodyComponent],
20
+ exports: [pgTabComponent, pgTabSetComponent, pgTabsNavComponent, pgTabLabelDirective, pgTabsInkBarDirective, pgTabBodyComponent],
21
+ imports: [CommonModule, ObserversModule]
22
+ }]
23
+ }] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFicy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZWYtZGV2LXVpLXRvb2wta2l0L3NyYy9saWIvcGctY29tcG9uZW50cy90YWJzL3RhYnMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDakQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDakUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBT3ZELE1BQU0sT0FBTyxZQUFZOzt5R0FBWixZQUFZOzBHQUFaLFlBQVksaUJBSlIsY0FBYyxFQUFFLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLGtCQUFrQixhQUUxSCxZQUFZLEVBQUUsZUFBZSxhQUQ3QixjQUFjLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLEVBQUUsbUJBQW1CLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCOzBHQUdwSCxZQUFZLFlBRmQsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDOzJGQUU3QixZQUFZO2tCQUx4QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxtQkFBbUIsRUFBRSxxQkFBcUIsRUFBRSxrQkFBa0IsQ0FBQztvQkFDckksT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLGtCQUFrQixDQUFDO29CQUNoSSxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDO2lCQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmVyc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vYnNlcnZlcnMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBwZ1RhYkJvZHlDb21wb25lbnQgfSBmcm9tICcuL3RhYi1ib2R5LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IHBnVGFiTGFiZWxEaXJlY3RpdmUgfSBmcm9tICcuL3RhYi1sYWJlbC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBwZ1RhYkNvbXBvbmVudCB9IGZyb20gJy4vdGFiLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IHBnVGFic0lua0JhckRpcmVjdGl2ZSB9IGZyb20gJy4vdGFicy1pbmstYmFyLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IHBnVGFic05hdkNvbXBvbmVudCB9IGZyb20gJy4vdGFicy1uYXYuY29tcG9uZW50JztcclxuaW1wb3J0IHsgcGdUYWJTZXRDb21wb25lbnQgfSBmcm9tICcuL3RhYnNldC5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtwZ1RhYkNvbXBvbmVudCwgcGdUYWJTZXRDb21wb25lbnQsIHBnVGFic05hdkNvbXBvbmVudCwgcGdUYWJMYWJlbERpcmVjdGl2ZSwgcGdUYWJzSW5rQmFyRGlyZWN0aXZlLCBwZ1RhYkJvZHlDb21wb25lbnRdLFxyXG4gIGV4cG9ydHM6IFtwZ1RhYkNvbXBvbmVudCwgcGdUYWJTZXRDb21wb25lbnQsIHBnVGFic05hdkNvbXBvbmVudCwgcGdUYWJMYWJlbERpcmVjdGl2ZSwgcGdUYWJzSW5rQmFyRGlyZWN0aXZlLCBwZ1RhYkJvZHlDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE9ic2VydmVyc01vZHVsZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIHBnVGFic01vZHVsZSB7fVxyXG4iXX0=