@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,259 @@
1
+ import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { debounce, get } from 'lodash-es';
4
+ import { FlyoutSize } from '@acpaas-ui/ngx-flyout';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@acpaas-ui/ngx-flyout";
8
+ import * as i3 from "@angular/forms";
9
+ import * as i4 from "@acpaas-ui/ngx-icon";
10
+ const _c0 = function (a0, a1) { return { "a-button--l": a0, "a-button--s": a1 }; };
11
+ function SearchFilterComponent_button_8_Template(rf, ctx) { if (rf & 1) {
12
+ const _r6 = i0.ɵɵgetCurrentView();
13
+ i0.ɵɵelementStart(0, "button", 12);
14
+ i0.ɵɵlistener("click", function SearchFilterComponent_button_8_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r6); const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.clear()); });
15
+ i0.ɵɵelement(1, "aui-icon", 13);
16
+ i0.ɵɵelementEnd();
17
+ } if (rf & 2) {
18
+ const ctx_r0 = i0.ɵɵnextContext();
19
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c0, ctx_r0.size === "large", ctx_r0.size === "small"));
20
+ i0.ɵɵattribute("disabled", ctx_r0.isDisabled ? "" : null);
21
+ } }
22
+ function SearchFilterComponent_aui_icon_9_Template(rf, ctx) { if (rf & 1) {
23
+ i0.ɵɵelement(0, "aui-icon", 13);
24
+ } }
25
+ function SearchFilterComponent_p_11_Template(rf, ctx) { if (rf & 1) {
26
+ i0.ɵɵelementStart(0, "p", 14);
27
+ i0.ɵɵtext(1);
28
+ i0.ɵɵelementEnd();
29
+ } if (rf & 2) {
30
+ const ctx_r2 = i0.ɵɵnextContext();
31
+ i0.ɵɵadvance(1);
32
+ i0.ɵɵtextInterpolate(ctx_r2.labelResults);
33
+ } }
34
+ function SearchFilterComponent_div_12_Template(rf, ctx) { if (rf & 1) {
35
+ i0.ɵɵelement(0, "div", 15);
36
+ } }
37
+ function SearchFilterComponent_ul_13_li_1_Template(rf, ctx) { if (rf & 1) {
38
+ i0.ɵɵelementStart(0, "li", 19)(1, "p", 20);
39
+ i0.ɵɵtext(2);
40
+ i0.ɵɵelementEnd()();
41
+ } if (rf & 2) {
42
+ const ctx_r7 = i0.ɵɵnextContext(2);
43
+ i0.ɵɵadvance(2);
44
+ i0.ɵɵtextInterpolate(ctx_r7.labelNoResults);
45
+ } }
46
+ function SearchFilterComponent_ul_13_li_2_Template(rf, ctx) { if (rf & 1) {
47
+ const _r12 = i0.ɵɵgetCurrentView();
48
+ i0.ɵɵelementStart(0, "li", 19)(1, "div", 21)(2, "div", 22)(3, "input", 23);
49
+ i0.ɵɵlistener("change", function SearchFilterComponent_ul_13_li_2_Template_input_change_3_listener() { const restoredCtx = i0.ɵɵrestoreView(_r12); const choice_r9 = restoredCtx.$implicit; const ctx_r11 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r11.toggleSelected(choice_r9.label)); });
50
+ i0.ɵɵelementEnd();
51
+ i0.ɵɵelementStart(4, "label", 24);
52
+ i0.ɵɵtext(5);
53
+ i0.ɵɵelementEnd()()()();
54
+ } if (rf & 2) {
55
+ const choice_r9 = ctx.$implicit;
56
+ const i_r10 = ctx.index;
57
+ const ctx_r8 = i0.ɵɵnextContext(2);
58
+ i0.ɵɵadvance(3);
59
+ i0.ɵɵpropertyInterpolate("id", "checkbox--" + i_r10 + "--" + ctx_r8.id);
60
+ i0.ɵɵpropertyInterpolate("name", "checkbox--" + i_r10 + "--" + ctx_r8.id);
61
+ i0.ɵɵproperty("checked", ctx_r8.selectedItems.indexOf(choice_r9.label) >= 0);
62
+ i0.ɵɵattribute("disabled", ctx_r8.isDisabled ? true : null);
63
+ i0.ɵɵadvance(1);
64
+ i0.ɵɵpropertyInterpolate("for", "checkbox--" + i_r10 + "--" + ctx_r8.id);
65
+ i0.ɵɵadvance(1);
66
+ i0.ɵɵtextInterpolate(choice_r9.label);
67
+ } }
68
+ function SearchFilterComponent_ul_13_Template(rf, ctx) { if (rf & 1) {
69
+ i0.ɵɵelementStart(0, "ul", 16);
70
+ i0.ɵɵtemplate(1, SearchFilterComponent_ul_13_li_1_Template, 3, 1, "li", 17);
71
+ i0.ɵɵtemplate(2, SearchFilterComponent_ul_13_li_2_Template, 6, 6, "li", 18);
72
+ i0.ɵɵelementEnd();
73
+ } if (rf & 2) {
74
+ const ctx_r4 = i0.ɵɵnextContext();
75
+ i0.ɵɵadvance(1);
76
+ i0.ɵɵproperty("ngIf", !ctx_r4.filteredChoices.length);
77
+ i0.ɵɵadvance(1);
78
+ i0.ɵɵproperty("ngForOf", ctx_r4.filteredChoices);
79
+ } }
80
+ const _c1 = function (a0, a1, a2) { return { "a-input--l": a0, "a-input--s": a1, "has-icon-right": a2 }; };
81
+ export class SearchFilterComponent {
82
+ constructor() {
83
+ this.flyoutSize = FlyoutSize.Small;
84
+ this.labelDeselect = 'Alles deselecteren';
85
+ this.labelResults = 'Resultaten';
86
+ this.labelNoResults = 'Geen resultaten gevonden.';
87
+ this.choices = [];
88
+ this.placeholder = 'Zoeken';
89
+ this.inputDelay = 150;
90
+ this.onSelect = () => { };
91
+ this.onClear = () => { };
92
+ this.size = 'default';
93
+ this.search = new EventEmitter();
94
+ this.query = '';
95
+ this.selectedItems = [];
96
+ this.filteredChoices = [];
97
+ this.loading = false;
98
+ this.isDisabled = false;
99
+ this.updateModel = () => { };
100
+ this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);
101
+ }
102
+ writeValue(value) {
103
+ this.selectedItems = Array.isArray(value) ? value : [];
104
+ }
105
+ registerOnChange(onChange) {
106
+ this.updateModel = onChange;
107
+ }
108
+ registerOnTouched() { }
109
+ setDisabledState(isDisabled) {
110
+ this.isDisabled = isDisabled;
111
+ }
112
+ ngOnChanges(changes) {
113
+ const choices = get(changes, 'choices.currentValue', null);
114
+ if (!choices) {
115
+ return;
116
+ }
117
+ if (this.remote) {
118
+ this.filteredChoices = [...choices];
119
+ this.loading = false;
120
+ }
121
+ else {
122
+ this.filterData();
123
+ }
124
+ }
125
+ filterData() {
126
+ if (this.remote) {
127
+ this.loading = true;
128
+ return this.search.emit(this.query);
129
+ }
130
+ this.filterChoices();
131
+ }
132
+ clear() {
133
+ this.selectedItems = [];
134
+ this.query = '';
135
+ this.filterData();
136
+ this.updateModel(this.selectedItems);
137
+ this.onClear();
138
+ }
139
+ toggleSelected(choice) {
140
+ const selected = this.selectedItems.indexOf(choice);
141
+ if (selected < 0) {
142
+ this.selectedItems = this.selectedItems.concat(choice);
143
+ }
144
+ else {
145
+ this.selectedItems = [...this.selectedItems.slice(0, selected), ...this.selectedItems.slice(selected + 1)];
146
+ }
147
+ this.updateModel(this.selectedItems);
148
+ this.onSelect();
149
+ }
150
+ filterChoices() {
151
+ this.filteredChoices = this.choices.filter((choice) => {
152
+ return (this.selectedItems.indexOf(choice.value) < 0 &&
153
+ choice.label.toLowerCase().indexOf(this.query.toLowerCase()) >= 0);
154
+ });
155
+ }
156
+ hasClose() {
157
+ return this.filteredChoices?.length && this.query?.length > 1;
158
+ }
159
+ getSelectedLabels() {
160
+ return this.selectedItems.length ? this.selectedItems.map((el) => el).join(', ') : null;
161
+ }
162
+ }
163
+ /** @nocollapse */ SearchFilterComponent.ɵfac = function SearchFilterComponent_Factory(t) { return new (t || SearchFilterComponent)(); };
164
+ /** @nocollapse */ SearchFilterComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: SearchFilterComponent, selectors: [["aui-search-filter"]], inputs: { id: "id", name: "name", flyoutSize: "flyoutSize", flyoutAlign: "flyoutAlign", label: "label", description: "description", labelDeselect: "labelDeselect", labelResults: "labelResults", labelNoResults: "labelNoResults", choices: "choices", remote: "remote", placeholder: "placeholder", inputDelay: "inputDelay", onSelect: "onSelect", onClear: "onClear", size: "size" }, outputs: { search: "search" }, features: [i0.ɵɵProvidersFeature([
165
+ {
166
+ provide: NG_VALUE_ACCESSOR,
167
+ useExisting: forwardRef((() => SearchFilterComponent)),
168
+ multi: true,
169
+ },
170
+ ]), i0.ɵɵNgOnChangesFeature], decls: 14, vars: 22, consts: [["aria-haspopup", "listbox", "auiFlyout", "", 1, "m-search-filter", 3, "align", "size"], [1, "a-input", 3, "ngClass"], [1, "a-input__label", 3, "for"], [1, "a-input__description", 3, "id"], [1, "m-search-filter__input"], ["aria-autocomplete", "list", "type", "text", "auiFlyoutAction", "", 3, "ngModel", "id", "name", "value", "input", "ngModelChange"], ["class", "a-button a-button--outlined has-icon m-search-filter__button a-button--danger", "aria-label", "Zoekopdracht wissen", "type", "button", 3, "ngClass", "click", 4, "ngIf"], ["name", "ai-close", 4, "ngIf"], ["auiFlyoutZone", "", 1, "m-search-filter__search", "m-search-filter__search--scroll"], ["class", "h6 m-search-filter__results-title u-margin-bottom-xs", 4, "ngIf"], ["class", "u-text-center u-padding a-spinner", 4, "ngIf"], ["class", "a-checkbox-list a-checkbox-list--flushed", 4, "ngIf"], ["aria-label", "Zoekopdracht wissen", "type", "button", 1, "a-button", "a-button--outlined", "has-icon", "m-search-filter__button", "a-button--danger", 3, "ngClass", "click"], ["name", "ai-close"], [1, "h6", "m-search-filter__results-title", "u-margin-bottom-xs"], [1, "u-text-center", "u-padding", "a-spinner"], [1, "a-checkbox-list", "a-checkbox-list--flushed"], ["class", "a-checkbox-list__item", 4, "ngIf"], ["class", "a-checkbox-list__item", 4, "ngFor", "ngForOf"], [1, "a-checkbox-list__item"], [1, "u-margin-xs"], [1, "a-input", "a-checkbox-list__checkbox"], [1, "a-input__checkbox"], ["type", "checkbox", 3, "checked", "id", "name", "change"], [3, "for"]], template: function SearchFilterComponent_Template(rf, ctx) { if (rf & 1) {
171
+ i0.ɵɵelementStart(0, "div", 0)(1, "div", 1)(2, "label", 2);
172
+ i0.ɵɵtext(3);
173
+ i0.ɵɵelementEnd();
174
+ i0.ɵɵelementStart(4, "small", 3);
175
+ i0.ɵɵtext(5, "Input description");
176
+ i0.ɵɵelementEnd();
177
+ i0.ɵɵelementStart(6, "div", 4)(7, "input", 5);
178
+ i0.ɵɵlistener("input", function SearchFilterComponent_Template_input_input_7_listener() { return ctx.filterDataFromSearch(); })("ngModelChange", function SearchFilterComponent_Template_input_ngModelChange_7_listener($event) { return ctx.query = $event; });
179
+ i0.ɵɵelementEnd();
180
+ i0.ɵɵtemplate(8, SearchFilterComponent_button_8_Template, 2, 5, "button", 6);
181
+ i0.ɵɵtemplate(9, SearchFilterComponent_aui_icon_9_Template, 1, 0, "aui-icon", 7);
182
+ i0.ɵɵelementEnd()();
183
+ i0.ɵɵelementStart(10, "div", 8);
184
+ i0.ɵɵtemplate(11, SearchFilterComponent_p_11_Template, 2, 1, "p", 9);
185
+ i0.ɵɵtemplate(12, SearchFilterComponent_div_12_Template, 1, 0, "div", 10);
186
+ i0.ɵɵtemplate(13, SearchFilterComponent_ul_13_Template, 3, 2, "ul", 11);
187
+ i0.ɵɵelementEnd()();
188
+ } if (rf & 2) {
189
+ i0.ɵɵproperty("align", ctx.flyoutAlign)("size", ctx.flyoutSize);
190
+ i0.ɵɵadvance(1);
191
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction3(18, _c1, ctx.size === "large", ctx.size === "small", ctx.hasClose));
192
+ i0.ɵɵadvance(1);
193
+ i0.ɵɵpropertyInterpolate("for", ctx.id + "-search");
194
+ i0.ɵɵadvance(1);
195
+ i0.ɵɵtextInterpolate(ctx.label);
196
+ i0.ɵɵadvance(1);
197
+ i0.ɵɵpropertyInterpolate("id", ctx.id + "-description");
198
+ i0.ɵɵadvance(3);
199
+ i0.ɵɵpropertyInterpolate("id", ctx.id + "-search");
200
+ i0.ɵɵpropertyInterpolate("name", ctx.name + "-search");
201
+ i0.ɵɵpropertyInterpolate("value", ctx.getSelectedLabels());
202
+ i0.ɵɵproperty("ngModel", ctx.query);
203
+ i0.ɵɵattribute("aria-labelledby", ctx.id + "-label")("placeholder", ctx.placeholder)("disabled", ctx.isDisabled ? "" : null);
204
+ i0.ɵɵadvance(1);
205
+ i0.ɵɵproperty("ngIf", ctx.hasClose);
206
+ i0.ɵɵadvance(1);
207
+ i0.ɵɵproperty("ngIf", !ctx.hasClose);
208
+ i0.ɵɵadvance(2);
209
+ i0.ɵɵproperty("ngIf", ctx.labelResults);
210
+ i0.ɵɵadvance(1);
211
+ i0.ɵɵproperty("ngIf", ctx.loading);
212
+ i0.ɵɵadvance(1);
213
+ i0.ɵɵproperty("ngIf", !ctx.loading);
214
+ } }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i2.FlyoutActionDirective, i2.FlyoutZoneDirective, i2.FlyoutDirective, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgModel, i4.IconComponent], styles: [".m-search-filter[_ngcontent-%COMP%]{display:block}.m-search-filter__input[_ngcontent-%COMP%]{display:flex;padding:0}.m-search-filter__input[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{border-right:none}.m-search-filter__button[_ngcontent-%COMP%]{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button[_ngcontent-%COMP%] .ai[_ngcontent-%COMP%]{position:relative;transform:none!important;top:0}"] });
215
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SearchFilterComponent, [{
216
+ type: Component,
217
+ args: [{ selector: 'aui-search-filter', providers: [
218
+ {
219
+ provide: NG_VALUE_ACCESSOR,
220
+ useExisting: forwardRef((() => SearchFilterComponent)),
221
+ multi: true,
222
+ },
223
+ ], template: "<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n <div\n class=\"a-input\"\n [ngClass]=\"{\n 'a-input--l': size === 'large',\n 'a-input--s': size === 'small',\n 'has-icon-right': hasClose\n }\"\n >\n <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">Input description</small>\n <div class=\"m-search-filter__input\">\n <input\n (input)=\"filterDataFromSearch()\"\n [(ngModel)]=\"query\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.placeholder]=\"placeholder\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n aria-autocomplete=\"list\"\n id=\"{{ id + '-search' }}\"\n name=\"{{ name + '-search' }}\"\n value=\"{{ getSelectedLabels() }}\"\n type=\"text\"\n auiFlyoutAction\n />\n <button\n *ngIf=\"hasClose\"\n [ngClass]=\"{\n 'a-button--l': size === 'large',\n 'a-button--s': size === 'small'\n }\"\n class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n aria-label=\"Zoekopdracht wissen\"\n type=\"button\"\n (click)=\"clear()\"\n [attr.disabled]=\"isDisabled ? '' : null\"\n >\n <aui-icon name=\"ai-close\"></aui-icon>\n </button>\n <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n </div>\n </div>\n <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n </li>\n <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n <div class=\"a-input a-checkbox-list__checkbox\">\n <div class=\"a-input__checkbox\">\n <input\n (change)=\"toggleSelected(choice.label)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n id=\"{{ 'checkbox--' + i + '--' + id }}\"\n name=\"{{ 'checkbox--' + i + '--' + id }}\"\n type=\"checkbox\"\n />\n <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n </div>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", styles: [".m-search-filter{display:block}.m-search-filter__input{display:flex;padding:0}.m-search-filter__input input{border-right:none}.m-search-filter__button{display:inline-block;padding:0;position:relative;vertical-align:middle}.m-search-filter__button .ai{position:relative;transform:none!important;top:0}\n"] }]
224
+ }], function () { return []; }, { id: [{
225
+ type: Input
226
+ }], name: [{
227
+ type: Input
228
+ }], flyoutSize: [{
229
+ type: Input
230
+ }], flyoutAlign: [{
231
+ type: Input
232
+ }], label: [{
233
+ type: Input
234
+ }], description: [{
235
+ type: Input
236
+ }], labelDeselect: [{
237
+ type: Input
238
+ }], labelResults: [{
239
+ type: Input
240
+ }], labelNoResults: [{
241
+ type: Input
242
+ }], choices: [{
243
+ type: Input
244
+ }], remote: [{
245
+ type: Input
246
+ }], placeholder: [{
247
+ type: Input
248
+ }], inputDelay: [{
249
+ type: Input
250
+ }], onSelect: [{
251
+ type: Input
252
+ }], onClear: [{
253
+ type: Input
254
+ }], size: [{
255
+ type: Input
256
+ }], search: [{
257
+ type: Output
258
+ }] }); })();
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-filter.component.js","sourceRoot":"","sources":["../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.ts","../../../../../../src/lib/search-filter/components/search-filter/search-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { debounce, get } from 'lodash-es';\n\nimport { FlyoutSize } from '@acpaas-ui/ngx-flyout';\n\nimport { SearchFilterChoice } from '../../types/search-filter.types';\n\n@Component({\n  selector: 'aui-search-filter',\n  templateUrl: './search-filter.component.html',\n  styleUrls: ['./search-filter.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchFilterComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class SearchFilterComponent implements OnChanges, ControlValueAccessor {\n  @Input() public id: string;\n  @Input() public name: string;\n  @Input() public flyoutSize = FlyoutSize.Small;\n  @Input() public flyoutAlign;\n  @Input() public label: string;\n  @Input() public description: string;\n  @Input() public labelDeselect = 'Alles deselecteren';\n  @Input() public labelResults = 'Resultaten';\n  @Input() public labelNoResults = 'Geen resultaten gevonden.';\n  @Input() public choices: SearchFilterChoice[] = [];\n  @Input() public remote: boolean;\n  @Input() public placeholder = 'Zoeken';\n  @Input() public inputDelay = 150;\n  @Input() public onSelect: () => void = () => {};\n  @Input() public onClear: () => void = () => {};\n  @Input() public size: 'large' | 'default' | 'small' | 'tiny' = 'default';\n\n  @Output() public search: EventEmitter<string> = new EventEmitter<string>();\n\n  public query = '';\n  public selectedItems: string[] = [];\n  public filteredChoices: SearchFilterChoice[] = [];\n  public loading = false;\n  public isDisabled = false;\n\n  public filterDataFromSearch: () => {};\n\n  constructor() {\n    this.filterDataFromSearch = debounce(this.filterData.bind(this), this.inputDelay);\n  }\n\n  public updateModel: (_) => any = () => {};\n\n  public writeValue(value: string[]): void {\n    this.selectedItems = Array.isArray(value) ? value : [];\n  }\n\n  public registerOnChange(onChange: (_) => any): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    const choices = get(changes, 'choices.currentValue', null);\n\n    if (!choices) {\n      return;\n    }\n\n    if (this.remote) {\n      this.filteredChoices = [...choices];\n      this.loading = false;\n    } else {\n      this.filterData();\n    }\n  }\n\n  public filterData(): void {\n    if (this.remote) {\n      this.loading = true;\n\n      return this.search.emit(this.query);\n    }\n\n    this.filterChoices();\n  }\n\n  public clear(): void {\n    this.selectedItems = [];\n    this.query = '';\n    this.filterData();\n    this.updateModel(this.selectedItems);\n    this.onClear();\n  }\n\n  public toggleSelected(choice: string): void {\n    const selected = this.selectedItems.indexOf(choice);\n\n    if (selected < 0) {\n      this.selectedItems = this.selectedItems.concat(choice);\n    } else {\n      this.selectedItems = [...this.selectedItems.slice(0, selected), ...this.selectedItems.slice(selected + 1)];\n    }\n\n    this.updateModel(this.selectedItems);\n    this.onSelect();\n  }\n\n  private filterChoices(): void {\n    this.filteredChoices = this.choices.filter((choice: SearchFilterChoice) => {\n      return (\n        this.selectedItems.indexOf(choice.value) < 0 &&\n        choice.label.toLowerCase().indexOf(this.query.toLowerCase()) >= 0\n      );\n    });\n  }\n\n  public hasClose(): boolean {\n    return this.filteredChoices?.length && this.query?.length > 1;\n  }\n\n  public getSelectedLabels(): string {\n    return this.selectedItems.length ? this.selectedItems.map((el) => el).join(', ') : null;\n  }\n}\n","<div [align]=\"flyoutAlign\" [size]=\"flyoutSize\" aria-haspopup=\"listbox\" auiFlyout class=\"m-search-filter\">\n  <div\n    class=\"a-input\"\n    [ngClass]=\"{\n      'a-input--l': size === 'large',\n      'a-input--s': size === 'small',\n      'has-icon-right': hasClose\n    }\"\n  >\n    <label class=\"a-input__label\" for=\"{{ id + '-search' }}\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"{{ id + '-description' }}\">Input description</small>\n    <div class=\"m-search-filter__input\">\n      <input\n        (input)=\"filterDataFromSearch()\"\n        [(ngModel)]=\"query\"\n        [attr.aria-labelledby]=\"id + '-label'\"\n        [attr.placeholder]=\"placeholder\"\n        [attr.disabled]=\"isDisabled ? '' : null\"\n        aria-autocomplete=\"list\"\n        id=\"{{ id + '-search' }}\"\n        name=\"{{ name + '-search' }}\"\n        value=\"{{ getSelectedLabels() }}\"\n        type=\"text\"\n        auiFlyoutAction\n      />\n      <button\n        *ngIf=\"hasClose\"\n        [ngClass]=\"{\n          'a-button--l': size === 'large',\n          'a-button--s': size === 'small'\n        }\"\n        class=\"a-button a-button--outlined has-icon m-search-filter__button a-button--danger\"\n        aria-label=\"Zoekopdracht wissen\"\n        type=\"button\"\n        (click)=\"clear()\"\n        [attr.disabled]=\"isDisabled ? '' : null\"\n      >\n        <aui-icon name=\"ai-close\"></aui-icon>\n      </button>\n      <aui-icon *ngIf=\"!hasClose\" name=\"ai-close\"></aui-icon>\n    </div>\n  </div>\n  <div auiFlyoutZone class=\"m-search-filter__search m-search-filter__search--scroll\">\n    <p *ngIf=\"labelResults\" class=\"h6 m-search-filter__results-title u-margin-bottom-xs\">{{ labelResults }}</p>\n    <div *ngIf=\"loading\" class=\"u-text-center u-padding a-spinner\"></div>\n    <ul *ngIf=\"!loading\" class=\"a-checkbox-list a-checkbox-list--flushed\">\n      <li *ngIf=\"!filteredChoices.length\" class=\"a-checkbox-list__item\">\n        <p class=\"u-margin-xs\">{{ labelNoResults }}</p>\n      </li>\n      <li *ngFor=\"let choice of filteredChoices; index as i\" class=\"a-checkbox-list__item\">\n        <div class=\"a-input a-checkbox-list__checkbox\">\n          <div class=\"a-input__checkbox\">\n            <input\n              (change)=\"toggleSelected(choice.label)\"\n              [attr.disabled]=\"isDisabled ? true : null\"\n              [checked]=\"selectedItems.indexOf(choice.label) >= 0\"\n              id=\"{{ 'checkbox--' + i + '--' + id }}\"\n              name=\"{{ 'checkbox--' + i + '--' + id }}\"\n              type=\"checkbox\"\n            />\n            <label for=\"{{ 'checkbox--' + i + '--' + id }}\">{{ choice.label }}</label>\n          </div>\n        </div>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
@@ -0,0 +1,3 @@
1
+ export { SearchFilterComponent } from './components/search-filter/search-filter.component';
2
+ export { SearchFilterModule } from './search-filter.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc2VhcmNoLWZpbHRlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBRTNGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgU2VhcmNoRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3NlYXJjaC1maWx0ZXIvc2VhcmNoLWZpbHRlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2VhcmNoRmlsdGVyQ2hvaWNlIH0gZnJvbSAnLi90eXBlcy9zZWFyY2gtZmlsdGVyLnR5cGVzJztcbmV4cG9ydCB7IFNlYXJjaEZpbHRlck1vZHVsZSB9IGZyb20gJy4vc2VhcmNoLWZpbHRlci5tb2R1bGUnO1xuIl19
@@ -0,0 +1,22 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { FormsModule } from '@angular/forms';
3
+ import { CommonModule } from '@angular/common';
4
+ import { FlyoutModule } from '@acpaas-ui/ngx-flyout';
5
+ import { IconModule } from '@acpaas-ui/ngx-icon';
6
+ import { SearchFilterComponent } from './components/search-filter/search-filter.component';
7
+ import * as i0 from "@angular/core";
8
+ export class SearchFilterModule {
9
+ }
10
+ /** @nocollapse */ SearchFilterModule.ɵfac = function SearchFilterModule_Factory(t) { return new (t || SearchFilterModule)(); };
11
+ /** @nocollapse */ SearchFilterModule.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: SearchFilterModule });
12
+ /** @nocollapse */ SearchFilterModule.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [CommonModule, FlyoutModule, FormsModule, IconModule] });
13
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SearchFilterModule, [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [CommonModule, FlyoutModule, FormsModule, IconModule],
17
+ declarations: [SearchFilterComponent],
18
+ exports: [SearchFilterComponent],
19
+ }]
20
+ }], null, null); })();
21
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(SearchFilterModule, { declarations: [SearchFilterComponent], imports: [CommonModule, FlyoutModule, FormsModule, IconModule], exports: [SearchFilterComponent] }); })();
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWZpbHRlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlYXJjaC1maWx0ZXIvc2VhcmNoLWZpbHRlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7O0FBTzNGLE1BQU0sT0FBTyxrQkFBa0I7O3VHQUFsQixrQkFBa0I7bUdBQWxCLGtCQUFrQjt1R0FKbkIsWUFBWSxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsVUFBVTt1RkFJbEQsa0JBQWtCO2NBTDlCLFFBQVE7ZUFBQztnQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUM7Z0JBQzlELFlBQVksRUFBRSxDQUFDLHFCQUFxQixDQUFDO2dCQUNyQyxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQzthQUNqQzs7d0ZBQ1ksa0JBQWtCLG1CQUhkLHFCQUFxQixhQUQxQixZQUFZLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxVQUFVLGFBRW5ELHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGbHlvdXRNb2R1bGUgfSBmcm9tICdAYWNwYWFzLXVpL25neC1mbHlvdXQnO1xuaW1wb3J0IHsgSWNvbk1vZHVsZSB9IGZyb20gJ0BhY3BhYXMtdWkvbmd4LWljb24nO1xuaW1wb3J0IHsgU2VhcmNoRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3NlYXJjaC1maWx0ZXIvc2VhcmNoLWZpbHRlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGbHlvdXRNb2R1bGUsIEZvcm1zTW9kdWxlLCBJY29uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbU2VhcmNoRmlsdGVyQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW1NlYXJjaEZpbHRlckNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFNlYXJjaEZpbHRlck1vZHVsZSB7fVxuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWZpbHRlci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvc2VhcmNoLWZpbHRlci90eXBlcy9zZWFyY2gtZmlsdGVyLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlYXJjaEZpbHRlckNob2ljZSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHZhbHVlOiBzdHJpbmc7XG59XG4iXX0=
@@ -0,0 +1,32 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SearchService {
4
+ constructor() {
5
+ this.matchItemWithSearchString = (item, searchString) => {
6
+ return String(item).toLowerCase().indexOf(searchString.toLowerCase()) > -1;
7
+ };
8
+ }
9
+ search(data, options = {}) {
10
+ const query = options.hasOwnProperty('query') ? options.query : '';
11
+ const minLength = options.hasOwnProperty('minLength') ? options.minLength : 0;
12
+ const key = options.hasOwnProperty('key') ? options.key : '';
13
+ if ((!query && options.showAllByDefault) || query.length < minLength) {
14
+ return [...data];
15
+ }
16
+ return [...data].filter(item => {
17
+ if (key && !item.hasOwnProperty(key)) {
18
+ return console.error(`"${key}" does not exist in item ${JSON.stringify(item, null, 2)}`);
19
+ }
20
+ if (key) {
21
+ return this.matchItemWithSearchString(item[key], query);
22
+ }
23
+ return this.matchItemWithSearchString(item, query);
24
+ });
25
+ }
26
+ }
27
+ /** @nocollapse */ SearchService.ɵfac = function SearchService_Factory(t) { return new (t || SearchService)(); };
28
+ /** @nocollapse */ SearchService.ɵprov = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjectable({ token: SearchService, factory: SearchService.ɵfac });
29
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SearchService, [{
30
+ type: Injectable
31
+ }], null, null); })();
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NoYXJlZC9zZXJ2aWNlcy9zZWFyY2guc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sYUFBYTtJQUQxQjtRQXdCVSw4QkFBeUIsR0FBRyxDQUFDLElBQVMsRUFBRSxZQUFZLEVBQVcsRUFBRTtZQUN2RSxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDN0UsQ0FBQyxDQUFBO0tBQ0Y7SUF6QlEsTUFBTSxDQUFDLElBQVcsRUFBRSxVQUF5QixFQUFFO1FBQ3BELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNuRSxNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDOUUsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBRTdELElBQUksQ0FBQyxDQUFDLEtBQUssSUFBSSxPQUFPLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxHQUFHLFNBQVMsRUFBRTtZQUNwRSxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztTQUNsQjtRQUVELE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUM3QixJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ3BDLE9BQU8sT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEdBQUcsNEJBQTRCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7YUFDMUY7WUFFRCxJQUFJLEdBQUcsRUFBRTtnQkFDUCxPQUFPLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7YUFDekQ7WUFFRCxPQUFPLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDckQsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzs2RkFyQlUsYUFBYTtrR0FBYixhQUFhLFdBQWIsYUFBYTt1RkFBYixhQUFhO2NBRHpCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNlYXJjaE9wdGlvbnMgfSBmcm9tICcuLi90eXBlcy9zZWFyY2gudHlwZXMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2VhcmNoU2VydmljZSB7XG4gIHB1YmxpYyBzZWFyY2goZGF0YTogYW55W10sIG9wdGlvbnM6IFNlYXJjaE9wdGlvbnMgPSB7fSk6IGFueVtdIHtcbiAgICBjb25zdCBxdWVyeSA9IG9wdGlvbnMuaGFzT3duUHJvcGVydHkoJ3F1ZXJ5JykgPyBvcHRpb25zLnF1ZXJ5IDogJyc7XG4gICAgY29uc3QgbWluTGVuZ3RoID0gb3B0aW9ucy5oYXNPd25Qcm9wZXJ0eSgnbWluTGVuZ3RoJykgPyBvcHRpb25zLm1pbkxlbmd0aCA6IDA7XG4gICAgY29uc3Qga2V5ID0gb3B0aW9ucy5oYXNPd25Qcm9wZXJ0eSgna2V5JykgPyBvcHRpb25zLmtleSA6ICcnO1xuXG4gICAgaWYgKCghcXVlcnkgJiYgb3B0aW9ucy5zaG93QWxsQnlEZWZhdWx0KSB8fCBxdWVyeS5sZW5ndGggPCBtaW5MZW5ndGgpIHtcbiAgICAgIHJldHVybiBbLi4uZGF0YV07XG4gICAgfVxuXG4gICAgcmV0dXJuIFsuLi5kYXRhXS5maWx0ZXIoaXRlbSA9PiB7XG4gICAgICBpZiAoa2V5ICYmICFpdGVtLmhhc093blByb3BlcnR5KGtleSkpIHtcbiAgICAgICAgcmV0dXJuIGNvbnNvbGUuZXJyb3IoYFwiJHtrZXl9XCIgZG9lcyBub3QgZXhpc3QgaW4gaXRlbSAke0pTT04uc3RyaW5naWZ5KGl0ZW0sIG51bGwsIDIpfWApO1xuICAgICAgfVxuXG4gICAgICBpZiAoa2V5KSB7XG4gICAgICAgIHJldHVybiB0aGlzLm1hdGNoSXRlbVdpdGhTZWFyY2hTdHJpbmcoaXRlbVtrZXldLCBxdWVyeSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB0aGlzLm1hdGNoSXRlbVdpdGhTZWFyY2hTdHJpbmcoaXRlbSwgcXVlcnkpO1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBtYXRjaEl0ZW1XaXRoU2VhcmNoU3RyaW5nID0gKGl0ZW06IGFueSwgc2VhcmNoU3RyaW5nKTogYm9vbGVhbiA9PiB7XG4gICAgcmV0dXJuIFN0cmluZyhpdGVtKS50b0xvd2VyQ2FzZSgpLmluZGV4T2Yoc2VhcmNoU3RyaW5nLnRvTG93ZXJDYXNlKCkpID4gLTE7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9zaGFyZWQvdHlwZXMvc2VhcmNoLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNlYXJjaE9wdGlvbnMge1xuICBrZXk/OiBzdHJpbmc7XG4gIG1pbkxlbmd0aD86IG51bWJlcjtcbiAgcXVlcnk/OiBzdHJpbmc7XG4gIHNob3dBbGxCeURlZmF1bHQ/OiBib29sZWFuO1xufVxuIl19
@@ -0,0 +1,49 @@
1
+ export class TimePickerValidators {
2
+ // time `hh:mm` 24h format
3
+ static minTime(time) {
4
+ const validator = (control) => {
5
+ const splittedControlValue = control.value.split(':');
6
+ const controlHours = parseInt(splittedControlValue[0], 10);
7
+ const controlMinutes = parseInt(splittedControlValue[1], 10);
8
+ const splittedMinTime = time.split(':');
9
+ const minHours = parseInt(splittedMinTime[0], 10);
10
+ const minMinutes = parseInt(splittedMinTime[1], 10);
11
+ // Don't throw error --> use Validator.required
12
+ if (isNaN(controlHours) || isNaN(controlMinutes) || isNaN(minHours) || isNaN(minMinutes)) {
13
+ return null;
14
+ }
15
+ if (minHours < controlHours) {
16
+ return null;
17
+ }
18
+ if (minHours === controlHours && minMinutes <= controlMinutes) {
19
+ return null;
20
+ }
21
+ return { minTime: { value: control.value } };
22
+ };
23
+ return validator;
24
+ }
25
+ // time `hh:mm` 24h format
26
+ static maxTime(time) {
27
+ const validator = (control) => {
28
+ const splittedControlValue = control.value.split(':');
29
+ const controlHours = parseInt(splittedControlValue[0], 10);
30
+ const controlMinutes = parseInt(splittedControlValue[1], 10);
31
+ const splittedMinTime = time.split(':');
32
+ const maxHours = parseInt(splittedMinTime[0], 10);
33
+ const maxMinutes = parseInt(splittedMinTime[1], 10);
34
+ // Don't throw error --> use Validator.required
35
+ if (isNaN(controlHours) || isNaN(controlMinutes) || isNaN(maxHours) || isNaN(maxMinutes)) {
36
+ return null;
37
+ }
38
+ if (maxHours > controlHours) {
39
+ return null;
40
+ }
41
+ if (maxHours === controlHours && maxMinutes >= controlMinutes) {
42
+ return null;
43
+ }
44
+ return { maxTime: { value: control.value } };
45
+ };
46
+ return validator;
47
+ }
48
+ }
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXBpY2tlci52YWxpZGF0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi90aW1lcGlja2VyL2NsYXNzZXMvdGltZXBpY2tlci52YWxpZGF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxvQkFBb0I7SUFDL0IsMEJBQTBCO0lBQ25CLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBWTtRQUNoQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE9BQXdCLEVBQTBCLEVBQUU7WUFDckUsTUFBTSxvQkFBb0IsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN0RCxNQUFNLFlBQVksR0FBRyxRQUFRLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDM0QsTUFBTSxjQUFjLEdBQUcsUUFBUSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzdELE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDeEMsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNsRCxNQUFNLFVBQVUsR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBRXBELCtDQUErQztZQUMvQyxJQUFJLEtBQUssQ0FBQyxZQUFZLENBQUMsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEtBQUssQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDeEYsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUVELElBQUksUUFBUSxHQUFHLFlBQVksRUFBRTtnQkFDM0IsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUVELElBQUksUUFBUSxLQUFLLFlBQVksSUFBSSxVQUFVLElBQUksY0FBYyxFQUFFO2dCQUM3RCxPQUFPLElBQUksQ0FBQzthQUNiO1lBRUQsT0FBTyxFQUFFLE9BQU8sRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUMvQyxDQUFDLENBQUM7UUFFRixPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQsMEJBQTBCO0lBQ25CLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBWTtRQUNoQyxNQUFNLFNBQVMsR0FBRyxDQUFDLE9BQXdCLEVBQTBCLEVBQUU7WUFDckUsTUFBTSxvQkFBb0IsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN0RCxNQUFNLFlBQVksR0FBRyxRQUFRLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDM0QsTUFBTSxjQUFjLEdBQUcsUUFBUSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzdELE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDeEMsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUNsRCxNQUFNLFVBQVUsR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBRXBELCtDQUErQztZQUMvQyxJQUFJLEtBQUssQ0FBQyxZQUFZLENBQUMsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEtBQUssQ0FBQyxVQUFVLENBQUMsRUFBRTtnQkFDeEYsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUVELElBQUksUUFBUSxHQUFHLFlBQVksRUFBRTtnQkFDM0IsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUVELElBQUksUUFBUSxLQUFLLFlBQVksSUFBSSxVQUFVLElBQUksY0FBYyxFQUFFO2dCQUM3RCxPQUFPLElBQUksQ0FBQzthQUNiO1lBRUQsT0FBTyxFQUFFLE9BQU8sRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUMvQyxDQUFDLENBQUM7UUFFRixPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIFZhbGlkYXRvckZuIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5leHBvcnQgY2xhc3MgVGltZVBpY2tlclZhbGlkYXRvcnMge1xuICAvLyB0aW1lIGBoaDptbWAgMjRoIGZvcm1hdFxuICBwdWJsaWMgc3RhdGljIG1pblRpbWUodGltZTogc3RyaW5nKTogVmFsaWRhdG9yRm4ge1xuICAgIGNvbnN0IHZhbGlkYXRvciA9IChjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpOiB7IFtrZXk6IHN0cmluZ106IGFueSB9ID0+IHtcbiAgICAgIGNvbnN0IHNwbGl0dGVkQ29udHJvbFZhbHVlID0gY29udHJvbC52YWx1ZS5zcGxpdCgnOicpO1xuICAgICAgY29uc3QgY29udHJvbEhvdXJzID0gcGFyc2VJbnQoc3BsaXR0ZWRDb250cm9sVmFsdWVbMF0sIDEwKTtcbiAgICAgIGNvbnN0IGNvbnRyb2xNaW51dGVzID0gcGFyc2VJbnQoc3BsaXR0ZWRDb250cm9sVmFsdWVbMV0sIDEwKTtcbiAgICAgIGNvbnN0IHNwbGl0dGVkTWluVGltZSA9IHRpbWUuc3BsaXQoJzonKTtcbiAgICAgIGNvbnN0IG1pbkhvdXJzID0gcGFyc2VJbnQoc3BsaXR0ZWRNaW5UaW1lWzBdLCAxMCk7XG4gICAgICBjb25zdCBtaW5NaW51dGVzID0gcGFyc2VJbnQoc3BsaXR0ZWRNaW5UaW1lWzFdLCAxMCk7XG5cbiAgICAgIC8vIERvbid0IHRocm93IGVycm9yIC0tPiB1c2UgVmFsaWRhdG9yLnJlcXVpcmVkXG4gICAgICBpZiAoaXNOYU4oY29udHJvbEhvdXJzKSB8fCBpc05hTihjb250cm9sTWludXRlcykgfHwgaXNOYU4obWluSG91cnMpIHx8IGlzTmFOKG1pbk1pbnV0ZXMpKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgICAgfVxuXG4gICAgICBpZiAobWluSG91cnMgPCBjb250cm9sSG91cnMpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9XG5cbiAgICAgIGlmIChtaW5Ib3VycyA9PT0gY29udHJvbEhvdXJzICYmIG1pbk1pbnV0ZXMgPD0gY29udHJvbE1pbnV0ZXMpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7IG1pblRpbWU6IHsgdmFsdWU6IGNvbnRyb2wudmFsdWUgfSB9O1xuICAgIH07XG5cbiAgICByZXR1cm4gdmFsaWRhdG9yO1xuICB9XG5cbiAgLy8gdGltZSBgaGg6bW1gIDI0aCBmb3JtYXRcbiAgcHVibGljIHN0YXRpYyBtYXhUaW1lKHRpbWU6IHN0cmluZyk6IFZhbGlkYXRvckZuIHtcbiAgICBjb25zdCB2YWxpZGF0b3IgPSAoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogeyBba2V5OiBzdHJpbmddOiBhbnkgfSA9PiB7XG4gICAgICBjb25zdCBzcGxpdHRlZENvbnRyb2xWYWx1ZSA9IGNvbnRyb2wudmFsdWUuc3BsaXQoJzonKTtcbiAgICAgIGNvbnN0IGNvbnRyb2xIb3VycyA9IHBhcnNlSW50KHNwbGl0dGVkQ29udHJvbFZhbHVlWzBdLCAxMCk7XG4gICAgICBjb25zdCBjb250cm9sTWludXRlcyA9IHBhcnNlSW50KHNwbGl0dGVkQ29udHJvbFZhbHVlWzFdLCAxMCk7XG4gICAgICBjb25zdCBzcGxpdHRlZE1pblRpbWUgPSB0aW1lLnNwbGl0KCc6Jyk7XG4gICAgICBjb25zdCBtYXhIb3VycyA9IHBhcnNlSW50KHNwbGl0dGVkTWluVGltZVswXSwgMTApO1xuICAgICAgY29uc3QgbWF4TWludXRlcyA9IHBhcnNlSW50KHNwbGl0dGVkTWluVGltZVsxXSwgMTApO1xuXG4gICAgICAvLyBEb24ndCB0aHJvdyBlcnJvciAtLT4gdXNlIFZhbGlkYXRvci5yZXF1aXJlZFxuICAgICAgaWYgKGlzTmFOKGNvbnRyb2xIb3VycykgfHwgaXNOYU4oY29udHJvbE1pbnV0ZXMpIHx8IGlzTmFOKG1heEhvdXJzKSB8fCBpc05hTihtYXhNaW51dGVzKSkge1xuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgIH1cblxuICAgICAgaWYgKG1heEhvdXJzID4gY29udHJvbEhvdXJzKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgICAgfVxuXG4gICAgICBpZiAobWF4SG91cnMgPT09IGNvbnRyb2xIb3VycyAmJiBtYXhNaW51dGVzID49IGNvbnRyb2xNaW51dGVzKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4geyBtYXhUaW1lOiB7IHZhbHVlOiBjb250cm9sLnZhbHVlIH0gfTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIHZhbGlkYXRvcjtcbiAgfVxufVxuIl19