@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.
- package/README.md +0 -2
- package/esm2020/acpaas-ui-ngx-forms.mjs +5 -0
- package/esm2020/lib/auto-complete/auto-complete.module.mjs +25 -0
- package/esm2020/lib/auto-complete/components/auto-complete/auto-complete.component.mjs +370 -0
- package/esm2020/lib/auto-complete/public-api.mjs +3 -0
- package/esm2020/lib/datepicker/components/datepicker/datepicker.component.mjs +274 -0
- package/esm2020/lib/datepicker/datepicker.conf.mjs +9 -0
- package/esm2020/lib/datepicker/datepicker.module.mjs +55 -0
- package/esm2020/lib/datepicker/public-api.mjs +4 -0
- package/esm2020/lib/datepicker/types/datepicker.types.mjs +2 -0
- package/esm2020/lib/mask/directives/mask.directive.mjs +25 -0
- package/esm2020/lib/mask/mask.module.mjs +20 -0
- package/esm2020/lib/mask/public-api.mjs +3 -0
- package/esm2020/lib/range-slider/components/range-slider/range-slider.component.mjs +349 -0
- package/esm2020/lib/range-slider/public-api.mjs +3 -0
- package/esm2020/lib/range-slider/range-slider.module.mjs +20 -0
- package/esm2020/lib/range-slider/types/range-slider.types.mjs +2 -0
- package/esm2020/lib/search-filter/components/search-filter/search-filter.component.mjs +259 -0
- package/esm2020/lib/search-filter/public-api.mjs +3 -0
- package/esm2020/lib/search-filter/search-filter.module.mjs +22 -0
- package/esm2020/lib/search-filter/types/search-filter.types.mjs +2 -0
- package/esm2020/lib/shared/services/search.service.mjs +32 -0
- package/esm2020/lib/shared/types/search.types.mjs +2 -0
- package/esm2020/lib/timepicker/classes/timepicker.validators.mjs +49 -0
- package/esm2020/lib/timepicker/components/timepicker/timepicker.component.mjs +229 -0
- package/esm2020/lib/timepicker/public-api.mjs +5 -0
- package/esm2020/lib/timepicker/timepicker.module.mjs +22 -0
- package/esm2020/lib/timepicker/types/timepicker.types.mjs +7 -0
- package/esm2020/lib/upload/classes/uploader.class.mjs +112 -0
- package/esm2020/lib/upload/components/upload/upload.component.mjs +97 -0
- package/esm2020/lib/upload/components/upload-input/upload-input.component.mjs +56 -0
- package/esm2020/lib/upload/components/upload-queue/upload-queue.component.mjs +78 -0
- package/esm2020/lib/upload/components/upload-zone/upload-zone.component.mjs +252 -0
- package/esm2020/lib/upload/components/validation-list/validation-list.component.mjs +64 -0
- package/esm2020/lib/upload/public-api.mjs +10 -0
- package/esm2020/lib/upload/services/validation-messages.service.mjs +29 -0
- package/esm2020/lib/upload/types/upload.types.mjs +2 -0
- package/esm2020/lib/upload/upload.conf.mjs +12 -0
- package/esm2020/lib/upload/upload.module.mjs +45 -0
- package/esm2020/public-api.mjs +8 -0
- package/fesm2015/acpaas-ui-ngx-forms.mjs +2591 -0
- package/fesm2015/acpaas-ui-ngx-forms.mjs.map +1 -0
- package/fesm2020/acpaas-ui-ngx-forms.mjs +2402 -0
- package/fesm2020/acpaas-ui-ngx-forms.mjs.map +1 -0
- package/{acpaas-ui-ngx-forms.d.ts → index.d.ts} +1 -1
- package/lib/auto-complete/auto-complete.module.d.ts +10 -0
- package/lib/auto-complete/components/auto-complete/auto-complete.component.d.ts +5 -0
- package/lib/datepicker/components/datepicker/datepicker.component.d.ts +15 -8
- package/lib/datepicker/datepicker.module.d.ts +11 -1
- package/lib/datepicker/public-api.d.ts +1 -1
- package/lib/mask/directives/mask.directive.d.ts +3 -0
- package/lib/mask/mask.module.d.ts +6 -0
- package/lib/range-slider/components/range-slider/range-slider.component.d.ts +8 -2
- package/lib/range-slider/range-slider.module.d.ts +7 -0
- package/lib/search-filter/components/search-filter/search-filter.component.d.ts +10 -4
- package/lib/search-filter/search-filter.module.d.ts +9 -0
- package/lib/shared/services/search.service.d.ts +3 -0
- package/lib/timepicker/components/timepicker/timepicker.component.d.ts +9 -4
- package/lib/timepicker/timepicker.module.d.ts +8 -0
- package/lib/upload/components/upload/upload.component.d.ts +5 -0
- package/lib/upload/components/upload-input/upload-input.component.d.ts +3 -0
- package/lib/upload/components/upload-queue/upload-queue.component.d.ts +3 -0
- package/lib/upload/components/upload-zone/upload-zone.component.d.ts +7 -0
- package/lib/upload/components/validation-list/validation-list.component.d.ts +3 -0
- package/lib/upload/services/validation-messages.service.d.ts +3 -0
- package/lib/upload/upload.module.d.ts +14 -1
- package/package.json +37 -24
- package/public-api.d.ts +0 -1
- package/acpaas-ui-ngx-forms.metadata.json +0 -1
- package/bundles/acpaas-ui-ngx-forms.umd.js +0 -3854
- package/bundles/acpaas-ui-ngx-forms.umd.js.map +0 -1
- package/bundles/acpaas-ui-ngx-forms.umd.min.js +0 -2
- package/bundles/acpaas-ui-ngx-forms.umd.min.js.map +0 -1
- package/esm2015/acpaas-ui-ngx-forms.js +0 -11
- package/esm2015/lib/auto-complete/auto-complete.module.js +0 -36
- package/esm2015/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -416
- package/esm2015/lib/auto-complete/public-api.js +0 -8
- package/esm2015/lib/datepicker/components/datepicker/datepicker.component.js +0 -335
- package/esm2015/lib/datepicker/datepicker.conf.js +0 -18
- package/esm2015/lib/datepicker/datepicker.module.js +0 -59
- package/esm2015/lib/datepicker/public-api.js +0 -9
- package/esm2015/lib/datepicker/types/datepicker.types.js +0 -20
- package/esm2015/lib/mask/directives/mask.directive.js +0 -51
- package/esm2015/lib/mask/mask.module.js +0 -25
- package/esm2015/lib/mask/public-api.js +0 -8
- package/esm2015/lib/range-slider/components/range-slider/range-slider.component.js +0 -424
- package/esm2015/lib/range-slider/public-api.js +0 -8
- package/esm2015/lib/range-slider/range-slider.module.js +0 -26
- package/esm2015/lib/range-slider/types/range-slider.types.js +0 -16
- package/esm2015/lib/search-filter/components/search-filter/search-filter.component.js +0 -219
- package/esm2015/lib/search-filter/public-api.js +0 -8
- package/esm2015/lib/search-filter/search-filter.module.js +0 -30
- package/esm2015/lib/search-filter/types/search-filter.types.js +0 -16
- package/esm2015/lib/shared/services/search.service.js +0 -58
- package/esm2015/lib/shared/types/search.types.js +0 -20
- package/esm2015/lib/timepicker/classes/timepicker.validators.js +0 -84
- package/esm2015/lib/timepicker/components/timepicker/timepicker.component.js +0 -227
- package/esm2015/lib/timepicker/public-api.js +0 -10
- package/esm2015/lib/timepicker/timepicker.module.js +0 -29
- package/esm2015/lib/timepicker/types/timepicker.types.js +0 -13
- package/esm2015/lib/upload/classes/uploader.class.js +0 -189
- package/esm2015/lib/upload/components/upload/upload.component.js +0 -100
- package/esm2015/lib/upload/components/upload-input/upload-input.component.js +0 -67
- package/esm2015/lib/upload/components/upload-queue/upload-queue.component.js +0 -68
- package/esm2015/lib/upload/components/upload-zone/upload-zone.component.js +0 -219
- package/esm2015/lib/upload/components/validation-list/validation-list.component.js +0 -62
- package/esm2015/lib/upload/public-api.js +0 -15
- package/esm2015/lib/upload/services/validation-messages.service.js +0 -48
- package/esm2015/lib/upload/types/upload.types.js +0 -48
- package/esm2015/lib/upload/upload.conf.js +0 -21
- package/esm2015/lib/upload/upload.module.js +0 -62
- package/esm2015/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -158
- package/esm2015/lib/wysiwyg/public-api.js +0 -9
- package/esm2015/lib/wysiwyg/wysiwyg.conf.js +0 -24
- package/esm2015/lib/wysiwyg/wysiwyg.module.js +0 -29
- package/esm2015/public-api.js +0 -14
- package/esm5/acpaas-ui-ngx-forms.js +0 -11
- package/esm5/lib/auto-complete/auto-complete.module.js +0 -40
- package/esm5/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -506
- package/esm5/lib/auto-complete/public-api.js +0 -8
- package/esm5/lib/datepicker/components/datepicker/datepicker.component.js +0 -384
- package/esm5/lib/datepicker/datepicker.conf.js +0 -18
- package/esm5/lib/datepicker/datepicker.module.js +0 -69
- package/esm5/lib/datepicker/public-api.js +0 -9
- package/esm5/lib/datepicker/types/datepicker.types.js +0 -20
- package/esm5/lib/mask/directives/mask.directive.js +0 -58
- package/esm5/lib/mask/mask.module.js +0 -29
- package/esm5/lib/mask/public-api.js +0 -8
- package/esm5/lib/range-slider/components/range-slider/range-slider.component.js +0 -514
- package/esm5/lib/range-slider/public-api.js +0 -8
- package/esm5/lib/range-slider/range-slider.module.js +0 -30
- package/esm5/lib/range-slider/types/range-slider.types.js +0 -16
- package/esm5/lib/search-filter/components/search-filter/search-filter.component.js +0 -256
- package/esm5/lib/search-filter/public-api.js +0 -8
- package/esm5/lib/search-filter/search-filter.module.js +0 -34
- package/esm5/lib/search-filter/types/search-filter.types.js +0 -16
- package/esm5/lib/shared/services/search.service.js +0 -68
- package/esm5/lib/shared/types/search.types.js +0 -20
- package/esm5/lib/timepicker/classes/timepicker.validators.js +0 -102
- package/esm5/lib/timepicker/components/timepicker/timepicker.component.js +0 -259
- package/esm5/lib/timepicker/public-api.js +0 -10
- package/esm5/lib/timepicker/timepicker.module.js +0 -33
- package/esm5/lib/timepicker/types/timepicker.types.js +0 -13
- package/esm5/lib/upload/classes/uploader.class.js +0 -249
- package/esm5/lib/upload/components/upload/upload.component.js +0 -117
- package/esm5/lib/upload/components/upload-input/upload-input.component.js +0 -84
- package/esm5/lib/upload/components/upload-queue/upload-queue.component.js +0 -78
- package/esm5/lib/upload/components/upload-zone/upload-zone.component.js +0 -264
- package/esm5/lib/upload/components/validation-list/validation-list.component.js +0 -81
- package/esm5/lib/upload/public-api.js +0 -15
- package/esm5/lib/upload/services/validation-messages.service.js +0 -47
- package/esm5/lib/upload/types/upload.types.js +0 -48
- package/esm5/lib/upload/upload.conf.js +0 -21
- package/esm5/lib/upload/upload.module.js +0 -71
- package/esm5/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -199
- package/esm5/lib/wysiwyg/public-api.js +0 -9
- package/esm5/lib/wysiwyg/wysiwyg.conf.js +0 -24
- package/esm5/lib/wysiwyg/wysiwyg.module.js +0 -33
- package/esm5/public-api.js +0 -14
- package/fesm2015/acpaas-ui-ngx-forms.js +0 -3071
- package/fesm2015/acpaas-ui-ngx-forms.js.map +0 -1
- package/fesm5/acpaas-ui-ngx-forms.js +0 -3627
- package/fesm5/acpaas-ui-ngx-forms.js.map +0 -1
- package/lib/wysiwyg/components/wysiwyg/wysiwyg.component.d.ts +0 -43
- package/lib/wysiwyg/public-api.d.ts +0 -3
- package/lib/wysiwyg/wysiwyg.conf.d.ts +0 -18
- 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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAgC,MAAM,eAAe,CAAC;AACpH,OAAO,EAGL,kBAAkB,EAElB,iBAAiB,GAClB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;;;;;;ICT7D,8BAA+D;;;;;IAHnE,8BAAmH,eAAA;IAC1E,YAAW;IAAA,iBAAQ;IAC1D,gCAAiF;IAC/E,oFAA+D;IAC/D,YAAiB;IAAA,iBAClB;IACD,2BAKE;IACJ,iBAAM;;;IAZ0B,wCAA4B;IAAC,sEAAqC;IACzD,eAAW;IAAX,kCAAW;IACN,eAAoC;IAApC,sEAAoC;IACnE,eAAc;IAAd,sCAAc;IACzB,eAAiB;IAAjB,kDAAiB;IAIjB,eAA2B;IAA3B,gDAA2B,iBAAA;IAD3B,mFAA2D;;;IAYvD,kCAAkD;IAAA,YAAU;IAAA,iBAAS;;;IAAlC,+BAAc;IAAC,eAAU;IAAV,6BAAU;;;IAU5D,kCAAwD;IAAA,YAAY;IAAA,iBAAS;;;IAAtC,iCAAgB;IAAC,eAAY;IAAZ,+BAAY;;;IAf5E,8BAA0D,cAAA,cAAA,iBAAA,iBAAA;IAIpB,YAAsB;IAAA,iBAAS;IAC7D,iFAAqE;IACvE,iBAAS;IACT,+BAA4C;IAC9C,iBAAM,EAAA;IAGR,+BAAuG,cAAA,kBAAA,kBAAA;IAGnE,aAAwB;IAAA,iBAAS;IAC/D,mFAA6E;IAC/E,iBAAS;IACT,gCAA4C;IAC9C,iBAAM,EAAA,EAAA;;;IAlBqB,+CAA0B;IAClD,eAA4B;IAA5B,wCAA4B;IAAC,sEAAqC;IAExB,eAAS;IAAT,8BAAS;IAA5C,mDAAkC;IACV,eAAsB;IAAtB,6CAAsB;IAC3B,eAAQ;IAAR,sCAAQ;IAMlC,eAA4B;IAA5B,wCAA4B;IAAC,sEAAqC;IAE3D,eAAoC;IAApC,qDAAoC;IACZ,eAAwB;IAAxB,+CAAwB;IAC3B,eAAU;IAAV,wCAAU;;ADF/C,MAAM,OAAO,mBAAmB;IAqB9B,YAAoB,WAA+B,EAAU,QAAmB;QAA5D,gBAAW,GAAX,WAAW,CAAoB;QAAU,aAAQ,GAAR,QAAQ,CAAW;QApBhE,OAAE,GAAG,iBAAiB,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QACjE,qBAAgB,GAAG,IAAI,CAAC;QACxB,uBAAkB,GAAG,IAAI,CAAC;QAC1B,aAAQ,GAAG,KAAK,CAAC;QACjB,SAAI,GAAwB,mBAAmB,CAAC,IAAI,CAAC;QACrD,mBAAc,GAAG,KAAK,CAAC;QACvB,qBAAgB,GAAG,SAAS,CAAC;QAItC,sBAAiB,GAAG,KAAK,CAAC;QAC1B,YAAO,GAAa,EAAE,CAAC;QACvB,UAAK,GAAa,EAAE,CAAC;QAGrB,gBAAW,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAGtC,wBAAmB,GAAqB,IAAI,OAAO,EAAW,CAAC;IAEY,CAAC;IAE7E,QAAQ;QACb,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAE7B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YACzC,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,IAAI;SACd,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YAC9F,IAAI,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,OAAO,EAAE;gBACtC,IAAI,CAAC,WAAW,CAAC,GAAG,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;aAC3D;iBAAM;gBACL,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACzF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;IACtC,CAAC;IAEM,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAEvD,IAAI,KAAK,EAAE;YACT,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC3E,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SAC9E;IACH,CAAC;IAEM,gBAAgB,CAAC,QAAQ;QAC9B,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC;IAC9B,CAAC;IAEM,iBAAiB,KAAU,CAAC;IAE5B,gBAAgB,CAAC,UAAmB;QACzC,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC/C,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACjD;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9C,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SAChD;IACH,CAAC;IAEO,wBAAwB;QAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACrD,OAAO,CAAC,IAAI,GAAG,MAAM,CAAC;QAEtB,OAAO,OAAO,CAAC,IAAI,KAAK,MAAM,CAAC;IACjC,CAAC;IAEO,UAAU;QAChB,OAAO,KAAK,CAAC,EAAE,CAAC;aACb,IAAI,CAAC,EAAE,CAAC;aACR,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACpB,OAAO,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,QAAQ;QACd,OAAO,KAAK,CAAC,EAAE,CAAC;aACb,IAAI,CAAC,EAAE,CAAC;aACR,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;YACpB,OAAO,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACP,CAAC;;yGAlGU,mBAAmB;qGAAnB,mBAAmB,kUARnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,CAAC,mBAAmB,EAAC;gBAClD,KAAK,EAAE,IAAI;aACZ;SACF;QC1BH,8BAA0B;QACxB,qEAYM;QAEN,sEAoBM;QACR,iBAAM;;QAnCE,eAAwB;QAAxB,6CAAwB;QAcxB,eAAuB;QAAvB,4CAAuB;;uFDalB,mBAAmB;cAb/B,SAAS;2BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,aACpC;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,EAAC,GAAG,EAAE,oBAAoB,EAAC;wBAClD,KAAK,EAAE,IAAI;qBACZ;iBACF;6FAGe,EAAE;kBAAjB,KAAK;YACU,gBAAgB;kBAA/B,KAAK;YACU,kBAAkB;kBAAjC,KAAK;YACU,QAAQ;kBAAvB,KAAK;YACU,IAAI;kBAAnB,KAAK;YACU,cAAc;kBAA7B,KAAK;YACU,gBAAgB;kBAA/B,KAAK;YACU,KAAK;kBAApB,KAAK;YACU,WAAW;kBAA1B,KAAK","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=
|