@impartner/design-components 2.0.1 → 2.1.1

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 (155) hide show
  1. package/README.md +2 -1
  2. package/esm2022/lib/badge/badge.component.mjs +17 -1
  3. package/esm2022/lib/datetime-picker/components/datepicker-nav/datepicker-nav.component.mjs +105 -0
  4. package/esm2022/lib/datetime-picker/components/datepicker-nav/index.mjs +2 -0
  5. package/esm2022/lib/datetime-picker/components/datepicker-template-host/datepicker-template-host.component.mjs +30 -0
  6. package/esm2022/lib/datetime-picker/components/datepicker-template-host/index.mjs +2 -0
  7. package/esm2022/lib/datetime-picker/components/datetime-picker/datetime-picker.component.mjs +370 -0
  8. package/esm2022/lib/datetime-picker/components/datetime-picker/index.mjs +2 -0
  9. package/esm2022/lib/datetime-picker/components/datetime-picker-input/datetime-picker-input.component.mjs +367 -0
  10. package/esm2022/lib/datetime-picker/components/datetime-picker-input/index.mjs +2 -0
  11. package/esm2022/lib/datetime-picker/components/datetime-picker-input-footer/datetime-picker-input-footer.component.mjs +68 -0
  12. package/esm2022/lib/datetime-picker/components/datetime-picker-input-footer/index.mjs +2 -0
  13. package/esm2022/lib/datetime-picker/components/index.mjs +6 -0
  14. package/esm2022/lib/datetime-picker/constants/datetime-picker-defaults.mjs +12 -0
  15. package/esm2022/lib/datetime-picker/constants/index.mjs +2 -0
  16. package/esm2022/lib/datetime-picker/datetime-picker.module.mjs +22 -0
  17. package/esm2022/lib/datetime-picker/index.mjs +4 -0
  18. package/esm2022/lib/datetime-picker/services/datetime-formatter/datetime-formatter.service.mjs +40 -0
  19. package/esm2022/lib/datetime-picker/services/datetime-formatter/index.mjs +2 -0
  20. package/esm2022/lib/datetime-picker/services/index.mjs +2 -0
  21. package/esm2022/lib/datetime-picker/types/datetime-picker-value.interface.mjs +2 -0
  22. package/esm2022/lib/datetime-picker/types/index.mjs +2 -0
  23. package/esm2022/lib/design-components.module.mjs +20 -7
  24. package/esm2022/lib/form-field/component/directives/corner-hint.directive.mjs +15 -0
  25. package/esm2022/lib/form-field/component/directives/error.directive.mjs +27 -0
  26. package/esm2022/lib/form-field/component/directives/form-root.directive.mjs +93 -0
  27. package/esm2022/lib/form-field/component/directives/hint.directive.mjs +25 -0
  28. package/esm2022/lib/form-field/component/directives/index.mjs +25 -0
  29. package/esm2022/lib/form-field/component/directives/label.directive.mjs +15 -0
  30. package/esm2022/lib/form-field/component/directives/prefix.directive.mjs +25 -0
  31. package/esm2022/lib/form-field/component/directives/suffix.directive.mjs +25 -0
  32. package/esm2022/lib/form-field/component/form-field.component.mjs +131 -0
  33. package/esm2022/lib/form-field/component/form-field.module.mjs +24 -0
  34. package/esm2022/lib/form-field/component/index.mjs +4 -0
  35. package/esm2022/lib/form-field/controls/checkbox/checkbox.component.mjs +14 -6
  36. package/esm2022/lib/form-field/controls/checkbox/checkbox.module.mjs +4 -7
  37. package/esm2022/lib/form-field/controls/index.mjs +2 -1
  38. package/esm2022/lib/form-field/controls/input/input.directive.mjs +4 -3
  39. package/esm2022/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +6 -4
  40. package/esm2022/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +4 -3
  41. package/esm2022/lib/form-field/controls/radio/radio.module.mjs +4 -7
  42. package/esm2022/lib/form-field/controls/select/index.mjs +6 -3
  43. package/esm2022/lib/form-field/controls/select/interfaces/index.mjs +2 -0
  44. package/esm2022/lib/form-field/controls/select/interfaces/select-option.interface.mjs +2 -0
  45. package/esm2022/lib/form-field/controls/select/option/index.mjs +2 -2
  46. package/esm2022/lib/form-field/controls/select/option/select-option.component.mjs +33 -128
  47. package/esm2022/lib/form-field/controls/select/option-display/index.mjs +2 -0
  48. package/esm2022/lib/form-field/controls/select/option-display/select-option-display.component.mjs +162 -0
  49. package/esm2022/lib/form-field/controls/select/option-group/index.mjs +2 -0
  50. package/esm2022/lib/form-field/controls/select/option-group/select-option-group.component.mjs +35 -0
  51. package/esm2022/lib/form-field/controls/select/option-parent.mjs +2 -1
  52. package/esm2022/lib/form-field/controls/select/select.component.mjs +348 -148
  53. package/esm2022/lib/form-field/controls/select/select.module.mjs +20 -13
  54. package/esm2022/lib/form-field/controls/select/value-tags-display/index.mjs +2 -0
  55. package/esm2022/lib/form-field/controls/select/value-tags-display/select-value-tags-display.component.mjs +91 -0
  56. package/esm2022/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +3 -3
  57. package/esm2022/lib/form-field/controls/shared/toggle/toggle.component.mjs +19 -3
  58. package/esm2022/lib/form-field/controls/shared/toggle/toggle.module.mjs +4 -6
  59. package/esm2022/lib/form-field/controls/tag-select/index.mjs +2 -0
  60. package/esm2022/lib/form-field/controls/tag-select/tag-select.component.mjs +146 -0
  61. package/esm2022/lib/form-field/impdc-forms.mjs +2 -3
  62. package/esm2022/lib/form-field/impdc-forms.module.mjs +32 -47
  63. package/esm2022/lib/form-field/shared/error-state.mixin.mjs +1 -1
  64. package/esm2022/lib/icon/icon.component.mjs +12 -5
  65. package/esm2022/lib/index.mjs +3 -1
  66. package/esm2022/lib/pagination/pagination.component.mjs +6 -6
  67. package/esm2022/lib/select-icon/select-icon.component.mjs +6 -6
  68. package/esm2022/lib/select-icon/select-icon.module.mjs +5 -1
  69. package/esm2022/lib/table/containers/table.component.mjs +3 -3
  70. package/esm2022/lib/tag/index.mjs +2 -0
  71. package/esm2022/lib/tag/tag.component.mjs +104 -0
  72. package/esm2022/lib/text-highlight/text-highlight.component.mjs +52 -37
  73. package/esm2022/lib/text-highlight/text-highlight.module.mjs +4 -6
  74. package/fesm2022/impartner-design-components.mjs +5620 -3983
  75. package/fesm2022/impartner-design-components.mjs.map +1 -1
  76. package/lib/badge/badge.component.d.ts +15 -1
  77. package/lib/datetime-picker/components/datepicker-nav/datepicker-nav.component.d.ts +31 -0
  78. package/lib/datetime-picker/components/datepicker-nav/index.d.ts +1 -0
  79. package/lib/datetime-picker/components/datepicker-template-host/datepicker-template-host.component.d.ts +14 -0
  80. package/lib/datetime-picker/components/datepicker-template-host/index.d.ts +1 -0
  81. package/lib/datetime-picker/components/datetime-picker/datetime-picker.component.d.ts +157 -0
  82. package/lib/datetime-picker/components/datetime-picker/index.d.ts +1 -0
  83. package/lib/datetime-picker/components/datetime-picker-input/datetime-picker-input.component.d.ts +160 -0
  84. package/lib/datetime-picker/components/datetime-picker-input/index.d.ts +1 -0
  85. package/lib/datetime-picker/components/datetime-picker-input-footer/datetime-picker-input-footer.component.d.ts +24 -0
  86. package/lib/datetime-picker/components/datetime-picker-input-footer/index.d.ts +1 -0
  87. package/lib/datetime-picker/components/index.d.ts +5 -0
  88. package/lib/datetime-picker/constants/datetime-picker-defaults.d.ts +4 -0
  89. package/lib/datetime-picker/constants/index.d.ts +1 -0
  90. package/lib/datetime-picker/datetime-picker.module.d.ts +8 -0
  91. package/lib/datetime-picker/index.d.ts +4 -0
  92. package/lib/datetime-picker/services/datetime-formatter/datetime-formatter.service.d.ts +20 -0
  93. package/lib/datetime-picker/services/datetime-formatter/index.d.ts +1 -0
  94. package/lib/datetime-picker/services/index.d.ts +1 -0
  95. package/lib/datetime-picker/types/datetime-picker-value.interface.d.ts +5 -0
  96. package/lib/datetime-picker/types/index.d.ts +1 -0
  97. package/lib/design-components.module.d.ts +14 -12
  98. package/lib/form-field/{directives → component/directives}/corner-hint.directive.d.ts +1 -1
  99. package/lib/form-field/{directives → component/directives}/error.directive.d.ts +1 -1
  100. package/lib/form-field/{directives → component/directives}/form-root.directive.d.ts +2 -2
  101. package/lib/form-field/{directives → component/directives}/hint.directive.d.ts +1 -1
  102. package/lib/form-field/component/directives/index.d.ts +15 -0
  103. package/lib/form-field/{directives → component/directives}/label.directive.d.ts +1 -1
  104. package/lib/form-field/{directives → component/directives}/prefix.directive.d.ts +1 -1
  105. package/lib/form-field/{directives → component/directives}/suffix.directive.d.ts +1 -1
  106. package/lib/form-field/{form-field.component.d.ts → component/form-field.component.d.ts} +3 -5
  107. package/lib/form-field/component/form-field.module.d.ts +14 -0
  108. package/lib/form-field/component/index.d.ts +3 -0
  109. package/lib/form-field/controls/checkbox/checkbox.component.d.ts +6 -2
  110. package/lib/form-field/controls/checkbox/checkbox.module.d.ts +1 -3
  111. package/lib/form-field/controls/index.d.ts +1 -0
  112. package/lib/form-field/controls/input/input.directive.d.ts +2 -2
  113. package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +1 -1
  114. package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +2 -2
  115. package/lib/form-field/controls/radio/radio.module.d.ts +1 -3
  116. package/lib/form-field/controls/select/index.d.ts +6 -2
  117. package/lib/form-field/controls/select/interfaces/index.d.ts +1 -0
  118. package/lib/form-field/controls/select/interfaces/select-option.interface.d.ts +6 -0
  119. package/lib/form-field/controls/select/option/index.d.ts +1 -1
  120. package/lib/form-field/controls/select/option/select-option.component.d.ts +10 -49
  121. package/lib/form-field/controls/select/option-display/index.d.ts +1 -0
  122. package/lib/form-field/controls/select/option-display/select-option-display.component.d.ts +64 -0
  123. package/lib/form-field/controls/select/option-group/index.d.ts +1 -0
  124. package/lib/form-field/controls/select/option-group/select-option-group.component.d.ts +11 -0
  125. package/lib/form-field/controls/select/option-parent.d.ts +12 -1
  126. package/lib/form-field/controls/select/select.component.d.ts +113 -51
  127. package/lib/form-field/controls/select/select.module.d.ts +5 -6
  128. package/lib/form-field/controls/select/value-tags-display/index.d.ts +1 -0
  129. package/lib/form-field/controls/select/value-tags-display/select-value-tags-display.component.d.ts +46 -0
  130. package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +1 -1
  131. package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +4 -1
  132. package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +1 -2
  133. package/lib/form-field/controls/tag-select/index.d.ts +1 -0
  134. package/lib/form-field/controls/tag-select/tag-select.component.d.ts +43 -0
  135. package/lib/form-field/impdc-forms.d.ts +1 -2
  136. package/lib/form-field/impdc-forms.module.d.ts +8 -14
  137. package/lib/form-field/shared/error-state.mixin.d.ts +4 -4
  138. package/lib/icon/icon.component.d.ts +5 -3
  139. package/lib/index.d.ts +2 -0
  140. package/lib/select-icon/select-icon.module.d.ts +4 -3
  141. package/lib/tag/index.d.ts +1 -0
  142. package/lib/tag/tag.component.d.ts +54 -0
  143. package/lib/text-highlight/text-highlight.component.d.ts +12 -6
  144. package/lib/text-highlight/text-highlight.module.d.ts +1 -2
  145. package/package.json +2 -2
  146. package/esm2022/lib/form-field/directives/corner-hint.directive.mjs +0 -14
  147. package/esm2022/lib/form-field/directives/error.directive.mjs +0 -26
  148. package/esm2022/lib/form-field/directives/form-root.directive.mjs +0 -91
  149. package/esm2022/lib/form-field/directives/hint.directive.mjs +0 -24
  150. package/esm2022/lib/form-field/directives/index.mjs +0 -8
  151. package/esm2022/lib/form-field/directives/label.directive.mjs +0 -14
  152. package/esm2022/lib/form-field/directives/prefix.directive.mjs +0 -24
  153. package/esm2022/lib/form-field/directives/suffix.directive.mjs +0 -24
  154. package/esm2022/lib/form-field/form-field.component.mjs +0 -132
  155. package/lib/form-field/directives/index.d.ts +0 -7
