@acpaas-ui/ngx-forms 6.1.9 → 6.1.10

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 (161) hide show
  1. package/.eslintrc.json +42 -0
  2. package/LICENSE.md +21 -0
  3. package/dist/README.md +23 -0
  4. package/dist/esm2020/lib/datepicker/components/datepicker/datepicker.component.mjs +232 -0
  5. package/{fesm2015 → dist/fesm2015}/acpaas-ui-ngx-forms.mjs +7 -4
  6. package/dist/fesm2015/acpaas-ui-ngx-forms.mjs.map +1 -0
  7. package/{fesm2020 → dist/fesm2020}/acpaas-ui-ngx-forms.mjs +7 -4
  8. package/dist/fesm2020/acpaas-ui-ngx-forms.mjs.map +1 -0
  9. package/dist/package.json +44 -0
  10. package/karma.conf.js +38 -0
  11. package/ng-package.json +8 -0
  12. package/package.json +6 -27
  13. package/src/lib/auto-complete/README.md +148 -0
  14. package/src/lib/auto-complete/auto-complete.module.ts +15 -0
  15. package/src/lib/auto-complete/components/auto-complete/auto-complete.component.html +51 -0
  16. package/src/lib/auto-complete/components/auto-complete/auto-complete.component.scss +4 -0
  17. package/src/lib/auto-complete/components/auto-complete/auto-complete.component.spec.ts +378 -0
  18. package/src/lib/auto-complete/components/auto-complete/auto-complete.component.ts +281 -0
  19. package/src/lib/auto-complete/public-api.ts +2 -0
  20. package/src/lib/datepicker/README.md +110 -0
  21. package/src/lib/datepicker/components/datepicker/datepicker.component.html +47 -0
  22. package/src/lib/datepicker/components/datepicker/datepicker.component.scss +13 -0
  23. package/src/lib/datepicker/components/datepicker/datepicker.component.spec.ts +204 -0
  24. package/src/lib/datepicker/components/datepicker/datepicker.component.ts +251 -0
  25. package/src/lib/datepicker/datepicker.conf.ts +11 -0
  26. package/src/lib/datepicker/datepicker.module.ts +50 -0
  27. package/src/lib/datepicker/public-api.ts +8 -0
  28. package/src/lib/datepicker/types/datepicker.types.ts +8 -0
  29. package/src/lib/range-slider/README.md +56 -0
  30. package/src/lib/range-slider/components/range-slider/range-slider.component.html +46 -0
  31. package/src/lib/range-slider/components/range-slider/range-slider.component.scss +12 -0
  32. package/src/lib/range-slider/components/range-slider/range-slider.component.spec.ts +216 -0
  33. package/src/lib/range-slider/components/range-slider/range-slider.component.ts +301 -0
  34. package/src/lib/range-slider/public-api.ts +3 -0
  35. package/src/lib/range-slider/range-slider.module.ts +11 -0
  36. package/src/lib/range-slider/types/range-slider.types.ts +4 -0
  37. package/src/lib/search-filter/README.md +86 -0
  38. package/src/lib/search-filter/components/search-filter/search-filter.component.html +66 -0
  39. package/src/lib/search-filter/components/search-filter/search-filter.component.scss +23 -0
  40. package/src/lib/search-filter/components/search-filter/search-filter.component.spec.ts +264 -0
  41. package/src/lib/search-filter/components/search-filter/search-filter.component.ts +140 -0
  42. package/src/lib/search-filter/public-api.ts +3 -0
  43. package/src/lib/search-filter/search-filter.module.ts +13 -0
  44. package/src/lib/search-filter/types/search-filter.types.ts +4 -0
  45. package/src/lib/shared/services/search.service.spec.ts +78 -0
  46. package/src/lib/shared/services/search.service.ts +32 -0
  47. package/src/lib/shared/types/search.types.ts +6 -0
  48. package/src/lib/timepicker/README.md +84 -0
  49. package/src/lib/timepicker/classes/timepicker.validators.spec.ts +54 -0
  50. package/src/lib/timepicker/classes/timepicker.validators.ts +61 -0
  51. package/src/lib/timepicker/components/timepicker/timepicker.component.html +37 -0
  52. package/src/lib/timepicker/components/timepicker/timepicker.component.scss +3 -0
  53. package/src/lib/timepicker/components/timepicker/timepicker.component.spec.ts +161 -0
  54. package/src/lib/timepicker/components/timepicker/timepicker.component.ts +128 -0
  55. package/src/lib/timepicker/public-api.ts +4 -0
  56. package/src/lib/timepicker/timepicker.module.ts +13 -0
  57. package/src/lib/timepicker/types/timepicker.types.ts +5 -0
  58. package/src/lib/upload/README.md +283 -0
  59. package/src/lib/upload/classes/uploader.class.spec.ts +100 -0
  60. package/src/lib/upload/classes/uploader.class.ts +144 -0
  61. package/src/lib/upload/components/upload/upload.component.html +28 -0
  62. package/src/lib/upload/components/upload/upload.component.scss +3 -0
  63. package/src/lib/upload/components/upload/upload.component.spec.ts +117 -0
  64. package/src/lib/upload/components/upload/upload.component.ts +50 -0
  65. package/src/lib/upload/components/upload-input/upload-input.component.html +11 -0
  66. package/src/lib/upload/components/upload-input/upload-input.component.spec.ts +55 -0
  67. package/src/lib/upload/components/upload-input/upload-input.component.ts +35 -0
  68. package/src/lib/upload/components/upload-queue/upload-queue.component.html +16 -0
  69. package/src/lib/upload/components/upload-queue/upload-queue.component.spec.ts +99 -0
  70. package/src/lib/upload/components/upload-queue/upload-queue.component.ts +36 -0
  71. package/src/lib/upload/components/upload-zone/upload-zone.component.html +55 -0
  72. package/src/lib/upload/components/upload-zone/upload-zone.component.scss +3 -0
  73. package/src/lib/upload/components/upload-zone/upload-zone.component.spec.ts +144 -0
  74. package/src/lib/upload/components/upload-zone/upload-zone.component.ts +142 -0
  75. package/src/lib/upload/components/validation-list/validation-list.component.html +15 -0
  76. package/src/lib/upload/components/validation-list/validation-list.component.spec.ts +57 -0
  77. package/src/lib/upload/components/validation-list/validation-list.component.ts +29 -0
  78. package/src/lib/upload/public-api.ts +10 -0
  79. package/src/lib/upload/services/validation-messages.service.spec.ts +66 -0
  80. package/src/lib/upload/services/validation-messages.service.ts +27 -0
  81. package/src/lib/upload/types/upload.types.ts +20 -0
  82. package/src/lib/upload/upload.conf.ts +15 -0
  83. package/src/lib/upload/upload.module.ts +34 -0
  84. package/src/public-api.ts +6 -0
  85. package/src/test.ts +9 -0
  86. package/tsconfig.lib.json +26 -0
  87. package/tsconfig.spec.json +17 -0
  88. package/esm2020/lib/datepicker/components/datepicker/datepicker.component.mjs +0 -229
  89. package/fesm2015/acpaas-ui-ngx-forms.mjs.map +0 -1
  90. package/fesm2020/acpaas-ui-ngx-forms.mjs.map +0 -1
  91. /package/{esm2020 → dist/esm2020}/acpaas-ui-ngx-forms.mjs +0 -0
  92. /package/{esm2020 → dist/esm2020}/lib/auto-complete/auto-complete.module.mjs +0 -0
  93. /package/{esm2020 → dist/esm2020}/lib/auto-complete/components/auto-complete/auto-complete.component.mjs +0 -0
  94. /package/{esm2020 → dist/esm2020}/lib/auto-complete/public-api.mjs +0 -0
  95. /package/{esm2020 → dist/esm2020}/lib/datepicker/datepicker.conf.mjs +0 -0
  96. /package/{esm2020 → dist/esm2020}/lib/datepicker/datepicker.module.mjs +0 -0
  97. /package/{esm2020 → dist/esm2020}/lib/datepicker/public-api.mjs +0 -0
  98. /package/{esm2020 → dist/esm2020}/lib/datepicker/types/datepicker.types.mjs +0 -0
  99. /package/{esm2020 → dist/esm2020}/lib/range-slider/components/range-slider/range-slider.component.mjs +0 -0
  100. /package/{esm2020 → dist/esm2020}/lib/range-slider/public-api.mjs +0 -0
  101. /package/{esm2020 → dist/esm2020}/lib/range-slider/range-slider.module.mjs +0 -0
  102. /package/{esm2020 → dist/esm2020}/lib/range-slider/types/range-slider.types.mjs +0 -0
  103. /package/{esm2020 → dist/esm2020}/lib/search-filter/components/search-filter/search-filter.component.mjs +0 -0
  104. /package/{esm2020 → dist/esm2020}/lib/search-filter/public-api.mjs +0 -0
  105. /package/{esm2020 → dist/esm2020}/lib/search-filter/search-filter.module.mjs +0 -0
  106. /package/{esm2020 → dist/esm2020}/lib/search-filter/types/search-filter.types.mjs +0 -0
  107. /package/{esm2020 → dist/esm2020}/lib/shared/services/search.service.mjs +0 -0
  108. /package/{esm2020 → dist/esm2020}/lib/shared/types/search.types.mjs +0 -0
  109. /package/{esm2020 → dist/esm2020}/lib/timepicker/classes/timepicker.validators.mjs +0 -0
  110. /package/{esm2020 → dist/esm2020}/lib/timepicker/components/timepicker/timepicker.component.mjs +0 -0
  111. /package/{esm2020 → dist/esm2020}/lib/timepicker/public-api.mjs +0 -0
  112. /package/{esm2020 → dist/esm2020}/lib/timepicker/timepicker.module.mjs +0 -0
  113. /package/{esm2020 → dist/esm2020}/lib/timepicker/types/timepicker.types.mjs +0 -0
  114. /package/{esm2020 → dist/esm2020}/lib/upload/classes/uploader.class.mjs +0 -0
  115. /package/{esm2020 → dist/esm2020}/lib/upload/components/upload/upload.component.mjs +0 -0
  116. /package/{esm2020 → dist/esm2020}/lib/upload/components/upload-input/upload-input.component.mjs +0 -0
  117. /package/{esm2020 → dist/esm2020}/lib/upload/components/upload-queue/upload-queue.component.mjs +0 -0
  118. /package/{esm2020 → dist/esm2020}/lib/upload/components/upload-zone/upload-zone.component.mjs +0 -0
  119. /package/{esm2020 → dist/esm2020}/lib/upload/components/validation-list/validation-list.component.mjs +0 -0
  120. /package/{esm2020 → dist/esm2020}/lib/upload/public-api.mjs +0 -0
  121. /package/{esm2020 → dist/esm2020}/lib/upload/services/validation-messages.service.mjs +0 -0
  122. /package/{esm2020 → dist/esm2020}/lib/upload/types/upload.types.mjs +0 -0
  123. /package/{esm2020 → dist/esm2020}/lib/upload/upload.conf.mjs +0 -0
  124. /package/{esm2020 → dist/esm2020}/lib/upload/upload.module.mjs +0 -0
  125. /package/{esm2020 → dist/esm2020}/public-api.mjs +0 -0
  126. /package/{index.d.ts → dist/index.d.ts} +0 -0
  127. /package/{lib → dist/lib}/auto-complete/auto-complete.module.d.ts +0 -0
  128. /package/{lib → dist/lib}/auto-complete/components/auto-complete/auto-complete.component.d.ts +0 -0
  129. /package/{lib → dist/lib}/auto-complete/public-api.d.ts +0 -0
  130. /package/{lib → dist/lib}/datepicker/components/datepicker/datepicker.component.d.ts +0 -0
  131. /package/{lib → dist/lib}/datepicker/datepicker.conf.d.ts +0 -0
  132. /package/{lib → dist/lib}/datepicker/datepicker.module.d.ts +0 -0
  133. /package/{lib → dist/lib}/datepicker/public-api.d.ts +0 -0
  134. /package/{lib → dist/lib}/datepicker/types/datepicker.types.d.ts +0 -0
  135. /package/{lib → dist/lib}/range-slider/components/range-slider/range-slider.component.d.ts +0 -0
  136. /package/{lib → dist/lib}/range-slider/public-api.d.ts +0 -0
  137. /package/{lib → dist/lib}/range-slider/range-slider.module.d.ts +0 -0
  138. /package/{lib → dist/lib}/range-slider/types/range-slider.types.d.ts +0 -0
  139. /package/{lib → dist/lib}/search-filter/components/search-filter/search-filter.component.d.ts +0 -0
  140. /package/{lib → dist/lib}/search-filter/public-api.d.ts +0 -0
  141. /package/{lib → dist/lib}/search-filter/search-filter.module.d.ts +0 -0
  142. /package/{lib → dist/lib}/search-filter/types/search-filter.types.d.ts +0 -0
  143. /package/{lib → dist/lib}/shared/services/search.service.d.ts +0 -0
  144. /package/{lib → dist/lib}/shared/types/search.types.d.ts +0 -0
  145. /package/{lib → dist/lib}/timepicker/classes/timepicker.validators.d.ts +0 -0
  146. /package/{lib → dist/lib}/timepicker/components/timepicker/timepicker.component.d.ts +0 -0
  147. /package/{lib → dist/lib}/timepicker/public-api.d.ts +0 -0
  148. /package/{lib → dist/lib}/timepicker/timepicker.module.d.ts +0 -0
  149. /package/{lib → dist/lib}/timepicker/types/timepicker.types.d.ts +0 -0
  150. /package/{lib → dist/lib}/upload/classes/uploader.class.d.ts +0 -0
  151. /package/{lib → dist/lib}/upload/components/upload/upload.component.d.ts +0 -0
  152. /package/{lib → dist/lib}/upload/components/upload-input/upload-input.component.d.ts +0 -0
  153. /package/{lib → dist/lib}/upload/components/upload-queue/upload-queue.component.d.ts +0 -0
  154. /package/{lib → dist/lib}/upload/components/upload-zone/upload-zone.component.d.ts +0 -0
  155. /package/{lib → dist/lib}/upload/components/validation-list/validation-list.component.d.ts +0 -0
  156. /package/{lib → dist/lib}/upload/public-api.d.ts +0 -0
  157. /package/{lib → dist/lib}/upload/services/validation-messages.service.d.ts +0 -0
  158. /package/{lib → dist/lib}/upload/types/upload.types.d.ts +0 -0
  159. /package/{lib → dist/lib}/upload/upload.conf.d.ts +0 -0
  160. /package/{lib → dist/lib}/upload/upload.module.d.ts +0 -0
  161. /package/{public-api.d.ts → dist/public-api.d.ts} +0 -0
