@acpaas-ui/ngx-forms 5.3.0 → 6.0.0-beta.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 (167) hide show
  1. package/README.md +0 -2
  2. package/esm2020/acpaas-ui-ngx-forms.mjs +5 -0
  3. package/esm2020/lib/auto-complete/auto-complete.module.mjs +25 -0
  4. package/esm2020/lib/auto-complete/components/auto-complete/auto-complete.component.mjs +370 -0
  5. package/esm2020/lib/auto-complete/public-api.mjs +3 -0
  6. package/esm2020/lib/datepicker/components/datepicker/datepicker.component.mjs +274 -0
  7. package/esm2020/lib/datepicker/datepicker.conf.mjs +9 -0
  8. package/esm2020/lib/datepicker/datepicker.module.mjs +55 -0
  9. package/esm2020/lib/datepicker/public-api.mjs +4 -0
  10. package/esm2020/lib/datepicker/types/datepicker.types.mjs +2 -0
  11. package/esm2020/lib/mask/directives/mask.directive.mjs +25 -0
  12. package/esm2020/lib/mask/mask.module.mjs +20 -0
  13. package/esm2020/lib/mask/public-api.mjs +3 -0
  14. package/esm2020/lib/range-slider/components/range-slider/range-slider.component.mjs +349 -0
  15. package/esm2020/lib/range-slider/public-api.mjs +3 -0
  16. package/esm2020/lib/range-slider/range-slider.module.mjs +20 -0
  17. package/esm2020/lib/range-slider/types/range-slider.types.mjs +2 -0
  18. package/esm2020/lib/search-filter/components/search-filter/search-filter.component.mjs +259 -0
  19. package/esm2020/lib/search-filter/public-api.mjs +3 -0
  20. package/esm2020/lib/search-filter/search-filter.module.mjs +22 -0
  21. package/esm2020/lib/search-filter/types/search-filter.types.mjs +2 -0
  22. package/esm2020/lib/shared/services/search.service.mjs +32 -0
  23. package/esm2020/lib/shared/types/search.types.mjs +2 -0
  24. package/esm2020/lib/timepicker/classes/timepicker.validators.mjs +49 -0
  25. package/esm2020/lib/timepicker/components/timepicker/timepicker.component.mjs +229 -0
  26. package/esm2020/lib/timepicker/public-api.mjs +5 -0
  27. package/esm2020/lib/timepicker/timepicker.module.mjs +22 -0
  28. package/esm2020/lib/timepicker/types/timepicker.types.mjs +7 -0
  29. package/esm2020/lib/upload/classes/uploader.class.mjs +112 -0
  30. package/esm2020/lib/upload/components/upload/upload.component.mjs +97 -0
  31. package/esm2020/lib/upload/components/upload-input/upload-input.component.mjs +56 -0
  32. package/esm2020/lib/upload/components/upload-queue/upload-queue.component.mjs +78 -0
  33. package/esm2020/lib/upload/components/upload-zone/upload-zone.component.mjs +252 -0
  34. package/esm2020/lib/upload/components/validation-list/validation-list.component.mjs +64 -0
  35. package/esm2020/lib/upload/public-api.mjs +10 -0
  36. package/esm2020/lib/upload/services/validation-messages.service.mjs +29 -0
  37. package/esm2020/lib/upload/types/upload.types.mjs +2 -0
  38. package/esm2020/lib/upload/upload.conf.mjs +12 -0
  39. package/esm2020/lib/upload/upload.module.mjs +45 -0
  40. package/esm2020/public-api.mjs +8 -0
  41. package/fesm2015/acpaas-ui-ngx-forms.mjs +2591 -0
  42. package/fesm2015/acpaas-ui-ngx-forms.mjs.map +1 -0
  43. package/fesm2020/acpaas-ui-ngx-forms.mjs +2402 -0
  44. package/fesm2020/acpaas-ui-ngx-forms.mjs.map +1 -0
  45. package/{acpaas-ui-ngx-forms.d.ts → index.d.ts} +1 -1
  46. package/lib/auto-complete/auto-complete.module.d.ts +10 -0
  47. package/lib/auto-complete/components/auto-complete/auto-complete.component.d.ts +5 -0
  48. package/lib/datepicker/components/datepicker/datepicker.component.d.ts +15 -8
  49. package/lib/datepicker/datepicker.module.d.ts +11 -1
  50. package/lib/datepicker/public-api.d.ts +1 -1
  51. package/lib/mask/directives/mask.directive.d.ts +3 -0
  52. package/lib/mask/mask.module.d.ts +6 -0
  53. package/lib/range-slider/components/range-slider/range-slider.component.d.ts +8 -2
  54. package/lib/range-slider/range-slider.module.d.ts +7 -0
  55. package/lib/search-filter/components/search-filter/search-filter.component.d.ts +10 -4
  56. package/lib/search-filter/search-filter.module.d.ts +9 -0
  57. package/lib/shared/services/search.service.d.ts +3 -0
  58. package/lib/timepicker/components/timepicker/timepicker.component.d.ts +9 -4
  59. package/lib/timepicker/timepicker.module.d.ts +8 -0
  60. package/lib/upload/components/upload/upload.component.d.ts +5 -0
  61. package/lib/upload/components/upload-input/upload-input.component.d.ts +3 -0
  62. package/lib/upload/components/upload-queue/upload-queue.component.d.ts +3 -0
  63. package/lib/upload/components/upload-zone/upload-zone.component.d.ts +7 -0
  64. package/lib/upload/components/validation-list/validation-list.component.d.ts +3 -0
  65. package/lib/upload/services/validation-messages.service.d.ts +3 -0
  66. package/lib/upload/upload.module.d.ts +14 -1
  67. package/package.json +37 -24
  68. package/public-api.d.ts +0 -1
  69. package/acpaas-ui-ngx-forms.metadata.json +0 -1
  70. package/bundles/acpaas-ui-ngx-forms.umd.js +0 -3854
  71. package/bundles/acpaas-ui-ngx-forms.umd.js.map +0 -1
  72. package/bundles/acpaas-ui-ngx-forms.umd.min.js +0 -2
  73. package/bundles/acpaas-ui-ngx-forms.umd.min.js.map +0 -1
  74. package/esm2015/acpaas-ui-ngx-forms.js +0 -11
  75. package/esm2015/lib/auto-complete/auto-complete.module.js +0 -36
  76. package/esm2015/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -416
  77. package/esm2015/lib/auto-complete/public-api.js +0 -8
  78. package/esm2015/lib/datepicker/components/datepicker/datepicker.component.js +0 -335
  79. package/esm2015/lib/datepicker/datepicker.conf.js +0 -18
  80. package/esm2015/lib/datepicker/datepicker.module.js +0 -59
  81. package/esm2015/lib/datepicker/public-api.js +0 -9
  82. package/esm2015/lib/datepicker/types/datepicker.types.js +0 -20
  83. package/esm2015/lib/mask/directives/mask.directive.js +0 -51
  84. package/esm2015/lib/mask/mask.module.js +0 -25
  85. package/esm2015/lib/mask/public-api.js +0 -8
  86. package/esm2015/lib/range-slider/components/range-slider/range-slider.component.js +0 -424
  87. package/esm2015/lib/range-slider/public-api.js +0 -8
  88. package/esm2015/lib/range-slider/range-slider.module.js +0 -26
  89. package/esm2015/lib/range-slider/types/range-slider.types.js +0 -16
  90. package/esm2015/lib/search-filter/components/search-filter/search-filter.component.js +0 -219
  91. package/esm2015/lib/search-filter/public-api.js +0 -8
  92. package/esm2015/lib/search-filter/search-filter.module.js +0 -30
  93. package/esm2015/lib/search-filter/types/search-filter.types.js +0 -16
  94. package/esm2015/lib/shared/services/search.service.js +0 -58
  95. package/esm2015/lib/shared/types/search.types.js +0 -20
  96. package/esm2015/lib/timepicker/classes/timepicker.validators.js +0 -84
  97. package/esm2015/lib/timepicker/components/timepicker/timepicker.component.js +0 -227
  98. package/esm2015/lib/timepicker/public-api.js +0 -10
  99. package/esm2015/lib/timepicker/timepicker.module.js +0 -29
  100. package/esm2015/lib/timepicker/types/timepicker.types.js +0 -13
  101. package/esm2015/lib/upload/classes/uploader.class.js +0 -189
  102. package/esm2015/lib/upload/components/upload/upload.component.js +0 -100
  103. package/esm2015/lib/upload/components/upload-input/upload-input.component.js +0 -67
  104. package/esm2015/lib/upload/components/upload-queue/upload-queue.component.js +0 -68
  105. package/esm2015/lib/upload/components/upload-zone/upload-zone.component.js +0 -219
  106. package/esm2015/lib/upload/components/validation-list/validation-list.component.js +0 -62
  107. package/esm2015/lib/upload/public-api.js +0 -15
  108. package/esm2015/lib/upload/services/validation-messages.service.js +0 -48
  109. package/esm2015/lib/upload/types/upload.types.js +0 -48
  110. package/esm2015/lib/upload/upload.conf.js +0 -21
  111. package/esm2015/lib/upload/upload.module.js +0 -62
  112. package/esm2015/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -158
  113. package/esm2015/lib/wysiwyg/public-api.js +0 -9
  114. package/esm2015/lib/wysiwyg/wysiwyg.conf.js +0 -24
  115. package/esm2015/lib/wysiwyg/wysiwyg.module.js +0 -29
  116. package/esm2015/public-api.js +0 -14
  117. package/esm5/acpaas-ui-ngx-forms.js +0 -11
  118. package/esm5/lib/auto-complete/auto-complete.module.js +0 -40
  119. package/esm5/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -506
  120. package/esm5/lib/auto-complete/public-api.js +0 -8
  121. package/esm5/lib/datepicker/components/datepicker/datepicker.component.js +0 -384
  122. package/esm5/lib/datepicker/datepicker.conf.js +0 -18
  123. package/esm5/lib/datepicker/datepicker.module.js +0 -69
  124. package/esm5/lib/datepicker/public-api.js +0 -9
  125. package/esm5/lib/datepicker/types/datepicker.types.js +0 -20
  126. package/esm5/lib/mask/directives/mask.directive.js +0 -58
  127. package/esm5/lib/mask/mask.module.js +0 -29
  128. package/esm5/lib/mask/public-api.js +0 -8
  129. package/esm5/lib/range-slider/components/range-slider/range-slider.component.js +0 -514
  130. package/esm5/lib/range-slider/public-api.js +0 -8
  131. package/esm5/lib/range-slider/range-slider.module.js +0 -30
  132. package/esm5/lib/range-slider/types/range-slider.types.js +0 -16
  133. package/esm5/lib/search-filter/components/search-filter/search-filter.component.js +0 -256
  134. package/esm5/lib/search-filter/public-api.js +0 -8
  135. package/esm5/lib/search-filter/search-filter.module.js +0 -34
  136. package/esm5/lib/search-filter/types/search-filter.types.js +0 -16
  137. package/esm5/lib/shared/services/search.service.js +0 -68
  138. package/esm5/lib/shared/types/search.types.js +0 -20
  139. package/esm5/lib/timepicker/classes/timepicker.validators.js +0 -102
  140. package/esm5/lib/timepicker/components/timepicker/timepicker.component.js +0 -259
  141. package/esm5/lib/timepicker/public-api.js +0 -10
  142. package/esm5/lib/timepicker/timepicker.module.js +0 -33
  143. package/esm5/lib/timepicker/types/timepicker.types.js +0 -13
  144. package/esm5/lib/upload/classes/uploader.class.js +0 -249
  145. package/esm5/lib/upload/components/upload/upload.component.js +0 -117
  146. package/esm5/lib/upload/components/upload-input/upload-input.component.js +0 -84
  147. package/esm5/lib/upload/components/upload-queue/upload-queue.component.js +0 -78
  148. package/esm5/lib/upload/components/upload-zone/upload-zone.component.js +0 -264
  149. package/esm5/lib/upload/components/validation-list/validation-list.component.js +0 -81
  150. package/esm5/lib/upload/public-api.js +0 -15
  151. package/esm5/lib/upload/services/validation-messages.service.js +0 -47
  152. package/esm5/lib/upload/types/upload.types.js +0 -48
  153. package/esm5/lib/upload/upload.conf.js +0 -21
  154. package/esm5/lib/upload/upload.module.js +0 -71
  155. package/esm5/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -199
  156. package/esm5/lib/wysiwyg/public-api.js +0 -9
  157. package/esm5/lib/wysiwyg/wysiwyg.conf.js +0 -24
  158. package/esm5/lib/wysiwyg/wysiwyg.module.js +0 -33
  159. package/esm5/public-api.js +0 -14
  160. package/fesm2015/acpaas-ui-ngx-forms.js +0 -3071
  161. package/fesm2015/acpaas-ui-ngx-forms.js.map +0 -1
  162. package/fesm5/acpaas-ui-ngx-forms.js +0 -3627
  163. package/fesm5/acpaas-ui-ngx-forms.js.map +0 -1
  164. package/lib/wysiwyg/components/wysiwyg/wysiwyg.component.d.ts +0 -43
  165. package/lib/wysiwyg/public-api.d.ts +0 -3
  166. package/lib/wysiwyg/wysiwyg.conf.d.ts +0 -18
  167. package/lib/wysiwyg/wysiwyg.module.d.ts +0 -2
