@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.
- package/README.md +24 -0
- package/esm2020/lib/markup-kit/card/card/card.component.mjs +37 -0
- package/esm2020/lib/markup-kit/card/card-long/card-long.component.mjs +46 -0
- package/esm2020/lib/markup-kit/card/card-long/cart-type-colors.enum.mjs +7 -0
- package/esm2020/lib/markup-kit/card/card-simple/card-simple.component.mjs +23 -0
- package/esm2020/lib/markup-kit/card/card.module.mjs +45 -0
- package/esm2020/lib/markup-kit/card/index.mjs +5 -0
- package/esm2020/lib/markup-kit/collapse/collapse/collapse.component.mjs +87 -0
- package/esm2020/lib/markup-kit/collapse/collapse-set/collapse-set.component.mjs +54 -0
- package/esm2020/lib/markup-kit/collapse/collapse.module.mjs +25 -0
- package/esm2020/lib/markup-kit/collapse/index.mjs +4 -0
- package/esm2020/lib/markup-kit/modals/fill/fill.component.mjs +52 -0
- package/esm2020/lib/markup-kit/modals/index.mjs +7 -0
- package/esm2020/lib/markup-kit/modals/markup-kit.module.mjs +49 -0
- package/esm2020/lib/markup-kit/modals/modal-size.enum.mjs +2 -0
- package/esm2020/lib/markup-kit/modals/right-filter/right-filter.component.mjs +28 -0
- package/esm2020/lib/markup-kit/modals/slide-right/slide-right.component.mjs +55 -0
- package/esm2020/lib/markup-kit/modals/slide-up/slide-up.component.mjs +55 -0
- package/esm2020/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +25 -0
- package/esm2020/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.mjs +14 -0
- package/esm2020/lib/markup-kit/page-layouts/index.mjs +7 -0
- package/esm2020/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +25 -0
- package/esm2020/lib/markup-kit/page-layouts/page-layouts.module.mjs +49 -0
- package/esm2020/lib/markup-kit/page-layouts/profile/profile.component.mjs +49 -0
- package/esm2020/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +18 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +40 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.mjs +29 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field.module.mjs +31 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/filtered-field.service.mjs +30 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/filtred-item.model.mjs +9 -0
- package/esm2020/lib/markup-kit/utils/filtered-field/index.mjs +5 -0
- package/esm2020/lib/markup-kit/utils/help-block/help-block.component.mjs +44 -0
- package/esm2020/lib/markup-kit/utils/help-block/hepl-block.module.mjs +30 -0
- package/esm2020/lib/markup-kit/utils/help-block/index.mjs +3 -0
- package/esm2020/lib/markup-kit/utils/loader/index.mjs +5 -0
- package/esm2020/lib/markup-kit/utils/loader/loader/loader.component.mjs +27 -0
- package/esm2020/lib/markup-kit/utils/loader/loader.module.mjs +58 -0
- package/esm2020/lib/markup-kit/utils/loader/loader.service.mjs +50 -0
- package/esm2020/lib/markup-kit/utils/loader/request-event.enum.mjs +7 -0
- package/esm2020/lib/pg-components/card/card.components.mjs +253 -0
- package/esm2020/lib/pg-components/card/card.module.mjs +25 -0
- package/esm2020/lib/pg-components/card/index.mjs +3 -0
- package/esm2020/lib/pg-components/progress/index.mjs +4 -0
- package/esm2020/lib/pg-components/progress/progress.component.mjs +39 -0
- package/esm2020/lib/pg-components/progress/progress.config.mjs +14 -0
- package/esm2020/lib/pg-components/progress/progress.module.mjs +22 -0
- package/esm2020/lib/pg-components/select/index.mjs +5 -0
- package/esm2020/lib/pg-components/select/option.component.mjs +60 -0
- package/esm2020/lib/pg-components/select/option.pipe.mjs +42 -0
- package/esm2020/lib/pg-components/select/select.component.mjs +762 -0
- package/esm2020/lib/pg-components/select/select.module.mjs +22 -0
- package/esm2020/lib/pg-components/spec-flow-test/index.mjs +3 -0
- package/esm2020/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.mjs +24 -0
- package/esm2020/lib/pg-components/spec-flow-test/spec-flow-test.module.mjs +27 -0
- package/esm2020/lib/pg-components/switch/index.mjs +3 -0
- package/esm2020/lib/pg-components/switch/switch.component.mjs +130 -0
- package/esm2020/lib/pg-components/switch/switch.module.mjs +18 -0
- package/esm2020/lib/pg-components/tabs/index.mjs +8 -0
- package/esm2020/lib/pg-components/tabs/tab-body.component.mjs +22 -0
- package/esm2020/lib/pg-components/tabs/tab-label.directive.mjs +44 -0
- package/esm2020/lib/pg-components/tabs/tab.component.mjs +66 -0
- package/esm2020/lib/pg-components/tabs/tabs-ink-bar.directive.mjs +78 -0
- package/esm2020/lib/pg-components/tabs/tabs-nav.component.mjs +335 -0
- package/esm2020/lib/pg-components/tabs/tabs.module.mjs +24 -0
- package/esm2020/lib/pg-components/tabs/tabset.component.mjs +260 -0
- package/esm2020/lib/pg-components/util/convert.mjs +4 -0
- package/esm2020/lib/pg-components/util/request-animation.mjs +26 -0
- package/esm2020/mef-dev-ui-kit.mjs +5 -0
- package/esm2020/public-api.mjs +16 -0
- package/fesm2015/mef-dev-ui-kit.mjs +3190 -0
- package/fesm2015/mef-dev-ui-kit.mjs.map +1 -0
- package/fesm2020/mef-dev-ui-kit.mjs +3183 -0
- package/fesm2020/mef-dev-ui-kit.mjs.map +1 -0
- package/lib/markup-kit/card/card/card.component.d.ts +17 -0
- package/lib/markup-kit/card/card-long/card-long.component.d.ts +21 -0
- package/lib/markup-kit/card/card-long/cart-type-colors.enum.d.ts +5 -0
- package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +10 -0
- package/lib/markup-kit/card/card.module.d.ts +18 -0
- package/lib/markup-kit/card/index.d.ts +4 -0
- package/lib/markup-kit/collapse/collapse/collapse.component.d.ts +19 -0
- package/lib/markup-kit/collapse/collapse-set/collapse-set.component.d.ts +18 -0
- package/lib/markup-kit/collapse/collapse.module.d.ts +14 -0
- package/lib/markup-kit/collapse/index.d.ts +3 -0
- package/lib/markup-kit/modals/fill/fill.component.d.ts +17 -0
- package/lib/markup-kit/modals/index.d.ts +6 -0
- package/lib/markup-kit/modals/markup-kit.module.d.ts +14 -0
- package/lib/markup-kit/modals/modal-size.enum.d.ts +5 -0
- package/lib/markup-kit/modals/right-filter/right-filter.component.d.ts +13 -0
- package/lib/markup-kit/modals/slide-right/slide-right.component.d.ts +19 -0
- package/lib/markup-kit/modals/slide-up/slide-up.component.d.ts +19 -0
- package/lib/markup-kit/page-layouts/central-page/central-page.component.d.ts +11 -0
- package/lib/markup-kit/page-layouts/central-page-row/central-page-row.component.d.ts +8 -0
- package/lib/markup-kit/page-layouts/index.d.ts +6 -0
- package/lib/markup-kit/page-layouts/manage-page/manage-page.component.d.ts +11 -0
- package/lib/markup-kit/page-layouts/page-layouts.module.d.ts +14 -0
- package/lib/markup-kit/page-layouts/profile/profile.component.d.ts +27 -0
- package/lib/markup-kit/page-layouts/table-page/table-page.component.d.ts +9 -0
- package/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.d.ts +14 -0
- package/lib/markup-kit/utils/filtered-field/filtered-field-item/filtered-field-item.component.d.ts +14 -0
- package/lib/markup-kit/utils/filtered-field/filtered-field.module.d.ts +9 -0
- package/lib/markup-kit/utils/filtered-field/filtered-field.service.d.ts +14 -0
- package/lib/markup-kit/utils/filtered-field/filtred-item.model.d.ts +7 -0
- package/lib/markup-kit/utils/filtered-field/index.d.ts +4 -0
- package/lib/markup-kit/utils/help-block/help-block.component.d.ts +10 -0
- package/lib/markup-kit/utils/help-block/hepl-block.module.d.ts +10 -0
- package/lib/markup-kit/utils/help-block/index.d.ts +2 -0
- package/lib/markup-kit/utils/loader/index.d.ts +4 -0
- package/lib/markup-kit/utils/loader/loader/loader.component.d.ts +12 -0
- package/lib/markup-kit/utils/loader/loader.module.d.ts +9 -0
- package/lib/markup-kit/utils/loader/loader.service.d.ts +15 -0
- package/lib/markup-kit/utils/loader/request-event.enum.d.ts +5 -0
- package/lib/pg-components/card/card.components.d.ts +60 -0
- package/lib/pg-components/card/card.module.d.ts +12 -0
- package/lib/pg-components/card/index.d.ts +2 -0
- package/lib/pg-components/progress/index.d.ts +3 -0
- package/lib/pg-components/progress/progress.component.d.ts +15 -0
- package/lib/pg-components/progress/progress.config.d.ts +7 -0
- package/lib/pg-components/progress/progress.module.d.ts +10 -0
- package/lib/pg-components/select/index.d.ts +4 -0
- package/lib/pg-components/select/option.component.d.ts +21 -0
- package/lib/pg-components/select/option.pipe.d.ts +8 -0
- package/lib/pg-components/select/select.component.d.ts +135 -0
- package/lib/pg-components/select/select.module.d.ts +12 -0
- package/lib/pg-components/spec-flow-test/index.d.ts +2 -0
- package/lib/pg-components/spec-flow-test/spec-flow-test/spec-flow-test.component.d.ts +22 -0
- package/lib/pg-components/spec-flow-test/spec-flow-test.module.d.ts +10 -0
- package/lib/pg-components/switch/index.d.ts +2 -0
- package/lib/pg-components/switch/switch.component.d.ts +29 -0
- package/lib/pg-components/switch/switch.module.d.ts +8 -0
- package/lib/pg-components/tabs/index.d.ts +7 -0
- package/lib/pg-components/tabs/tab-body.component.d.ts +7 -0
- package/lib/pg-components/tabs/tab-label.directive.d.ts +15 -0
- package/lib/pg-components/tabs/tab.component.d.ts +22 -0
- package/lib/pg-components/tabs/tabs-ink-bar.directive.d.ts +23 -0
- package/lib/pg-components/tabs/tabs-nav.component.d.ts +79 -0
- package/lib/pg-components/tabs/tabs.module.d.ts +14 -0
- package/lib/pg-components/tabs/tabset.component.d.ts +67 -0
- package/lib/pg-components/util/convert.d.ts +1 -0
- package/lib/pg-components/util/request-animation.d.ts +1 -0
- package/mef-dev-ui-kit.d.ts +5 -0
- package/package.json +44 -0
- package/public-api.d.ts +14 -0
- package/src/lib/styles/designe-colors.scss +68 -0
- 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=
|