package/.eslintrc.json ADDED
@@ -0,0 +1,42 @@
1
+ {
2
+ "extends": "../../.eslintrc.json",
3
+ "ignorePatterns": [
4
+ "!**/*"
5
+ ],
6
+ "overrides": [
7
+ {
8
+ "files": [
9
+ "*.ts"
10
+ ],
11
+ "parserOptions": {
12
+ "project": [
13
+ "packages/ngx-forms/tsconfig.(lib|spec).json"
14
+ ]
15
+ },
16
+ "rules": {
17
+ "@angular-eslint/directive-selector": [
18
+ "error",
19
+ {
20
+ "type": "attribute",
21
+ "prefix": "aui",
22
+ "style": "camelCase"
23
+ }
24
+ ],
25
+ "@angular-eslint/component-selector": [
26
+ "error",
27
+ {
28
+ "type": "element",
29
+ "prefix": "aui",
30
+ "style": "kebab-case"
31
+ }
32
+ ]
33
+ }
34
+ },
35
+ {
36
+ "files": [
37
+ "*.html"
38
+ ],
39
+ "rules": {}
40
+ }
41
+ ]
42
+ }
package/LICENSE.md ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2016-present Digipolis
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/README.md ADDED
@@ -0,0 +1,23 @@
1
+ # @acpaas-ui/ngx-forms
2
+
3
+ The forms module is a collection of several forms-related modules, like an autocomplete, a datepicker, a range slider, a timepicker, etc.
4
+ You can find an overview in the [Modules](#modules) section below.
5
+
6
+ ## Documentation
7
+
8
+ Visit our [documentation site](https://antwerp-ui.digipolis.be/) for full how-to docs and guidelines
9
+
10
+ ## <a name="modules"></a>Modules
11
+
12
+ | Name | Description | Documentation |
13
+ | -------------------- | --------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------ |
14
+ | `AutoCompleteModule` | This module creates an input field with autocomplete functionality. | [Documentation](src/lib/auto-complete/README.md) |
15
+ | `DatepickerModule` | This package allows the user to select a date either by input or by picking one in the calendar flyout. | [Documentation](src/lib/datepicker/README.md) |
16
+ | `RangeSliderModule` | This module provides a range slider. | [Documentation](src/lib/range-slider/README.md) |
17
+ | `SearchFilterModule` | This package allows the user to use a JIRA-like filter component with remote search capabilities. | [Documentation](src/lib/search-filter/README.md) |
18
+ | `TimepickerModule` | This package allows the user set the time either by choosing a slot in the dropdown or by typing in the autocomplete field. | [Documentation](src/lib/timepicker/README.md) |
19
+ | `UploadModule` | This module provides a couple of upload components and a specific `Uploader` class. | [Documentation](src/lib/upload/README.md) |
20
+
21
+ ## Contributing
22
+
23
+ Visit our [Contribution Guidelines](../../CONTRIBUTING.md) for more information on how to contribute.
@@ -0,0 +1,232 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Output, ViewChild, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
5
+ import { DateHelper } from '@acpaas-ui/ngx-utils';
6
+ import { TZDate } from '@date-fns/tz';
7
+ import { FlyoutDirective } from '@acpaas-ui/ngx-flyout';
8
+ import { CALENDAR_DEFAULT_MONTH_LABELS, CALENDAR_DEFAULT_WEEKDAY_LABELS, CALENDAR_MONTH_LABELS, CALENDAR_WEEKDAY_LABELS, } from '@acpaas-ui/ngx-calendar';
9
+ import { DATEPICKER_DEFAULT_ERROR_LABELS, DATEPICKER_ERROR_LABELS, } from '../../datepicker.conf';
10
+ import { IntervalBuilder } from '@acpaas-ui/ngx-utils';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@acpaas-ui/ngx-calendar";
13
+ import * as i2 from "@angular/forms";
14
+ import * as i3 from "@angular/common";
15
+ import * as i4 from "@acpaas-ui/ngx-icon";
16
+ import * as i5 from "@acpaas-ui/ngx-flyout";
17
+ export class DatepickerComponent {
18
+ constructor(moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS, moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS, errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS, calendarService, formBuilder, ref) {
19
+ this.moduleMonthLabels = moduleMonthLabels;
20
+ this.moduleWeekdayLabels = moduleWeekdayLabels;
21
+ this.errorLabels = errorLabels;
22
+ this.calendarService = calendarService;
23
+ this.formBuilder = formBuilder;
24
+ this.ref = ref;
25
+ this.placeholder = 'dd/mm/yyyy';
26
+ this.ariaOpenDatepickerLabel = 'Open kalender';
27
+ // eslint-disable-next-line @angular-eslint/no-output-native
28
+ this.blur = new EventEmitter();
29
+ this.isDisabled = false;
30
+ this.componentDestroyed$ = new Subject();
31
+ this.onChange = () => undefined;
32
+ this.onTouched = () => undefined;
33
+ }
34
+ ngOnInit() {
35
+ this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;
36
+ this.monthLabels = this.monthLabels || this.moduleMonthLabels;
37
+ this.createInterval();
38
+ this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });
39
+ this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {
40
+ if (value) {
41
+ const date = DateHelper.parseDate(value, 'dd/MM/yyyy');
42
+ if (date instanceof Date) {
43
+ this.selectedDate = date;
44
+ const brusselsDate = new TZDate(date, 'Europe/Brussels');
45
+ const year = brusselsDate.getFullYear();
46
+ const month = brusselsDate.getMonth();
47
+ const day = brusselsDate.getDate();
48
+ this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));
49
+ }
50
+ else if (typeof date === 'string') {
51
+ this.onChange(value);
52
+ }
53
+ else {
54
+ this.onChange(value);
55
+ }
56
+ }
57
+ else {
58
+ this.selectedDate = null;
59
+ this.onChange('');
60
+ }
61
+ });
62
+ }
63
+ ngOnChanges(changes) {
64
+ if (changes.min || changes.max) {
65
+ this.createInterval();
66
+ }
67
+ }
68
+ ngOnDestroy() {
69
+ this.componentDestroyed$.next(true);
70
+ this.componentDestroyed$.complete();
71
+ }
72
+ createInterval() {
73
+ if (!this.min && !this.max) {
74
+ return;
75
+ }
76
+ // Create an interval if min/max is filled in
77
+ this.interval = IntervalBuilder.dateInterval(this.min ? new Date(this.min) : null, this.max ? new Date(this.max) : null)
78
+ .not()
79
+ .build();
80
+ }
81
+ writeValue(value) {
82
+ if (typeof value === 'string') {
83
+ if (this.isISODateFormat(value)) {
84
+ this.selectedDate = DateHelper.parseDate(value);
85
+ }
86
+ else {
87
+ const parsed = DateHelper.parseDate(value, 'dd/MM/yyyy');
88
+ this.selectedDate = parsed instanceof Date ? parsed : null;
89
+ }
90
+ }
91
+ else if (value instanceof Date) {
92
+ this.selectedDate = value;
93
+ }
94
+ else {
95
+ this.selectedDate = null;
96
+ }
97
+ const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';
98
+ this.formControl.setValue(dateString);
99
+ }
100
+ registerOnChange(onChange) {
101
+ this.onChange = onChange;
102
+ }
103
+ registerOnTouched(onTouched) {
104
+ this.onTouched = onTouched;
105
+ }
106
+ setDisabledState(isDisabled) {
107
+ this.isDisabled = isDisabled;
108
+ if (this.formControl) {
109
+ if (isDisabled && this.formControl.enabled) {
110
+ this.formControl.disable();
111
+ }
112
+ else if (!isDisabled && this.formControl.disabled) {
113
+ this.formControl.enable();
114
+ }
115
+ }
116
+ this.ref.markForCheck();
117
+ }
118
+ selectDateFromCalendar(result) {
119
+ if (result.complete) {
120
+ this.formControl.setValue(this.formatDate(result.date));
121
+ this.flyout.close();
122
+ }
123
+ }
124
+ formatDate(date) {
125
+ return DateHelper.formatDate(date, 'DD/MM/YYYY', {
126
+ leadingZero: true,
127
+ monthLabels: this.monthLabels,
128
+ weekdayLabels: this.weekdayLabels,
129
+ });
130
+ }
131
+ validate(ctrl) {
132
+ // no error on empty value (add required validator in app)
133
+ if (ctrl.value === '' || ctrl.value === null) {
134
+ return null;
135
+ }
136
+ // throw format error if no valid date was provided
137
+ const date = DateHelper.parseDate(ctrl.value);
138
+ if (!date) {
139
+ return {
140
+ format: this.errorLabels.ERRORS_INVALID_DATE,
141
+ };
142
+ }
143
+ // no error if valid date an no range provided
144
+ if (!this.range || !this.range.length) {
145
+ return null;
146
+ }
147
+ // throw error when out of range
148
+ const range = this.calendarService.getRangeForDate(date, this.range);
149
+ return range.indexOf(date.getDate()) >= 0
150
+ ? {
151
+ range: this.errorLabels.ERRORS_INVALID_RANGE,
152
+ }
153
+ : null;
154
+ }
155
+ handleBlur(e) {
156
+ this.blur.emit(e);
157
+ this.onTouched(e);
158
+ }
159
+ isISODateFormat(value) {
160
+ if (typeof value !== 'string') {
161
+ return false;
162
+ }
163
+ return value.match(/\d{4}-\d{2}-\d{2}T.*/);
164
+ }
165
+ }
166
+ /** @nocollapse */ DatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatepickerComponent, deps: [{ token: CALENDAR_MONTH_LABELS }, { token: CALENDAR_WEEKDAY_LABELS }, { token: DATEPICKER_ERROR_LABELS }, { token: i1.CalendarService }, { token: i2.UntypedFormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
167
+ /** @nocollapse */ DatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DatepickerComponent, selector: "aui-datepicker", inputs: { id: "id", name: "name", placeholder: "placeholder", label: "label", description: "description", range: "range", min: "min", max: "max", autocomplete: "autocomplete", weekdayLabels: "weekdayLabels", monthLabels: "monthLabels", ariaOpenDatepickerLabel: "ariaOpenDatepickerLabel" }, outputs: { blur: "blur" }, providers: [
168
+ {
169
+ provide: NG_VALUE_ACCESSOR,
170
+ useExisting: forwardRef((() => DatepickerComponent)),
171
+ multi: true,
172
+ },
173
+ {
174
+ provide: NG_VALIDATORS,
175
+ useExisting: forwardRef((() => DatepickerComponent)),
176
+ multi: true,
177
+ },
178
+ ], viewQueries: [{ propertyName: "flyout", first: true, predicate: FlyoutDirective, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n <label class=\"a-input__label\" for=\"{{ id }}\" *ngIf=\"label\">{{ label }}</label>\n <small class=\"a-input__description\" *ngIf=\"description\"> {{ description }}</small>\n <div class=\"a-input__wrapper\">\n <input\n (blur)=\"handleBlur($event)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [autocomplete]=\"autocomplete\"\n [formControl]=\"formControl\"\n id=\"{{ id }}\"\n label=\"Pick date\"\n description=\"Description\"\n name=\"{{ name }}\"\n placeholder=\"{{ placeholder }}\"\n type=\"text\"\n />\n <ng-container *ngIf=\"isDisabled\">\n <aui-icon\n name=\"ai-calendar\"\n />\n </ng-container>\n <ng-container *ngIf=\"!isDisabled\">\n <aui-icon\n auiFlyoutAction\n [openOnFocus]=\"false\"\n name=\"ai-calendar\"\n className=\"is-clickable\"\n role=\"button\"\n [attr.aria-label]=\"ariaOpenDatepickerLabel\"\n tabindex=\"0\"\n />\n </ng-container>\n\n <ng-container *ngIf=\"!isDisabled\">\n <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n <aui-calendar\n (selectDate)=\"selectDateFromCalendar($event)\"\n [range]=\"range\"\n [selectedDate]=\"selectedDate\"\n [interval]=\"interval\"\n [weekdayLabels]=\"weekdayLabels\"\n [monthLabels]=\"monthLabels\"\n ></aui-calendar>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [":host,.aui-datepicker{display:block}.m-flyout.is-open .m-datepicker{opacity:1;transform:translateY(calc(var(--BORDER-WIDTH) * -1));transition-delay:0s;visibility:visible}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i1.CalendarComponent, selector: "aui-calendar", inputs: ["ariaPreviousLabels", "ariaNextLabels", "selectedDate", "range", "interval", "weekdayLabels", "monthLabels"], outputs: ["selectDate"] }, { kind: "component", type: i4.IconComponent, selector: "aui-icon", inputs: ["name", "ariaLabel", "className"] }, { kind: "directive", type: i5.FlyoutActionDirective, selector: "[auiFlyoutAction]", inputs: ["openOnFocus", "disabled"], exportAs: ["auiFlyoutAction"] }, { kind: "directive", type: i5.FlyoutZoneDirective, selector: "[auiFlyoutZone]", inputs: ["auiFlyoutZone"], exportAs: ["auiFlyoutZone"] }, { kind: "directive", type: i5.FlyoutDirective, selector: "[auiFlyout]", inputs: ["size", "align", "toggleClick", "activateOnFocus"], outputs: ["opened", "closed"], exportAs: ["auiFlyout"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
179
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DatepickerComponent, decorators: [{
180
+ type: Component,
181
+ args: [{ selector: 'aui-datepicker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
182
+ {
183
+ provide: NG_VALUE_ACCESSOR,
184
+ useExisting: forwardRef((() => DatepickerComponent)),
185
+ multi: true,
186
+ },
187
+ {
188
+ provide: NG_VALIDATORS,
189
+ useExisting: forwardRef((() => DatepickerComponent)),
190
+ multi: true,
191
+ },
192
+ ], template: "<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n <label class=\"a-input__label\" for=\"{{ id }}\" *ngIf=\"label\">{{ label }}</label>\n <small class=\"a-input__description\" *ngIf=\"description\"> {{ description }}</small>\n <div class=\"a-input__wrapper\">\n <input\n (blur)=\"handleBlur($event)\"\n [attr.disabled]=\"isDisabled ? true : null\"\n [autocomplete]=\"autocomplete\"\n [formControl]=\"formControl\"\n id=\"{{ id }}\"\n label=\"Pick date\"\n description=\"Description\"\n name=\"{{ name }}\"\n placeholder=\"{{ placeholder }}\"\n type=\"text\"\n />\n <ng-container *ngIf=\"isDisabled\">\n <aui-icon\n name=\"ai-calendar\"\n />\n </ng-container>\n <ng-container *ngIf=\"!isDisabled\">\n <aui-icon\n auiFlyoutAction\n [openOnFocus]=\"false\"\n name=\"ai-calendar\"\n className=\"is-clickable\"\n role=\"button\"\n [attr.aria-label]=\"ariaOpenDatepickerLabel\"\n tabindex=\"0\"\n />\n </ng-container>\n\n <ng-container *ngIf=\"!isDisabled\">\n <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n <aui-calendar\n (selectDate)=\"selectDateFromCalendar($event)\"\n [range]=\"range\"\n [selectedDate]=\"selectedDate\"\n [interval]=\"interval\"\n [weekdayLabels]=\"weekdayLabels\"\n [monthLabels]=\"monthLabels\"\n ></aui-calendar>\n </div>\n </ng-container>\n </div>\n</div>\n", styles: [":host,.aui-datepicker{display:block}.m-flyout.is-open .m-datepicker{opacity:1;transform:translateY(calc(var(--BORDER-WIDTH) * -1));transition-delay:0s;visibility:visible}\n"] }]
193
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
194
+ type: Inject,
195
+ args: [CALENDAR_MONTH_LABELS]
196
+ }] }, { type: undefined, decorators: [{
197
+ type: Inject,
198
+ args: [CALENDAR_WEEKDAY_LABELS]
199
+ }] }, { type: undefined, decorators: [{
200
+ type: Inject,
201
+ args: [DATEPICKER_ERROR_LABELS]
202
+ }] }, { type: i1.CalendarService }, { type: i2.UntypedFormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { flyout: [{
203
+ type: ViewChild,
204
+ args: [FlyoutDirective, { static: true }]
205
+ }], id: [{
206
+ type: Input
207
+ }], name: [{
208
+ type: Input
209
+ }], placeholder: [{
210
+ type: Input
211
+ }], label: [{
212
+ type: Input
213
+ }], description: [{
214
+ type: Input
215
+ }], range: [{
216
+ type: Input
217
+ }], min: [{
218
+ type: Input
219
+ }], max: [{
220
+ type: Input
221
+ }], autocomplete: [{
222
+ type: Input
223
+ }], weekdayLabels: [{
224
+ type: Input
225
+ }], monthLabels: [{
226
+ type: Input
227
+ }], ariaOpenDatepickerLabel: [{
228
+ type: Input
229
+ }], blur: [{
230
+ type: Output
231
+ }] } });
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.ts","../../../../../../src/lib/datepicker/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  ControlValueAccessor,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { DateHelper, DateRange } from '@acpaas-ui/ngx-utils';\nimport { TZDate } from '@date-fns/tz';\nimport { FlyoutDirective } from '@acpaas-ui/ngx-flyout';\nimport {\n  CALENDAR_DEFAULT_MONTH_LABELS,\n  CALENDAR_DEFAULT_WEEKDAY_LABELS,\n  CALENDAR_MONTH_LABELS,\n  CALENDAR_WEEKDAY_LABELS,\n  CalendarService,\n  DatepickerResult,\n  WeekdayLabelsConfig,\n  MonthLabelsConfig,\n} from '@acpaas-ui/ngx-calendar';\n\nimport {\n  DATEPICKER_SEPARATOR_CHAR,\n  DATEPICKER_DEFAULT_ERROR_LABELS,\n  DATEPICKER_ERROR_LABELS,\n} from '../../datepicker.conf';\nimport { DatepickerValidationErrors } from '../../types/datepicker.types';\nimport { Interval, IntervalBuilder } from '@acpaas-ui/ngx-utils';\n\n@Component({\n  selector: 'aui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatepickerComponent), // eslint-disable-line @angular-eslint/no-forward-ref\n      multi: true,\n    },\n  ],\n})\nexport class DatepickerComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor {\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @Input() id: string;\n  @Input() name: string;\n  @Input() placeholder = 'dd/mm/yyyy';\n  @Input() label: string;\n  @Input() description: string;\n  @Input() range: DateRange;\n  @Input()\n  min: Date | null;\n  @Input()\n  max: Date | null;\n  @Input() autocomplete: 'off';\n  @Input() weekdayLabels: WeekdayLabelsConfig;\n  @Input() monthLabels: MonthLabelsConfig;\n  @Input() ariaOpenDatepickerLabel = 'Open kalender';\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() blur = new EventEmitter<Event>();\n\n  public formControl: UntypedFormControl;\n  public selectedDate: Date;\n  public isDisabled = false;\n  public interval: Interval.IInterval<Date>;\n\n  private componentDestroyed$: Subject<boolean> = new Subject<boolean>();\n\n  constructor(\n    @Inject(CALENDAR_MONTH_LABELS) private moduleMonthLabels = CALENDAR_DEFAULT_MONTH_LABELS,\n    @Inject(CALENDAR_WEEKDAY_LABELS) private moduleWeekdayLabels = CALENDAR_DEFAULT_WEEKDAY_LABELS,\n    @Inject(DATEPICKER_ERROR_LABELS) private errorLabels = DATEPICKER_DEFAULT_ERROR_LABELS,\n    public calendarService: CalendarService,\n    private formBuilder: UntypedFormBuilder,\n    private ref: ChangeDetectorRef\n  ) {}\n\n  public ngOnInit(): void {\n    this.weekdayLabels = this.weekdayLabels || this.moduleWeekdayLabels;\n    this.monthLabels = this.monthLabels || this.moduleMonthLabels;\n    this.createInterval();\n    this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });\n    this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {\n      if (value) {\n        const date = DateHelper.parseDate(value, 'dd/MM/yyyy');\n        if (date instanceof Date) {\n          this.selectedDate = date;\n          const brusselsDate = new TZDate(date, 'Europe/Brussels');\n          const year = brusselsDate.getFullYear();\n          const month = brusselsDate.getMonth();\n          const day = brusselsDate.getDate();\n          this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));\n        } else if (typeof date === 'string') {\n          this.onChange(value);\n        } else {\n          this.onChange(value);\n        }\n      } else {\n        this.selectedDate = null;\n        this.onChange('');\n      }\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.min || changes.max) {\n      this.createInterval();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.componentDestroyed$.next(true);\n    this.componentDestroyed$.complete();\n  }\n\n  private createInterval() {\n    if (!this.min && !this.max) {\n      return;\n    }\n    // Create an interval if min/max is filled in\n    this.interval = IntervalBuilder.dateInterval(\n      this.min ? new Date(this.min) : null,\n      this.max ? new Date(this.max) : null\n    )\n      .not()\n      .build();\n  }\n\n  public writeValue(value: string | Date): void {\n    if (typeof value === 'string') {\n      if (this.isISODateFormat(value)) {\n        this.selectedDate = DateHelper.parseDate(value) as Date;\n      } else {\n        const parsed = DateHelper.parseDate(value, 'dd/MM/yyyy');\n        this.selectedDate = parsed instanceof Date ? parsed : null;\n      }\n    } else if (value instanceof Date) {\n      this.selectedDate = value;\n    } else {\n      this.selectedDate = null;\n    }\n\n    const dateString = this.selectedDate ? this.formatDate(this.selectedDate) : '';\n    this.formControl.setValue(dateString);\n  }\n\n  public registerOnChange(onChange: (res: any) => void): void {\n    this.onChange = onChange;\n  }\n\n  public registerOnTouched(onTouched: (_: any) => void): void {\n    this.onTouched = onTouched;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n\n    if (this.formControl) {\n      if (isDisabled && this.formControl.enabled) {\n        this.formControl.disable();\n      } else if (!isDisabled && this.formControl.disabled) {\n        this.formControl.enable();\n      }\n    }\n\n    this.ref.markForCheck();\n  }\n\n  public selectDateFromCalendar(result: DatepickerResult): void {\n    if (result.complete) {\n      this.formControl.setValue(this.formatDate(result.date));\n      this.flyout.close();\n    }\n  }\n\n  public formatDate(date: Date): string {\n    return DateHelper.formatDate(date, 'DD/MM/YYYY', {\n      leadingZero: true,\n      monthLabels: this.monthLabels,\n      weekdayLabels: this.weekdayLabels,\n    });\n  }\n\n  public validate(ctrl: UntypedFormControl): DatepickerValidationErrors {\n    // no error on empty value (add required validator in app)\n    if (ctrl.value === '' || ctrl.value === null) {\n      return null;\n    }\n\n    // throw format error if no valid date was provided\n    const date = DateHelper.parseDate(ctrl.value);\n    if (!date) {\n      return {\n        format: this.errorLabels.ERRORS_INVALID_DATE,\n      };\n    }\n\n    // no error if valid date an no range provided\n    if (!this.range || !this.range.length) {\n      return null;\n    }\n\n    // throw error when out of range\n    const range = this.calendarService.getRangeForDate(date, this.range);\n\n    return range.indexOf(date.getDate()) >= 0\n      ? {\n          range: this.errorLabels.ERRORS_INVALID_RANGE,\n        }\n      : null;\n  }\n\n  public handleBlur(e: Event): void {\n    this.blur.emit(e);\n    this.onTouched(e);\n  }\n\n  private onChange: (res: any) => void = () => undefined;\n\n  private onTouched: (_: any) => void = () => undefined;\n\n  private isISODateFormat(value: string) {\n    if (typeof value !== 'string') {\n      return false;\n    }\n    return value.match(/\\d{4}-\\d{2}-\\d{2}T.*/);\n  }\n}\n","<div aria-haspopup=\"grid\" auiFlyout class=\"aui-datepicker a-input has-icon-right\">\n  <label class=\"a-input__label\" for=\"{{ id }}\" *ngIf=\"label\">{{ label }}</label>\n  <small class=\"a-input__description\" *ngIf=\"description\"> {{ description }}</small>\n  <div class=\"a-input__wrapper\">\n    <input\n      (blur)=\"handleBlur($event)\"\n      [attr.disabled]=\"isDisabled ? true : null\"\n      [autocomplete]=\"autocomplete\"\n      [formControl]=\"formControl\"\n      id=\"{{ id }}\"\n      label=\"Pick date\"\n      description=\"Description\"\n      name=\"{{ name }}\"\n      placeholder=\"{{ placeholder }}\"\n      type=\"text\"\n    />\n    <ng-container *ngIf=\"isDisabled\">\n      <aui-icon\n        name=\"ai-calendar\"\n      />\n    </ng-container>\n    <ng-container *ngIf=\"!isDisabled\">\n      <aui-icon\n        auiFlyoutAction\n        [openOnFocus]=\"false\"\n        name=\"ai-calendar\"\n        className=\"is-clickable\"\n        role=\"button\"\n        [attr.aria-label]=\"ariaOpenDatepickerLabel\"\n        tabindex=\"0\"\n      />\n    </ng-container>\n\n    <ng-container *ngIf=\"!isDisabled\">\n      <div auiFlyoutZone class=\"m-datepicker m-datepicker--fixed\" role=\"dialog\">\n        <aui-calendar\n          (selectDate)=\"selectDateFromCalendar($event)\"\n          [range]=\"range\"\n          [selectedDate]=\"selectedDate\"\n          [interval]=\"interval\"\n          [weekdayLabels]=\"weekdayLabels\"\n          [monthLabels]=\"monthLabels\"\n        ></aui-calendar>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -351,9 +351,8 @@ class DatepickerComponent {
351
351
  this.formControl = this.formBuilder.control({ value: '', disabled: this.isDisabled });
352
352
  this.formControl.valueChanges.pipe(takeUntil(this.componentDestroyed$)).subscribe((value) => {
353
353
  if (value) {
354
- const format = value.split(DATEPICKER_SEPARATOR_CHAR).reverse().join('-');
355
- const date = DateHelper.parseDate(format, 'yyyy-MM-dd');
356
- if (date) {
354
+ const date = DateHelper.parseDate(value, 'dd/MM/yyyy');
355
+ if (date instanceof Date) {
357
356
  this.selectedDate = date;
358
357
  const brusselsDate = new TZDate(date, 'Europe/Brussels');
359
358
  const year = brusselsDate.getFullYear();
@@ -361,6 +360,9 @@ class DatepickerComponent {
361
360
  const day = brusselsDate.getDate();
362
361
  this.onChange(DateHelper.toUtcMidnightInBrussels(year, month, day));
363
362
  }
363
+ else if (typeof date === 'string') {
364
+ this.onChange(value);
365
+ }
364
366
  else {
365
367
  this.onChange(value);
366
368
  }
@@ -395,7 +397,8 @@ class DatepickerComponent {
395
397
  this.selectedDate = DateHelper.parseDate(value);
396
398
  }
397
399
  else {
398
- this.selectedDate = DateHelper.parseDate(value, 'dd/MM/yyyy');
400
+ const parsed = DateHelper.parseDate(value, 'dd/MM/yyyy');
401
+ this.selectedDate = parsed instanceof Date ? parsed : null;
399
402
  }
400
403
  }
401
404
  else if (value instanceof Date) {