@@ -0,0 +1,370 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, ElementRef, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild, booleanAttribute, inject } from '@angular/core';
2
+ import { CommonModule, TranslationWidth } from '@angular/common';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { FormBuilder, FormControl, ReactiveFormsModule, Validators } from '@angular/forms';
5
+ import { NgbDateAdapter, NgbDatepicker, NgbDatepickerModule, NgbTimepickerModule } from '@ng-bootstrap/ng-bootstrap';
6
+ import { nanoid } from 'nanoid';
7
+ import { Subject, debounceTime } from 'rxjs';
8
+ import { IMPDC_FORM_ROOT, ImpdcFormFieldControl, ImpdcFormsModule, mixinDisabled, mixinErrorState, mixinTabIndex } from '../../../form-field';
9
+ import { DEFAULT_MAX_DATE, DEFAULT_MIN_DATE, DEFAULT_USE_MERIDIAN_LABEL } from '../../constants';
10
+ import { DatepickerTemplateHostComponent } from '../datepicker-template-host';
11
+ import { DatetimePickerInputFooterComponent } from '../datetime-picker-input-footer';
12
+ import * as i0 from "@angular/core";
13
+ import * as i1 from "../../../form-field";
14
+ import * as i2 from "@angular/forms";
15
+ import * as i3 from "@angular/common";
16
+ import * as i4 from "@ng-bootstrap/ng-bootstrap";
17
+ import * as i5 from "../../../form-field/component/directives/form-root.directive";
18
+ import * as i6 from "../../../form-field/controls/checkbox/checkbox.component";
19
+ export const DEFAULT_TIME_LAYOUT = {
20
+ border: false,
21
+ layout: 'inline'
22
+ };
23
+ const _DatetimePickerComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
24
+ constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
25
+ this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
26
+ this._formRoot = _formRoot;
27
+ this._parentForm = _parentForm;
28
+ this._parentFormGroup = _parentFormGroup;
29
+ this.ngControl = ngControl;
30
+ this.stateChanges = new Subject();
31
+ }
32
+ })));
33
+ /**
34
+ * A control for selecting date or datetime via an inline calendar control.
35
+ *
36
+ * Implements [ControlValueAccessor](https://angular.io/api/forms/ControlValueAccessor) to support two-way binding with
37
+ * Angular forms via usage of the \`[(ngModel)]\`, \`[formControl]\`, and \`[formControlName]\` directives.
38
+ *
39
+ * The date and time controls inside this component leverage the value adapter patterns and services of NG-Bootstrap's
40
+ * [Datepicker](https://ng-bootstrap.github.io/#/components/datepicker/overview#date-model) and
41
+ * [Timepicker](https://ng-bootstrap.github.io/#/components/timepicker/examples#adapter) components when working with input values.
42
+ * This means that `date` values will be [NgbDateStruct](https://ng-bootstrap.github.io/#/components/datepicker/api#NgbDateStruct)
43
+ * objects and `time` values will be [NgbTimeStruct](https://ng-bootstrap.github.io/#/components/timepicker/api#NgbTimeStruct) objects
44
+ * by default, and the [NgbDateAdapter](https://ng-bootstrap.github.io/#/components/datepicker/api#NgbDateAdapter) and
45
+ * [NgbTimeAdapter](https://ng-bootstrap.github.io/#/components/timepicker/api#NgbTimeAdapter) services will be used to handle them respectively.
46
+ * If usage of alternative date and time models is desired, consult NG-Bootstrap's documentation for directions.
47
+ */
48
+ export class DatetimePickerComponent extends _DatetimePickerComponentBase {
49
+ /**
50
+ * The earliest allowable date for display or selection.
51
+ *
52
+ * @default { year: 1900, month: 1, day: 1 }
53
+ */
54
+ get minDate() {
55
+ return { ...this._minDate };
56
+ }
57
+ set minDate(value) {
58
+ this._minDate = value || DEFAULT_MIN_DATE;
59
+ }
60
+ /**
61
+ * The latest allowable date for display or selection.
62
+ *
63
+ * @default { year: 2099, month: 12, day: 31 }
64
+ */
65
+ get maxDate() {
66
+ return { ...this._maxDate };
67
+ }
68
+ set maxDate(value) {
69
+ this._maxDate = value || DEFAULT_MAX_DATE;
70
+ }
71
+ /**
72
+ * Configurable options for setting the layout of the date and time controls within the component.
73
+ */
74
+ get timeLayout() {
75
+ return { ...this._timeLayout };
76
+ }
77
+ set timeLayout(value) {
78
+ this._timeLayout = {
79
+ ...DEFAULT_TIME_LAYOUT,
80
+ ...value
81
+ };
82
+ }
83
+ constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
84
+ super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
85
+ this._changeDetector = inject(ChangeDetectorRef);
86
+ this._destroyRef = inject(DestroyRef);
87
+ this._hostElement = inject(ElementRef);
88
+ this._ngbDateAdapter = inject((NgbDateAdapter));
89
+ this._uid = `impdc-datetime-picker-${nanoid()}`;
90
+ this.NgTranslationWidth = TranslationWidth;
91
+ this.formGroup = inject(FormBuilder).group({
92
+ date: new FormControl(null),
93
+ time: new FormControl(null),
94
+ useMeridian: new FormControl(true, { nonNullable: true })
95
+ });
96
+ this.cvaOnChange = (_) => { };
97
+ this.cvaOnTouched = () => { };
98
+ this._minDate = DEFAULT_MIN_DATE;
99
+ this._maxDate = DEFAULT_MAX_DATE;
100
+ this._timeLayout = { ...DEFAULT_TIME_LAYOUT };
101
+ /**
102
+ * Label to be displayed with time controls to allow the user to input 24-hour or meridian-based (AM, PM) time.
103
+ */
104
+ this.meridianToggleLabel = DEFAULT_USE_MERIDIAN_LABEL;
105
+ /**
106
+ * Set whether to display controls for selecting a time value in addition to the date.
107
+ */
108
+ this.withTime = false;
109
+ /**
110
+ * Events fire when raw value of picker input changes. Mainly exists to handle
111
+ * two-way binding of `value` input property.
112
+ * @ignore
113
+ */
114
+ this.valueChange = new EventEmitter();
115
+ /** @ignore */
116
+ this.blur = new EventEmitter();
117
+ this._focused = false;
118
+ this.controlType = 'impdc-datetime-picker';
119
+ this.supportsAffixes = false;
120
+ this.markDateDisabledFn = (date, current) => {
121
+ return (this._dateIsOutsideCurrentMonth(date, current) ||
122
+ (!!this.markDateDisabled && this.markDateDisabled(date, current)));
123
+ };
124
+ if (this.ngControl) {
125
+ this.ngControl.valueAccessor = this;
126
+ }
127
+ this.id = this.id;
128
+ }
129
+ /** @ignore */
130
+ focus() {
131
+ this.ngbDatepicker.focus();
132
+ }
133
+ /* Lifecycle Hooks */
134
+ /** @ignore */
135
+ ngDoCheck() {
136
+ const ngControl = this.ngControl;
137
+ if (!ngControl) {
138
+ return;
139
+ }
140
+ if (this._previousControl !== ngControl.control) {
141
+ if (this._previousControl !== undefined &&
142
+ ngControl.disabled !== null &&
143
+ ngControl.disabled !== this.disabled) {
144
+ this.disabled = ngControl?.disabled;
145
+ }
146
+ this._previousControl = ngControl.control;
147
+ }
148
+ this.updateErrorState();
149
+ }
150
+ /** @ignore */
151
+ ngOnChanges(changes) {
152
+ // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal
153
+ // to the parent form field so it can run change detection when disabled state is changed.
154
+ if (changes['disabled']) {
155
+ this.stateChanges.next();
156
+ }
157
+ }
158
+ /** @ignore */
159
+ ngOnDestroy() {
160
+ this.stateChanges.complete();
161
+ }
162
+ /** @ignore */
163
+ ngOnInit() {
164
+ this.formGroup.valueChanges
165
+ .pipe(takeUntilDestroyed(this._destroyRef), debounceTime(100))
166
+ .subscribe(formValue => {
167
+ const changeValue = this._getValueFromFormModel(formValue);
168
+ this.cvaOnChange(changeValue);
169
+ this.valueChange.emit(changeValue);
170
+ this.cvaOnTouched();
171
+ });
172
+ }
173
+ /* ControlValueAccessor */
174
+ /** @ignore */
175
+ writeValue(obj) {
176
+ let newValue = {};
177
+ if (obj && 'date' in obj) {
178
+ newValue = {
179
+ ...newValue,
180
+ date: obj.date
181
+ };
182
+ }
183
+ if (this.withTime && obj && 'time' in obj) {
184
+ newValue = {
185
+ ...newValue,
186
+ time: obj.time
187
+ };
188
+ }
189
+ this.formGroup.patchValue(newValue, { emitEvent: false });
190
+ if ('date' in newValue) {
191
+ this.ngbDatepicker.focusDate(this._ngbDateAdapter.fromModel(newValue.date));
192
+ }
193
+ this.stateChanges.next();
194
+ }
195
+ /** @ignore */
196
+ registerOnChange(fn) {
197
+ this.cvaOnChange = fn;
198
+ }
199
+ /** @ignore */
200
+ registerOnTouched(fn) {
201
+ this.cvaOnTouched = fn;
202
+ }
203
+ /** @ignore */
204
+ setDisabledState(isDisabled) {
205
+ this.disabled = isDisabled;
206
+ if (isDisabled) {
207
+ this.formGroup.disable();
208
+ }
209
+ else {
210
+ this.formGroup.enable();
211
+ }
212
+ }
213
+ /* ImpdcFormFieldControl */
214
+ get value() {
215
+ return this._getValueFromFormModel(this.formGroup.value);
216
+ }
217
+ set value(value) {
218
+ this.writeValue(value);
219
+ }
220
+ get id() {
221
+ return this._id;
222
+ }
223
+ set id(value) {
224
+ this._id = value || this._uid;
225
+ this.stateChanges.next();
226
+ }
227
+ /**
228
+ * Used to set requiredness of control in a template-based manner;
229
+ * not necessary when using the Angular reactive forms API and `required` validator.
230
+ *
231
+ * @default false
232
+ */
233
+ get required() {
234
+ return (this._required ??
235
+ this.ngControl?.control?.hasValidator(Validators.required) ??
236
+ false);
237
+ }
238
+ set required(value) {
239
+ this._required = value;
240
+ this.stateChanges.next();
241
+ }
242
+ get focused() {
243
+ return this._focused;
244
+ }
245
+ /* Internals */
246
+ get useMeridian() {
247
+ return this.formGroup.getRawValue().useMeridian;
248
+ }
249
+ get useMeridianLabelText() {
250
+ return this.meridianToggleLabel?.trim() || DEFAULT_USE_MERIDIAN_LABEL;
251
+ }
252
+ handleFocusOut(evt) {
253
+ if (!evt.relatedTarget ||
254
+ !this._hostElement.nativeElement.contains(evt.relatedTarget)) {
255
+ this._onBlur(evt);
256
+ }
257
+ }
258
+ _getValueFromFormModel(formValue) {
259
+ if (!formValue.date && !formValue.time) {
260
+ return null;
261
+ }
262
+ let result = {
263
+ date: formValue.date
264
+ };
265
+ if (this.withTime) {
266
+ result = {
267
+ ...result,
268
+ time: formValue.time
269
+ };
270
+ }
271
+ return result;
272
+ }
273
+ _dateIsOutsideCurrentMonth(date, current) {
274
+ return !!current && date.month !== current.month;
275
+ }
276
+ _onFocus() {
277
+ if (!this.disabled) {
278
+ this._focused = true;
279
+ this.stateChanges.next();
280
+ }
281
+ }
282
+ _onBlur(focusEvent) {
283
+ this._focused = false;
284
+ if (!this.disabled) {
285
+ this.cvaOnTouched();
286
+ this.blur.emit(focusEvent);
287
+ this._changeDetector.markForCheck();
288
+ this.stateChanges.next();
289
+ }
290
+ }
291
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: DatetimePickerComponent, deps: [{ token: i1.ErrorStateMatcher }, { token: IMPDC_FORM_ROOT, optional: true }, { token: i2.NgForm, optional: true }, { token: i2.FormGroupDirective, optional: true }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
292
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.1", type: DatetimePickerComponent, isStandalone: true, selector: "impdc-datetime-picker", inputs: { disabled: "disabled", tabIndex: "tabIndex", markDateDisabled: "markDateDisabled", minDate: "minDate", maxDate: "maxDate", timeLayout: "timeLayout", meridianToggleLabel: "meridianToggleLabel", withTime: "withTime", errorStateMatcher: "errorStateMatcher", value: "value", id: "id", required: ["required", "required", booleanAttribute] }, outputs: { valueChange: "valueChange", blur: "blur" }, host: { listeners: { "focus": "_onFocus(); focus()" }, properties: { "attr.id": "id", "attr.tabindex": "tabIndex", "attr.aria-required": "required.toString()", "attr.aria-disabled": "disabled.toString()", "attr.aria-invalid": "errorState", "class.is-invalid": "errorState", "class.impdc-form-field-control": "true", "class.impdc-datetime-picker--required": "required", "class.impdc-datetime-picker--disabled": "disabled", "class.impdc-datetime-picker--invalid": "errorState", "class.impdc-datetime-picker--empty": "empty" } }, providers: [
293
+ {
294
+ provide: ImpdcFormFieldControl,
295
+ useExisting: DatetimePickerComponent
296
+ }
297
+ ], viewQueries: [{ propertyName: "ngbDatepicker", first: true, predicate: NgbDatepicker, descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<impdc-datepicker-template-host #templateHost></impdc-datepicker-template-host>\n<div\n [formGroup]=\"formGroup\"\n class=\"d-flex\"\n [ngClass]=\"{\n 'flex-column': withTime && timeLayout.layout === 'stacked'\n }\"\n (focusout)=\"handleFocusOut($event)\">\n <ngb-datepicker\n class=\"impdc-datetime-picker--datepicker\"\n formControlName=\"date\"\n [dayTemplate]=\"templateHost.dayTemplateRef\"\n [contentTemplate]=\"templateHost.contentTemplateRef\"\n [showWeekNumbers]=\"false\"\n outsideDays=\"visible\"\n [weekdays]=\"NgTranslationWidth.Abbreviated\"\n [markDisabled]=\"markDateDisabledFn\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\" />\n @if (withTime) {\n <div\n class=\"impdc-datetime-picker--timepicker d-flex flex-column gap-4 p-4 w-100\"\n [ngClass]=\"{\n 'border-0': !timeLayout.border,\n 'border-gray-200': timeLayout.border,\n 'mt-2': timeLayout.layout === 'stacked',\n 'border-top': timeLayout.border && timeLayout.layout === 'stacked',\n 'ms-2': timeLayout.layout === 'inline',\n 'border-start': timeLayout.border && timeLayout.layout === 'inline'\n }\">\n <impdc-checkbox\n [label]=\"useMeridianLabelText\"\n formControlName=\"useMeridian\"\n [isSwitch]=\"true\"\n layout=\"check-end\" />\n <ngb-timepicker\n formControlName=\"time\"\n [meridian]=\"useMeridian\"\n [seconds]=\"false\"\n [spinners]=\"false\"\n size=\"medium\"></ngb-timepicker>\n </div>\n }\n</div>\n", styles: [":host{display:block}ngb-datepicker{border:0}ngb-timepicker{font-size:var(--impd-font-size-sm)}::ng-deep .ngb-dp-header{display:none}::ng-deep .ngb-tp-spacer{width:var(--impd-size-4)}.impdc-datetime-picker--datepicker,.impdc-datetime-picker--timepicker{max-width:312px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: NgbDatepickerModule }, { kind: "component", type: i4.NgbDatepicker, selector: "ngb-datepicker", inputs: ["contentTemplate", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "maxDate", "minDate", "navigation", "outsideDays", "showWeekNumbers", "startDate", "weekdays"], outputs: ["navigate", "dateSelect"], exportAs: ["ngbDatepicker"] }, { kind: "ngmodule", type: NgbTimepickerModule }, { kind: "component", type: i4.NgbTimepicker, selector: "ngb-timepicker", inputs: ["meridian", "spinners", "seconds", "hourStep", "minuteStep", "secondStep", "readonlyInputs", "size"], exportAs: ["ngbTimepicker"] }, { kind: "component", type: DatepickerTemplateHostComponent, selector: "impdc-datepicker-template-host" }, { kind: "ngmodule", type: ImpdcFormsModule }, { kind: "directive", type: i5.RootFormGroupDirective, selector: "[formGroup]" }, { kind: "component", type: i6.CheckboxComponent, selector: "impdc-checkbox", inputs: ["tabIndex", "id", "label", "description", "isSwitch", "switchIcons", "inline", "layout", "checked", "indeterminate", "disabled", "errorStateMatcher", "required"], outputs: ["change", "indeterminateChange"], exportAs: ["impdcCheckControl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
298
+ }
299
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: DatetimePickerComponent, decorators: [{
300
+ type: Component,
301
+ args: [{ selector: 'impdc-datetime-picker', standalone: true, imports: [
302
+ CommonModule,
303
+ ReactiveFormsModule,
304
+ NgbDatepickerModule,
305
+ NgbTimepickerModule,
306
+ DatepickerTemplateHostComponent,
307
+ DatetimePickerInputFooterComponent,
308
+ ImpdcFormsModule
309
+ ], changeDetection: ChangeDetectionStrategy.OnPush, inputs: ['disabled', 'tabIndex'], host: {
310
+ '[attr.id]': 'id',
311
+ '[attr.tabindex]': 'tabIndex',
312
+ '[attr.aria-required]': 'required.toString()',
313
+ '[attr.aria-disabled]': 'disabled.toString()',
314
+ '[attr.aria-invalid]': 'errorState',
315
+ '[class.is-invalid]': 'errorState',
316
+ '[class.impdc-form-field-control]': 'true',
317
+ '[class.impdc-datetime-picker--required]': 'required',
318
+ '[class.impdc-datetime-picker--disabled]': 'disabled',
319
+ '[class.impdc-datetime-picker--invalid]': 'errorState',
320
+ '[class.impdc-datetime-picker--empty]': 'empty',
321
+ '(focus)': '_onFocus(); focus()'
322
+ }, providers: [
323
+ {
324
+ provide: ImpdcFormFieldControl,
325
+ useExisting: DatetimePickerComponent
326
+ }
327
+ ], template: "<impdc-datepicker-template-host #templateHost></impdc-datepicker-template-host>\n<div\n [formGroup]=\"formGroup\"\n class=\"d-flex\"\n [ngClass]=\"{\n 'flex-column': withTime && timeLayout.layout === 'stacked'\n }\"\n (focusout)=\"handleFocusOut($event)\">\n <ngb-datepicker\n class=\"impdc-datetime-picker--datepicker\"\n formControlName=\"date\"\n [dayTemplate]=\"templateHost.dayTemplateRef\"\n [contentTemplate]=\"templateHost.contentTemplateRef\"\n [showWeekNumbers]=\"false\"\n outsideDays=\"visible\"\n [weekdays]=\"NgTranslationWidth.Abbreviated\"\n [markDisabled]=\"markDateDisabledFn\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\" />\n @if (withTime) {\n <div\n class=\"impdc-datetime-picker--timepicker d-flex flex-column gap-4 p-4 w-100\"\n [ngClass]=\"{\n 'border-0': !timeLayout.border,\n 'border-gray-200': timeLayout.border,\n 'mt-2': timeLayout.layout === 'stacked',\n 'border-top': timeLayout.border && timeLayout.layout === 'stacked',\n 'ms-2': timeLayout.layout === 'inline',\n 'border-start': timeLayout.border && timeLayout.layout === 'inline'\n }\">\n <impdc-checkbox\n [label]=\"useMeridianLabelText\"\n formControlName=\"useMeridian\"\n [isSwitch]=\"true\"\n layout=\"check-end\" />\n <ngb-timepicker\n formControlName=\"time\"\n [meridian]=\"useMeridian\"\n [seconds]=\"false\"\n [spinners]=\"false\"\n size=\"medium\"></ngb-timepicker>\n </div>\n }\n</div>\n", styles: [":host{display:block}ngb-datepicker{border:0}ngb-timepicker{font-size:var(--impd-font-size-sm)}::ng-deep .ngb-dp-header{display:none}::ng-deep .ngb-tp-spacer{width:var(--impd-size-4)}.impdc-datetime-picker--datepicker,.impdc-datetime-picker--timepicker{max-width:312px}\n"] }]
328
+ }], ctorParameters: () => [{ type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
329
+ type: Optional
330
+ }, {
331
+ type: Inject,
332
+ args: [IMPDC_FORM_ROOT]
333
+ }] }, { type: i2.NgForm, decorators: [{
334
+ type: Optional
335
+ }] }, { type: i2.FormGroupDirective, decorators: [{
336
+ type: Optional
337
+ }] }, { type: i2.NgControl, decorators: [{
338
+ type: Self
339
+ }, {
340
+ type: Optional
341
+ }] }], propDecorators: { ngbDatepicker: [{
342
+ type: ViewChild,
343
+ args: [NgbDatepicker, { static: true }]
344
+ }], markDateDisabled: [{
345
+ type: Input
346
+ }], minDate: [{
347
+ type: Input
348
+ }], maxDate: [{
349
+ type: Input
350
+ }], timeLayout: [{
351
+ type: Input
352
+ }], meridianToggleLabel: [{
353
+ type: Input
354
+ }], withTime: [{
355
+ type: Input
356
+ }], errorStateMatcher: [{
357
+ type: Input
358
+ }], valueChange: [{
359
+ type: Output
360
+ }], blur: [{
361
+ type: Output
362
+ }], value: [{
363
+ type: Input
364
+ }], id: [{
365
+ type: Input
366
+ }], required: [{
367
+ type: Input,
368
+ args: [{ transform: booleanAttribute }]
369
+ }] } });
370
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/datetime-picker/components/datetime-picker/datetime-picker.component.ts","../../../../../../../../projects/design-components/src/lib/datetime-picker/components/datetime-picker/datetime-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewChild,\n  booleanAttribute,\n  inject\n} from '@angular/core';\nimport { CommonModule, TranslationWidth } from '@angular/common';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport {\n  NgbDateAdapter,\n  NgbDateStruct,\n  NgbDatepicker,\n  NgbDatepickerModule,\n  NgbTimepickerModule\n} from '@ng-bootstrap/ng-bootstrap';\nimport { nanoid } from 'nanoid';\nimport { Subject, debounceTime } from 'rxjs';\n\nimport {\n  ErrorStateMatcher,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  IMPDC_FORM_ROOT,\n  ImpdcFormFieldControl,\n  ImpdcFormRoot,\n  ImpdcFormsModule,\n  mixinDisabled,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../../form-field';\nimport {\n  DEFAULT_MAX_DATE,\n  DEFAULT_MIN_DATE,\n  DEFAULT_USE_MERIDIAN_LABEL\n} from '../../constants';\nimport { IDatetimePickerValue } from '../../types';\nimport { DatepickerTemplateHostComponent } from '../datepicker-template-host';\nimport { DatetimePickerInputFooterComponent } from '../datetime-picker-input-footer';\n\ninterface ITimeOptions {\n  readonly border: boolean;\n  readonly layout: 'inline' | 'stacked';\n}\n\nexport const DEFAULT_TIME_LAYOUT: ITimeOptions = {\n  border: false,\n  layout: 'inline'\n} as const;\n\nconst _DatetimePickerComponentBase = mixinTabIndex(\n  mixinDisabled(\n    mixinErrorState(\n      class {\n        public readonly stateChanges = new Subject<void>();\n\n        constructor(\n          public _defaultErrorStateMatcher: ErrorStateMatcher,\n          public _formRoot: ImpdcFormRoot,\n          public _parentForm: NgForm,\n          public _parentFormGroup: FormGroupDirective,\n          public ngControl: NgControl | null\n        ) {}\n      }\n    )\n  )\n);\n\n/**\n * A control for selecting date or datetime via an inline calendar control.\n *\n * Implements [ControlValueAccessor](https://angular.io/api/forms/ControlValueAccessor) to support two-way binding with\n * Angular forms via usage of the \\`[(ngModel)]\\`, \\`[formControl]\\`, and \\`[formControlName]\\` directives.\n *\n * The date and time controls inside this component leverage the value adapter patterns and services of NG-Bootstrap's\n * [Datepicker](https://ng-bootstrap.github.io/#/components/datepicker/overview#date-model) and\n * [Timepicker](https://ng-bootstrap.github.io/#/components/timepicker/examples#adapter) components when working with input values.\n * This means that `date` values will be [NgbDateStruct](https://ng-bootstrap.github.io/#/components/datepicker/api#NgbDateStruct)\n * objects and `time` values will be [NgbTimeStruct](https://ng-bootstrap.github.io/#/components/timepicker/api#NgbTimeStruct) objects\n * by default, and the [NgbDateAdapter](https://ng-bootstrap.github.io/#/components/datepicker/api#NgbDateAdapter) and\n * [NgbTimeAdapter](https://ng-bootstrap.github.io/#/components/timepicker/api#NgbTimeAdapter) services will be used to handle them respectively.\n * If usage of alternative date and time models is desired, consult NG-Bootstrap's documentation for directions.\n */\n@Component({\n  selector: 'impdc-datetime-picker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    NgbDatepickerModule,\n    NgbTimepickerModule,\n    DatepickerTemplateHostComponent,\n    DatetimePickerInputFooterComponent,\n    ImpdcFormsModule\n  ],\n  templateUrl: './datetime-picker.component.html',\n  styleUrls: ['./datetime-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['disabled', 'tabIndex'],\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.impdc-datetime-picker--required]': 'required',\n    '[class.impdc-datetime-picker--disabled]': 'disabled',\n    '[class.impdc-datetime-picker--invalid]': 'errorState',\n    '[class.impdc-datetime-picker--empty]': 'empty',\n    '(focus)': '_onFocus(); focus()'\n  },\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: DatetimePickerComponent\n    }\n  ]\n})\nexport class DatetimePickerComponent\n  extends _DatetimePickerComponentBase\n  implements\n    ControlValueAccessor,\n    DoCheck,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    ImpdcFormFieldControl<IDatetimePickerValue<any, any> | null>,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  private readonly _changeDetector = inject(ChangeDetectorRef);\n  private readonly _destroyRef = inject(DestroyRef);\n  private readonly _hostElement = inject(ElementRef);\n  private readonly _ngbDateAdapter = inject(NgbDateAdapter<any>);\n  private readonly _uid = `impdc-datetime-picker-${nanoid()}`;\n  private _previousControl?: AbstractControl | null;\n\n  protected readonly NgTranslationWidth = TranslationWidth;\n  protected readonly formGroup = inject(FormBuilder).group({\n    date: new FormControl<any>(null),\n    time: new FormControl<any>(null),\n    useMeridian: new FormControl<boolean>(true, { nonNullable: true })\n  });\n  protected cvaOnChange = (_: any) => {};\n  protected cvaOnTouched = () => {};\n\n  @ViewChild(NgbDatepicker, { static: true })\n  protected ngbDatepicker!: NgbDatepicker;\n\n  /**\n   * A callback function that can be evaluated to decide if a given date is disabled\n   * in the calendar view.\n   *\n   * @param date An [`NgbDate`](https://ng-bootstrap.github.io/#/components/datepicker/api#NgbDate) value describing the singular date being evaluated.\n   * @param current The month and year selected for the current calendar view.\n   */\n  @Input()\n  public markDateDisabled?: (\n    date: NgbDateStruct,\n    current?: { month: number; year: number }\n  ) => boolean;\n\n  /**\n   * The earliest allowable date for display or selection.\n   *\n   * @default { year: 1900, month: 1, day: 1 }\n   */\n  @Input()\n  public get minDate(): NgbDateStruct {\n    return { ...this._minDate };\n  }\n  public set minDate(value: NgbDateStruct | null) {\n    this._minDate = value || DEFAULT_MIN_DATE;\n  }\n  private _minDate: NgbDateStruct = DEFAULT_MIN_DATE;\n\n  /**\n   * The latest allowable date for display or selection.\n   *\n   * @default { year: 2099, month: 12, day: 31 }\n   */\n  @Input()\n  public get maxDate(): NgbDateStruct {\n    return { ...this._maxDate };\n  }\n  public set maxDate(value: NgbDateStruct | null) {\n    this._maxDate = value || DEFAULT_MAX_DATE;\n  }\n  private _maxDate: NgbDateStruct = DEFAULT_MAX_DATE;\n\n  /**\n   * Configurable options for setting the layout of the date and time controls within the component.\n   */\n  @Input()\n  public get timeLayout(): ITimeOptions {\n    return { ...this._timeLayout };\n  }\n  public set timeLayout(value: Partial<ITimeOptions>) {\n    this._timeLayout = {\n      ...DEFAULT_TIME_LAYOUT,\n      ...value\n    };\n  }\n  private _timeLayout: ITimeOptions = { ...DEFAULT_TIME_LAYOUT };\n\n  /**\n   * Label to be displayed with time controls to allow the user to input 24-hour or meridian-based (AM, PM) time.\n   */\n  @Input()\n  public meridianToggleLabel: string = DEFAULT_USE_MERIDIAN_LABEL;\n\n  /**\n   * Set whether to display controls for selecting a time value in addition to the date.\n   */\n  @Input()\n  public withTime = false;\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /**\n   * Events fire when raw value of picker input changes. Mainly exists to handle\n   * two-way binding of `value` input property.\n   * @ignore\n   */\n  @Output()\n  public readonly valueChange: EventEmitter<IDatetimePickerValue<\n    any,\n    any\n  > | null> = new EventEmitter<IDatetimePickerValue<any, any> | null>();\n\n  /** @ignore */\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  public readonly blur = new EventEmitter<FocusEvent>();\n\n  constructor(\n    _defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() @Inject(IMPDC_FORM_ROOT) _formRoot: ImpdcFormRoot,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    @Self() @Optional() ngControl: NgControl\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.id = this.id;\n  }\n\n  /** @ignore */\n  public focus(): void {\n    this.ngbDatepicker.focus();\n  }\n\n  /* Lifecycle Hooks */\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (this._previousControl !== ngControl.control) {\n      if (\n        this._previousControl !== undefined &&\n        ngControl.disabled !== null &&\n        ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = ngControl?.disabled;\n      }\n\n      this._previousControl = ngControl.control;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal\n    // to the parent form field so it can run change detection when disabled state is changed.\n    if (changes['disabled']) {\n      this.stateChanges.next();\n    }\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  /** @ignore */\n  public ngOnInit(): void {\n    this.formGroup.valueChanges\n      .pipe(takeUntilDestroyed(this._destroyRef), debounceTime(100))\n      .subscribe(formValue => {\n        const changeValue = this._getValueFromFormModel(formValue);\n        this.cvaOnChange(changeValue);\n        this.valueChange.emit(changeValue);\n        this.cvaOnTouched();\n      });\n  }\n\n  /* ControlValueAccessor */\n\n  /** @ignore */\n  public writeValue(obj: IDatetimePickerValue<any, any> | any): void {\n    let newValue: Partial<IDatetimePickerValue> = {};\n    if (obj && 'date' in obj) {\n      newValue = {\n        ...newValue,\n        date: obj.date\n      };\n    }\n\n    if (this.withTime && obj && 'time' in obj) {\n      newValue = {\n        ...newValue,\n        time: obj.time\n      };\n    }\n\n    this.formGroup.patchValue(newValue, { emitEvent: false });\n    if ('date' in newValue) {\n      this.ngbDatepicker.focusDate(\n        this._ngbDateAdapter.fromModel(newValue.date)\n      );\n    }\n\n    this.stateChanges.next();\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: any): void {\n    this.cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: any): void {\n    this.cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n\n    if (isDisabled) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /* ImpdcFormFieldControl */\n\n  @Input()\n  public get value(): IDatetimePickerValue<any, any> | null {\n    return this._getValueFromFormModel(this.formGroup.value);\n  }\n  public set value(value: IDatetimePickerValue<any, any> | null) {\n    this.writeValue(value);\n  }\n\n  @Input()\n  public get id(): string {\n    return this._id;\n  }\n  public set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  protected _id!: string;\n\n  /**\n   * Used to set requiredness of control in a template-based manner;\n   * not necessary when using the Angular reactive forms API and `required` validator.\n   *\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public get required(): boolean {\n    return (\n      this._required ??\n      this.ngControl?.control?.hasValidator(Validators.required) ??\n      false\n    );\n  }\n  public set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n  private _required: boolean | undefined;\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n  protected _focused = false;\n\n  public readonly controlType: string = 'impdc-datetime-picker';\n  public readonly supportsAffixes: boolean = false;\n\n  /* Internals */\n\n  protected get useMeridian(): boolean {\n    return this.formGroup.getRawValue().useMeridian;\n  }\n\n  protected get useMeridianLabelText(): string {\n    return this.meridianToggleLabel?.trim() || DEFAULT_USE_MERIDIAN_LABEL;\n  }\n\n  protected handleFocusOut(evt: FocusEvent): void {\n    if (\n      !evt.relatedTarget ||\n      !this._hostElement.nativeElement.contains(evt.relatedTarget)\n    ) {\n      this._onBlur(evt);\n    }\n  }\n\n  private _getValueFromFormModel(\n    formValue: Partial<{ date: any; time: any; useMeridian: any }>\n  ): IDatetimePickerValue<any, any> | null {\n    if (!formValue.date && !formValue.time) {\n      return null;\n    }\n\n    let result: IDatetimePickerValue<any, any> = {\n      date: formValue.date\n    };\n\n    if (this.withTime) {\n      result = {\n        ...result,\n        time: formValue.time\n      };\n    }\n\n    return result;\n  }\n\n  private _dateIsOutsideCurrentMonth(\n    date: NgbDateStruct,\n    current?: { month: number; year: number }\n  ): boolean {\n    return !!current && date.month !== current.month;\n  }\n\n  protected readonly markDateDisabledFn = (\n    date: NgbDateStruct,\n    current?: { month: number; year: number }\n  ) => {\n    return (\n      this._dateIsOutsideCurrentMonth(date, current) ||\n      (!!this.markDateDisabled && this.markDateDisabled(date, current))\n    );\n  };\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  protected _onBlur(focusEvent: FocusEvent): void {\n    this._focused = false;\n\n    if (!this.disabled) {\n      this.cvaOnTouched();\n      this.blur.emit(focusEvent);\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n}\n","<impdc-datepicker-template-host #templateHost></impdc-datepicker-template-host>\n<div\n  [formGroup]=\"formGroup\"\n  class=\"d-flex\"\n  [ngClass]=\"{\n    'flex-column': withTime && timeLayout.layout === 'stacked'\n  }\"\n  (focusout)=\"handleFocusOut($event)\">\n  <ngb-datepicker\n    class=\"impdc-datetime-picker--datepicker\"\n    formControlName=\"date\"\n    [dayTemplate]=\"templateHost.dayTemplateRef\"\n    [contentTemplate]=\"templateHost.contentTemplateRef\"\n    [showWeekNumbers]=\"false\"\n    outsideDays=\"visible\"\n    [weekdays]=\"NgTranslationWidth.Abbreviated\"\n    [markDisabled]=\"markDateDisabledFn\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\" />\n  @if (withTime) {\n  <div\n    class=\"impdc-datetime-picker--timepicker d-flex flex-column gap-4 p-4 w-100\"\n    [ngClass]=\"{\n      'border-0': !timeLayout.border,\n      'border-gray-200': timeLayout.border,\n      'mt-2': timeLayout.layout === 'stacked',\n      'border-top': timeLayout.border && timeLayout.layout === 'stacked',\n      'ms-2': timeLayout.layout === 'inline',\n      'border-start': timeLayout.border && timeLayout.layout === 'inline'\n    }\">\n    <impdc-checkbox\n      [label]=\"useMeridianLabelText\"\n      formControlName=\"useMeridian\"\n      [isSwitch]=\"true\"\n      layout=\"check-end\" />\n    <ngb-timepicker\n      formControlName=\"time\"\n      [meridian]=\"useMeridian\"\n      [seconds]=\"false\"\n      [spinners]=\"false\"\n      size=\"medium\"></ngb-timepicker>\n  </div>\n  }\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './datetime-picker.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2RhdGV0aW1lLXBpY2tlci9jb21wb25lbnRzL2RhdGV0aW1lLXBpY2tlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kYXRldGltZS1waWNrZXIuY29tcG9uZW50JztcbiJdfQ==