@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,229 @@
1
+ import { ChangeDetectionStrategy, Component, forwardRef, Input } from '@angular/core';
2
+ import { UntypedFormControl, NG_VALUE_ACCESSOR, } from '@angular/forms';
3
+ import { Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import { DateHelper } from '@acpaas-ui/js-date-utils';
6
+ import { TimepickerInputSize } from '../../types/timepicker.types';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/forms";
9
+ import * as i2 from "@angular/common";
10
+ import * as i3 from "@acpaas-ui/ngx-icon";
11
+ function TimepickerComponent_div_1_aui_icon_4_Template(rf, ctx) { if (rf & 1) {
12
+ i0.ɵɵelement(0, "aui-icon", 8);
13
+ } }
14
+ const _c0 = function (a0) { return { "has-error": a0 }; };
15
+ const _c1 = function (a0) { return { "is-error": a0 }; };
16
+ function TimepickerComponent_div_1_Template(rf, ctx) { if (rf & 1) {
17
+ i0.ɵɵelementStart(0, "div", 3)(1, "label", 4);
18
+ i0.ɵɵtext(2);
19
+ i0.ɵɵelementEnd();
20
+ i0.ɵɵelementStart(3, "small", 5);
21
+ i0.ɵɵtemplate(4, TimepickerComponent_div_1_aui_icon_4_Template, 1, 0, "aui-icon", 6);
22
+ i0.ɵɵtext(5);
23
+ i0.ɵɵelementEnd();
24
+ i0.ɵɵelement(6, "input", 7);
25
+ i0.ɵɵelementEnd();
26
+ } if (rf & 2) {
27
+ const ctx_r0 = i0.ɵɵnextContext();
28
+ i0.ɵɵclassMap("a-input--" + ctx_r0.size);
29
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(10, _c0, ctx_r0.hasError));
30
+ i0.ɵɵadvance(2);
31
+ i0.ɵɵtextInterpolate(ctx_r0.label);
32
+ i0.ɵɵadvance(1);
33
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(12, _c1, ctx_r0.hasError));
34
+ i0.ɵɵadvance(1);
35
+ i0.ɵɵproperty("ngIf", ctx_r0.hasError);
36
+ i0.ɵɵadvance(1);
37
+ i0.ɵɵtextInterpolate1(" ", ctx_r0.description, "");
38
+ i0.ɵɵadvance(1);
39
+ i0.ɵɵproperty("formControl", ctx_r0.timeControl)("id", ctx_r0.id);
40
+ i0.ɵɵattribute("aria-label", ctx_r0.ariaLabelHours + ":" + ctx_r0.ariaLabelMinutes);
41
+ } }
42
+ function TimepickerComponent_div_2_option_6_Template(rf, ctx) { if (rf & 1) {
43
+ i0.ɵɵelementStart(0, "option", 17);
44
+ i0.ɵɵtext(1);
45
+ i0.ɵɵelementEnd();
46
+ } if (rf & 2) {
47
+ const hour_r5 = ctx.$implicit;
48
+ i0.ɵɵproperty("value", hour_r5);
49
+ i0.ɵɵadvance(1);
50
+ i0.ɵɵtextInterpolate(hour_r5);
51
+ } }
52
+ function TimepickerComponent_div_2_option_13_Template(rf, ctx) { if (rf & 1) {
53
+ i0.ɵɵelementStart(0, "option", 17);
54
+ i0.ɵɵtext(1);
55
+ i0.ɵɵelementEnd();
56
+ } if (rf & 2) {
57
+ const minute_r6 = ctx.$implicit;
58
+ i0.ɵɵproperty("value", minute_r6);
59
+ i0.ɵɵadvance(1);
60
+ i0.ɵɵtextInterpolate(minute_r6);
61
+ } }
62
+ function TimepickerComponent_div_2_Template(rf, ctx) { if (rf & 1) {
63
+ i0.ɵɵelementStart(0, "div", 9)(1, "div", 10)(2, "div", 11)(3, "select", 12)(4, "option", 13);
64
+ i0.ɵɵtext(5);
65
+ i0.ɵɵelementEnd();
66
+ i0.ɵɵtemplate(6, TimepickerComponent_div_2_option_6_Template, 2, 2, "option", 14);
67
+ i0.ɵɵelementEnd();
68
+ i0.ɵɵelement(7, "aui-icon", 15);
69
+ i0.ɵɵelementEnd()();
70
+ i0.ɵɵelementStart(8, "div", 10)(9, "div", 11)(10, "select", 16)(11, "option", 13);
71
+ i0.ɵɵtext(12);
72
+ i0.ɵɵelementEnd();
73
+ i0.ɵɵtemplate(13, TimepickerComponent_div_2_option_13_Template, 2, 2, "option", 14);
74
+ i0.ɵɵelementEnd();
75
+ i0.ɵɵelement(14, "aui-icon", 15);
76
+ i0.ɵɵelementEnd()()();
77
+ } if (rf & 2) {
78
+ const ctx_r1 = i0.ɵɵnextContext();
79
+ i0.ɵɵproperty("formGroup", ctx_r1.fallbackForm);
80
+ i0.ɵɵadvance(1);
81
+ i0.ɵɵclassMap("a-input--" + ctx_r1.size);
82
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(14, _c0, ctx_r1.hasError));
83
+ i0.ɵɵadvance(2);
84
+ i0.ɵɵproperty("id", ctx_r1.id);
85
+ i0.ɵɵattribute("aria-label", ctx_r1.ariaLabelHours);
86
+ i0.ɵɵadvance(2);
87
+ i0.ɵɵtextInterpolate(ctx_r1.hoursPlaceholder);
88
+ i0.ɵɵadvance(1);
89
+ i0.ɵɵproperty("ngForOf", ctx_r1.hours);
90
+ i0.ɵɵadvance(2);
91
+ i0.ɵɵclassMap("a-input--" + ctx_r1.size);
92
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(16, _c0, ctx_r1.hasError));
93
+ i0.ɵɵadvance(2);
94
+ i0.ɵɵattribute("aria-label", ctx_r1.ariaLabelMinutes);
95
+ i0.ɵɵadvance(2);
96
+ i0.ɵɵtextInterpolate(ctx_r1.minutesPlaceholder);
97
+ i0.ɵɵadvance(1);
98
+ i0.ɵɵproperty("ngForOf", ctx_r1.minutes);
99
+ } }
100
+ export class TimepickerComponent {
101
+ constructor(formBuilder, renderer) {
102
+ this.formBuilder = formBuilder;
103
+ this.renderer = renderer;
104
+ this.id = 'aui-timepicker-' + Math.random().toString(36).substring(2);
105
+ this.hoursPlaceholder = 'uu';
106
+ this.minutesPlaceholder = 'mm';
107
+ this.hasError = false;
108
+ this.size = TimepickerInputSize.Auto;
109
+ this.ariaLabelHours = 'Uur';
110
+ this.ariaLabelMinutes = 'Minuten';
111
+ this.shouldUseFallback = false;
112
+ this.minutes = [];
113
+ this.hours = [];
114
+ this.timeControl = new UntypedFormControl();
115
+ this.componentDestroyed$ = new Subject();
116
+ }
117
+ ngOnInit() {
118
+ this.shouldUseFallback = this.supportsNativeTimepicker();
119
+ this.minutes = this.getMinutes();
120
+ this.hours = this.getHours();
121
+ this.fallbackForm = this.formBuilder.group({
122
+ hours: null,
123
+ minutes: null,
124
+ });
125
+ this.fallbackForm.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((formData) => {
126
+ if (formData.hours && formData.minutes) {
127
+ this.updateModel(`${formData.hours}:${formData.minutes}`);
128
+ }
129
+ else {
130
+ this.updateModel('');
131
+ }
132
+ });
133
+ this.timeControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((time) => {
134
+ this.updateModel(time);
135
+ });
136
+ }
137
+ ngOnDestroy() {
138
+ this.componentDestroyed$.next(true);
139
+ this.componentDestroyed$.complete();
140
+ }
141
+ writeValue(value) {
142
+ this.timeControl.setValue(value, { emitEvent: false });
143
+ if (value) {
144
+ const splitted = value.split(':');
145
+ this.fallbackForm.get('hours').setValue(splitted[0], { emitEvent: false });
146
+ this.fallbackForm.get('minutes').setValue(splitted[1], { emitEvent: false });
147
+ }
148
+ }
149
+ registerOnChange(onChange) {
150
+ this.updateModel = onChange;
151
+ }
152
+ registerOnTouched() { }
153
+ setDisabledState(isDisabled) {
154
+ if (isDisabled) {
155
+ this.timeControl.disable({ emitEvent: false });
156
+ this.fallbackForm.disable({ emitEvent: false });
157
+ }
158
+ else {
159
+ this.timeControl.enable({ emitEvent: false });
160
+ this.fallbackForm.enable({ emitEvent: false });
161
+ }
162
+ }
163
+ supportsNativeTimepicker() {
164
+ const element = this.renderer.createElement('input');
165
+ element.type = 'time';
166
+ return element.type === 'text';
167
+ }
168
+ getMinutes() {
169
+ return Array(60)
170
+ .fill('')
171
+ .map((value, index) => {
172
+ return DateHelper.addLeadingZero(index);
173
+ });
174
+ }
175
+ getHours() {
176
+ return Array(24)
177
+ .fill('')
178
+ .map((value, index) => {
179
+ return DateHelper.addLeadingZero(index);
180
+ });
181
+ }
182
+ }
183
+ /** @nocollapse */ TimepickerComponent.ɵfac = function TimepickerComponent_Factory(t) { return new (t || TimepickerComponent)(i0.ɵɵdirectiveInject(i1.UntypedFormBuilder), i0.ɵɵdirectiveInject(i0.Renderer2)); };
184
+ /** @nocollapse */ TimepickerComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TimepickerComponent, selectors: [["aui-timepicker"]], inputs: { id: "id", hoursPlaceholder: "hoursPlaceholder", minutesPlaceholder: "minutesPlaceholder", hasError: "hasError", size: "size", ariaLabelHours: "ariaLabelHours", ariaLabelMinutes: "ariaLabelMinutes", label: "label", description: "description" }, features: [i0.ɵɵProvidersFeature([
185
+ {
186
+ provide: NG_VALUE_ACCESSOR,
187
+ useExisting: forwardRef((() => TimepickerComponent)),
188
+ multi: true,
189
+ },
190
+ ])], decls: 3, vars: 2, consts: [[1, "m-timepicker"], ["class", "a-input", 3, "class", "ngClass", 4, "ngIf"], [3, "formGroup", 4, "ngIf"], [1, "a-input", 3, "ngClass"], ["for", "id", 1, "a-input__label"], ["id", "id", 1, "a-input__description", 3, "ngClass"], ["name", "ai-alert-triangle", 4, "ngIf"], ["type", "time", 3, "formControl", "id"], ["name", "ai-alert-triangle"], [3, "formGroup"], [1, "a-input", "has-icon-right", 3, "ngClass"], [1, "a-input__wrapper"], ["formControlName", "hours", 3, "id"], ["disabled", "", "value", "null"], [3, "value", 4, "ngFor", "ngForOf"], ["name", "ai-arrow-down-1"], ["formControlName", "minutes"], [3, "value"]], template: function TimepickerComponent_Template(rf, ctx) { if (rf & 1) {
191
+ i0.ɵɵelementStart(0, "div", 0);
192
+ i0.ɵɵtemplate(1, TimepickerComponent_div_1_Template, 7, 14, "div", 1);
193
+ i0.ɵɵtemplate(2, TimepickerComponent_div_2_Template, 15, 18, "div", 2);
194
+ i0.ɵɵelementEnd();
195
+ } if (rf & 2) {
196
+ i0.ɵɵadvance(1);
197
+ i0.ɵɵproperty("ngIf", !ctx.shouldUseFallback);
198
+ i0.ɵɵadvance(1);
199
+ i0.ɵɵproperty("ngIf", ctx.shouldUseFallback);
200
+ } }, dependencies: [i1.NgSelectOption, i1.ɵNgSelectMultipleOption, i1.DefaultValueAccessor, i1.SelectControlValueAccessor, i1.NgControlStatus, i1.NgControlStatusGroup, i1.FormControlDirective, i1.FormGroupDirective, i1.FormControlName, i2.NgClass, i2.NgForOf, i2.NgIf, i3.IconComponent], styles: ["[_nghost-%COMP%]{display:block}"], changeDetection: 0 });
201
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimepickerComponent, [{
202
+ type: Component,
203
+ args: [{ selector: 'aui-timepicker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
204
+ {
205
+ provide: NG_VALUE_ACCESSOR,
206
+ useExisting: forwardRef((() => TimepickerComponent)),
207
+ multi: true,
208
+ },
209
+ ], template: "<div class=\"m-timepicker\">\n <div *ngIf=\"!shouldUseFallback\" [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input\">\n <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n <small class=\"a-input__description\" id=\"id\" [ngClass]=\"{ 'is-error': hasError }\">\n <aui-icon *ngIf=\"hasError\" name=\"ai-alert-triangle\"></aui-icon>\n {{ description }}</small\n >\n <input\n [attr.aria-label]=\"ariaLabelHours + ':' + ariaLabelMinutes\"\n [formControl]=\"timeControl\"\n [id]=\"id\"\n type=\"time\"\n />\n </div>\n\n <div *ngIf=\"shouldUseFallback\" [formGroup]=\"fallbackForm\">\n <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n <div class=\"a-input__wrapper\">\n <select [attr.aria-label]=\"ariaLabelHours\" [id]=\"id\" formControlName=\"hours\">\n <option disabled value=\"null\">{{ hoursPlaceholder }}</option>\n <option *ngFor=\"let hour of hours\" [value]=\"hour\">{{ hour }}</option>\n </select>\n <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n </div>\n </div>\n\n <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n <div class=\"a-input__wrapper\">\n <select [attr.aria-label]=\"ariaLabelMinutes\" formControlName=\"minutes\">\n <option disabled value=\"null\">{{ minutesPlaceholder }}</option>\n <option *ngFor=\"let minute of minutes\" [value]=\"minute\">{{ minute }}</option>\n </select>\n <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n </div>\n </div>\n </div>\n</div>\n", styles: [":host{display:block}\n"] }]
210
+ }], function () { return [{ type: i1.UntypedFormBuilder }, { type: i0.Renderer2 }]; }, { id: [{
211
+ type: Input
212
+ }], hoursPlaceholder: [{
213
+ type: Input
214
+ }], minutesPlaceholder: [{
215
+ type: Input
216
+ }], hasError: [{
217
+ type: Input
218
+ }], size: [{
219
+ type: Input
220
+ }], ariaLabelHours: [{
221
+ type: Input
222
+ }], ariaLabelMinutes: [{
223
+ type: Input
224
+ }], label: [{
225
+ type: Input
226
+ }], description: [{
227
+ type: Input
228
+ }] }); })();
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.ts","../../../../../../src/lib/timepicker/components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, forwardRef, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { DateHelper } from '@acpaas-ui/js-date-utils';\n\nimport { TimepickerInputSize } from '../../types/timepicker.types';\n\n@Component({\n  selector: 'aui-timepicker',\n  templateUrl: './timepicker.component.html',\n  styleUrls: ['./timepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TimepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class TimepickerComponent implements OnInit, OnDestroy, ControlValueAccessor {\n  @Input() public id = 'aui-timepicker-' + Math.random().toString(36).substring(2);\n  @Input() public hoursPlaceholder = 'uu';\n  @Input() public minutesPlaceholder = 'mm';\n  @Input() public hasError = false;\n  @Input() public size: TimepickerInputSize = TimepickerInputSize.Auto;\n  @Input() public ariaLabelHours = 'Uur';\n  @Input() public ariaLabelMinutes = 'Minuten';\n  @Input() public label: string;\n  @Input() public description: string;\n\n  public shouldUseFallback = false;\n  public minutes: string[] = [];\n  public hours: string[] = [];\n  public updateModel: (value: string) => any;\n\n  public timeControl = new UntypedFormControl();\n  public fallbackForm: UntypedFormGroup;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(private formBuilder: UntypedFormBuilder, private renderer: Renderer2) {}\n\n  public ngOnInit() {\n    this.shouldUseFallback = this.supportsNativeTimepicker();\n    this.minutes = this.getMinutes();\n    this.hours = this.getHours();\n\n    this.fallbackForm = this.formBuilder.group({\n      hours: null,\n      minutes: null,\n    });\n\n    this.fallbackForm.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((formData) => {\n      if (formData.hours && formData.minutes) {\n        this.updateModel(`${formData.hours}:${formData.minutes}`);\n      } else {\n        this.updateModel('');\n      }\n    });\n\n    this.timeControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((time) => {\n      this.updateModel(time);\n    });\n  }\n\n  public ngOnDestroy() {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  public writeValue(value: any): void {\n    this.timeControl.setValue(value, { emitEvent: false });\n\n    if (value) {\n      const splitted = value.split(':');\n      this.fallbackForm.get('hours').setValue(splitted[0], { emitEvent: false });\n      this.fallbackForm.get('minutes').setValue(splitted[1], { emitEvent: false });\n    }\n  }\n\n  public registerOnChange(onChange): void {\n    this.updateModel = onChange;\n  }\n\n  public registerOnTouched(): void {}\n\n  public setDisabledState(isDisabled: boolean) {\n    if (isDisabled) {\n      this.timeControl.disable({ emitEvent: false });\n      this.fallbackForm.disable({ emitEvent: false });\n    } else {\n      this.timeControl.enable({ emitEvent: false });\n      this.fallbackForm.enable({ emitEvent: false });\n    }\n  }\n\n  private supportsNativeTimepicker(): boolean {\n    const element = this.renderer.createElement('input');\n    element.type = 'time';\n\n    return element.type === 'text';\n  }\n\n  private getMinutes(): string[] {\n    return Array(60)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n\n  private getHours(): string[] {\n    return Array(24)\n      .fill('')\n      .map((value, index) => {\n        return DateHelper.addLeadingZero(index);\n      });\n  }\n}\n","<div class=\"m-timepicker\">\n  <div *ngIf=\"!shouldUseFallback\" [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input\">\n    <label class=\"a-input__label\" for=\"id\">{{ label }}</label>\n    <small class=\"a-input__description\" id=\"id\" [ngClass]=\"{ 'is-error': hasError }\">\n      <aui-icon *ngIf=\"hasError\" name=\"ai-alert-triangle\"></aui-icon>\n      {{ description }}</small\n    >\n    <input\n      [attr.aria-label]=\"ariaLabelHours + ':' + ariaLabelMinutes\"\n      [formControl]=\"timeControl\"\n      [id]=\"id\"\n      type=\"time\"\n    />\n  </div>\n\n  <div *ngIf=\"shouldUseFallback\" [formGroup]=\"fallbackForm\">\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelHours\" [id]=\"id\" formControlName=\"hours\">\n          <option disabled value=\"null\">{{ hoursPlaceholder }}</option>\n          <option *ngFor=\"let hour of hours\" [value]=\"hour\">{{ hour }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n\n    <div [class]=\"'a-input--' + size\" [ngClass]=\"{ 'has-error': hasError }\" class=\"a-input has-icon-right\">\n      <div class=\"a-input__wrapper\">\n        <select [attr.aria-label]=\"ariaLabelMinutes\" formControlName=\"minutes\">\n          <option disabled value=\"null\">{{ minutesPlaceholder }}</option>\n          <option *ngFor=\"let minute of minutes\" [value]=\"minute\">{{ minute }}</option>\n        </select>\n        <aui-icon name=\"ai-arrow-down-1\"></aui-icon>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -0,0 +1,5 @@
1
+ export { TimePickerValidators } from './classes/timepicker.validators';
2
+ export { TimepickerComponent } from './components/timepicker/timepicker.component';
3
+ export { TimepickerInputSize } from './types/timepicker.types';
4
+ export { TimepickerModule } from './timepicker.module';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdGltZXBpY2tlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVGltZVBpY2tlclZhbGlkYXRvcnMgfSBmcm9tICcuL2NsYXNzZXMvdGltZXBpY2tlci52YWxpZGF0b3JzJztcbmV4cG9ydCB7IFRpbWVwaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZXBpY2tlci90aW1lcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBUaW1lcGlja2VySW5wdXRTaXplIH0gZnJvbSAnLi90eXBlcy90aW1lcGlja2VyLnR5cGVzJztcbmV4cG9ydCB7IFRpbWVwaWNrZXJNb2R1bGUgfSBmcm9tICcuL3RpbWVwaWNrZXIubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,22 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { ReactiveFormsModule } from '@angular/forms';
3
+ import { CommonModule } from '@angular/common';
4
+ import { IconModule } from '@acpaas-ui/ngx-icon';
5
+ import { TimepickerComponent } from './components/timepicker/timepicker.component';
6
+ import * as i0 from "@angular/core";
7
+ export class TimepickerModule {
8
+ }
9
+ /** @nocollapse */ TimepickerModule.ɵfac = function TimepickerModule_Factory(t) { return new (t || TimepickerModule)(); };
10
+ /** @nocollapse */ TimepickerModule.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: TimepickerModule });
11
+ /** @nocollapse */ TimepickerModule.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ imports: [ReactiveFormsModule, CommonModule, IconModule] });
12
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimepickerModule, [{
13
+ type: NgModule,
14
+ args: [{
15
+ imports: [ReactiveFormsModule, CommonModule, IconModule],
16
+ declarations: [TimepickerComponent],
17
+ exports: [TimepickerComponent],
18
+ providers: [],
19
+ }]
20
+ }], null, null); })();
21
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(TimepickerModule, { declarations: [TimepickerComponent], imports: [ReactiveFormsModule, CommonModule, IconModule], exports: [TimepickerComponent] }); })();
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3RpbWVwaWNrZXIvdGltZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFDOztBQVFuRixNQUFNLE9BQU8sZ0JBQWdCOzttR0FBaEIsZ0JBQWdCO2lHQUFoQixnQkFBZ0I7cUdBTGpCLG1CQUFtQixFQUFFLFlBQVksRUFBRSxVQUFVO3VGQUs1QyxnQkFBZ0I7Y0FONUIsUUFBUTtlQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixFQUFFLFlBQVksRUFBRSxVQUFVLENBQUM7Z0JBQ3hELFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO2dCQUNuQyxPQUFPLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztnQkFDOUIsU0FBUyxFQUFFLEVBQUU7YUFDZDs7d0ZBQ1ksZ0JBQWdCLG1CQUpaLG1CQUFtQixhQUR4QixtQkFBbUIsRUFBRSxZQUFZLEVBQUUsVUFBVSxhQUU3QyxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJY29uTW9kdWxlIH0gZnJvbSAnQGFjcGFhcy11aS9uZ3gtaWNvbic7XG5pbXBvcnQgeyBUaW1lcGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbWVwaWNrZXIvdGltZXBpY2tlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbUmVhY3RpdmVGb3Jtc01vZHVsZSwgQ29tbW9uTW9kdWxlLCBJY29uTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbVGltZXBpY2tlckNvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtUaW1lcGlja2VyQ29tcG9uZW50XSxcbiAgcHJvdmlkZXJzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgVGltZXBpY2tlck1vZHVsZSB7fVxuIl19
@@ -0,0 +1,7 @@
1
+ export var TimepickerInputSize;
2
+ (function (TimepickerInputSize) {
3
+ TimepickerInputSize["Auto"] = "auto";
4
+ TimepickerInputSize["Small"] = "small";
5
+ TimepickerInputSize["Large"] = "large";
6
+ })(TimepickerInputSize || (TimepickerInputSize = {}));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXBpY2tlci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdGltZXBpY2tlci90eXBlcy90aW1lcGlja2VyLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG1CQUlYO0FBSkQsV0FBWSxtQkFBbUI7SUFDN0Isb0NBQWEsQ0FBQTtJQUNiLHNDQUFlLENBQUE7SUFDZixzQ0FBZSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxtQkFBbUIsS0FBbkIsbUJBQW1CLFFBSTlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gVGltZXBpY2tlcklucHV0U2l6ZSB7XG4gIEF1dG8gPSAnYXV0bycsXG4gIFNtYWxsID0gJ3NtYWxsJyxcbiAgTGFyZ2UgPSAnbGFyZ2UnLFxufVxuIl19
@@ -0,0 +1,112 @@
1
+ import { Observable } from 'rxjs';
2
+ import { UPLOAD_OPTIONS_DEFAULT } from '../upload.conf';
3
+ export class Uploader {
4
+ constructor(options) {
5
+ this.options = UPLOAD_OPTIONS_DEFAULT;
6
+ this.setOptions(options);
7
+ }
8
+ setOptions(options) {
9
+ this.options = Object.assign({}, this.options, options);
10
+ }
11
+ uploadFiles(files) {
12
+ const formData = this.filesToFormData(files);
13
+ return new Observable(observer => {
14
+ const xhr = new XMLHttpRequest();
15
+ // Progress callback
16
+ xhr.upload.addEventListener('progress', (e) => {
17
+ if (e.lengthComputable) {
18
+ const percentComplete = e.loaded / e.total;
19
+ observer.next({
20
+ progress: percentComplete,
21
+ data: null,
22
+ });
23
+ }
24
+ });
25
+ // Complete callback
26
+ xhr.onload = () => {
27
+ observer.next({
28
+ progress: 1,
29
+ data: xhr.response,
30
+ });
31
+ // observer.complete();
32
+ };
33
+ // Do request
34
+ xhr.responseType = 'json';
35
+ xhr.open('post', this.options.url);
36
+ xhr.send(formData);
37
+ });
38
+ }
39
+ validateFiles(files) {
40
+ const validFiles = [];
41
+ const invalidFiles = [];
42
+ if (files.length > 0) {
43
+ for (const file of files) {
44
+ const errors = [];
45
+ if (!this.validateFileType(file)) {
46
+ errors.push('INVALID_FILE_TYPE');
47
+ }
48
+ if (!this.validateFileSize(file)) {
49
+ errors.push('INVALID_FILE_SIZE');
50
+ }
51
+ if (!this.validateMimeType(file)) {
52
+ errors.push('INVALID_MIME_TYPE');
53
+ }
54
+ if (errors.length === 0) {
55
+ validFiles.push(file);
56
+ }
57
+ else {
58
+ invalidFiles.push({
59
+ reasons: errors,
60
+ file,
61
+ });
62
+ }
63
+ }
64
+ }
65
+ return {
66
+ validFiles,
67
+ invalidFiles,
68
+ };
69
+ }
70
+ filesToFormData(files) {
71
+ const formData = new FormData();
72
+ if (!this.options.url || this.options.url === '') {
73
+ throw new Error('Define the upload url.');
74
+ }
75
+ for (const file of files) {
76
+ formData.append('file', file);
77
+ }
78
+ return formData;
79
+ }
80
+ getFileExtension(file) {
81
+ return file.name.split('.')[file.name.split('.').length - 1];
82
+ }
83
+ validateFileType(file) {
84
+ const allowedFileTypes = this.options.allowedFileTypes;
85
+ const ext = this.getFileExtension(file);
86
+ // Filter defined?
87
+ if (!Array.isArray(allowedFileTypes) || allowedFileTypes.length === 0) {
88
+ return true;
89
+ }
90
+ // Make allowedFileTypes case insensitive
91
+ const toUpper = (x) => x.toUpperCase();
92
+ const allowedFileTypesToUpper = allowedFileTypes.map(toUpper);
93
+ return allowedFileTypesToUpper.lastIndexOf(ext.toUpperCase()) !== -1;
94
+ }
95
+ validateFileSize(file) {
96
+ const maxFileSize = this.options.maxFileSize;
97
+ // Filter defined?
98
+ if (!maxFileSize || maxFileSize === 0) {
99
+ return true;
100
+ }
101
+ return maxFileSize > file.size;
102
+ }
103
+ validateMimeType(file) {
104
+ const allowedMimeTypes = this.options.allowedMimeTypes;
105
+ // Filter defined?
106
+ if (!Array.isArray(allowedMimeTypes) || allowedMimeTypes.length === 0) {
107
+ return true;
108
+ }
109
+ return allowedMimeTypes.lastIndexOf(file.type) !== -1;
110
+ }
111
+ }
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader.class.js","sourceRoot":"","sources":["../../../../../src/lib/upload/classes/uploader.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from 'rxjs';\n\nimport { UPLOAD_OPTIONS_DEFAULT } from '../upload.conf';\nimport { InvalidFile, UploadOptions } from '../types/upload.types';\n\nexport class Uploader {\n  public options: UploadOptions = UPLOAD_OPTIONS_DEFAULT;\n\n  constructor(options?: UploadOptions) {\n    this.setOptions(options);\n  }\n\n  public setOptions(options) {\n    this.options = Object.assign({}, this.options, options);\n  }\n\n  public uploadFiles(files: File[]): Observable<{ progress: number, data: object[] }> {\n    const formData: FormData = this.filesToFormData(files);\n\n    return new Observable(observer => {\n      const xhr = new XMLHttpRequest();\n\n      // Progress callback\n      xhr.upload.addEventListener('progress', (e) => {\n        if (e.lengthComputable) {\n          const percentComplete = e.loaded / e.total;\n\n          observer.next({\n            progress: percentComplete,\n            data: null,\n          });\n        }\n      });\n\n      // Complete callback\n      xhr.onload = () => {\n        observer.next({\n          progress: 1,\n          data: xhr.response,\n        });\n        // observer.complete();\n      };\n\n      // Do request\n      xhr.responseType = 'json';\n      xhr.open('post', this.options.url);\n      xhr.send(formData);\n    });\n  }\n\n  public validateFiles(files) {\n    const validFiles: File[] = [];\n    const invalidFiles: InvalidFile[] = [];\n\n    if (files.length > 0) {\n\n      for (const file of files) {\n        const errors = [];\n\n        if (!this.validateFileType(file)) {\n          errors.push('INVALID_FILE_TYPE');\n        }\n\n        if (!this.validateFileSize(file)) {\n          errors.push('INVALID_FILE_SIZE');\n        }\n\n        if (!this.validateMimeType(file)) {\n          errors.push('INVALID_MIME_TYPE');\n        }\n\n        if (errors.length === 0) {\n          validFiles.push(file);\n        } else {\n          invalidFiles.push({\n            reasons: errors,\n            file,\n          });\n        }\n      }\n    }\n\n    return {\n      validFiles,\n      invalidFiles,\n    };\n  }\n\n  protected filesToFormData(files: File[]): FormData {\n    const formData = new FormData();\n\n    if (!this.options.url || this.options.url === '') {\n      throw new Error('Define the upload url.');\n    }\n\n    for (const file of files) {\n      formData.append('file', file);\n    }\n\n    return formData;\n  }\n\n  protected getFileExtension(file: File): string {\n    return file.name.split('.')[file.name.split('.').length - 1];\n  }\n\n  protected validateFileType(file: File): boolean {\n    const allowedFileTypes = this.options.allowedFileTypes;\n    const ext = this.getFileExtension(file);\n\n    // Filter defined?\n    if (!Array.isArray(allowedFileTypes) || allowedFileTypes.length === 0) {\n      return true;\n    }\n\n    // Make allowedFileTypes case insensitive\n    const toUpper = (x) => x.toUpperCase();\n    const allowedFileTypesToUpper = allowedFileTypes.map(toUpper);\n\n    return allowedFileTypesToUpper.lastIndexOf(ext.toUpperCase()) !== -1;\n  }\n\n  protected validateFileSize(file: File): boolean {\n    const maxFileSize = this.options.maxFileSize;\n\n    // Filter defined?\n    if (!maxFileSize || maxFileSize === 0) {\n      return true;\n    }\n\n    return maxFileSize > file.size;\n  }\n\n  protected validateMimeType(file: File): boolean {\n    const allowedMimeTypes = this.options.allowedMimeTypes;\n\n    // Filter defined?\n    if (!Array.isArray(allowedMimeTypes) || allowedMimeTypes.length === 0) {\n      return true;\n    }\n\n    return allowedMimeTypes.lastIndexOf(file.type) !== -1;\n  }\n}\n"]}
@@ -0,0 +1,97 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { UPLOAD_OPTIONS_DEFAULT } from '../../upload.conf';
3
+ import { Uploader } from '../../classes/uploader.class';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "../upload-queue/upload-queue.component";
7
+ import * as i3 from "../upload-zone/upload-zone.component";
8
+ import * as i4 from "../validation-list/validation-list.component";
9
+ function UploadComponent_aui_upload_queue_5_Template(rf, ctx) { if (rf & 1) {
10
+ const _r2 = i0.ɵɵgetCurrentView();
11
+ i0.ɵɵelementStart(0, "aui-upload-queue", 5);
12
+ i0.ɵɵlistener("uploadedFiles", function UploadComponent_aui_upload_queue_5_Template_aui_upload_queue_uploadedFiles_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onUploadedFiles($event)); });
13
+ i0.ɵɵelementEnd();
14
+ } if (rf & 2) {
15
+ const ctx_r0 = i0.ɵɵnextContext();
16
+ i0.ɵɵproperty("ariaLabelRemove", ctx_r0.ariaLabelRemove)("files", ctx_r0.queuedFiles)("uploader", ctx_r0.uploader);
17
+ } }
18
+ const _c0 = [[["", 8, "m-upload__button"]]];
19
+ const _c1 = [".m-upload__button"];
20
+ export class UploadComponent {
21
+ constructor() {
22
+ this.id = '';
23
+ this.accept = [];
24
+ this.capture = '';
25
+ this.ariaLabelRemove = 'Verwijder';
26
+ this.disabled = false;
27
+ this.multiple = true;
28
+ this.label = '';
29
+ this.description = '';
30
+ this.options = UPLOAD_OPTIONS_DEFAULT;
31
+ this.selectUploadedFiles = new EventEmitter();
32
+ this.uploadedFiles = [];
33
+ this.invalidFiles = [];
34
+ this.queuedFiles = [];
35
+ }
36
+ ngOnInit() {
37
+ if (!this.id) {
38
+ this.ariaId = 'aui-upload-' + Math.random().toString(36).substring(2);
39
+ this.id = this.ariaId;
40
+ }
41
+ this.uploader = new Uploader(this.options);
42
+ }
43
+ onUploadedFiles(files) {
44
+ this.uploadedFiles = this.uploadedFiles.concat(files);
45
+ this.selectUploadedFiles.emit(this.uploadedFiles);
46
+ }
47
+ onInvalidFiles(files) {
48
+ this.invalidFiles = files;
49
+ }
50
+ onQueuedFiles(files) {
51
+ this.queuedFiles = this.queuedFiles.concat(files);
52
+ }
53
+ }
54
+ /** @nocollapse */ UploadComponent.ɵfac = function UploadComponent_Factory(t) { return new (t || UploadComponent)(); };
55
+ /** @nocollapse */ UploadComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: UploadComponent, selectors: [["aui-upload"]], inputs: { id: "id", accept: "accept", capture: "capture", ariaLabelRemove: "ariaLabelRemove", disabled: "disabled", multiple: "multiple", label: "label", description: "description", options: "options" }, outputs: { selectUploadedFiles: "selectUploadedFiles" }, ngContentSelectors: _c1, decls: 6, vars: 12, consts: [[1, "m-upload", "aui-upload"], [3, "id", "accept", "capture", "ariaId", "disabled", "multiple", "uploader", "label", "description", "invalidFiles", "queuedFiles", "uploadedFiles"], [1, "m-upload__button"], [3, "ariaLabelRemove", "invalidFiles"], [3, "ariaLabelRemove", "files", "uploader", "uploadedFiles", 4, "ngIf"], [3, "ariaLabelRemove", "files", "uploader", "uploadedFiles"]], template: function UploadComponent_Template(rf, ctx) { if (rf & 1) {
56
+ i0.ɵɵprojectionDef(_c0);
57
+ i0.ɵɵelementStart(0, "div", 0)(1, "aui-upload-zone", 1);
58
+ i0.ɵɵlistener("invalidFiles", function UploadComponent_Template_aui_upload_zone_invalidFiles_1_listener($event) { return ctx.onInvalidFiles($event); })("queuedFiles", function UploadComponent_Template_aui_upload_zone_queuedFiles_1_listener($event) { return ctx.onQueuedFiles($event); })("uploadedFiles", function UploadComponent_Template_aui_upload_zone_uploadedFiles_1_listener($event) { return ctx.onUploadedFiles($event); });
59
+ i0.ɵɵelementStart(2, "div", 2);
60
+ i0.ɵɵprojection(3);
61
+ i0.ɵɵelementEnd()();
62
+ i0.ɵɵelement(4, "aui-validation-list", 3);
63
+ i0.ɵɵtemplate(5, UploadComponent_aui_upload_queue_5_Template, 1, 3, "aui-upload-queue", 4);
64
+ i0.ɵɵelementEnd();
65
+ } if (rf & 2) {
66
+ i0.ɵɵadvance(1);
67
+ i0.ɵɵproperty("id", ctx.id)("accept", ctx.accept)("capture", ctx.capture)("ariaId", ctx.ariaId)("disabled", ctx.disabled)("multiple", ctx.multiple)("uploader", ctx.uploader)("label", ctx.label)("description", ctx.description);
68
+ i0.ɵɵadvance(3);
69
+ i0.ɵɵproperty("ariaLabelRemove", ctx.ariaLabelRemove)("invalidFiles", ctx.invalidFiles);
70
+ i0.ɵɵadvance(1);
71
+ i0.ɵɵproperty("ngIf", !(ctx.options == null ? null : ctx.options.autoUpload));
72
+ } }, dependencies: [i1.NgIf, i2.UploadQueueComponent, i3.UploadZoneComponent, i4.ValidationListComponent], styles: [".m-upload__button[_ngcontent-%COMP%] > .m-upload__input[_ngcontent-%COMP%]{display:none}"] });
73
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UploadComponent, [{
74
+ type: Component,
75
+ args: [{ selector: 'aui-upload', template: "<div class=\"m-upload aui-upload\">\n <aui-upload-zone\n [id]=\"id\"\n [accept]=\"accept\"\n [capture]=\"capture\"\n [ariaId]=\"ariaId\"\n [disabled]=\"disabled\"\n [multiple]=\"multiple\"\n [uploader]=\"uploader\"\n (invalidFiles)=\"onInvalidFiles($event)\"\n (queuedFiles)=\"onQueuedFiles($event)\"\n (uploadedFiles)=\"onUploadedFiles($event)\"\n [label]=\"label\"\n [description]=\"description\"\n >\n <div class=\"m-upload__button\">\n <ng-content select=\".m-upload__button\"></ng-content>\n </div>\n </aui-upload-zone>\n <aui-validation-list [ariaLabelRemove]=\"ariaLabelRemove\" [invalidFiles]=\"invalidFiles\"></aui-validation-list>\n <aui-upload-queue\n (uploadedFiles)=\"onUploadedFiles($event)\"\n *ngIf=\"!options?.autoUpload\"\n [ariaLabelRemove]=\"ariaLabelRemove\"\n [files]=\"queuedFiles\"\n [uploader]=\"uploader\"\n ></aui-upload-queue>\n</div>\n", styles: [".m-upload__button>.m-upload__input{display:none}\n"] }]
76
+ }], null, { id: [{
77
+ type: Input
78
+ }], accept: [{
79
+ type: Input
80
+ }], capture: [{
81
+ type: Input
82
+ }], ariaLabelRemove: [{
83
+ type: Input
84
+ }], disabled: [{
85
+ type: Input
86
+ }], multiple: [{
87
+ type: Input
88
+ }], label: [{
89
+ type: Input
90
+ }], description: [{
91
+ type: Input
92
+ }], options: [{
93
+ type: Input
94
+ }], selectUploadedFiles: [{
95
+ type: Output
96
+ }] }); })();
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdXBsb2FkL2NvbXBvbmVudHMvdXBsb2FkL3VwbG9hZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL3VwbG9hZC9jb21wb25lbnRzL3VwbG9hZC91cGxvYWQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcvRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7Ozs7O0lDZ0J0RCwyQ0FNQztJQUxDLHlNQUFpQixlQUFBLDhCQUF1QixDQUFBLElBQUM7SUFLMUMsaUJBQW1COzs7SUFIbEIsd0RBQW1DLDZCQUFBLDZCQUFBOzs7O0FEWnZDLE1BQU0sT0FBTyxlQUFlO0lBTDVCO1FBTWtCLE9BQUUsR0FBRyxFQUFFLENBQUM7UUFDUixXQUFNLEdBQUcsRUFBRSxDQUFDO1FBQ1osWUFBTyxHQUFHLEVBQUUsQ0FBQztRQUNiLG9CQUFlLEdBQUcsV0FBVyxDQUFDO1FBQzlCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsYUFBUSxHQUFHLElBQUksQ0FBQztRQUNoQixVQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ1gsZ0JBQVcsR0FBRyxFQUFFLENBQUM7UUFDakIsWUFBTyxHQUFrQixzQkFBc0IsQ0FBQztRQUMvQyx3QkFBbUIsR0FBMkIsSUFBSSxZQUFZLEVBQVksQ0FBQztRQUlyRixrQkFBYSxHQUFhLEVBQUUsQ0FBQztRQUM3QixpQkFBWSxHQUFrQixFQUFFLENBQUM7UUFDakMsZ0JBQVcsR0FBVyxFQUFFLENBQUM7S0FzQmpDO0lBcEJRLFFBQVE7UUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNaLElBQUksQ0FBQyxNQUFNLEdBQUcsYUFBYSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3RFLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQztTQUN2QjtRQUNELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFTSxlQUFlLENBQUMsS0FBZTtRQUNwQyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFTSxjQUFjLENBQUMsS0FBb0I7UUFDeEMsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7SUFDNUIsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFhO1FBQ2hDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEQsQ0FBQzs7aUdBckNVLGVBQWU7aUdBQWYsZUFBZTs7UUNYNUIsOEJBQWlDLHlCQUFBO1FBUzdCLHlIQUFnQiwwQkFBc0IsSUFBQywwR0FDeEIseUJBQXFCLElBREcsOEdBRXRCLDJCQUF1QixJQUZEO1FBTXZDLDhCQUE4QjtRQUM1QixrQkFBb0Q7UUFDdEQsaUJBQU0sRUFBQTtRQUVSLHlDQUE2RztRQUM3RywwRkFNb0I7UUFDdEIsaUJBQU07O1FBekJGLGVBQVM7UUFBVCwyQkFBUyxzQkFBQSx3QkFBQSxzQkFBQSwwQkFBQSwwQkFBQSwwQkFBQSxvQkFBQSxnQ0FBQTtRQWlCVSxlQUFtQztRQUFuQyxxREFBbUMsa0NBQUE7UUFHckQsZUFBMEI7UUFBMUIsNkVBQTBCOzt1RkRYbEIsZUFBZTtjQUwzQixTQUFTOzJCQUNFLFlBQVk7Z0JBS04sRUFBRTtrQkFBakIsS0FBSztZQUNVLE1BQU07a0JBQXJCLEtBQUs7WUFDVSxPQUFPO2tCQUF0QixLQUFLO1lBQ1UsZUFBZTtrQkFBOUIsS0FBSztZQUNVLFFBQVE7a0JBQXZCLEtBQUs7WUFDVSxRQUFRO2tCQUF2QixLQUFLO1lBQ1UsS0FBSztrQkFBcEIsS0FBSztZQUNVLFdBQVc7a0JBQTFCLEtBQUs7WUFDVSxPQUFPO2tCQUF0QixLQUFLO1lBQ1csbUJBQW1CO2tCQUFuQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBJbnZhbGlkRmlsZSwgVXBsb2FkT3B0aW9ucyB9IGZyb20gJy4uLy4uL3R5cGVzL3VwbG9hZC50eXBlcyc7XG5pbXBvcnQgeyBVUExPQURfT1BUSU9OU19ERUZBVUxUIH0gZnJvbSAnLi4vLi4vdXBsb2FkLmNvbmYnO1xuaW1wb3J0IHsgVXBsb2FkZXIgfSBmcm9tICcuLi8uLi9jbGFzc2VzL3VwbG9hZGVyLmNsYXNzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLXVwbG9hZCcsXG4gIHN0eWxlVXJsczogWycuL3VwbG9hZC5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vdXBsb2FkLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgVXBsb2FkQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgcHVibGljIGlkID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBhY2NlcHQgPSBbXTtcbiAgQElucHV0KCkgcHVibGljIGNhcHR1cmUgPSAnJztcbiAgQElucHV0KCkgcHVibGljIGFyaWFMYWJlbFJlbW92ZSA9ICdWZXJ3aWpkZXInO1xuICBASW5wdXQoKSBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbiAgQElucHV0KCkgcHVibGljIG11bHRpcGxlID0gdHJ1ZTtcbiAgQElucHV0KCkgcHVibGljIGxhYmVsID0gJyc7XG4gIEBJbnB1dCgpIHB1YmxpYyBkZXNjcmlwdGlvbiA9ICcnO1xuICBASW5wdXQoKSBwdWJsaWMgb3B0aW9uczogVXBsb2FkT3B0aW9ucyA9IFVQTE9BRF9PUFRJT05TX0RFRkFVTFQ7XG4gIEBPdXRwdXQoKSBwdWJsaWMgc2VsZWN0VXBsb2FkZWRGaWxlczogRXZlbnRFbWl0dGVyPG9iamVjdFtdPiA9IG5ldyBFdmVudEVtaXR0ZXI8b2JqZWN0W10+KCk7XG5cbiAgcHVibGljIHVwbG9hZGVyO1xuICBwdWJsaWMgYXJpYUlkO1xuICBwdWJsaWMgdXBsb2FkZWRGaWxlczogb2JqZWN0W10gPSBbXTtcbiAgcHVibGljIGludmFsaWRGaWxlczogSW52YWxpZEZpbGVbXSA9IFtdO1xuICBwdWJsaWMgcXVldWVkRmlsZXM6IEZpbGVbXSA9IFtdO1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICBpZiAoIXRoaXMuaWQpIHtcbiAgICAgIHRoaXMuYXJpYUlkID0gJ2F1aS11cGxvYWQtJyArIE1hdGgucmFuZG9tKCkudG9TdHJpbmcoMzYpLnN1YnN0cmluZygyKTtcbiAgICAgIHRoaXMuaWQgPSB0aGlzLmFyaWFJZDtcbiAgICB9XG4gICAgdGhpcy51cGxvYWRlciA9IG5ldyBVcGxvYWRlcih0aGlzLm9wdGlvbnMpO1xuICB9XG5cbiAgcHVibGljIG9uVXBsb2FkZWRGaWxlcyhmaWxlczogb2JqZWN0W10pIHtcbiAgICB0aGlzLnVwbG9hZGVkRmlsZXMgPSB0aGlzLnVwbG9hZGVkRmlsZXMuY29uY2F0KGZpbGVzKTtcbiAgICB0aGlzLnNlbGVjdFVwbG9hZGVkRmlsZXMuZW1pdCh0aGlzLnVwbG9hZGVkRmlsZXMpO1xuICB9XG5cbiAgcHVibGljIG9uSW52YWxpZEZpbGVzKGZpbGVzOiBJbnZhbGlkRmlsZVtdKSB7XG4gICAgdGhpcy5pbnZhbGlkRmlsZXMgPSBmaWxlcztcbiAgfVxuXG4gIHB1YmxpYyBvblF1ZXVlZEZpbGVzKGZpbGVzOiBGaWxlW10pIHtcbiAgICB0aGlzLnF1ZXVlZEZpbGVzID0gdGhpcy5xdWV1ZWRGaWxlcy5jb25jYXQoZmlsZXMpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibS11cGxvYWQgYXVpLXVwbG9hZFwiPlxuICA8YXVpLXVwbG9hZC16b25lXG4gICAgW2lkXT1cImlkXCJcbiAgICBbYWNjZXB0XT1cImFjY2VwdFwiXG4gICAgW2NhcHR1cmVdPVwiY2FwdHVyZVwiXG4gICAgW2FyaWFJZF09XCJhcmlhSWRcIlxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgW211bHRpcGxlXT1cIm11bHRpcGxlXCJcbiAgICBbdXBsb2FkZXJdPVwidXBsb2FkZXJcIlxuICAgIChpbnZhbGlkRmlsZXMpPVwib25JbnZhbGlkRmlsZXMoJGV2ZW50KVwiXG4gICAgKHF1ZXVlZEZpbGVzKT1cIm9uUXVldWVkRmlsZXMoJGV2ZW50KVwiXG4gICAgKHVwbG9hZGVkRmlsZXMpPVwib25VcGxvYWRlZEZpbGVzKCRldmVudClcIlxuICAgIFtsYWJlbF09XCJsYWJlbFwiXG4gICAgW2Rlc2NyaXB0aW9uXT1cImRlc2NyaXB0aW9uXCJcbiAgPlxuICAgIDxkaXYgY2xhc3M9XCJtLXVwbG9hZF9fYnV0dG9uXCI+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCIubS11cGxvYWRfX2J1dHRvblwiPjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgPC9hdWktdXBsb2FkLXpvbmU+XG4gIDxhdWktdmFsaWRhdGlvbi1saXN0IFthcmlhTGFiZWxSZW1vdmVdPVwiYXJpYUxhYmVsUmVtb3ZlXCIgW2ludmFsaWRGaWxlc109XCJpbnZhbGlkRmlsZXNcIj48L2F1aS12YWxpZGF0aW9uLWxpc3Q+XG4gIDxhdWktdXBsb2FkLXF1ZXVlXG4gICAgKHVwbG9hZGVkRmlsZXMpPVwib25VcGxvYWRlZEZpbGVzKCRldmVudClcIlxuICAgICpuZ0lmPVwiIW9wdGlvbnM/LmF1dG9VcGxvYWRcIlxuICAgIFthcmlhTGFiZWxSZW1vdmVdPVwiYXJpYUxhYmVsUmVtb3ZlXCJcbiAgICBbZmlsZXNdPVwicXVldWVkRmlsZXNcIlxuICAgIFt1cGxvYWRlcl09XCJ1cGxvYWRlclwiXG4gID48L2F1aS11cGxvYWQtcXVldWU+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,56 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../upload/upload.component";
5
+ const _c0 = [[["", 8, "m-upload__message"]], [["", 8, "m-upload__description"]], [["", 8, "m-upload__button"]]];
6
+ const _c1 = [".m-upload__message", ".m-upload__description", ".m-upload__button"];
7
+ export class UploadInputComponent {
8
+ constructor() {
9
+ this.propagateChange = (_) => undefined;
10
+ }
11
+ writeValue(value) {
12
+ }
13
+ registerOnChange(fn) {
14
+ this.propagateChange = fn;
15
+ }
16
+ registerOnTouched() {
17
+ }
18
+ onUpload(files) {
19
+ const data = (this.format ? this.format(files) : files);
20
+ this.propagateChange(data);
21
+ }
22
+ }
23
+ /** @nocollapse */ UploadInputComponent.ɵfac = function UploadInputComponent_Factory(t) { return new (t || UploadInputComponent)(); };
24
+ /** @nocollapse */ UploadInputComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: UploadInputComponent, selectors: [["aui-upload-input"]], inputs: { options: "options", format: "format" }, features: [i0.ɵɵProvidersFeature([{
25
+ provide: NG_VALUE_ACCESSOR,
26
+ useExisting: UploadInputComponent,
27
+ multi: true,
28
+ }])], ngContentSelectors: _c1, decls: 7, vars: 1, consts: [[3, "options", "selectUploadedFiles"], [1, "m-upload__message"], [1, "m-upload__description"], [1, "m-upload__button"]], template: function UploadInputComponent_Template(rf, ctx) { if (rf & 1) {
29
+ i0.ɵɵprojectionDef(_c0);
30
+ i0.ɵɵelementStart(0, "aui-upload", 0);
31
+ i0.ɵɵlistener("selectUploadedFiles", function UploadInputComponent_Template_aui_upload_selectUploadedFiles_0_listener($event) { return ctx.onUpload($event); });
32
+ i0.ɵɵelementStart(1, "div", 1);
33
+ i0.ɵɵprojection(2);
34
+ i0.ɵɵelementEnd();
35
+ i0.ɵɵelementStart(3, "div", 2);
36
+ i0.ɵɵprojection(4, 1);
37
+ i0.ɵɵelementEnd();
38
+ i0.ɵɵelementStart(5, "div", 3);
39
+ i0.ɵɵprojection(6, 2);
40
+ i0.ɵɵelementEnd()();
41
+ } if (rf & 2) {
42
+ i0.ɵɵproperty("options", ctx.options);
43
+ } }, dependencies: [i1.UploadComponent], encapsulation: 2 });
44
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UploadInputComponent, [{
45
+ type: Component,
46
+ args: [{ selector: 'aui-upload-input', providers: [{
47
+ provide: NG_VALUE_ACCESSOR,
48
+ useExisting: UploadInputComponent,
49
+ multi: true,
50
+ }], template: "<aui-upload (selectUploadedFiles)=\"onUpload($event)\" [options]=\"options\">\n <div class=\"m-upload__message\">\n <ng-content select=\".m-upload__message\"></ng-content>\n </div>\n <div class=\"m-upload__description\">\n <ng-content select=\".m-upload__description\"></ng-content>\n </div>\n <div class=\"m-upload__button\">\n <ng-content select=\".m-upload__button\"></ng-content>\n </div>\n</aui-upload>\n" }]
51
+ }], null, { options: [{
52
+ type: Input
53
+ }], format: [{
54
+ type: Input
55
+ }] }); })();
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvdXBsb2FkL2NvbXBvbmVudHMvdXBsb2FkLWlucHV0L3VwbG9hZC1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL3VwbG9hZC9jb21wb25lbnRzL3VwbG9hZC1pbnB1dC91cGxvYWQtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7OztBQWF6RSxNQUFNLE9BQU8sb0JBQW9CO0lBVGpDO1FBYVMsb0JBQWUsR0FBRyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDO0tBZ0JoRDtJQWRRLFVBQVUsQ0FBQyxLQUFVO0lBQzVCLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxFQUFFO1FBQ3hCLElBQUksQ0FBQyxlQUFlLEdBQUcsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxpQkFBaUI7SUFDakIsQ0FBQztJQUVNLFFBQVEsQ0FBQyxLQUFLO1FBQ25CLE1BQU0sSUFBSSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDOzsyR0FuQlUsb0JBQW9CO3NHQUFwQixvQkFBb0Isd0hBTnBCLENBQUM7Z0JBQ1YsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLG9CQUFvQjtnQkFDakMsS0FBSyxFQUFFLElBQUk7YUFDWixDQUFDOztRQ1pKLHFDQUF5RTtRQUE3RCx1SUFBdUIsb0JBQWdCLElBQUM7UUFDbEQsOEJBQStCO1FBQzdCLGtCQUFxRDtRQUN2RCxpQkFBTTtRQUNOLDhCQUFtQztRQUNqQyxxQkFBeUQ7UUFDM0QsaUJBQU07UUFDTiw4QkFBOEI7UUFDNUIscUJBQW9EO1FBQ3RELGlCQUFNLEVBQUE7O1FBVDZDLHFDQUFtQjs7dUZEYzNELG9CQUFvQjtjQVRoQyxTQUFTOzJCQUNFLGtCQUFrQixhQUVqQixDQUFDO3dCQUNWLE9BQU8sRUFBRSxpQkFBaUI7d0JBQzFCLFdBQVcsc0JBQXNCO3dCQUNqQyxLQUFLLEVBQUUsSUFBSTtxQkFDWixDQUFDO2dCQUdjLE9BQU87a0JBQXRCLEtBQUs7WUFDVSxNQUFNO2tCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBVcGxvYWRPcHRpb25zIH0gZnJvbSAnLi4vLi4vdHlwZXMvdXBsb2FkLnR5cGVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXVpLXVwbG9hZC1pbnB1dCcsXG4gIHRlbXBsYXRlVXJsOiAnLi91cGxvYWQtaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICBwcm92aWRlcnM6IFt7XG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgdXNlRXhpc3Rpbmc6IFVwbG9hZElucHV0Q29tcG9uZW50LFxuICAgIG11bHRpOiB0cnVlLFxuICB9XSxcbn0pXG5leHBvcnQgY2xhc3MgVXBsb2FkSW5wdXRDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gIEBJbnB1dCgpIHB1YmxpYyBvcHRpb25zOiBVcGxvYWRPcHRpb25zO1xuICBASW5wdXQoKSBwdWJsaWMgZm9ybWF0OiBhbnk7XG5cbiAgcHVibGljIHByb3BhZ2F0ZUNoYW5nZSA9IChfOiBhbnkpID0+IHVuZGVmaW5lZDtcblxuICBwdWJsaWMgd3JpdGVWYWx1ZSh2YWx1ZTogYW55KSB7XG4gIH1cblxuICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShmbikge1xuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZCgpIHtcbiAgfVxuXG4gIHB1YmxpYyBvblVwbG9hZChmaWxlcykge1xuICAgIGNvbnN0IGRhdGEgPSAodGhpcy5mb3JtYXQgPyB0aGlzLmZvcm1hdChmaWxlcykgOiBmaWxlcyk7XG4gICAgdGhpcy5wcm9wYWdhdGVDaGFuZ2UoZGF0YSk7XG4gIH1cbn1cbiIsIjxhdWktdXBsb2FkIChzZWxlY3RVcGxvYWRlZEZpbGVzKT1cIm9uVXBsb2FkKCRldmVudClcIiBbb3B0aW9uc109XCJvcHRpb25zXCI+XG4gIDxkaXYgY2xhc3M9XCJtLXVwbG9hZF9fbWVzc2FnZVwiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIi5tLXVwbG9hZF9fbWVzc2FnZVwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJtLXVwbG9hZF9fZGVzY3JpcHRpb25cIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCIubS11cGxvYWRfX2Rlc2NyaXB0aW9uXCI+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm0tdXBsb2FkX19idXR0b25cIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCIubS11cGxvYWRfX2J1dHRvblwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2F1aS11cGxvYWQ+XG4iXX0=