@@ -0,0 +1,349 @@
1
+ import { Component, forwardRef, HostBinding, HostListener, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ function RangeSliderComponent_div_6_Template(rf, ctx) { if (rf & 1) {
6
+ i0.ɵɵelement(0, "div", 11);
7
+ } }
8
+ function RangeSliderComponent_span_9_Template(rf, ctx) { if (rf & 1) {
9
+ const _r5 = i0.ɵɵgetCurrentView();
10
+ i0.ɵɵelementStart(0, "span", 12);
11
+ i0.ɵɵlistener("blur", function RangeSliderComponent_span_9_Template_span_blur_0_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.toggleFocus(false, null, $event)); })("dragexit", function RangeSliderComponent_span_9_Template_span_dragexit_0_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onMouseUp($event)); })("focus", function RangeSliderComponent_span_9_Template_span_focus_0_listener($event) { i0.ɵɵrestoreView(_r5); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.toggleFocus(true, "end", $event)); })("mousedown", function RangeSliderComponent_span_9_Template_span_mousedown_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onMouseDown("end")); })("touchstart", function RangeSliderComponent_span_9_Template_span_touchstart_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.onMouseDown("end")); });
12
+ i0.ɵɵelementEnd();
13
+ } if (rf & 2) {
14
+ const ctx_r1 = i0.ɵɵnextContext();
15
+ i0.ɵɵstyleProp("left", ctx_r1.endPercentage + "%");
16
+ i0.ɵɵattribute("aria-label", ctx_r1.ariaLabelMax);
17
+ } }
18
+ export class RangeSliderComponent {
19
+ constructor(elRef) {
20
+ this.elRef = elRef;
21
+ this.coreBranding = true;
22
+ this.min = 0;
23
+ this.max = 100;
24
+ this.minimalDistance = 1;
25
+ this.step = 0;
26
+ this.label = '';
27
+ this.labelBefore = '';
28
+ this.labelAfter = '';
29
+ this.ariaLabelMin = 'Minimum';
30
+ this.ariaLabelMax = 'Maximum';
31
+ this.start = 0;
32
+ this.end = false;
33
+ this.steps = [];
34
+ this.active = null;
35
+ this.isDisabled = false;
36
+ this.hasFocus = false;
37
+ this.click = false;
38
+ this.propagateChange = (value) => { };
39
+ }
40
+ get disabledClass() {
41
+ return this.isDisabled;
42
+ }
43
+ ngOnInit() {
44
+ if (this.step > 0) {
45
+ for (let i = 0; i <= this.max; i += Number(this.step)) {
46
+ this.steps.push(i);
47
+ }
48
+ }
49
+ this.startPercentage = this.startToPercentage();
50
+ if (this.end) {
51
+ this.endPercentage = this.endToPercentage();
52
+ }
53
+ }
54
+ writeValue(value) {
55
+ if (value && value.start) {
56
+ this.start = value.start;
57
+ }
58
+ else if (!isNaN(value) && value !== '') {
59
+ this.start = Number(value);
60
+ }
61
+ else {
62
+ this.setStart(Number(this.min));
63
+ }
64
+ this.startPercentage = this.startToPercentage();
65
+ if (value && value.end) {
66
+ this.end = value.end;
67
+ this.endPercentage = this.endToPercentage();
68
+ }
69
+ }
70
+ registerOnTouched() { }
71
+ registerOnChange(fn) {
72
+ this.propagateChange = fn;
73
+ }
74
+ setDisabledState(isDisabled) {
75
+ this.isDisabled = isDisabled;
76
+ }
77
+ onMouseDown(handle) {
78
+ if (this.isDisabled) {
79
+ return;
80
+ }
81
+ this.hasFocus = true;
82
+ this.active = handle;
83
+ }
84
+ toggleFocus(hasFocus, element, $event) {
85
+ if (this.isDisabled) {
86
+ return;
87
+ }
88
+ $event.preventDefault();
89
+ this.hasFocus = hasFocus;
90
+ this.active = element;
91
+ }
92
+ onKeyDown($event) {
93
+ if (!this.hasFocus) {
94
+ return;
95
+ }
96
+ const key = $event.keyCode;
97
+ const keyCodes = {
98
+ end: 35,
99
+ home: 36,
100
+ left: 37,
101
+ up: 38,
102
+ right: 39,
103
+ down: 40,
104
+ };
105
+ if (Object.keys(keyCodes)
106
+ .map((e) => keyCodes[e])
107
+ .indexOf(key) === -1) {
108
+ return;
109
+ }
110
+ let increment = this.minimalDistance;
111
+ if (this.step > 0) {
112
+ increment = Number(this.step);
113
+ }
114
+ const processValue = (dir) => {
115
+ let newValue = this.active === 'start' ? this.start : Number(this.end);
116
+ if (dir === 'up') {
117
+ newValue += increment;
118
+ }
119
+ else {
120
+ newValue -= increment;
121
+ }
122
+ let newPercentage = ((newValue - this.min) / (this.max - this.min)) * 100;
123
+ if (newPercentage > 100) {
124
+ newPercentage = 100;
125
+ }
126
+ if (newPercentage < 0) {
127
+ newPercentage = 0;
128
+ }
129
+ return newPercentage;
130
+ };
131
+ switch (key) {
132
+ case keyCodes.right:
133
+ case keyCodes.up:
134
+ this.updateHandle(processValue('up'));
135
+ $event.preventDefault();
136
+ break;
137
+ case keyCodes.left:
138
+ case keyCodes.down:
139
+ this.updateHandle(processValue('down'));
140
+ $event.preventDefault();
141
+ break;
142
+ case keyCodes.end:
143
+ this.updateHandle(100);
144
+ $event.preventDefault();
145
+ break;
146
+ case keyCodes.home:
147
+ this.updateHandle(0);
148
+ $event.preventDefault();
149
+ break;
150
+ }
151
+ }
152
+ onMouseUp(event) {
153
+ if (this.active === 'start') {
154
+ this.setStart(this.round(this.start, this.step, 0));
155
+ this.startPercentage = this.startToPercentage();
156
+ }
157
+ if (this.active === 'end') {
158
+ this.setEnd(this.round(this.end, this.step, 0));
159
+ this.endPercentage = this.endToPercentage();
160
+ }
161
+ this.click = false;
162
+ }
163
+ mouseDown(event) {
164
+ this.click = true;
165
+ }
166
+ onMouseMove(event) {
167
+ if (!this.active || !this.click) {
168
+ return;
169
+ }
170
+ event.preventDefault(); // Do not select text while sliding
171
+ const x = event.x !== undefined ? event.x : event.targetTouches[0].pageX;
172
+ const rect = this.elRef.nativeElement.getBoundingClientRect();
173
+ const newPercentage = this.calcPercentage(x, rect.width, rect.left);
174
+ this.updateHandle(newPercentage);
175
+ }
176
+ updateHandle(newPercentage) {
177
+ if (this.active === 'start') {
178
+ this.startPercentage = newPercentage;
179
+ this.setStart(this.percentageToStart());
180
+ if (this.minimalDistanceNotRespected()) {
181
+ this.setStart(Number(this.end) - Number(this.minimalDistance));
182
+ this.startPercentage = this.startToPercentage();
183
+ }
184
+ }
185
+ if (this.active === 'end' && this.endPercentage) {
186
+ this.endPercentage = newPercentage;
187
+ this.setEnd(this.percentageToEnd());
188
+ if (this.minimalDistanceNotRespected()) {
189
+ this.setEnd(Number(this.start) + Number(this.minimalDistance));
190
+ this.endPercentage = this.endToPercentage();
191
+ }
192
+ }
193
+ }
194
+ // ---------- HELPERS ---------- //
195
+ setStart(value) {
196
+ this.start = value;
197
+ if (this.end) {
198
+ this.propagateChange({
199
+ start: this.start,
200
+ end: this.end,
201
+ });
202
+ }
203
+ else {
204
+ this.propagateChange(this.start);
205
+ }
206
+ }
207
+ setEnd(value) {
208
+ this.end = value;
209
+ this.propagateChange({
210
+ start: this.start,
211
+ end: this.end,
212
+ });
213
+ }
214
+ round(n, increment, offset) {
215
+ if (increment > 0) {
216
+ return Math.round((n - offset) / increment) * increment + offset;
217
+ }
218
+ return n;
219
+ }
220
+ startToPercentage() {
221
+ return Math.round(((this.start - this.min) / (this.max - this.min)) * 100);
222
+ }
223
+ percentageToStart() {
224
+ return Math.round((this.startPercentage / 100) * (this.max - this.min) + Number(this.min));
225
+ }
226
+ endToPercentage() {
227
+ return Math.round(((Number(this.end) - this.min) / (this.max - this.min)) * 100);
228
+ }
229
+ percentageToEnd() {
230
+ return Math.round((this.endPercentage / 100) * (this.max - this.min) + Number(this.min));
231
+ }
232
+ minimalDistanceNotRespected() {
233
+ return this.minimalDistance >= 0 && this.end && this.start > Number(this.end) - this.minimalDistance;
234
+ }
235
+ calcPercentage(mouseX, width, offsetLeft) {
236
+ const mousePos = mouseX - offsetLeft;
237
+ let newPercentage = Math.round((mousePos / width) * 100);
238
+ if (newPercentage > 100) {
239
+ newPercentage = 100;
240
+ }
241
+ if (newPercentage < 0) {
242
+ newPercentage = 0;
243
+ }
244
+ return newPercentage;
245
+ }
246
+ }
247
+ /** @nocollapse */ RangeSliderComponent.ɵfac = function RangeSliderComponent_Factory(t) { return new (t || RangeSliderComponent)(i0.ɵɵdirectiveInject(i0.ElementRef)); };
248
+ /** @nocollapse */ RangeSliderComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: RangeSliderComponent, selectors: [["aui-range-slider"]], hostVars: 4, hostBindings: function RangeSliderComponent_HostBindings(rf, ctx) { if (rf & 1) {
249
+ i0.ɵɵlistener("keydown", function RangeSliderComponent_keydown_HostBindingHandler($event) { return ctx.onKeyDown($event); }, false, i0.ɵɵresolveDocument)("touchend", function RangeSliderComponent_touchend_HostBindingHandler($event) { return ctx.onMouseUp($event); })("mouseup", function RangeSliderComponent_mouseup_HostBindingHandler($event) { return ctx.onMouseUp($event); })("touchstart", function RangeSliderComponent_touchstart_HostBindingHandler($event) { return ctx.mouseDown($event); })("mousedown", function RangeSliderComponent_mousedown_HostBindingHandler($event) { return ctx.mouseDown($event); })("touchmove", function RangeSliderComponent_touchmove_HostBindingHandler($event) { return ctx.onMouseMove($event); })("mousemove", function RangeSliderComponent_mousemove_HostBindingHandler($event) { return ctx.onMouseMove($event); });
250
+ } if (rf & 2) {
251
+ i0.ɵɵclassProp("m-range-slider", ctx.coreBranding)("is-disabled", ctx.disabledClass);
252
+ } }, inputs: { min: "min", max: "max", minimalDistance: "minimalDistance", step: "step", label: "label", labelBefore: "labelBefore", labelAfter: "labelAfter", ariaLabelMin: "ariaLabelMin", ariaLabelMax: "ariaLabelMax" }, features: [i0.ɵɵProvidersFeature([
253
+ {
254
+ provide: NG_VALUE_ACCESSOR,
255
+ useExisting: forwardRef((() => RangeSliderComponent)),
256
+ multi: true,
257
+ },
258
+ ])], decls: 15, vars: 16, consts: [[1, "a-range-slider"], [1, "a-range-slider__labels"], [1, "a-range-slider__label"], [1, "a-range-slider__inner"], [1, "a-range-slider__tickmarks"], ["class", "a-range-slider__tickmark", 4, "ngFor", "ngForOf"], [1, "a-range-slider__bar"], ["tabindex", "0", 1, "a-range-slider__handle", 3, "blur", "dragexit", "focus", "mousedown", "touchstart"], ["class", "a-range-slider__handle", "name", "a-range-slider__handle__end", "tabindex", "0", 3, "left", "blur", "dragexit", "focus", "mousedown", "touchstart", 4, "ngIf"], [1, "a-range-slider__descriptions"], [1, "a-range-slider__description", "small"], [1, "a-range-slider__tickmark"], ["name", "a-range-slider__handle__end", "tabindex", "0", 1, "a-range-slider__handle", 3, "blur", "dragexit", "focus", "mousedown", "touchstart"]], template: function RangeSliderComponent_Template(rf, ctx) { if (rf & 1) {
259
+ i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "div", 2);
260
+ i0.ɵɵtext(3);
261
+ i0.ɵɵelementEnd()();
262
+ i0.ɵɵelementStart(4, "div", 3)(5, "div", 4);
263
+ i0.ɵɵtemplate(6, RangeSliderComponent_div_6_Template, 1, 0, "div", 5);
264
+ i0.ɵɵelementEnd();
265
+ i0.ɵɵelement(7, "div", 6);
266
+ i0.ɵɵelementStart(8, "span", 7);
267
+ i0.ɵɵlistener("blur", function RangeSliderComponent_Template_span_blur_8_listener($event) { return ctx.toggleFocus(false, null, $event); })("dragexit", function RangeSliderComponent_Template_span_dragexit_8_listener($event) { return ctx.onMouseUp($event); })("focus", function RangeSliderComponent_Template_span_focus_8_listener($event) { return ctx.toggleFocus(true, "start", $event); })("mousedown", function RangeSliderComponent_Template_span_mousedown_8_listener() { return ctx.onMouseDown("start"); })("touchstart", function RangeSliderComponent_Template_span_touchstart_8_listener() { return ctx.onMouseDown("start"); });
268
+ i0.ɵɵelementEnd();
269
+ i0.ɵɵtemplate(9, RangeSliderComponent_span_9_Template, 1, 3, "span", 8);
270
+ i0.ɵɵelementEnd();
271
+ i0.ɵɵelementStart(10, "div", 9)(11, "div", 10);
272
+ i0.ɵɵtext(12);
273
+ i0.ɵɵelementEnd();
274
+ i0.ɵɵelementStart(13, "div", 10);
275
+ i0.ɵɵtext(14);
276
+ i0.ɵɵelementEnd()()();
277
+ } if (rf & 2) {
278
+ i0.ɵɵadvance(3);
279
+ i0.ɵɵtextInterpolate(ctx.label);
280
+ i0.ɵɵadvance(3);
281
+ i0.ɵɵproperty("ngForOf", ctx.steps);
282
+ i0.ɵɵadvance(1);
283
+ i0.ɵɵstyleProp("left", ctx.endPercentage ? ctx.startPercentage + "%" : false)("width", ctx.endPercentage ? ctx.endPercentage - ctx.startPercentage + "%" : ctx.startPercentage + "%");
284
+ i0.ɵɵadvance(1);
285
+ i0.ɵɵstyleProp("left", ctx.startPercentage + "%");
286
+ i0.ɵɵattribute("aria-label", ctx.ariaLabelMin);
287
+ i0.ɵɵadvance(1);
288
+ i0.ɵɵproperty("ngIf", ctx.end);
289
+ i0.ɵɵadvance(3);
290
+ i0.ɵɵtextInterpolate3("", ctx.labelBefore, "", ctx.min, "", ctx.labelAfter, "");
291
+ i0.ɵɵadvance(2);
292
+ i0.ɵɵtextInterpolate3("", ctx.labelBefore, "", ctx.max, "", ctx.labelAfter, "");
293
+ } }, dependencies: [i1.NgForOf, i1.NgIf], styles: ["[_nghost-%COMP%]{display:block;position:relative}.is-disabled[_nghost-%COMP%]{cursor:not-allowed}.is-disabled[_nghost-%COMP%] .m-range-slider__handle[_ngcontent-%COMP%]:hover{cursor:not-allowed}"] });
294
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeSliderComponent, [{
295
+ type: Component,
296
+ args: [{ selector: 'aui-range-slider', providers: [
297
+ {
298
+ provide: NG_VALUE_ACCESSOR,
299
+ useExisting: forwardRef((() => RangeSliderComponent)),
300
+ multi: true,
301
+ },
302
+ ], template: "<div class=\"a-range-slider\">\n <div class=\"a-range-slider__labels\">\n <div class=\"a-range-slider__label\">{{ label }}</div>\n </div>\n <div class=\"a-range-slider__inner\">\n <div class=\"a-range-slider__tickmarks\">\n <div *ngFor=\"let step of steps; let i = index\" class=\"a-range-slider__tickmark\"></div>\n </div>\n <div\n [style.left]=\"endPercentage ? startPercentage + '%' : false\"\n [style.width]=\"endPercentage ? endPercentage - startPercentage + '%' : startPercentage + '%'\"\n class=\"a-range-slider__bar\"\n ></div>\n <span\n (blur)=\"toggleFocus(false, null, $event)\"\n (dragexit)=\"onMouseUp($event)\"\n (focus)=\"toggleFocus(true, 'start', $event)\"\n (mousedown)=\"onMouseDown('start')\"\n (touchstart)=\"onMouseDown('start')\"\n [style.left]=\"startPercentage + '%'\"\n class=\"a-range-slider__handle\"\n [attr.aria-label]=\"ariaLabelMin\"\n tabindex=\"0\"\n >\n </span>\n\n <span\n (blur)=\"toggleFocus(false, null, $event)\"\n (dragexit)=\"onMouseUp($event)\"\n (focus)=\"toggleFocus(true, 'end', $event)\"\n (mousedown)=\"onMouseDown('end')\"\n (touchstart)=\"onMouseDown('end')\"\n *ngIf=\"end\"\n [style.left]=\"endPercentage + '%'\"\n class=\"a-range-slider__handle\"\n name=\"a-range-slider__handle__end\"\n [attr.aria-label]=\"ariaLabelMax\"\n tabindex=\"0\"\n >\n </span>\n </div>\n <div class=\"a-range-slider__descriptions\">\n <div class=\"a-range-slider__description small\">{{ labelBefore }}{{ min }}{{ labelAfter }}</div>\n <div class=\"a-range-slider__description small\">{{ labelBefore }}{{ max }}{{ labelAfter }}</div>\n </div>\n</div>\n", styles: [":host{display:block;position:relative}:host.is-disabled{cursor:not-allowed}:host.is-disabled .m-range-slider__handle:hover{cursor:not-allowed}\n"] }]
303
+ }], function () { return [{ type: i0.ElementRef }]; }, { coreBranding: [{
304
+ type: HostBinding,
305
+ args: ['class.m-range-slider']
306
+ }], min: [{
307
+ type: Input
308
+ }], max: [{
309
+ type: Input
310
+ }], minimalDistance: [{
311
+ type: Input
312
+ }], step: [{
313
+ type: Input
314
+ }], label: [{
315
+ type: Input
316
+ }], labelBefore: [{
317
+ type: Input
318
+ }], labelAfter: [{
319
+ type: Input
320
+ }], ariaLabelMin: [{
321
+ type: Input
322
+ }], ariaLabelMax: [{
323
+ type: Input
324
+ }], disabledClass: [{
325
+ type: HostBinding,
326
+ args: ['class.is-disabled']
327
+ }], onKeyDown: [{
328
+ type: HostListener,
329
+ args: ['document:keydown', ['$event']]
330
+ }], onMouseUp: [{
331
+ type: HostListener,
332
+ args: ['touchend', ['$event']]
333
+ }, {
334
+ type: HostListener,
335
+ args: ['mouseup', ['$event']]
336
+ }], mouseDown: [{
337
+ type: HostListener,
338
+ args: ['touchstart', ['$event']]
339
+ }, {
340
+ type: HostListener,
341
+ args: ['mousedown', ['$event']]
342
+ }], onMouseMove: [{
343
+ type: HostListener,
344
+ args: ['touchmove', ['$event']]
345
+ }, {
346
+ type: HostListener,
347
+ args: ['mousemove', ['$event']]
348
+ }] }); })();
349
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-slider.component.js","sourceRoot":"","sources":["../../../../../../src/lib/range-slider/components/range-slider/range-slider.component.ts","../../../../../../src/lib/range-slider/components/range-slider/range-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, HostBinding, HostListener, Input, OnInit } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { RangeSliderRange } from '../../types/range-slider.types';\n\n@Component({\n  selector: 'aui-range-slider',\n  templateUrl: './range-slider.component.html',\n  styleUrls: ['./range-slider.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RangeSliderComponent), // eslint-disable-line\n      multi: true,\n    },\n  ],\n})\nexport class RangeSliderComponent implements OnInit, ControlValueAccessor {\n  @HostBinding('class.m-range-slider') coreBranding = true;\n  @Input() public min = 0;\n  @Input() public max = 100;\n  @Input() public minimalDistance = 1;\n  @Input() public step = 0;\n  @Input() public label = '';\n  @Input() public labelBefore = '';\n  @Input() public labelAfter = '';\n  @Input() public ariaLabelMin = 'Minimum';\n  @Input() public ariaLabelMax = 'Maximum';\n  public start = 0;\n  public end: number | boolean = false;\n  public steps = [];\n  public startPercentage;\n  public endPercentage;\n  public active = null;\n  public isDisabled = false;\n  public hasFocus = false;\n  public click = false;\n\n  constructor(private elRef: ElementRef) {}\n\n  @HostBinding('class.is-disabled') get disabledClass() {\n    return this.isDisabled;\n  }\n\n  public propagateChange = (value: number | RangeSliderRange) => {};\n\n  public ngOnInit() {\n    if (this.step > 0) {\n      for (let i = 0; i <= this.max; i += Number(this.step)) {\n        this.steps.push(i);\n      }\n    }\n\n    this.startPercentage = this.startToPercentage();\n\n    if (this.end) {\n      this.endPercentage = this.endToPercentage();\n    }\n  }\n\n  public writeValue(value: any) {\n    if (value && value.start) {\n      this.start = value.start;\n    } else if (!isNaN(value) && value !== '') {\n      this.start = Number(value);\n    } else {\n      this.setStart(Number(this.min));\n    }\n\n    this.startPercentage = this.startToPercentage();\n\n    if (value && value.end) {\n      this.end = value.end;\n      this.endPercentage = this.endToPercentage();\n    }\n  }\n\n  public registerOnTouched() {}\n\n  public registerOnChange(fn) {\n    this.propagateChange = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  public onMouseDown(handle) {\n    if (this.isDisabled) {\n      return;\n    }\n\n    this.hasFocus = true;\n    this.active = handle;\n  }\n\n  public toggleFocus(hasFocus, element, $event) {\n    if (this.isDisabled) {\n      return;\n    }\n\n    $event.preventDefault();\n    this.hasFocus = hasFocus;\n    this.active = element;\n  }\n\n  @HostListener('document:keydown', ['$event'])\n  public onKeyDown($event) {\n    if (!this.hasFocus) {\n      return;\n    }\n\n    const key = $event.keyCode;\n    const keyCodes = {\n      end: 35,\n      home: 36,\n      left: 37,\n      up: 38,\n      right: 39,\n      down: 40,\n    };\n\n    if (\n      Object.keys(keyCodes)\n        .map((e) => keyCodes[e])\n        .indexOf(key) === -1\n    ) {\n      return;\n    }\n    let increment = this.minimalDistance;\n\n    if (this.step > 0) {\n      increment = Number(this.step);\n    }\n\n    const processValue = (dir) => {\n      let newValue = this.active === 'start' ? this.start : Number(this.end);\n      if (dir === 'up') {\n        newValue += increment;\n      } else {\n        newValue -= increment;\n      }\n      let newPercentage = ((newValue - this.min) / (this.max - this.min)) * 100;\n\n      if (newPercentage > 100) {\n        newPercentage = 100;\n      }\n      if (newPercentage < 0) {\n        newPercentage = 0;\n      }\n      return newPercentage;\n    };\n\n    switch (key) {\n      case keyCodes.right:\n      case keyCodes.up:\n        this.updateHandle(processValue('up'));\n        $event.preventDefault();\n        break;\n      case keyCodes.left:\n      case keyCodes.down:\n        this.updateHandle(processValue('down'));\n        $event.preventDefault();\n        break;\n      case keyCodes.end:\n        this.updateHandle(100);\n        $event.preventDefault();\n        break;\n      case keyCodes.home:\n        this.updateHandle(0);\n        $event.preventDefault();\n        break;\n    }\n  }\n\n  @HostListener('touchend', ['$event'])\n  @HostListener('mouseup', ['$event'])\n  public onMouseUp(event) {\n    if (this.active === 'start') {\n      this.setStart(this.round(this.start, this.step, 0));\n      this.startPercentage = this.startToPercentage();\n    }\n\n    if (this.active === 'end') {\n      this.setEnd(this.round(this.end, this.step, 0));\n      this.endPercentage = this.endToPercentage();\n    }\n    this.click = false;\n  }\n\n  @HostListener('touchstart', ['$event'])\n  @HostListener('mousedown', ['$event'])\n  mouseDown(event) {\n    this.click = true;\n  }\n\n  @HostListener('touchmove', ['$event'])\n  @HostListener('mousemove', ['$event'])\n  public onMouseMove(event: MouseEvent | TouchEvent) {\n    if (!this.active || !this.click) {\n      return;\n    }\n\n    event.preventDefault(); // Do not select text while sliding\n\n    const x =\n      (event as MouseEvent).x !== undefined ? (event as MouseEvent).x : (event as TouchEvent).targetTouches[0].pageX;\n    const rect = this.elRef.nativeElement.getBoundingClientRect();\n    const newPercentage = this.calcPercentage(x, rect.width, rect.left);\n    this.updateHandle(newPercentage);\n  }\n\n  public updateHandle(newPercentage) {\n    if (this.active === 'start') {\n      this.startPercentage = newPercentage;\n      this.setStart(this.percentageToStart());\n\n      if (this.minimalDistanceNotRespected()) {\n        this.setStart(Number(this.end) - Number(this.minimalDistance));\n        this.startPercentage = this.startToPercentage();\n      }\n    }\n\n    if (this.active === 'end' && this.endPercentage) {\n      this.endPercentage = newPercentage;\n      this.setEnd(this.percentageToEnd());\n\n      if (this.minimalDistanceNotRespected()) {\n        this.setEnd(Number(this.start) + Number(this.minimalDistance));\n        this.endPercentage = this.endToPercentage();\n      }\n    }\n  }\n\n  // ---------- HELPERS ---------- //\n  public setStart(value) {\n    this.start = value;\n\n    if (this.end) {\n      this.propagateChange({\n        start: this.start,\n        end: this.end,\n      } as RangeSliderRange);\n    } else {\n      this.propagateChange(this.start);\n    }\n  }\n\n  public setEnd(value) {\n    this.end = value;\n\n    this.propagateChange({\n      start: this.start,\n      end: this.end,\n    } as RangeSliderRange);\n  }\n\n  public round(n, increment, offset) {\n    if (increment > 0) {\n      return Math.round((n - offset) / increment) * increment + offset;\n    }\n\n    return n;\n  }\n\n  public startToPercentage() {\n    return Math.round(((this.start - this.min) / (this.max - this.min)) * 100);\n  }\n\n  public percentageToStart() {\n    return Math.round((this.startPercentage / 100) * (this.max - this.min) + Number(this.min));\n  }\n\n  public endToPercentage() {\n    return Math.round(((Number(this.end) - this.min) / (this.max - this.min)) * 100);\n  }\n\n  public percentageToEnd() {\n    return Math.round((this.endPercentage / 100) * (this.max - this.min) + Number(this.min));\n  }\n\n  public minimalDistanceNotRespected() {\n    return this.minimalDistance >= 0 && this.end && this.start > Number(this.end) - this.minimalDistance;\n  }\n\n  public calcPercentage(mouseX, width, offsetLeft) {\n    const mousePos = mouseX - offsetLeft;\n\n    let newPercentage = Math.round((mousePos / width) * 100);\n\n    if (newPercentage > 100) {\n      newPercentage = 100;\n    }\n\n    if (newPercentage < 0) {\n      newPercentage = 0;\n    }\n\n    return newPercentage;\n  }\n}\n","<div class=\"a-range-slider\">\n  <div class=\"a-range-slider__labels\">\n    <div class=\"a-range-slider__label\">{{ label }}</div>\n  </div>\n  <div class=\"a-range-slider__inner\">\n    <div class=\"a-range-slider__tickmarks\">\n      <div *ngFor=\"let step of steps; let i = index\" class=\"a-range-slider__tickmark\"></div>\n    </div>\n    <div\n      [style.left]=\"endPercentage ? startPercentage + '%' : false\"\n      [style.width]=\"endPercentage ? endPercentage - startPercentage + '%' : startPercentage + '%'\"\n      class=\"a-range-slider__bar\"\n    ></div>\n    <span\n      (blur)=\"toggleFocus(false, null, $event)\"\n      (dragexit)=\"onMouseUp($event)\"\n      (focus)=\"toggleFocus(true, 'start', $event)\"\n      (mousedown)=\"onMouseDown('start')\"\n      (touchstart)=\"onMouseDown('start')\"\n      [style.left]=\"startPercentage + '%'\"\n      class=\"a-range-slider__handle\"\n      [attr.aria-label]=\"ariaLabelMin\"\n      tabindex=\"0\"\n    >\n    </span>\n\n    <span\n      (blur)=\"toggleFocus(false, null, $event)\"\n      (dragexit)=\"onMouseUp($event)\"\n      (focus)=\"toggleFocus(true, 'end', $event)\"\n      (mousedown)=\"onMouseDown('end')\"\n      (touchstart)=\"onMouseDown('end')\"\n      *ngIf=\"end\"\n      [style.left]=\"endPercentage + '%'\"\n      class=\"a-range-slider__handle\"\n      name=\"a-range-slider__handle__end\"\n      [attr.aria-label]=\"ariaLabelMax\"\n      tabindex=\"0\"\n    >\n    </span>\n  </div>\n  <div class=\"a-range-slider__descriptions\">\n    <div class=\"a-range-slider__description small\">{{ labelBefore }}{{ min }}{{ labelAfter }}</div>\n    <div class=\"a-range-slider__description small\">{{ labelBefore }}{{ max }}{{ labelAfter }}</div>\n  </div>\n</div>\n"]}
@@ -0,0 +1,3 @@
1
+ export { RangeSliderComponent } from './components/range-slider/range-slider.component';
2
+ export { RangeSliderModule } from './range-slider.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvcmFuZ2Utc2xpZGVyL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFFeEYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBSYW5nZVNsaWRlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9yYW5nZS1zbGlkZXIvcmFuZ2Utc2xpZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBSYW5nZVNsaWRlclJhbmdlIH0gZnJvbSAnLi90eXBlcy9yYW5nZS1zbGlkZXIudHlwZXMnO1xuZXhwb3J0IHsgUmFuZ2VTbGlkZXJNb2R1bGUgfSBmcm9tICcuL3JhbmdlLXNsaWRlci5tb2R1bGUnO1xuIl19
@@ -0,0 +1,20 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { RangeSliderComponent } from './components/range-slider/range-slider.component';
5
+ import * as i0 from "@angular/core";
6
+ export class RangeSliderModule {
7
+ }
8
+ /** @nocollapse */ RangeSliderModule.ɵfac = function RangeSliderModule_Factory(t) { return new (t || RangeSliderModule)(); };
9
+ /** @nocollapse */ RangeSliderModule.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: RangeSliderModule });
10
+ /** @nocollapse */ RangeSliderModule.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [CommonModule, FormsModule] });
11
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeSliderModule, [{
12
+ type: NgModule,
13
+ args: [{
14
+ imports: [CommonModule, FormsModule],
15
+ declarations: [RangeSliderComponent],
16
+ exports: [RangeSliderComponent],
17
+ }]
18
+ }], null, null); })();
19
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(RangeSliderModule, { declarations: [RangeSliderComponent], imports: [CommonModule, FormsModule], exports: [RangeSliderComponent] }); })();
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2Utc2xpZGVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvcmFuZ2Utc2xpZGVyL3JhbmdlLXNsaWRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtEQUFrRCxDQUFDOztBQU94RixNQUFNLE9BQU8saUJBQWlCOztxR0FBakIsaUJBQWlCO2tHQUFqQixpQkFBaUI7c0dBSmxCLFlBQVksRUFBRSxXQUFXO3VGQUl4QixpQkFBaUI7Y0FMN0IsUUFBUTtlQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7Z0JBQ3BDLFlBQVksRUFBRSxDQUFDLG9CQUFvQixDQUFDO2dCQUNwQyxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQzthQUNoQzs7d0ZBQ1ksaUJBQWlCLG1CQUhiLG9CQUFvQixhQUR6QixZQUFZLEVBQUUsV0FBVyxhQUV6QixvQkFBb0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgUmFuZ2VTbGlkZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvcmFuZ2Utc2xpZGVyL3JhbmdlLXNsaWRlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZV0sXG4gIGRlY2xhcmF0aW9uczogW1JhbmdlU2xpZGVyQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW1JhbmdlU2xpZGVyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgUmFuZ2VTbGlkZXJNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2Utc2xpZGVyLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9yYW5nZS1zbGlkZXIvdHlwZXMvcmFuZ2Utc2xpZGVyLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFJhbmdlU2xpZGVyUmFuZ2Uge1xuICBzdGFydDogbnVtYmVyO1xuICBlbmQ6IG51bWJlcjtcbn1cbiJdfQ==