@dereekb/dbx-form 10.2.0 → 11.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (144) hide show
  1. package/calendar/lib/calendar.schedule.selection.cell.component.d.ts +0 -1
  2. package/calendar/lib/calendar.schedule.selection.component.d.ts +1 -2
  3. package/calendar/lib/calendar.schedule.selection.days.component.d.ts +1 -2
  4. package/calendar/lib/calendar.schedule.selection.dialog.button.component.d.ts +1 -2
  5. package/calendar/lib/calendar.schedule.selection.popover.button.component.d.ts +1 -2
  6. package/calendar/lib/calendar.schedule.selection.range.component.d.ts +2 -3
  7. package/calendar/lib/calendar.schedule.selection.store.provide.d.ts +1 -2
  8. package/calendar/lib/calendar.schedule.selection.toggle.button.component.d.ts +0 -1
  9. package/calendar/lib/field/schedule/calendar.schedule.field.component.d.ts +2 -3
  10. package/esm2022/calendar/lib/calendar.module.mjs +6 -6
  11. package/esm2022/calendar/lib/calendar.schedule.selection.cell.component.mjs +10 -13
  12. package/esm2022/calendar/lib/calendar.schedule.selection.component.mjs +49 -52
  13. package/esm2022/calendar/lib/calendar.schedule.selection.days.component.mjs +23 -27
  14. package/esm2022/calendar/lib/calendar.schedule.selection.days.form.component.mjs +5 -8
  15. package/esm2022/calendar/lib/calendar.schedule.selection.dialog.button.component.mjs +12 -13
  16. package/esm2022/calendar/lib/calendar.schedule.selection.dialog.component.mjs +4 -4
  17. package/esm2022/calendar/lib/calendar.schedule.selection.popover.button.component.mjs +22 -24
  18. package/esm2022/calendar/lib/calendar.schedule.selection.popover.component.mjs +4 -4
  19. package/esm2022/calendar/lib/calendar.schedule.selection.popover.content.component.mjs +4 -4
  20. package/esm2022/calendar/lib/calendar.schedule.selection.range.component.mjs +81 -86
  21. package/esm2022/calendar/lib/calendar.schedule.selection.store.mjs +123 -123
  22. package/esm2022/calendar/lib/calendar.schedule.selection.store.provide.mjs +8 -13
  23. package/esm2022/calendar/lib/calendar.schedule.selection.toggle.button.component.mjs +39 -42
  24. package/esm2022/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +24 -31
  25. package/esm2022/calendar/lib/field/schedule/calendar.schedule.module.mjs +6 -6
  26. package/esm2022/lib/form/action/form.action.directive.mjs +29 -20
  27. package/esm2022/lib/form/action/form.action.module.mjs +4 -4
  28. package/esm2022/lib/form/action/transition/form.action.transition.module.mjs +4 -4
  29. package/esm2022/lib/form/action/transition/form.action.transition.safety.directive.mjs +7 -18
  30. package/esm2022/lib/form/form.module.mjs +4 -4
  31. package/esm2022/lib/form/io/form.changes.directive.mjs +7 -13
  32. package/esm2022/lib/form/io/form.input.directive.mjs +7 -13
  33. package/esm2022/lib/form/io/form.io.module.mjs +4 -4
  34. package/esm2022/lib/form/io/form.loading.directive.mjs +9 -15
  35. package/esm2022/lib/form.module.mjs +4 -4
  36. package/esm2022/lib/formly/field/checklist/checklist.field.mjs +4 -4
  37. package/esm2022/lib/formly/field/checklist/checklist.item.field.component.mjs +23 -31
  38. package/esm2022/lib/formly/field/checklist/checklist.item.field.content.default.component.mjs +5 -4
  39. package/esm2022/lib/formly/field/checklist/checklist.item.field.module.mjs +6 -6
  40. package/esm2022/lib/formly/field/component/component.field.component.mjs +4 -4
  41. package/esm2022/lib/formly/field/component/component.field.module.mjs +6 -6
  42. package/esm2022/lib/formly/field/form.field.module.mjs +4 -4
  43. package/esm2022/lib/formly/field/selection/list/list.field.component.mjs +33 -36
  44. package/esm2022/lib/formly/field/selection/list/list.field.module.mjs +6 -6
  45. package/esm2022/lib/formly/field/selection/pickable/pickable.chip.field.component.mjs +3 -3
  46. package/esm2022/lib/formly/field/selection/pickable/pickable.field.directive.mjs +72 -74
  47. package/esm2022/lib/formly/field/selection/pickable/pickable.field.module.mjs +6 -6
  48. package/esm2022/lib/formly/field/selection/pickable/pickable.list.field.component.mjs +21 -24
  49. package/esm2022/lib/formly/field/selection/searchable/searchable.chip.field.component.mjs +6 -9
  50. package/esm2022/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.mjs +27 -34
  51. package/esm2022/lib/formly/field/selection/searchable/searchable.field.directive.mjs +32 -30
  52. package/esm2022/lib/formly/field/selection/searchable/searchable.field.module.mjs +6 -6
  53. package/esm2022/lib/formly/field/selection/searchable/searchable.text.field.component.mjs +8 -11
  54. package/esm2022/lib/formly/field/selection/selection.module.mjs +4 -4
  55. package/esm2022/lib/formly/field/selection/sourceselect/sourceselect.field.component.mjs +143 -145
  56. package/esm2022/lib/formly/field/selection/sourceselect/sourceselect.field.module.mjs +6 -6
  57. package/esm2022/lib/formly/field/texteditor/texteditor.field.component.mjs +19 -24
  58. package/esm2022/lib/formly/field/texteditor/texteditor.field.module.mjs +6 -6
  59. package/esm2022/lib/formly/field/value/array/array.field.component.mjs +22 -25
  60. package/esm2022/lib/formly/field/value/array/array.field.module.mjs +6 -6
  61. package/esm2022/lib/formly/field/value/boolean/boolean.field.module.mjs +4 -4
  62. package/esm2022/lib/formly/field/value/date/date.field.module.mjs +6 -6
  63. package/esm2022/lib/formly/field/value/date/datetime.field.component.mjs +233 -236
  64. package/esm2022/lib/formly/field/value/date/datetime.field.service.mjs +7 -15
  65. package/esm2022/lib/formly/field/value/date/fixeddaterange.field.component.mjs +97 -101
  66. package/esm2022/lib/formly/field/value/number/number.field.module.mjs +4 -4
  67. package/esm2022/lib/formly/field/value/phone/phone.field.component.mjs +15 -18
  68. package/esm2022/lib/formly/field/value/phone/phone.field.module.mjs +6 -6
  69. package/esm2022/lib/formly/field/value/text/text.field.module.mjs +4 -4
  70. package/esm2022/lib/formly/field/value/value.module.mjs +4 -4
  71. package/esm2022/lib/formly/field/wrapper/autotouch.wrapper.component.mjs +4 -4
  72. package/esm2022/lib/formly/field/wrapper/expand.wrapper.component.mjs +39 -0
  73. package/esm2022/lib/formly/field/wrapper/expand.wrapper.delegate.mjs +55 -0
  74. package/esm2022/lib/formly/field/wrapper/flex.wrapper.component.mjs +4 -4
  75. package/esm2022/lib/formly/field/wrapper/form.wrapper.module.mjs +10 -10
  76. package/esm2022/lib/formly/field/wrapper/index.mjs +3 -3
  77. package/esm2022/lib/formly/field/wrapper/info.wrapper.component.mjs +4 -4
  78. package/esm2022/lib/formly/field/wrapper/section.wrapper.component.mjs +4 -4
  79. package/esm2022/lib/formly/field/wrapper/style.wrapper.component.mjs +8 -11
  80. package/esm2022/lib/formly/field/wrapper/subsection.wrapper.component.mjs +4 -4
  81. package/esm2022/lib/formly/field/wrapper/toggle.wrapper.component.mjs +15 -18
  82. package/esm2022/lib/formly/field/wrapper/working.wrapper.component.mjs +6 -9
  83. package/esm2022/lib/formly/field/wrapper/wrapper.key.mjs +2 -3
  84. package/esm2022/lib/formly/field/wrapper/wrapper.mjs +3 -3
  85. package/esm2022/lib/formly/form/form.form.module.mjs +4 -4
  86. package/esm2022/lib/formly/form/search.form.component.mjs +6 -9
  87. package/esm2022/lib/formly/formly.context.directive.mjs +5 -8
  88. package/esm2022/lib/formly/formly.context.mjs +10 -12
  89. package/esm2022/lib/formly/formly.directive.mjs +16 -25
  90. package/esm2022/lib/formly/formly.form.component.mjs +73 -77
  91. package/esm2022/lib/formly/formly.module.mjs +6 -6
  92. package/esm2022/lib/layout/form.layout.module.mjs +4 -4
  93. package/esm2022/lib/layout/form.spacer.component.mjs +4 -4
  94. package/esm2022/mapbox/lib/field/latlng/latlng.field.component.mjs +48 -57
  95. package/esm2022/mapbox/lib/field/latlng/latlng.field.marker.component.mjs +17 -20
  96. package/esm2022/mapbox/lib/field/latlng/latlng.module.mjs +6 -6
  97. package/esm2022/mapbox/lib/field/zoom/zoom.field.component.mjs +26 -32
  98. package/esm2022/mapbox/lib/field/zoom/zoom.module.mjs +6 -6
  99. package/esm2022/mapbox/lib/mapbox.module.mjs +4 -4
  100. package/fesm2022/dereekb-dbx-form-calendar.mjs +383 -407
  101. package/fesm2022/dereekb-dbx-form-calendar.mjs.map +1 -1
  102. package/fesm2022/dereekb-dbx-form-mapbox.mjs +96 -111
  103. package/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -1
  104. package/fesm2022/dereekb-dbx-form.mjs +1071 -1163
  105. package/fesm2022/dereekb-dbx-form.mjs.map +1 -1
  106. package/lib/form/action/form.action.directive.d.ts +3 -3
  107. package/lib/form/action/transition/form.action.transition.safety.directive.d.ts +3 -7
  108. package/lib/form/io/form.changes.directive.d.ts +2 -3
  109. package/lib/form/io/form.input.directive.d.ts +3 -4
  110. package/lib/form/io/form.loading.directive.d.ts +3 -4
  111. package/lib/formly/field/checklist/checklist.field.d.ts +0 -1
  112. package/lib/formly/field/checklist/checklist.item.field.component.d.ts +4 -6
  113. package/lib/formly/field/selection/pickable/pickable.list.field.component.d.ts +0 -1
  114. package/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.d.ts +1 -2
  115. package/lib/formly/field/selection/searchable/searchable.field.directive.d.ts +0 -1
  116. package/lib/formly/field/selection/sourceselect/sourceselect.field.component.d.ts +2 -2
  117. package/lib/formly/field/texteditor/texteditor.field.component.d.ts +2 -4
  118. package/lib/formly/field/value/date/datetime.field.component.d.ts +1 -3
  119. package/lib/formly/field/value/date/datetime.field.service.d.ts +1 -4
  120. package/lib/formly/field/value/date/fixeddaterange.field.component.d.ts +2 -6
  121. package/lib/formly/field/wrapper/{expandable.wrapper.component.d.ts → expand.wrapper.component.d.ts} +4 -4
  122. package/lib/formly/field/wrapper/{expandable.wrapper.delegate.d.ts → expand.wrapper.delegate.d.ts} +7 -7
  123. package/lib/formly/field/wrapper/form.wrapper.module.d.ts +1 -1
  124. package/lib/formly/field/wrapper/index.d.ts +2 -2
  125. package/lib/formly/field/wrapper/toggle.wrapper.component.d.ts +4 -4
  126. package/lib/formly/field/wrapper/wrapper.d.ts +1 -1
  127. package/lib/formly/field/wrapper/wrapper.key.d.ts +1 -1
  128. package/lib/formly/formly.directive.d.ts +0 -1
  129. package/lib/formly/formly.form.component.d.ts +2 -3
  130. package/mapbox/esm2022/lib/field/latlng/latlng.field.component.mjs +48 -57
  131. package/mapbox/esm2022/lib/field/latlng/latlng.field.marker.component.mjs +17 -20
  132. package/mapbox/esm2022/lib/field/latlng/latlng.module.mjs +6 -6
  133. package/mapbox/esm2022/lib/field/zoom/zoom.field.component.mjs +26 -32
  134. package/mapbox/esm2022/lib/field/zoom/zoom.module.mjs +6 -6
  135. package/mapbox/esm2022/lib/mapbox.module.mjs +4 -4
  136. package/mapbox/fesm2022/dereekb-dbx-form-mapbox.mjs +96 -111
  137. package/mapbox/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -1
  138. package/mapbox/lib/field/latlng/latlng.field.component.d.ts +4 -6
  139. package/mapbox/lib/field/latlng/latlng.field.marker.component.d.ts +1 -2
  140. package/mapbox/lib/field/zoom/zoom.field.component.d.ts +2 -3
  141. package/mapbox/package.json +1 -1
  142. package/package.json +1 -1
  143. package/esm2022/lib/formly/field/wrapper/expandable.wrapper.component.mjs +0 -39
  144. package/esm2022/lib/formly/field/wrapper/expandable.wrapper.delegate.mjs +0 -58
@@ -1,7 +1,7 @@
1
1
  import { asArray, filterMaybeValues, isISO8601DayStringStart, mapIdentityFunction } from '@dereekb/util';
2
2
  import { dateFromLogicalDate, DateTimeMinuteInstance, guessCurrentTimezone, readableTimeStringToDate, toLocalReadableTimeString, utcDayForDate, safeToJsDate, findMinDate, findMaxDate, isSameDateHoursAndMinutes, getTimezoneAbbreviation, isSameDateDay, dateTimezoneUtcNormal, toJsDayDate, isSameDate, dateTimeMinuteWholeDayDecisionFunction } from '@dereekb/date';
3
3
  import { switchMap, shareReplay, map, startWith, tap, first, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, combineLatest, Subject, merge, interval, of, combineLatestWith, filter, skip } from 'rxjs';
4
- import { ChangeDetectorRef, Component } from '@angular/core';
4
+ import { ChangeDetectorRef, Component, inject } from '@angular/core';
5
5
  import { FormControl, Validators } from '@angular/forms';
6
6
  import { FieldType } from '@ngx-formly/material';
7
7
  import { addMinutes, startOfDay, addDays } from 'date-fns';
@@ -12,19 +12,18 @@ import { DbxDateTimeValueMode, dbxDateTimeInputValueParseFactory, dbxDateTimeIsS
12
12
  import { streamValueFromControl } from '../../../../form/form.angular.util';
13
13
  import { toggleDisableFormControl } from '../../../../form/form';
14
14
  import * as i0 from "@angular/core";
15
- import * as i1 from "./datetime.field.service";
16
- import * as i2 from "@angular/common";
17
- import * as i3 from "@angular/forms";
18
- import * as i4 from "@angular/material/input";
19
- import * as i5 from "@angular/material/form-field";
20
- import * as i6 from "@angular/material/divider";
21
- import * as i7 from "@angular/material/button";
22
- import * as i8 from "@angular/material/datepicker";
23
- import * as i9 from "@angular/material/menu";
24
- import * as i10 from "@angular/material/icon";
25
- import * as i11 from "@ngbracket/ngx-layout/flex";
26
- import * as i12 from "@ngbracket/ngx-layout/extended";
27
- import * as i13 from "@dereekb/dbx-core";
15
+ import * as i1 from "@angular/common";
16
+ import * as i2 from "@angular/forms";
17
+ import * as i3 from "@angular/material/input";
18
+ import * as i4 from "@angular/material/form-field";
19
+ import * as i5 from "@angular/material/divider";
20
+ import * as i6 from "@angular/material/button";
21
+ import * as i7 from "@angular/material/datepicker";
22
+ import * as i8 from "@angular/material/menu";
23
+ import * as i9 from "@angular/material/icon";
24
+ import * as i10 from "@ngbracket/ngx-layout/flex";
25
+ import * as i11 from "@ngbracket/ngx-layout/extended";
26
+ import * as i12 from "@dereekb/dbx-core";
28
27
  export var DbxDateTimeFieldTimeMode;
29
28
  (function (DbxDateTimeFieldTimeMode) {
30
29
  /**
@@ -67,6 +66,81 @@ export const DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR = 'dateTimeFieldDate
67
66
  */
68
67
  export const DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR = 'dateTimeFieldTimeNotInRange';
69
68
  export class DbxDateTimeFieldComponent extends FieldType {
69
+ cdRef = inject(ChangeDetectorRef);
70
+ dbxDateTimeFieldConfigService = inject(DbxDateTimeFieldMenuPresetsService);
71
+ _sub = new SubscriptionObject();
72
+ _valueSub = new SubscriptionObject();
73
+ _autoFillDateSync = new SubscriptionObject();
74
+ _config = new BehaviorSubject(undefined);
75
+ latestConfig$ = this._config.pipe(switchMapMaybeDefault(), distinctUntilChanged(), shareReplay(1));
76
+ _syncConfigObs = new BehaviorSubject(undefined);
77
+ _defaultTimezone = new BehaviorSubject(undefined);
78
+ _timeDate = new BehaviorSubject(undefined);
79
+ _presets = new BehaviorSubject(of([]));
80
+ _fullDayInputCtrl;
81
+ _fullDayControlObs = new BehaviorSubject(undefined);
82
+ fullDayControl$ = this._fullDayControlObs.pipe(filterMaybe());
83
+ _offset = new BehaviorSubject(0);
84
+ _formControlObs = new BehaviorSubject(undefined);
85
+ formControl$ = this._formControlObs.pipe(filterMaybe());
86
+ _cleared = new Subject();
87
+ _updateTime = new Subject();
88
+ _resyncTimeInputSub = new SubscriptionObject();
89
+ _resyncTimeInput = new Subject();
90
+ timeErrorStateMatcher = {
91
+ isErrorState: (control, form) => {
92
+ if (control) {
93
+ return (control.invalid && (control.dirty || control.touched)) || this.errorStateMatcher.isErrorState(this.formControl, form);
94
+ }
95
+ else {
96
+ return false;
97
+ }
98
+ }
99
+ };
100
+ resyncTimeInput$ = this._resyncTimeInput.pipe(debounceTime(200), shareReplay(1));
101
+ _configUpdateTimeSync = new SubscriptionObject(this.latestConfig$.pipe(skip(1)).subscribe((x) => {
102
+ this._updateTime.next();
103
+ }));
104
+ timezone$ = this._defaultTimezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(map((defaultTimezone) => {
105
+ return defaultTimezone ?? guessCurrentTimezone();
106
+ }), distinctUntilChanged(), shareReplay(1));
107
+ timezoneInstance$ = this.timezone$.pipe(map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)), shareReplay(1));
108
+ timeDate$ = this._timeDate.pipe(switchMapMaybeDefault(), switchMap((x) => {
109
+ let obs;
110
+ if (x) {
111
+ // if the string is not a date string, then treat it as a path
112
+ if ((typeof x === 'string' && !isISO8601DayStringStart(x)) || isDbxDateTimeFieldTimeDateConfig(x)) {
113
+ const { path, mapValue } = typeof x === 'string' ? { path: x } : x;
114
+ obs =
115
+ streamValueFromControl(this.form, path)?.pipe(map(mapValue ?? mapIdentityFunction()), map((x) => (x ? toJsDayDate(x) : undefined))) ?? of(undefined);
116
+ }
117
+ else {
118
+ obs = of(toJsDayDate(x));
119
+ }
120
+ }
121
+ else {
122
+ obs = of(undefined);
123
+ }
124
+ return obs;
125
+ }), distinctUntilChanged(isSameDateDay), shareReplay(1));
126
+ valueInSystemTimezone$ = this.formControl$.pipe(map((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))), combineLatestWith(this.timezoneInstance$), switchMap(([x, timezoneInstance]) => {
127
+ return x.pipe(map(dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)));
128
+ }), throttleTime(20, undefined, { leading: true, trailing: true }), // throttle incoming values and timezone changes
129
+ distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
130
+ refreshInteral$ = interval(10 * 1000);
131
+ /**
132
+ * Used to trigger/display visual updates (specifically on timeDistance, etc.).
133
+ */
134
+ displayValue$ = this.refreshInteral$.pipe(
135
+ // every 10 seconds, refresh w/interval
136
+ startWith(0), map(() => new Date().getMinutes()), distinctUntilChanged(), tap(() => this.cdRef.markForCheck()), switchMap(() => this.valueInSystemTimezone$), shareReplay(1));
137
+ timeString$ = this.valueInSystemTimezone$.pipe(map((x) => (x ? toLocalReadableTimeString(x) : '')), distinctUntilChanged(), shareReplay(1));
138
+ dateInputCtrl = new FormControl(null, {
139
+ validators: []
140
+ });
141
+ timeInputCtrl = new FormControl(null, {
142
+ validators: [Validators.pattern(/^(now)$|^([0-9]|(0[0-9])|(1[0-9])|(2[0-3]))(:)?([0-5][0-9])?(\s)?([apAP][Mm])?(\\s)*$/)]
143
+ });
70
144
  get dateLabel() {
71
145
  return this.props.dateLabel ?? 'Date';
72
146
  }
@@ -148,242 +222,165 @@ export class DbxDateTimeFieldComponent extends FieldType {
148
222
  get minuteStep() {
149
223
  return this.field.props.minuteStep ?? this.field.props.step ?? 5;
150
224
  }
151
- constructor(cdRef, dbxDateTimeFieldConfigService) {
152
- super();
153
- this.cdRef = cdRef;
154
- this.dbxDateTimeFieldConfigService = dbxDateTimeFieldConfigService;
155
- this._sub = new SubscriptionObject();
156
- this._valueSub = new SubscriptionObject();
157
- this._autoFillDateSync = new SubscriptionObject();
158
- this._config = new BehaviorSubject(undefined);
159
- this.latestConfig$ = this._config.pipe(switchMapMaybeDefault(), distinctUntilChanged(), shareReplay(1));
160
- this._syncConfigObs = new BehaviorSubject(undefined);
161
- this._defaultTimezone = new BehaviorSubject(undefined);
162
- this._timeDate = new BehaviorSubject(undefined);
163
- this._presets = new BehaviorSubject(of([]));
164
- this._fullDayControlObs = new BehaviorSubject(undefined);
165
- this.fullDayControl$ = this._fullDayControlObs.pipe(filterMaybe());
166
- this._offset = new BehaviorSubject(0);
167
- this._formControlObs = new BehaviorSubject(undefined);
168
- this.formControl$ = this._formControlObs.pipe(filterMaybe());
169
- this._cleared = new Subject();
170
- this._updateTime = new Subject();
171
- this._resyncTimeInputSub = new SubscriptionObject();
172
- this._resyncTimeInput = new Subject();
173
- this.timeErrorStateMatcher = {
174
- isErrorState: (control, form) => {
225
+ fullDay$ = this.fullDayControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), distinctUntilChanged(), shareReplay(1));
226
+ showTimeInput$ = this.fullDay$.pipe(map((x) => !x && this.timeMode !== DbxDateTimeFieldTimeMode.NONE));
227
+ showAddTime$ = this.showTimeInput$.pipe(map((x) => !x && this.timeMode === DbxDateTimeFieldTimeMode.OPTIONAL), shareReplay(1));
228
+ currentDate$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), shareReplay(1));
229
+ date$ = this.currentDate$.pipe(filterMaybe(), shareReplay(1));
230
+ timezoneAbbreviation$ = combineLatest([this.currentDate$, this.timezone$, this.timeDate$]).pipe(map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? date ?? new Date())), distinctUntilChanged(), shareReplay(1));
231
+ dateValue$ = merge(this.date$, this.valueInSystemTimezone$.pipe(skipFirstMaybe())).pipe(map((x) => (x ? startOfDay(x) : null)), distinctUntilChanged(isSameDateDay), shareReplay(1));
232
+ timeInput$ = this._updateTime.pipe(debounceTime(5), map(() => this.timeInputCtrl.value || ''), distinctUntilChanged());
233
+ syncConfigObs$ = this._syncConfigObs.pipe(switchMapMaybeDefault(), shareReplay(1));
234
+ parsedSyncConfigs$ = this.syncConfigObs$.pipe(map((x) => {
235
+ let parsed;
236
+ if (x) {
237
+ parsed = filterMaybeValues(asArray(x).map((y) => {
238
+ const control = this.form.get(y.syncWith);
175
239
  if (control) {
176
- return (control.invalid && (control.dirty || control.touched)) || this.errorStateMatcher.isErrorState(this.formControl, form);
177
- }
178
- else {
179
- return false;
180
- }
181
- }
182
- };
183
- this.resyncTimeInput$ = this._resyncTimeInput.pipe(debounceTime(200), shareReplay(1));
184
- this._configUpdateTimeSync = new SubscriptionObject(this.latestConfig$.pipe(skip(1)).subscribe((x) => {
185
- this._updateTime.next();
186
- }));
187
- this.timezone$ = this._defaultTimezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(map((defaultTimezone) => {
188
- return defaultTimezone ?? guessCurrentTimezone();
189
- }), distinctUntilChanged(), shareReplay(1));
190
- this.timezoneInstance$ = this.timezone$.pipe(map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)), shareReplay(1));
191
- this.timeDate$ = this._timeDate.pipe(switchMapMaybeDefault(), switchMap((x) => {
192
- let obs;
193
- if (x) {
194
- // if the string is not a date string, then treat it as a path
195
- if ((typeof x === 'string' && !isISO8601DayStringStart(x)) || isDbxDateTimeFieldTimeDateConfig(x)) {
196
- const { path, mapValue } = typeof x === 'string' ? { path: x } : x;
197
- obs =
198
- streamValueFromControl(this.form, path)?.pipe(map(mapValue ?? mapIdentityFunction()), map((x) => (x ? toJsDayDate(x) : undefined))) ?? of(undefined);
240
+ return {
241
+ control,
242
+ ...y
243
+ };
199
244
  }
200
245
  else {
201
- obs = of(toJsDayDate(x));
246
+ return undefined;
202
247
  }
248
+ }));
249
+ }
250
+ else {
251
+ parsed = [];
252
+ }
253
+ return parsed;
254
+ }), shareReplay(1));
255
+ syncConfigBeforeValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'before');
256
+ syncConfigAfterValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'after');
257
+ isTimeCleared$ = combineLatest([this.currentDate$, this._timeDate.pipe(startWith(null))]).pipe(switchMap(([date, time]) => {
258
+ const isTimeCleared = Boolean(!date && !time);
259
+ return this._cleared.pipe(map(() => true), startWith(isTimeCleared));
260
+ }), distinctUntilChanged(), shareReplay(1));
261
+ rawDateTime$ = combineLatest([
262
+ this._config.pipe(first(), switchMap(() => (this.timeOnly ? of(null) : this.dateValue$))),
263
+ this.timeInput$.pipe(startWith(null)),
264
+ this.fullDay$,
265
+ this.timeDate$,
266
+ this.isTimeCleared$
267
+ ]).pipe(map(([date, timeString, fullDay, timeDate, isTimeCleared]) => {
268
+ let result;
269
+ if (!isTimeCleared) {
270
+ if (!date || this.timeOnly) {
271
+ date = timeDate ?? new Date(); // use the time date, or default to the current day
203
272
  }
204
- else {
205
- obs = of(undefined);
206
- }
207
- return obs;
208
- }), distinctUntilChanged(isSameDateDay), shareReplay(1));
209
- this.valueInSystemTimezone$ = this.formControl$.pipe(map((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))), combineLatestWith(this.timezoneInstance$), switchMap(([x, timezoneInstance]) => {
210
- return x.pipe(map(dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)));
211
- }), throttleTime(20, undefined, { leading: true, trailing: true }), // throttle incoming values and timezone changes
212
- distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
213
- this.refreshInteral$ = interval(10 * 1000);
214
- /**
215
- * Used to trigger/display visual updates (specifically on timeDistance, etc.).
216
- */
217
- this.displayValue$ = this.refreshInteral$.pipe(
218
- // every 10 seconds, refresh w/interval
219
- startWith(0), map(() => new Date().getMinutes()), distinctUntilChanged(), tap(() => this.cdRef.markForCheck()), switchMap(() => this.valueInSystemTimezone$), shareReplay(1));
220
- this.timeString$ = this.valueInSystemTimezone$.pipe(map((x) => (x ? toLocalReadableTimeString(x) : '')), distinctUntilChanged(), shareReplay(1));
221
- this.dateInputCtrl = new FormControl(null, {
222
- validators: []
223
- });
224
- this.timeInputCtrl = new FormControl(null, {
225
- validators: [Validators.pattern(/^(now)$|^([0-9]|(0[0-9])|(1[0-9])|(2[0-3]))(:)?([0-5][0-9])?(\s)?([apAP][Mm])?(\\s)*$/)]
226
- });
227
- this.fullDay$ = this.fullDayControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), distinctUntilChanged(), shareReplay(1));
228
- this.showTimeInput$ = this.fullDay$.pipe(map((x) => !x && this.timeMode !== DbxDateTimeFieldTimeMode.NONE));
229
- this.showAddTime$ = this.showTimeInput$.pipe(map((x) => !x && this.timeMode === DbxDateTimeFieldTimeMode.OPTIONAL), shareReplay(1));
230
- this.currentDate$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), shareReplay(1));
231
- this.date$ = this.currentDate$.pipe(filterMaybe(), shareReplay(1));
232
- this.timezoneAbbreviation$ = combineLatest([this.currentDate$, this.timezone$, this.timeDate$]).pipe(map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? date ?? new Date())), distinctUntilChanged(), shareReplay(1));
233
- this.dateValue$ = merge(this.date$, this.valueInSystemTimezone$.pipe(skipFirstMaybe())).pipe(map((x) => (x ? startOfDay(x) : null)), distinctUntilChanged(isSameDateDay), shareReplay(1));
234
- this.timeInput$ = this._updateTime.pipe(debounceTime(5), map(() => this.timeInputCtrl.value || ''), distinctUntilChanged());
235
- this.syncConfigObs$ = this._syncConfigObs.pipe(switchMapMaybeDefault(), shareReplay(1));
236
- this.parsedSyncConfigs$ = this.syncConfigObs$.pipe(map((x) => {
237
- let parsed;
238
- if (x) {
239
- parsed = filterMaybeValues(asArray(x).map((y) => {
240
- const control = this.form.get(y.syncWith);
241
- if (control) {
242
- return {
243
- control,
244
- ...y
245
- };
273
+ if (date) {
274
+ if (fullDay) {
275
+ if (this.dateTimeField.fullDayInUTC) {
276
+ result = utcDayForDate(date);
246
277
  }
247
278
  else {
248
- return undefined;
279
+ result = startOfDay(date);
249
280
  }
250
- }));
251
- }
252
- else {
253
- parsed = [];
254
- }
255
- return parsed;
256
- }), shareReplay(1));
257
- this.syncConfigBeforeValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'before');
258
- this.syncConfigAfterValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'after');
259
- this.isTimeCleared$ = combineLatest([this.currentDate$, this._timeDate.pipe(startWith(null))]).pipe(switchMap(([date, time]) => {
260
- const isTimeCleared = Boolean(!date && !time);
261
- return this._cleared.pipe(map(() => true), startWith(isTimeCleared));
262
- }), distinctUntilChanged(), shareReplay(1));
263
- this.rawDateTime$ = combineLatest([
264
- this._config.pipe(first(), switchMap(() => (this.timeOnly ? of(null) : this.dateValue$))),
265
- this.timeInput$.pipe(startWith(null)),
266
- this.fullDay$,
267
- this.timeDate$,
268
- this.isTimeCleared$
269
- ]).pipe(map(([date, timeString, fullDay, timeDate, isTimeCleared]) => {
270
- let result;
271
- if (!isTimeCleared) {
272
- if (!date || this.timeOnly) {
273
- date = timeDate ?? new Date(); // use the time date, or default to the current day
274
281
  }
275
- if (date) {
276
- if (fullDay) {
277
- if (this.dateTimeField.fullDayInUTC) {
278
- result = utcDayForDate(date);
279
- }
280
- else {
281
- result = startOfDay(date);
282
- }
283
- }
284
- else if (timeString) {
285
- result =
286
- readableTimeStringToDate(timeString, {
287
- date,
288
- useSystemTimezone: true
289
- }) ?? date;
290
- }
291
- else if (!this.timeOnly) {
292
- if (this.timeMode !== DbxDateTimeFieldTimeMode.REQUIRED) {
293
- // only autofill the date if the time is marked as required (and the time string is empty)
294
- result = date;
295
- }
296
- }
282
+ else if (timeString) {
283
+ result =
284
+ readableTimeStringToDate(timeString, {
285
+ date,
286
+ useSystemTimezone: true
287
+ }) ?? date;
297
288
  }
298
- }
299
- return result;
300
- }), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
301
- this.dateTimePickerConfig$ = combineLatest([this._config.pipe(switchMapMaybeObs()), this.syncConfigBeforeValue$, this.syncConfigAfterValue$]).pipe(map(([x, dateInputMin, dateInputMax]) => {
302
- let result = x;
303
- if (dateInputMin != null || dateInputMax != null) {
304
- const { min: limitMin, max: limitMax } = x?.limits ?? {};
305
- const min = findMinDate([dateInputMin, dateFromLogicalDate(limitMin)]);
306
- const max = findMaxDate([dateInputMax, dateFromLogicalDate(limitMax)]);
307
- result = {
308
- ...x,
309
- limits: {
310
- ...x?.limits,
311
- min,
312
- max
313
- }
314
- };
315
- }
316
- return result;
317
- }), distinctUntilChanged(), shareReplay(1));
318
- this.dateInputMin$ = this.dateTimePickerConfig$.pipe(map((x) => (x?.limits?.min ?? null)), distinctUntilChanged(isSameDate), shareReplay(1));
319
- this.dateInputMax$ = this.dateTimePickerConfig$.pipe(map((x) => (x?.limits?.max ?? null)), distinctUntilChanged(isSameDate), shareReplay(1));
320
- /**
321
- * Whether or not there is a limited min/max date range applied/available.
322
- */
323
- this.hasRestrictedDateRange$ = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(map(([a, b]) => Boolean(a || b)), distinctUntilChanged(), shareReplay(1));
324
- this.dateMinAndMaxIsSameDay$ = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(map(([a, b]) => Boolean(a && b) && isSameDateDay(a, b)), distinctUntilChanged(), shareReplay(1));
325
- this.pickerFilter$ = this.dateTimePickerConfig$.pipe(distinctUntilChanged(), map((x) => {
326
- if (x) {
327
- const filter = dateTimeMinuteWholeDayDecisionFunction(x, false);
328
- return (x) => (x != null ? filter(x) : true);
329
- }
330
- else {
331
- return () => true;
332
- }
333
- }), shareReplay(1));
334
- this.defaultPickerFilter = () => true;
335
- this.timeOutput$ = combineLatest([this.rawDateTime$, this._offset, this.dateTimePickerConfig$]).pipe(throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }), distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0 && current[2] === next[2]), tap(([, stepsOffset]) => (stepsOffset ? this._offset.next(0) : 0)), map(([date, stepsOffset, config]) => {
336
- if (date != null) {
337
- const instance = new DateTimeMinuteInstance({
338
- date,
339
- ...config,
340
- roundDownToMinute: true
341
- });
342
- // only clamp when the steps offset is set
343
- if (stepsOffset) {
344
- date = instance.clamp(date);
345
- const minutes = stepsOffset * this.minuteStep;
346
- if (minutes != 0) {
347
- date = addMinutes(date, minutes);
348
- date = instance.clamp(date); // clamp the date again
289
+ else if (!this.timeOnly) {
290
+ if (this.timeMode !== DbxDateTimeFieldTimeMode.REQUIRED) {
291
+ // only autofill the date if the time is marked as required (and the time string is empty)
292
+ result = date;
349
293
  }
350
294
  }
351
295
  }
352
- return date;
353
- }), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
354
- this.dateTimePickerInstance$ = this.dateTimePickerConfig$.pipe(map((config) => {
355
- return new DateTimeMinuteInstance({
296
+ }
297
+ return result;
298
+ }), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
299
+ dateTimePickerConfig$ = combineLatest([this._config.pipe(switchMapMaybeObs()), this.syncConfigBeforeValue$, this.syncConfigAfterValue$]).pipe(map(([x, dateInputMin, dateInputMax]) => {
300
+ let result = x;
301
+ if (dateInputMin != null || dateInputMax != null) {
302
+ const { min: limitMin, max: limitMax } = x?.limits ?? {};
303
+ const min = findMinDate([dateInputMin, dateFromLogicalDate(limitMin)]);
304
+ const max = findMaxDate([dateInputMax, dateFromLogicalDate(limitMax)]);
305
+ result = {
306
+ ...x,
307
+ limits: {
308
+ ...x?.limits,
309
+ min,
310
+ max
311
+ }
312
+ };
313
+ }
314
+ return result;
315
+ }), distinctUntilChanged(), shareReplay(1));
316
+ dateInputMin$ = this.dateTimePickerConfig$.pipe(map((x) => (x?.limits?.min ?? null)), distinctUntilChanged(isSameDate), shareReplay(1));
317
+ dateInputMax$ = this.dateTimePickerConfig$.pipe(map((x) => (x?.limits?.max ?? null)), distinctUntilChanged(isSameDate), shareReplay(1));
318
+ /**
319
+ * Whether or not there is a limited min/max date range applied/available.
320
+ */
321
+ hasRestrictedDateRange$ = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(map(([a, b]) => Boolean(a || b)), distinctUntilChanged(), shareReplay(1));
322
+ dateMinAndMaxIsSameDay$ = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(map(([a, b]) => Boolean(a && b) && isSameDateDay(a, b)), distinctUntilChanged(), shareReplay(1));
323
+ pickerFilter$ = this.dateTimePickerConfig$.pipe(distinctUntilChanged(), map((x) => {
324
+ if (x) {
325
+ const filter = dateTimeMinuteWholeDayDecisionFunction(x, false);
326
+ return (x) => (x != null ? filter(x) : true);
327
+ }
328
+ else {
329
+ return () => true;
330
+ }
331
+ }), shareReplay(1));
332
+ defaultPickerFilter = () => true;
333
+ timeOutput$ = combineLatest([this.rawDateTime$, this._offset, this.dateTimePickerConfig$]).pipe(throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }), distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0 && current[2] === next[2]), tap(([, stepsOffset]) => (stepsOffset ? this._offset.next(0) : 0)), map(([date, stepsOffset, config]) => {
334
+ if (date != null) {
335
+ const instance = new DateTimeMinuteInstance({
336
+ date,
356
337
  ...config,
357
338
  roundDownToMinute: true
358
339
  });
359
- }), shareReplay(1));
360
- this.hasEmptyDisplayValue$ = this.displayValue$.pipe(map((x) => !x), distinctUntilChanged(), shareReplay(1));
361
- this.presets$ = this._presets.pipe(switchMapMaybeObs(), map((x) => x.map(dateTimePreset)), shareReplay(1));
362
- this.showClearButton$ = this.hasEmptyDisplayValue$.pipe(map((x) => Boolean(this.showClearButton && !x)), distinctUntilChanged(), shareReplay(1));
363
- this.canAutofillDateWithOnlyAvailableDate$ = this.dateMinAndMaxIsSameDay$;
364
- this.showDateInput$ = this.dateMinAndMaxIsSameDay$.pipe(map((dateMinAndMaxIsSameDay) => {
365
- return this.showDateInput && (this.alwaysShowDateInput || !dateMinAndMaxIsSameDay);
366
- }), distinctUntilChanged(), shareReplay(1));
367
- this.currentErrorMessage$ = this.formControl$.pipe(switchMap((formControl) => formControl.statusChanges.pipe(filter((x) => x === 'INVALID' || x === 'VALID'), map((x) => {
368
- let currentErrorMessage;
369
- if (x === 'INVALID') {
370
- if (this.formControl.hasError('required')) {
371
- currentErrorMessage = 'Date is required';
372
- }
373
- else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR)) {
374
- currentErrorMessage = 'Date does not fall on an available dates in schedule.';
375
- }
376
- else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR)) {
377
- currentErrorMessage = 'Time is not valid for the given date.';
378
- }
379
- else {
380
- currentErrorMessage = 'The given date and time is invalid.';
340
+ // only clamp when the steps offset is set
341
+ if (stepsOffset) {
342
+ date = instance.clamp(date);
343
+ const minutes = stepsOffset * this.minuteStep;
344
+ if (minutes != 0) {
345
+ date = addMinutes(date, minutes);
346
+ date = instance.clamp(date); // clamp the date again
381
347
  }
382
348
  }
383
- return currentErrorMessage;
384
- }))), startWith(undefined), shareReplay(1));
385
- this.hasError$ = this.currentErrorMessage$.pipe(map((x) => Boolean(x)), distinctUntilChanged(), shareReplay(1));
386
- }
349
+ }
350
+ return date;
351
+ }), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
352
+ dateTimePickerInstance$ = this.dateTimePickerConfig$.pipe(map((config) => {
353
+ return new DateTimeMinuteInstance({
354
+ ...config,
355
+ roundDownToMinute: true
356
+ });
357
+ }), shareReplay(1));
358
+ hasEmptyDisplayValue$ = this.displayValue$.pipe(map((x) => !x), distinctUntilChanged(), shareReplay(1));
359
+ presets$ = this._presets.pipe(switchMapMaybeObs(), map((x) => x.map(dateTimePreset)), shareReplay(1));
360
+ showClearButton$ = this.hasEmptyDisplayValue$.pipe(map((x) => Boolean(this.showClearButton && !x)), distinctUntilChanged(), shareReplay(1));
361
+ canAutofillDateWithOnlyAvailableDate$ = this.dateMinAndMaxIsSameDay$;
362
+ showDateInput$ = this.dateMinAndMaxIsSameDay$.pipe(map((dateMinAndMaxIsSameDay) => {
363
+ return this.showDateInput && (this.alwaysShowDateInput || !dateMinAndMaxIsSameDay);
364
+ }), distinctUntilChanged(), shareReplay(1));
365
+ currentErrorMessage$ = this.formControl$.pipe(switchMap((formControl) => formControl.statusChanges.pipe(filter((x) => x === 'INVALID' || x === 'VALID'), map((x) => {
366
+ let currentErrorMessage;
367
+ if (x === 'INVALID') {
368
+ if (this.formControl.hasError('required')) {
369
+ currentErrorMessage = 'Date is required';
370
+ }
371
+ else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR)) {
372
+ currentErrorMessage = 'Date does not fall on an available dates in schedule.';
373
+ }
374
+ else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR)) {
375
+ currentErrorMessage = 'Time is not valid for the given date.';
376
+ }
377
+ else {
378
+ currentErrorMessage = 'The given date and time is invalid.';
379
+ }
380
+ }
381
+ return currentErrorMessage;
382
+ }))), startWith(undefined), shareReplay(1));
383
+ hasError$ = this.currentErrorMessage$.pipe(map((x) => Boolean(x)), distinctUntilChanged(), shareReplay(1));
387
384
  ngOnInit() {
388
385
  this._formControlObs.next(this.formControl);
389
386
  const inputPickerConfig = this.dateTimeField.pickerConfig;
@@ -663,11 +660,11 @@ export class DbxDateTimeFieldComponent extends FieldType {
663
660
  clearValue() {
664
661
  this._cleared.next();
665
662
  }
666
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDateTimeFieldComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DbxDateTimeFieldMenuPresetsService }], target: i0.ɵɵFactoryTarget.Component }); }
667
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxDateTimeFieldComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutGap=\"6px grid\" fxLayoutAlign=\"space-evenly stretch\">\n <!-- Date -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput$ | async\">\n <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n </div>\n <!-- Time -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"(showDateInput$ | async) ? '50' : '100'\">\n <ng-container *ngIf=\"showTimeInput$ | async\">\n <ng-container *ngTemplateOutlet=\"timeMenuAndInputTemplate\"></ng-container>\n </ng-container>\n <div *ngIf=\"showAddTime$ | async\" class=\"add-time-button-wrapper\">\n <button mat-button class=\"mat-datepicker-button-highlight dbx-button-spacer add-time-button\" ngClass.lt-sm=\"add-time-button-full\" (click)=\"addTime()\">\n <mat-icon>timer</mat-icon>\n Add Time\n </button>\n </div>\n </div>\n <!-- Date Hint -->\n <ng-container [ngSwitch]=\"hasError$ | async\">\n <ng-container *ngSwitchCase=\"false\">\n <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n <div class=\"dbx-hint\">\n <ng-container [ngSwitch]=\"hasEmptyDisplayValue$ | async\">\n <ng-container *ngSwitchCase=\"true\">\n <span class=\"dbx-small\">No date/time set</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"false\">\n <ng-container [ngSwitch]=\"fullDay$ | async\">\n <small *ngSwitchCase=\"true\">\n <b class=\"dbx-ok\">{{ allDayLabel }}</b>\n {{ displayValue$ | async | date: 'fullDate' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | dateDistance }})\n </small>\n <small *ngSwitchCase=\"false\">\n <ng-container *ngIf=\"displayValue$ | async\">\n <b class=\"dbx-ok\">{{ atTimeLabel }}</b>\n {{ displayValue$ | async | date: 'medium' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | timeDistance }})\n </ng-container>\n </small>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"true\">\n <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n </ng-container>\n </ng-container>\n</div>\n\n<!-- Date Input Template -->\n<ng-template #dateInputTemplate>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ dateLabel }}</mat-label>\n <input #dateInput matInput [disabled]=\"disabled\" [required]=\"isDateRequired\" [min]=\"dateInputMin$ | async\" [max]=\"dateInputMax$ | async\" [matDatepicker]=\"picker\" [matDatepickerFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" (dateChange)=\"datePicked($event)\" [value]=\"dateValue$ | async\" (keydown)=\"keydownOnDateInput($event)\" />\n <mat-datepicker #picker></mat-datepicker>\n <button matPrefix class=\"dbx-datetime-row-button\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n <mat-icon>calendar_today</mat-icon>\n </button>\n <button matSuffix *ngIf=\"showClearButton$ | async\" class=\"dbx-datetime-clear-button\" mat-icon-button aria-label=\"clears the date and time menu\" [disabled]=\"disabled\" (click)=\"clearValue()\">\n <mat-icon>clear</mat-icon>\n </button>\n <span matTextSuffix *ngIf=\"!(showTimeInput$ | async)\">\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n </mat-form-field>\n</ng-template>\n\n<!-- Time Menu/Input Template -->\n<ng-template #timeMenuAndInputTemplate>\n <mat-menu #timemenu=\"matMenu\">\n <ng-container *ngIf=\"timeMode === 'optional'\">\n <button mat-menu-item (click)=\"removeTime()\">\n <span>Remove Time</span>\n </button>\n <mat-divider></mat-divider>\n </ng-container>\n <ng-container *ngFor=\"let preset of presets$ | async\">\n <button mat-menu-item (click)=\"selectPreset(preset)\">{{ preset.label | getValue }}</button>\n </ng-container>\n </mat-menu>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ timeLabel }}</mat-label>\n <input #timeInput [errorStateMatcher]=\"timeErrorStateMatcher\" matInput [required]=\"isTimeRequired\" [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n <button matPrefix class=\"dbx-datetime-row-button\" mat-icon-button [matMenuTriggerFor]=\"timemenu\" aria-label=\"opens the time menu\" [disabled]=\"disabled\">\n <mat-icon>timer</mat-icon>\n </button>\n <span matTextSuffix>\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n <mat-error *ngIf=\"timeInputCtrl.hasError('pattern')\">The input time is not recognizable.</mat-error>\n </mat-form-field>\n</ng-template>\n\n<!-- Timezone Suffix -->\n<ng-template #timezoneSuffixTemplate>\n <span *ngIf=\"showTimezone\" class=\"dbx-datetime-timezone dbx-faint\">{{ timezoneAbbreviation$ | async }}</span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i5.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i6.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i7.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i8.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i8.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i10.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i11.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i11.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i11.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i11.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i12.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.DatePipe, name: "date" }, { kind: "pipe", type: i13.DateDistancePipe, name: "dateDistance" }, { kind: "pipe", type: i13.TimeDistancePipe, name: "timeDistance" }, { kind: "pipe", type: i13.GetValuePipe, name: "getValue" }] }); }
663
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDateTimeFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
664
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxDateTimeFieldComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutGap=\"6px grid\" fxLayoutAlign=\"space-evenly stretch\">\n <!-- Date -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput$ | async\">\n <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n </div>\n <!-- Time -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"(showDateInput$ | async) ? '50' : '100'\">\n <ng-container *ngIf=\"showTimeInput$ | async\">\n <ng-container *ngTemplateOutlet=\"timeMenuAndInputTemplate\"></ng-container>\n </ng-container>\n <div *ngIf=\"showAddTime$ | async\" class=\"add-time-button-wrapper\">\n <button mat-button class=\"mat-datepicker-button-highlight dbx-button-spacer add-time-button\" ngClass.lt-sm=\"add-time-button-full\" (click)=\"addTime()\">\n <mat-icon>timer</mat-icon>\n Add Time\n </button>\n </div>\n </div>\n <!-- Date Hint -->\n <ng-container [ngSwitch]=\"hasError$ | async\">\n <ng-container *ngSwitchCase=\"false\">\n <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n <div class=\"dbx-hint\">\n <ng-container [ngSwitch]=\"hasEmptyDisplayValue$ | async\">\n <ng-container *ngSwitchCase=\"true\">\n <span class=\"dbx-small\">No date/time set</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"false\">\n <ng-container [ngSwitch]=\"fullDay$ | async\">\n <small *ngSwitchCase=\"true\">\n <b class=\"dbx-ok\">{{ allDayLabel }}</b>\n {{ displayValue$ | async | date: 'fullDate' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | dateDistance }})\n </small>\n <small *ngSwitchCase=\"false\">\n <ng-container *ngIf=\"displayValue$ | async\">\n <b class=\"dbx-ok\">{{ atTimeLabel }}</b>\n {{ displayValue$ | async | date: 'medium' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | timeDistance }})\n </ng-container>\n </small>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"true\">\n <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n </ng-container>\n </ng-container>\n</div>\n\n<!-- Date Input Template -->\n<ng-template #dateInputTemplate>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ dateLabel }}</mat-label>\n <input #dateInput matInput [disabled]=\"disabled\" [required]=\"isDateRequired\" [min]=\"dateInputMin$ | async\" [max]=\"dateInputMax$ | async\" [matDatepicker]=\"picker\" [matDatepickerFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" (dateChange)=\"datePicked($event)\" [value]=\"dateValue$ | async\" (keydown)=\"keydownOnDateInput($event)\" />\n <mat-datepicker #picker></mat-datepicker>\n <button matPrefix class=\"dbx-datetime-row-button\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n <mat-icon>calendar_today</mat-icon>\n </button>\n <button matSuffix *ngIf=\"showClearButton$ | async\" class=\"dbx-datetime-clear-button\" mat-icon-button aria-label=\"clears the date and time menu\" [disabled]=\"disabled\" (click)=\"clearValue()\">\n <mat-icon>clear</mat-icon>\n </button>\n <span matTextSuffix *ngIf=\"!(showTimeInput$ | async)\">\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n </mat-form-field>\n</ng-template>\n\n<!-- Time Menu/Input Template -->\n<ng-template #timeMenuAndInputTemplate>\n <mat-menu #timemenu=\"matMenu\">\n <ng-container *ngIf=\"timeMode === 'optional'\">\n <button mat-menu-item (click)=\"removeTime()\">\n <span>Remove Time</span>\n </button>\n <mat-divider></mat-divider>\n </ng-container>\n <ng-container *ngFor=\"let preset of presets$ | async\">\n <button mat-menu-item (click)=\"selectPreset(preset)\">{{ preset.label | getValue }}</button>\n </ng-container>\n </mat-menu>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ timeLabel }}</mat-label>\n <input #timeInput [errorStateMatcher]=\"timeErrorStateMatcher\" matInput [required]=\"isTimeRequired\" [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n <button matPrefix class=\"dbx-datetime-row-button\" mat-icon-button [matMenuTriggerFor]=\"timemenu\" aria-label=\"opens the time menu\" [disabled]=\"disabled\">\n <mat-icon>timer</mat-icon>\n </button>\n <span matTextSuffix>\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n <mat-error *ngIf=\"timeInputCtrl.hasError('pattern')\">The input time is not recognizable.</mat-error>\n </mat-form-field>\n</ng-template>\n\n<!-- Timezone Suffix -->\n<ng-template #timezoneSuffixTemplate>\n <span *ngIf=\"showTimezone\" class=\"dbx-datetime-timezone dbx-faint\">{{ timezoneAbbreviation$ | async }}</span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { 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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i5.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i7.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i8.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i8.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i8.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i10.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i10.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i10.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i10.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i11.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.DatePipe, name: "date" }, { kind: "pipe", type: i12.DateDistancePipe, name: "dateDistance" }, { kind: "pipe", type: i12.TimeDistancePipe, name: "timeDistance" }, { kind: "pipe", type: i12.GetValuePipe, name: "getValue" }] });
668
665
  }
669
666
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDateTimeFieldComponent, decorators: [{
670
667
  type: Component,
671
668
  args: [{ template: "<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutGap=\"6px grid\" fxLayoutAlign=\"space-evenly stretch\">\n <!-- Date -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput$ | async\">\n <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n </div>\n <!-- Time -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"(showDateInput$ | async) ? '50' : '100'\">\n <ng-container *ngIf=\"showTimeInput$ | async\">\n <ng-container *ngTemplateOutlet=\"timeMenuAndInputTemplate\"></ng-container>\n </ng-container>\n <div *ngIf=\"showAddTime$ | async\" class=\"add-time-button-wrapper\">\n <button mat-button class=\"mat-datepicker-button-highlight dbx-button-spacer add-time-button\" ngClass.lt-sm=\"add-time-button-full\" (click)=\"addTime()\">\n <mat-icon>timer</mat-icon>\n Add Time\n </button>\n </div>\n </div>\n <!-- Date Hint -->\n <ng-container [ngSwitch]=\"hasError$ | async\">\n <ng-container *ngSwitchCase=\"false\">\n <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n <div class=\"dbx-hint\">\n <ng-container [ngSwitch]=\"hasEmptyDisplayValue$ | async\">\n <ng-container *ngSwitchCase=\"true\">\n <span class=\"dbx-small\">No date/time set</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"false\">\n <ng-container [ngSwitch]=\"fullDay$ | async\">\n <small *ngSwitchCase=\"true\">\n <b class=\"dbx-ok\">{{ allDayLabel }}</b>\n {{ displayValue$ | async | date: 'fullDate' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | dateDistance }})\n </small>\n <small *ngSwitchCase=\"false\">\n <ng-container *ngIf=\"displayValue$ | async\">\n <b class=\"dbx-ok\">{{ atTimeLabel }}</b>\n {{ displayValue$ | async | date: 'medium' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | timeDistance }})\n </ng-container>\n </small>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"true\">\n <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n </ng-container>\n </ng-container>\n</div>\n\n<!-- Date Input Template -->\n<ng-template #dateInputTemplate>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ dateLabel }}</mat-label>\n <input #dateInput matInput [disabled]=\"disabled\" [required]=\"isDateRequired\" [min]=\"dateInputMin$ | async\" [max]=\"dateInputMax$ | async\" [matDatepicker]=\"picker\" [matDatepickerFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" (dateChange)=\"datePicked($event)\" [value]=\"dateValue$ | async\" (keydown)=\"keydownOnDateInput($event)\" />\n <mat-datepicker #picker></mat-datepicker>\n <button matPrefix class=\"dbx-datetime-row-button\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n <mat-icon>calendar_today</mat-icon>\n </button>\n <button matSuffix *ngIf=\"showClearButton$ | async\" class=\"dbx-datetime-clear-button\" mat-icon-button aria-label=\"clears the date and time menu\" [disabled]=\"disabled\" (click)=\"clearValue()\">\n <mat-icon>clear</mat-icon>\n </button>\n <span matTextSuffix *ngIf=\"!(showTimeInput$ | async)\">\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n </mat-form-field>\n</ng-template>\n\n<!-- Time Menu/Input Template -->\n<ng-template #timeMenuAndInputTemplate>\n <mat-menu #timemenu=\"matMenu\">\n <ng-container *ngIf=\"timeMode === 'optional'\">\n <button mat-menu-item (click)=\"removeTime()\">\n <span>Remove Time</span>\n </button>\n <mat-divider></mat-divider>\n </ng-container>\n <ng-container *ngFor=\"let preset of presets$ | async\">\n <button mat-menu-item (click)=\"selectPreset(preset)\">{{ preset.label | getValue }}</button>\n </ng-container>\n </mat-menu>\n <mat-form-field class=\"dbx-datetime-row-field\">\n <mat-label>{{ timeLabel }}</mat-label>\n <input #timeInput [errorStateMatcher]=\"timeErrorStateMatcher\" matInput [required]=\"isTimeRequired\" [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n <button matPrefix class=\"dbx-datetime-row-button\" mat-icon-button [matMenuTriggerFor]=\"timemenu\" aria-label=\"opens the time menu\" [disabled]=\"disabled\">\n <mat-icon>timer</mat-icon>\n </button>\n <span matTextSuffix>\n <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n </span>\n <mat-error *ngIf=\"timeInputCtrl.hasError('pattern')\">The input time is not recognizable.</mat-error>\n </mat-form-field>\n</ng-template>\n\n<!-- Timezone Suffix -->\n<ng-template #timezoneSuffixTemplate>\n <span *ngIf=\"showTimezone\" class=\"dbx-datetime-timezone dbx-faint\">{{ timezoneAbbreviation$ | async }}</span>\n</ng-template>\n" }]
672
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DbxDateTimeFieldMenuPresetsService }]; } });
673
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/datetime.field.component.ts","../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/datetime.field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { type Maybe, type ReadableTimeString, type ArrayOrValue, type ISO8601DateString, asArray, filterMaybeValues, type DecisionFunction, type Milliseconds, type TimezoneString, type LogicalDate, type DateOrDayString, isISO8601DayStringStart, type MapFunction, mapIdentityFunction, MinuteOfDay, UnixDateTimeNumber, ISO8601DayString } from '@dereekb/util';\nimport { dateFromLogicalDate, DateTimeMinuteConfig, DateTimeMinuteInstance, guessCurrentTimezone, readableTimeStringToDate, toLocalReadableTimeString, utcDayForDate, safeToJsDate, findMinDate, findMaxDate, isSameDateHoursAndMinutes, getTimezoneAbbreviation, isSameDateDay, dateTimezoneUtcNormal, DateTimezoneUtcNormalInstance, toJsDayDate, isSameDate, dateTimeMinuteWholeDayDecisionFunction } from '@dereekb/date';\nimport { switchMap, shareReplay, map, startWith, tap, first, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, Observable, combineLatest, Subject, merge, interval, of, combineLatestWith, filter, skip } from 'rxjs';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\nimport { AbstractControl, FormControl, Validators, FormGroup, ValidationErrors } from '@angular/forms';\nimport { FieldType } from '@ngx-formly/material';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { MatDatepickerInputEvent } from '@angular/material/datepicker';\nimport { addMinutes, startOfDay, addDays } from 'date-fns';\nimport { asObservableFromGetter, filterMaybe, ObservableOrValueGetter, skipFirstMaybe, SubscriptionObject, switchMapMaybeDefault, switchMapMaybeObs } from '@dereekb/rxjs';\nimport { DateTimePreset, DateTimePresetConfiguration, dateTimePreset } from './datetime';\nimport { DbxDateTimeFieldMenuPresetsService } from './datetime.field.service';\nimport { DbxDateTimeValueMode, dbxDateTimeInputValueParseFactory, dbxDateTimeIsSameDateTimeFieldValue, dbxDateTimeOutputValueFactory } from './date.value';\nimport { FormControlPath, streamValueFromControl } from '../../../../form/form.angular.util';\nimport { toggleDisableFormControl } from '../../../../form/form';\nimport { ErrorStateMatcher } from '@angular/material/core';\n\nexport enum DbxDateTimeFieldTimeMode {\n  /**\n   * Time is required.\n   */\n  REQUIRED = 'required',\n  /**\n   * Time is optional.\n   */\n  OPTIONAL = 'optional',\n  /**\n   * Time is permenantly off.\n   */\n  NONE = 'none'\n}\n\nexport type DbxDateTimePickerConfiguration = Omit<DateTimeMinuteConfig, 'date'>;\n\nexport type DbxDateTimeFieldSyncType = 'before' | 'after';\n\nexport interface DbxDateTimeFieldSyncField {\n  /**\n   * Field key/path to sync with/against.\n   */\n  readonly syncWith: string;\n  /**\n   * How to sync against the other field.\n   */\n  readonly syncType: DbxDateTimeFieldSyncType;\n}\n\n/**\n * Configuration for the time date field that has a reference and optional map function to map the value.\n */\nexport interface DbxDateTimeFieldTimeDateConfig<I = unknown> {\n  readonly path: FormControlPath;\n  readonly mapValue?: MapFunction<I, Maybe<DateOrDayString>>;\n}\n\nexport function isDbxDateTimeFieldTimeDateConfig(input: unknown): input is DbxDateTimeFieldTimeDateConfig {\n  return input != null && typeof input === 'object' && typeof (input as DbxDateTimeFieldTimeDateConfig).path === 'string';\n}\n\nexport interface DbxDateTimeFieldProps extends FormlyFieldProps {\n  /**\n   * Custom date label.\n   *\n   * Defaults to Date\n   */\n  readonly dateLabel?: string;\n\n  /**\n   * Custom time label.\n   *\n   * Defaults to Time\n   */\n  readonly timeLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"All Day\". Defaults to \"All Day\".\n   */\n  readonly allDayLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"At\". Defaults to \"At\".\n   */\n  readonly atTimeLabel?: string;\n\n  /**\n   * Value mode.\n   *\n   * Defaults to DATE\n   */\n  readonly valueMode?: DbxDateTimeValueMode;\n\n  /**\n   * Whether or not the date is hidden, and automatically uses today/input date.\n   */\n  readonly timeOnly?: boolean;\n\n  /**\n   * Only applicable when timeOnly is false.\n   *\n   * Whether or not to always show the date input even when there is only a single date that can be selected.\n   *\n   * Defaults to true.\n   */\n  readonly alwaysShowDateInput?: boolean;\n\n  /**\n   * Whether or not to autofill the date when time is picked.\n   *\n   * Defaults to false.\n   */\n  readonly autofillDateWhenTimeIsPicked?: boolean;\n\n  /**\n   * Whether or not the time can be added/removed optionally.\n   *\n   * This is ignored if timeOnly is specified.\n   */\n  readonly timeMode?: DbxDateTimeFieldTimeMode;\n\n  /**\n   * Other form control for enabling/disabling whether or not it is a full day.\n   *\n   * This field is only used if time is optional.\n   *\n   * When time is off, the field is set to true.\n   */\n  readonly fullDayFieldName?: string;\n\n  /**\n   * Whether or not to pass the date value as a UTC date, or a date in the current timezone.\n   */\n  readonly fullDayInUTC?: boolean;\n\n  /**\n   * Whether or not ot hide the date hint info content.\n   *\n   * False by default\n   */\n  readonly hideDateHint?: boolean;\n\n  /**\n   * Whether or not to hide the date/calendar picker.\n   */\n  readonly hideDatePicker?: boolean;\n\n  /**\n   * Custom picker configuration\n   */\n  readonly pickerConfig?: ObservableOrValueGetter<DbxDateTimePickerConfiguration>;\n\n  /**\n   * Used for syncing with one or more fields with a Date value.\n   */\n  readonly getSyncFieldsObs?: () => Observable<ArrayOrValue<DbxDateTimeFieldSyncField>>;\n\n  /**\n   * (Optional) The input timezone to default to.\n   *\n   * Ignored if fullDayInUTC is true.\n   */\n  readonly timezone?: Maybe<ObservableOrValueGetter<Maybe<TimezoneString>>>;\n\n  /**\n   * (Optional) The date to apply the time to.\n   *\n   * The timezone abbrviation will also use this date when using the time-only mode.\n   */\n  readonly timeDate?: Maybe<ObservableOrValueGetter<Maybe<DbxDateTimeFieldTimeDateConfig | FormControlPath | DateOrDayString>>>;\n\n  /**\n   * Whether or not to display the timezone. True by default.\n   */\n  readonly showTimezone?: Maybe<boolean>;\n\n  /**\n   * Custom presets to show in the dropdown.\n   */\n  readonly presets?: ObservableOrValueGetter<DateTimePresetConfiguration[]>;\n\n  /**\n   * The time in ms to prevent output from going out when the input value changes.\n   */\n  readonly inputOutputDebounceTime?: Milliseconds;\n\n  /**\n   * Whether or not to display the clear date button. True by default.\n   */\n  readonly showClearButton?: Maybe<boolean>;\n\n  /**\n   * The number of minutes to add/subtract when using the arrow keys.\n   */\n  readonly minuteStep?: Maybe<number>;\n}\n\nexport interface DbxDateTimeFieldSyncParsedField extends Pick<DbxDateTimeFieldSyncField, 'syncType'> {\n  control: AbstractControl<Maybe<Date | ISO8601DateString>>;\n}\n\nexport function syncConfigValueObs(parseConfigsObs: Observable<DbxDateTimeFieldSyncParsedField[]>, type: DbxDateTimeFieldSyncType): Observable<Date | null> {\n  return parseConfigsObs.pipe(\n    switchMap((x) => {\n      const config = x.find((y) => y.syncType === type);\n      let result: Observable<Date | null>;\n\n      if (config) {\n        const { control } = config;\n        result = control.valueChanges.pipe(\n          startWith(control.value),\n          map((x) => safeToJsDate(x) ?? null)\n        );\n      } else {\n        result = of(null);\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n}\n\nconst TIME_OUTPUT_THROTTLE_TIME: Milliseconds = 10;\n\n/**\n * Error code used when the selected date is not in the schedule.\n */\nexport const DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR = 'dateTimeFieldDateNotInSchedule';\n\n/**\n * Error code used when the selected time/time input is not in the limited range.\n */\nexport const DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR = 'dateTimeFieldTimeNotInRange';\n\n@Component({\n  templateUrl: 'datetime.field.component.html'\n})\nexport class DbxDateTimeFieldComponent extends FieldType<FieldTypeConfig<DbxDateTimeFieldProps>> implements OnInit, OnDestroy {\n  private _sub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n  private _autoFillDateSync = new SubscriptionObject();\n\n  private _config = new BehaviorSubject<Maybe<Observable<DbxDateTimePickerConfiguration>>>(undefined);\n  readonly latestConfig$ = this._config.pipe(switchMapMaybeDefault(), distinctUntilChanged(), shareReplay(1));\n\n  private _syncConfigObs = new BehaviorSubject<Maybe<Observable<ArrayOrValue<DbxDateTimeFieldSyncField>>>>(undefined);\n\n  private _defaultTimezone = new BehaviorSubject<Maybe<Observable<Maybe<TimezoneString>>>>(undefined);\n  private _timeDate = new BehaviorSubject<Maybe<Observable<Maybe<DbxDateTimeFieldTimeDateConfig | FormControlPath | DateOrDayString>>>>(undefined);\n  private _presets = new BehaviorSubject<Observable<DateTimePresetConfiguration[]>>(of([]));\n\n  private _fullDayInputCtrl?: FormControl;\n  private _fullDayControlObs = new BehaviorSubject<Maybe<AbstractControl<boolean>>>(undefined);\n  readonly fullDayControl$ = this._fullDayControlObs.pipe(filterMaybe());\n\n  private _offset = new BehaviorSubject<number>(0);\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl<Maybe<Date>>>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  private _cleared = new Subject<void>();\n  private _updateTime = new Subject<void>();\n\n  private _resyncTimeInputSub = new SubscriptionObject();\n  private _resyncTimeInput = new Subject<void>();\n\n  readonly timeErrorStateMatcher: ErrorStateMatcher = {\n    isErrorState: (control: AbstractControl | null, form) => {\n      if (control) {\n        return (control.invalid && (control.dirty || control.touched)) || this.errorStateMatcher.isErrorState(this.formControl, form);\n      } else {\n        return false;\n      }\n    }\n  };\n\n  readonly resyncTimeInput$ = this._resyncTimeInput.pipe(debounceTime(200), shareReplay(1));\n\n  private _configUpdateTimeSync = new SubscriptionObject(\n    this.latestConfig$.pipe(skip(1)).subscribe((x) => {\n      this._updateTime.next();\n    })\n  );\n\n  readonly timezone$: Observable<Maybe<TimezoneString>> = this._defaultTimezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(\n    map((defaultTimezone) => {\n      return defaultTimezone ?? guessCurrentTimezone();\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly timezoneInstance$: Observable<Maybe<DateTimezoneUtcNormalInstance>> = this.timezone$.pipe(\n    map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)),\n    shareReplay(1)\n  );\n\n  readonly timeDate$: Observable<Maybe<Date>> = this._timeDate.pipe(\n    switchMapMaybeDefault(),\n    switchMap((x) => {\n      let obs: Observable<Maybe<Date>>;\n\n      if (x) {\n        // if the string is not a date string, then treat it as a path\n        if ((typeof x === 'string' && !isISO8601DayStringStart(x)) || isDbxDateTimeFieldTimeDateConfig(x)) {\n          const { path, mapValue }: DbxDateTimeFieldTimeDateConfig = typeof x === 'string' ? { path: x } : x;\n          obs =\n            streamValueFromControl<DateOrDayString>(this.form, path)?.pipe(\n              map(mapValue ?? mapIdentityFunction()),\n              map((x) => (x ? toJsDayDate(x) : undefined))\n            ) ?? of(undefined);\n        } else {\n          obs = of(toJsDayDate(x));\n        }\n      } else {\n        obs = of(undefined);\n      }\n\n      return obs;\n    }),\n    distinctUntilChanged(isSameDateDay),\n    shareReplay(1)\n  );\n\n  readonly valueInSystemTimezone$: Observable<Maybe<Date>> = this.formControl$.pipe(\n    map((control) => control.valueChanges.pipe(startWith<Maybe<Date | ISO8601DayString | MinuteOfDay | UnixDateTimeNumber>>(control.value), shareReplay(1))),\n    combineLatestWith(this.timezoneInstance$),\n    switchMap(([x, timezoneInstance]) => {\n      return x.pipe(map(dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)));\n    }),\n    throttleTime(20, undefined, { leading: true, trailing: true }), // throttle incoming values and timezone changes\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly refreshInteral$ = interval(10 * 1000);\n\n  /**\n   * Used to trigger/display visual updates (specifically on timeDistance, etc.).\n   */\n  readonly displayValue$ = this.refreshInteral$.pipe(\n    // every 10 seconds, refresh w/interval\n    startWith(0),\n    map(() => new Date().getMinutes()),\n    distinctUntilChanged(),\n    tap(() => this.cdRef.markForCheck()),\n    switchMap(() => this.valueInSystemTimezone$),\n    shareReplay(1)\n  );\n\n  readonly timeString$: Observable<ReadableTimeString | ''> = this.valueInSystemTimezone$.pipe(\n    map((x) => (x ? toLocalReadableTimeString(x) : '')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateInputCtrl = new FormControl<Maybe<Date>>(null, {\n    validators: []\n  });\n\n  readonly timeInputCtrl = new FormControl<Maybe<ReadableTimeString>>(null, {\n    validators: [Validators.pattern(/^(now)$|^([0-9]|(0[0-9])|(1[0-9])|(2[0-3]))(:)?([0-5][0-9])?(\\s)?([apAP][Mm])?(\\\\s)*$/)]\n  });\n\n  get dateLabel(): string {\n    return this.props.dateLabel ?? 'Date';\n  }\n\n  get timeLabel(): string {\n    return this.props.timeLabel ?? 'Time';\n  }\n\n  get allDayLabel(): string {\n    return this.props.allDayLabel ?? 'All Day';\n  }\n\n  get atTimeLabel(): string {\n    return this.props.atTimeLabel ?? 'At';\n  }\n\n  get dateOnly(): boolean {\n    return this.timeMode === DbxDateTimeFieldTimeMode.NONE;\n  }\n\n  get dateTimeField(): DbxDateTimeFieldProps {\n    return this.field.props;\n  }\n\n  get timeOnly(): Maybe<boolean> {\n    const timeValuesOnly = this.valueMode === DbxDateTimeValueMode.MINUTE_OF_DAY;\n\n    if (timeValuesOnly) {\n      return true;\n    } else {\n      return this.dateTimeField.timeOnly;\n    }\n  }\n\n  get alwaysShowDateInput(): boolean {\n    return this.props.alwaysShowDateInput ?? true;\n  }\n\n  get autofillDateWhenTimeIsPicked(): boolean {\n    return this.props.autofillDateWhenTimeIsPicked ?? this.alwaysShowDateInput === false;\n  }\n\n  get showDateInput(): boolean {\n    return !this.timeOnly;\n  }\n\n  get valueMode(): DbxDateTimeValueMode {\n    return this.field.props.valueMode ?? DbxDateTimeValueMode.DATE;\n  }\n\n  get timeMode(): DbxDateTimeFieldTimeMode {\n    const dateValuesOnly = this.valueMode === DbxDateTimeValueMode.DAY_STRING;\n\n    if (dateValuesOnly) {\n      return DbxDateTimeFieldTimeMode.NONE;\n    } else {\n      return this.timeOnly ? DbxDateTimeFieldTimeMode.REQUIRED : this.dateTimeField.timeMode ?? DbxDateTimeFieldTimeMode.REQUIRED;\n    }\n  }\n\n  get isDateRequired(): boolean {\n    return this.props.required ?? false;\n  }\n\n  get isTimeRequired(): boolean {\n    return this.isDateRequired && this.timeMode === DbxDateTimeFieldTimeMode.REQUIRED;\n  }\n\n  get description(): Maybe<string> {\n    return this.field.props.description;\n  }\n\n  get hideDateHint(): boolean {\n    return this.field.props.hideDateHint ?? false;\n  }\n\n  get hideDatePicker(): boolean {\n    return this.field.props.hideDatePicker ?? false;\n  }\n\n  get timezone() {\n    return this.field.props.timezone;\n  }\n\n  get timeDate() {\n    return this.field.props.timeDate;\n  }\n\n  get showTimezone() {\n    return this.field.props.showTimezone ?? true;\n  }\n\n  get presets() {\n    return this.field.props.presets;\n  }\n\n  get showClearButton() {\n    return this.field.props.showClearButton;\n  }\n\n  get minuteStep() {\n    return this.field.props.minuteStep ?? this.field.props.step ?? 5;\n  }\n\n  readonly fullDay$: Observable<boolean> = this.fullDayControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showTimeInput$: Observable<boolean> = this.fullDay$.pipe(map((x) => !x && this.timeMode !== DbxDateTimeFieldTimeMode.NONE));\n\n  readonly showAddTime$ = this.showTimeInput$.pipe(\n    map((x) => !x && this.timeMode === DbxDateTimeFieldTimeMode.OPTIONAL),\n    shareReplay(1)\n  );\n\n  readonly currentDate$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), shareReplay(1));\n  readonly date$ = this.currentDate$.pipe(filterMaybe(), shareReplay(1));\n\n  readonly timezoneAbbreviation$ = combineLatest([this.currentDate$, this.timezone$, this.timeDate$]).pipe(\n    map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? date ?? new Date())),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateValue$: Observable<Maybe<Date>> = merge(this.date$, this.valueInSystemTimezone$.pipe(skipFirstMaybe())).pipe(\n    map((x: Maybe<Date>) => (x ? startOfDay(x) : null)),\n    distinctUntilChanged<Maybe<Date>>(isSameDateDay),\n    shareReplay(1)\n  );\n\n  readonly timeInput$: Observable<ReadableTimeString> = this._updateTime.pipe(\n    debounceTime(5),\n    map(() => this.timeInputCtrl.value || ''),\n    distinctUntilChanged()\n  );\n\n  readonly syncConfigObs$ = this._syncConfigObs.pipe(switchMapMaybeDefault(), shareReplay(1));\n\n  readonly parsedSyncConfigs$: Observable<DbxDateTimeFieldSyncParsedField[]> = this.syncConfigObs$.pipe(\n    map((x) => {\n      let parsed: DbxDateTimeFieldSyncParsedField[];\n\n      if (x) {\n        parsed = filterMaybeValues(\n          asArray(x).map((y) => {\n            const control = this.form.get(y.syncWith);\n\n            if (control) {\n              return {\n                control,\n                ...y\n              };\n            } else {\n              return undefined;\n            }\n          })\n        );\n      } else {\n        parsed = [];\n      }\n\n      return parsed;\n    }),\n    shareReplay(1)\n  );\n\n  readonly syncConfigBeforeValue$: Observable<Date | null> = syncConfigValueObs(this.parsedSyncConfigs$, 'before');\n  readonly syncConfigAfterValue$: Observable<Date | null> = syncConfigValueObs(this.parsedSyncConfigs$, 'after');\n\n  readonly isTimeCleared$ = combineLatest([this.currentDate$, this._timeDate.pipe(startWith(null))]).pipe(\n    switchMap(([date, time]) => {\n      const isTimeCleared = Boolean(!date && !time);\n      return this._cleared.pipe(\n        map(() => true),\n        startWith(isTimeCleared)\n      );\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly rawDateTime$: Observable<Maybe<Date>> = combineLatest([\n    this._config.pipe(\n      first(),\n      switchMap(() => (this.timeOnly ? of(null) : this.dateValue$))\n    ),\n    this.timeInput$.pipe(startWith(null)),\n    this.fullDay$,\n    this.timeDate$,\n    this.isTimeCleared$\n  ]).pipe(\n    map(([date, timeString, fullDay, timeDate, isTimeCleared]) => {\n      let result: Maybe<Date>;\n\n      if (!isTimeCleared) {\n        if (!date || this.timeOnly) {\n          date = timeDate ?? new Date(); // use the time date, or default to the current day\n        }\n\n        if (date) {\n          if (fullDay) {\n            if (this.dateTimeField.fullDayInUTC) {\n              result = utcDayForDate(date);\n            } else {\n              result = startOfDay(date);\n            }\n          } else if (timeString) {\n            result =\n              readableTimeStringToDate(timeString, {\n                date,\n                useSystemTimezone: true\n              }) ?? date;\n          } else if (!this.timeOnly) {\n            if (this.timeMode !== DbxDateTimeFieldTimeMode.REQUIRED) {\n              // only autofill the date if the time is marked as required (and the time string is empty)\n              result = date;\n            }\n          }\n        }\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly dateTimePickerConfig$: Observable<Maybe<DbxDateTimePickerConfiguration>> = combineLatest([this._config.pipe(switchMapMaybeObs()), this.syncConfigBeforeValue$, this.syncConfigAfterValue$]).pipe(\n    map(([x, dateInputMin, dateInputMax]) => {\n      let result: Maybe<DbxDateTimePickerConfiguration> = x;\n\n      if (dateInputMin != null || dateInputMax != null) {\n        const { min: limitMin, max: limitMax } = x?.limits ?? {};\n        const min = findMinDate([dateInputMin, dateFromLogicalDate(limitMin)]);\n        const max = findMaxDate([dateInputMax, dateFromLogicalDate(limitMax)]);\n\n        result = {\n          ...x,\n          limits: {\n            ...x?.limits,\n            min,\n            max\n          }\n        };\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateInputMin$: Observable<Date | null> = this.dateTimePickerConfig$.pipe(\n    map((x) => (x?.limits?.min ?? null) as Date | null),\n    distinctUntilChanged<Date | null>(isSameDate),\n    shareReplay(1)\n  );\n\n  readonly dateInputMax$: Observable<Date | null> = this.dateTimePickerConfig$.pipe(\n    map((x) => (x?.limits?.max ?? null) as Date | null),\n    distinctUntilChanged<Date | null>(isSameDate),\n    shareReplay(1)\n  );\n\n  /**\n   * Whether or not there is a limited min/max date range applied/available.\n   */\n  readonly hasRestrictedDateRange$: Observable<boolean> = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(\n    map(([a, b]) => Boolean(a || b)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateMinAndMaxIsSameDay$: Observable<boolean> = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(\n    map(([a, b]) => Boolean(a && b) && isSameDateDay(a, b)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly pickerFilter$: Observable<DecisionFunction<Date | null>> = this.dateTimePickerConfig$.pipe(\n    distinctUntilChanged(),\n    map((x) => {\n      if (x) {\n        const filter = dateTimeMinuteWholeDayDecisionFunction(x, false);\n        return (x: Date | null) => (x != null ? filter(x) : true);\n      } else {\n        return () => true;\n      }\n    }),\n    shareReplay(1)\n  );\n\n  readonly defaultPickerFilter: DecisionFunction<Date | null> = () => true;\n\n  readonly timeOutput$: Observable<Maybe<Date>> = combineLatest([this.rawDateTime$, this._offset, this.dateTimePickerConfig$]).pipe(\n    throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n    distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0 && current[2] === next[2]),\n    tap(([, stepsOffset]) => (stepsOffset ? this._offset.next(0) : 0)),\n    map(([date, stepsOffset, config]) => {\n      if (date != null) {\n        const instance = new DateTimeMinuteInstance({\n          date,\n          ...config,\n          roundDownToMinute: true\n        });\n\n        // only clamp when the steps offset is set\n        if (stepsOffset) {\n          date = instance.clamp(date);\n\n          const minutes = stepsOffset * this.minuteStep;\n\n          if (minutes != 0) {\n            date = addMinutes(date, minutes);\n            date = instance.clamp(date); // clamp the date again\n          }\n        }\n      }\n\n      return date;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly dateTimePickerInstance$ = this.dateTimePickerConfig$.pipe(\n    map((config) => {\n      return new DateTimeMinuteInstance({\n        ...config,\n        roundDownToMinute: true\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly hasEmptyDisplayValue$ = this.displayValue$.pipe(\n    map((x) => !x),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly presets$: Observable<DateTimePreset[]> = this._presets.pipe(\n    switchMapMaybeObs(),\n    map((x: DateTimePresetConfiguration[]) => x.map(dateTimePreset)),\n    shareReplay(1)\n  );\n\n  readonly showClearButton$: Observable<boolean> = this.hasEmptyDisplayValue$.pipe(\n    map((x) => Boolean(this.showClearButton && !x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly canAutofillDateWithOnlyAvailableDate$: Observable<boolean> = this.dateMinAndMaxIsSameDay$;\n\n  readonly showDateInput$: Observable<boolean> = this.dateMinAndMaxIsSameDay$.pipe(\n    map((dateMinAndMaxIsSameDay) => {\n      return this.showDateInput && (this.alwaysShowDateInput || !dateMinAndMaxIsSameDay);\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly currentErrorMessage$ = this.formControl$.pipe(\n    switchMap((formControl) =>\n      formControl.statusChanges.pipe(\n        filter((x) => x === 'INVALID' || x === 'VALID'),\n        map((x) => {\n          let currentErrorMessage: string | undefined;\n\n          if (x === 'INVALID') {\n            if (this.formControl.hasError('required')) {\n              currentErrorMessage = 'Date is required';\n            } else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR)) {\n              currentErrorMessage = 'Date does not fall on an available dates in schedule.';\n            } else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR)) {\n              currentErrorMessage = 'Time is not valid for the given date.';\n            } else {\n              currentErrorMessage = 'The given date and time is invalid.';\n            }\n          }\n\n          return currentErrorMessage;\n        })\n      )\n    ),\n    startWith(undefined),\n    shareReplay(1)\n  );\n\n  readonly hasError$ = this.currentErrorMessage$.pipe(\n    map((x) => Boolean(x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  constructor(private readonly cdRef: ChangeDetectorRef, private readonly dbxDateTimeFieldConfigService: DbxDateTimeFieldMenuPresetsService) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    const inputPickerConfig = this.dateTimeField.pickerConfig;\n    this._config.next(inputPickerConfig ? asObservableFromGetter(inputPickerConfig) : of({}));\n    this._syncConfigObs.next(this.dateTimeField.getSyncFieldsObs?.());\n\n    this._sub.subscription = this.valueInSystemTimezone$\n      .pipe(\n        combineLatestWith(this.timezoneInstance$.pipe(map((timezoneInstance) => dbxDateTimeOutputValueFactory(this.valueMode, timezoneInstance)))),\n        throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n        switchMap(([currentValue, valueFactory]) => {\n          return this.timeOutput$.pipe(\n            throttleTime(TIME_OUTPUT_THROTTLE_TIME * 2, undefined, { leading: false, trailing: true }),\n            skipFirstMaybe(),\n            distinctUntilChanged(isSameDateHoursAndMinutes),\n            map((x) => valueFactory(x)),\n            filter((x) => !dbxDateTimeIsSameDateTimeFieldValue(x, currentValue))\n          );\n        })\n      )\n      .subscribe((value) => {\n        this.formControl.setValue(value);\n        this.formControl.markAsDirty();\n        this.formControl.markAsTouched();\n      });\n\n    let hasSetMidnightFromInput = false;\n\n    /*\n    this._valueSub.subscription = this.timeString$.subscribe((x) => {\n      this.setTime(x);\n    });\n    */\n\n    if (this.autofillDateWhenTimeIsPicked) {\n      this._autoFillDateSync.subscription = this.canAutofillDateWithOnlyAvailableDate$\n        .pipe(\n          switchMap((canAutofill) => {\n            if (canAutofill) {\n              // when the time updates the first time, set the current min date\n              return this._updateTime.pipe(\n                debounceTime(200),\n                switchMap((x) => this.dateInputMin$),\n                filterMaybe()\n              );\n            } else {\n              return of(null); // don't show anything\n            }\n          })\n        )\n        .subscribe((autoDate) => {\n          if (autoDate != null) {\n            this.dateInputCtrl.setValue(autoDate);\n          }\n        });\n    }\n\n    this._valueSub.subscription = this.valueInSystemTimezone$\n      .pipe(\n        map((x) => (x ? isSameDate(x, startOfDay(x)) : false)),\n        distinctUntilChanged(),\n        switchMap((isInputValueAtMidnight) => {\n          hasSetMidnightFromInput = false;\n          return this.timeString$.pipe(\n            // skip(1),\n            map((timeString) => [timeString, isInputValueAtMidnight] as [string, boolean])\n          );\n        })\n      )\n      .subscribe(([x, isInputValueAtMidnight]) => {\n        // Skip events where the timeInput value is cleared, unless the input value is at midnight and we've already processed it being at midnight\n        if (!this.timeInputCtrl.value && x === '12:00AM' && (!isInputValueAtMidnight || (isInputValueAtMidnight && hasSetMidnightFromInput))) {\n          return;\n        }\n\n        // update the has set flag\n        if (x === '12:00AM' && isInputValueAtMidnight) {\n          hasSetMidnightFromInput = true;\n        }\n\n        this.setTime(x);\n      });\n\n    // Set default timezone if provided.\n    if (this.timezone && !this.dateTimeField.fullDayInUTC) {\n      this._defaultTimezone.next(asObservableFromGetter(this.timezone));\n    }\n\n    this._timeDate.next(asObservableFromGetter(this.timeDate));\n\n    // Watch for disabled changes so we can propogate them properly.\n    this.formControl.registerOnDisabledChange((isDisabled) => {\n      toggleDisableFormControl(this.dateInputCtrl, isDisabled);\n      toggleDisableFormControl(this.timeInputCtrl, isDisabled);\n    });\n\n    const isFullDayField = this.dateTimeField.fullDayFieldName;\n    let fullDayFieldCtrl: Maybe<AbstractControl>;\n\n    if (isFullDayField) {\n      fullDayFieldCtrl = this.form.get(isFullDayField);\n    }\n\n    if (!fullDayFieldCtrl) {\n      const isFullDay = this.timeMode === DbxDateTimeFieldTimeMode.NONE;\n      this._fullDayInputCtrl = new FormControl(isFullDay);\n\n      // Set the control in the form too if the name is defined.\n      if (isFullDayField) {\n        (this.form as FormGroup).addControl(isFullDayField, this._fullDayInputCtrl);\n      }\n\n      fullDayFieldCtrl = this._fullDayInputCtrl;\n    }\n\n    this._fullDayControlObs.next(fullDayFieldCtrl);\n\n    switch (this.timeMode) {\n      case DbxDateTimeFieldTimeMode.OPTIONAL:\n        break;\n      case DbxDateTimeFieldTimeMode.NONE:\n        this.removeTime();\n        break;\n      case DbxDateTimeFieldTimeMode.REQUIRED:\n        this.addTime();\n        break;\n    }\n\n    if (this.presets != null) {\n      this._presets.next(asObservableFromGetter(this.presets));\n    } else {\n      this._presets.next(this.dbxDateTimeFieldConfigService.configurations$);\n    }\n\n    this._resyncTimeInputSub.subscription = this.resyncTimeInput$.pipe(switchMap((x) => combineLatest([this.currentDate$, this.timeString$]).pipe(first()))).subscribe(([currentDate, timeString]) => {\n      // only resync when the current date is set, otherwise do not change the time string.\n      // This helps in cases where the user picks a time first and we don't want it to be cleared.\n      if (currentDate != null) {\n        this.timeInputCtrl.setValue(timeString, { emitEvent: false });\n      }\n    });\n\n    // add validators/errors for the form\n    this.formControl.addAsyncValidators([\n      (x) => {\n        const formValue = x.value as Maybe<Date>;\n        let obs: Observable<ValidationErrors>;\n\n        if (formValue != null) {\n          obs = combineLatest([this.timezoneInstance$, this.dateTimePickerInstance$]).pipe(\n            map(([timezoneInstance, x]) => {\n              // the form value is going to be in the output form, so we need to parse it back to the \"input\" date before evaluating it\n              const formValueInSystemTimezone = dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)(formValue);\n\n              let errors: ValidationErrors = {\n                ...this.timeInputCtrl.errors\n              };\n\n              if (formValueInSystemTimezone) {\n                if (x.dateIsInSchedule(formValueInSystemTimezone)) {\n                  if (!x.isInValidRange(formValueInSystemTimezone)) {\n                    errors = {\n                      [DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR]: true\n                    };\n                  }\n                } else {\n                  errors = {\n                    [DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR]: true\n                  };\n                }\n              }\n\n              return errors;\n            }),\n            first()\n          );\n        } else {\n          obs = of({});\n        }\n\n        return obs;\n      }\n    ]);\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._valueSub.destroy();\n    this._config.complete();\n    this._configUpdateTimeSync.destroy();\n    this._defaultTimezone.complete();\n    this._resyncTimeInputSub.destroy();\n    this._autoFillDateSync.destroy();\n    this._timeDate.complete();\n    this._presets.complete();\n    this._fullDayControlObs.complete();\n    this._offset.complete();\n    this._formControlObs.complete();\n    this._updateTime.complete();\n    this._cleared.complete();\n    this._resyncTimeInput.complete();\n    this._syncConfigObs.complete();\n  }\n\n  selectPreset(preset: DateTimePreset): void {\n    const value = preset.value();\n\n    if (value.logicalDate) {\n      this.setLogicalTime(value.logicalDate);\n    } else if (value.timeString) {\n      this.setTime(value.timeString);\n    }\n  }\n\n  datePicked(event: MatDatepickerInputEvent<Date>): void {\n    const date = event.value;\n\n    if (date) {\n      this.setDateInputValue(date);\n    }\n  }\n\n  setLogicalTime(time: LogicalDate): void {\n    const date = dateFromLogicalDate(time);\n\n    if (date) {\n      this.setTimeFromDate(date);\n    }\n  }\n\n  setDateInputValue(date: Date) {\n    this.dateInputCtrl.setValue(date);\n    this._updateTime.next();\n  }\n\n  setTimeFromDate(timeDate: Date): void {\n    const timeString = toLocalReadableTimeString(timeDate);\n    this.setTime(timeString);\n  }\n\n  setTime(time: ReadableTimeString): void {\n    if (this.timeInputCtrl.value !== time) {\n      this.timeInputCtrl.setValue(time);\n      this._offset.next(0);\n      this._updateTime.next();\n    }\n  }\n\n  keydownOnDateInput(event: KeyboardEvent): void {\n    let direction = 0;\n\n    switch (event.key?.toLowerCase()) {\n      case 'arrowup':\n        direction = 1;\n        break;\n      case 'arrowdown':\n        direction = -1;\n        break;\n    }\n\n    let offset = 1;\n\n    if (event.ctrlKey && event.shiftKey) {\n      offset = 365;\n    } else if (event.ctrlKey) {\n      offset = 30;\n    } else if (event.shiftKey) {\n      offset = 7;\n    }\n\n    if (direction !== 0) {\n      combineLatest([this.date$, this.dateTimePickerConfig$])\n        .pipe(first())\n        .subscribe(([date, config]) => {\n          const newDate = startOfDay(addDays(date, offset * direction));\n          const instance = new DateTimeMinuteInstance({\n            date: newDate,\n            ...config\n          });\n\n          const nextDate = instance.isInSchedule(newDate) ? newDate : instance.findNextAvailableDayInSchedule(newDate, direction === 1 ? 'future' : 'past');\n\n          if (nextDate != null) {\n            this.setDateInputValue(instance.clampToLimit(nextDate));\n          }\n        });\n    }\n  }\n\n  keydownOnTimeInput(event: KeyboardEvent): void {\n    let direction = 0;\n\n    switch (event.key?.toLowerCase()) {\n      case 'arrowup':\n        direction = 1;\n        break;\n      case 'arrowdown':\n        direction = -1;\n        break;\n    }\n\n    let offset = 1;\n\n    if (event.altKey && event.shiftKey) {\n      offset = 300;\n    } else if (event.altKey) {\n      offset = 60;\n    } else if (event.shiftKey) {\n      offset = 5;\n    }\n\n    if (direction !== 0) {\n      this._offset.next(this._offset.value + offset * direction);\n      this._updateTime.next();\n    }\n  }\n\n  focusTime(): void {\n    // do nothing\n  }\n\n  focusOutTime(): void {\n    // only refresh when there is not a pattern error\n    if (!this.timeInputCtrl.hasError('pattern')) {\n      this._updateTime.next();\n      this._resyncTimeInput.next();\n    }\n  }\n\n  addTime(): void {\n    this.setFullDay(false);\n  }\n\n  removeTime(): void {\n    this.setFullDay(true);\n  }\n\n  setFullDay(fullDay: boolean): void {\n    this.fullDayControl$.pipe(first()).subscribe((x) => {\n      x.setValue(fullDay);\n    });\n  }\n\n  clearValue(): void {\n    this._cleared.next();\n  }\n}\n","<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutGap=\"6px grid\" fxLayoutAlign=\"space-evenly stretch\">\n  <!-- Date -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput$ | async\">\n    <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n  </div>\n  <!-- Time -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"(showDateInput$ | async) ? '50' : '100'\">\n    <ng-container *ngIf=\"showTimeInput$ | async\">\n      <ng-container *ngTemplateOutlet=\"timeMenuAndInputTemplate\"></ng-container>\n    </ng-container>\n    <div *ngIf=\"showAddTime$ | async\" class=\"add-time-button-wrapper\">\n      <button mat-button class=\"mat-datepicker-button-highlight dbx-button-spacer add-time-button\" ngClass.lt-sm=\"add-time-button-full\" (click)=\"addTime()\">\n        <mat-icon>timer</mat-icon>\n        Add Time\n      </button>\n    </div>\n  </div>\n  <!-- Date Hint -->\n  <ng-container [ngSwitch]=\"hasError$ | async\">\n    <ng-container *ngSwitchCase=\"false\">\n      <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n        <div class=\"dbx-hint\">\n          <ng-container [ngSwitch]=\"hasEmptyDisplayValue$ | async\">\n            <ng-container *ngSwitchCase=\"true\">\n              <span class=\"dbx-small\">No date/time set</span>\n            </ng-container>\n            <ng-container *ngSwitchCase=\"false\">\n              <ng-container [ngSwitch]=\"fullDay$ | async\">\n                <small *ngSwitchCase=\"true\">\n                  <b class=\"dbx-ok\">{{ allDayLabel }}</b>\n                  {{ displayValue$ | async | date: 'fullDate' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | dateDistance }})\n                </small>\n                <small *ngSwitchCase=\"false\">\n                  <ng-container *ngIf=\"displayValue$ | async\">\n                    <b class=\"dbx-ok\">{{ atTimeLabel }}</b>\n                    {{ displayValue$ | async | date: 'medium' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | timeDistance }})\n                  </ng-container>\n                </small>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"true\">\n      <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n    </ng-container>\n  </ng-container>\n</div>\n\n<!-- Date Input Template -->\n<ng-template #dateInputTemplate>\n  <mat-form-field class=\"dbx-datetime-row-field\">\n    <mat-label>{{ dateLabel }}</mat-label>\n    <input #dateInput matInput [disabled]=\"disabled\" [required]=\"isDateRequired\" [min]=\"dateInputMin$ | async\" [max]=\"dateInputMax$ | async\" [matDatepicker]=\"picker\" [matDatepickerFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" (dateChange)=\"datePicked($event)\" [value]=\"dateValue$ | async\" (keydown)=\"keydownOnDateInput($event)\" />\n    <mat-datepicker #picker></mat-datepicker>\n    <button matPrefix class=\"dbx-datetime-row-button\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n      <mat-icon>calendar_today</mat-icon>\n    </button>\n    <button matSuffix *ngIf=\"showClearButton$ | async\" class=\"dbx-datetime-clear-button\" mat-icon-button aria-label=\"clears the date and time menu\" [disabled]=\"disabled\" (click)=\"clearValue()\">\n      <mat-icon>clear</mat-icon>\n    </button>\n    <span matTextSuffix *ngIf=\"!(showTimeInput$ | async)\">\n      <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n    </span>\n  </mat-form-field>\n</ng-template>\n\n<!-- Time Menu/Input Template -->\n<ng-template #timeMenuAndInputTemplate>\n  <mat-menu #timemenu=\"matMenu\">\n    <ng-container *ngIf=\"timeMode === 'optional'\">\n      <button mat-menu-item (click)=\"removeTime()\">\n        <span>Remove Time</span>\n      </button>\n      <mat-divider></mat-divider>\n    </ng-container>\n    <ng-container *ngFor=\"let preset of presets$ | async\">\n      <button mat-menu-item (click)=\"selectPreset(preset)\">{{ preset.label | getValue }}</button>\n    </ng-container>\n  </mat-menu>\n  <mat-form-field class=\"dbx-datetime-row-field\">\n    <mat-label>{{ timeLabel }}</mat-label>\n    <input #timeInput [errorStateMatcher]=\"timeErrorStateMatcher\" matInput [required]=\"isTimeRequired\" [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n    <button matPrefix class=\"dbx-datetime-row-button\" mat-icon-button [matMenuTriggerFor]=\"timemenu\" aria-label=\"opens the time menu\" [disabled]=\"disabled\">\n      <mat-icon>timer</mat-icon>\n    </button>\n    <span matTextSuffix>\n      <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n    </span>\n    <mat-error *ngIf=\"timeInputCtrl.hasError('pattern')\">The input time is not recognizable.</mat-error>\n  </mat-form-field>\n</ng-template>\n\n<!-- Timezone Suffix -->\n<ng-template #timezoneSuffixTemplate>\n  <span *ngIf=\"showTimezone\" class=\"dbx-datetime-timezone dbx-faint\">{{ timezoneAbbreviation$ | async }}</span>\n</ng-template>\n"]}
669
+ }] });
670
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/datetime.field.component.ts","../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/datetime.field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { type Maybe, type ReadableTimeString, type ArrayOrValue, type ISO8601DateString, asArray, filterMaybeValues, type DecisionFunction, type Milliseconds, type TimezoneString, type LogicalDate, type DateOrDayString, isISO8601DayStringStart, type MapFunction, mapIdentityFunction, MinuteOfDay, UnixDateTimeNumber, ISO8601DayString } from '@dereekb/util';\nimport { dateFromLogicalDate, DateTimeMinuteConfig, DateTimeMinuteInstance, guessCurrentTimezone, readableTimeStringToDate, toLocalReadableTimeString, utcDayForDate, safeToJsDate, findMinDate, findMaxDate, isSameDateHoursAndMinutes, getTimezoneAbbreviation, isSameDateDay, dateTimezoneUtcNormal, DateTimezoneUtcNormalInstance, toJsDayDate, isSameDate, dateTimeMinuteWholeDayDecisionFunction } from '@dereekb/date';\nimport { switchMap, shareReplay, map, startWith, tap, first, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, Observable, combineLatest, Subject, merge, interval, of, combineLatestWith, filter, skip } from 'rxjs';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, inject } from '@angular/core';\nimport { AbstractControl, FormControl, Validators, FormGroup, ValidationErrors } from '@angular/forms';\nimport { FieldType } from '@ngx-formly/material';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { MatDatepickerInputEvent } from '@angular/material/datepicker';\nimport { addMinutes, startOfDay, addDays } from 'date-fns';\nimport { asObservableFromGetter, filterMaybe, ObservableOrValueGetter, skipFirstMaybe, SubscriptionObject, switchMapMaybeDefault, switchMapMaybeObs } from '@dereekb/rxjs';\nimport { DateTimePreset, DateTimePresetConfiguration, dateTimePreset } from './datetime';\nimport { DbxDateTimeFieldMenuPresetsService } from './datetime.field.service';\nimport { DbxDateTimeValueMode, dbxDateTimeInputValueParseFactory, dbxDateTimeIsSameDateTimeFieldValue, dbxDateTimeOutputValueFactory } from './date.value';\nimport { FormControlPath, streamValueFromControl } from '../../../../form/form.angular.util';\nimport { toggleDisableFormControl } from '../../../../form/form';\nimport { ErrorStateMatcher } from '@angular/material/core';\n\nexport enum DbxDateTimeFieldTimeMode {\n  /**\n   * Time is required.\n   */\n  REQUIRED = 'required',\n  /**\n   * Time is optional.\n   */\n  OPTIONAL = 'optional',\n  /**\n   * Time is permenantly off.\n   */\n  NONE = 'none'\n}\n\nexport type DbxDateTimePickerConfiguration = Omit<DateTimeMinuteConfig, 'date'>;\n\nexport type DbxDateTimeFieldSyncType = 'before' | 'after';\n\nexport interface DbxDateTimeFieldSyncField {\n  /**\n   * Field key/path to sync with/against.\n   */\n  readonly syncWith: string;\n  /**\n   * How to sync against the other field.\n   */\n  readonly syncType: DbxDateTimeFieldSyncType;\n}\n\n/**\n * Configuration for the time date field that has a reference and optional map function to map the value.\n */\nexport interface DbxDateTimeFieldTimeDateConfig<I = unknown> {\n  readonly path: FormControlPath;\n  readonly mapValue?: MapFunction<I, Maybe<DateOrDayString>>;\n}\n\nexport function isDbxDateTimeFieldTimeDateConfig(input: unknown): input is DbxDateTimeFieldTimeDateConfig {\n  return input != null && typeof input === 'object' && typeof (input as DbxDateTimeFieldTimeDateConfig).path === 'string';\n}\n\nexport interface DbxDateTimeFieldProps extends FormlyFieldProps {\n  /**\n   * Custom date label.\n   *\n   * Defaults to Date\n   */\n  readonly dateLabel?: string;\n\n  /**\n   * Custom time label.\n   *\n   * Defaults to Time\n   */\n  readonly timeLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"All Day\". Defaults to \"All Day\".\n   */\n  readonly allDayLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"At\". Defaults to \"At\".\n   */\n  readonly atTimeLabel?: string;\n\n  /**\n   * Value mode.\n   *\n   * Defaults to DATE\n   */\n  readonly valueMode?: DbxDateTimeValueMode;\n\n  /**\n   * Whether or not the date is hidden, and automatically uses today/input date.\n   */\n  readonly timeOnly?: boolean;\n\n  /**\n   * Only applicable when timeOnly is false.\n   *\n   * Whether or not to always show the date input even when there is only a single date that can be selected.\n   *\n   * Defaults to true.\n   */\n  readonly alwaysShowDateInput?: boolean;\n\n  /**\n   * Whether or not to autofill the date when time is picked.\n   *\n   * Defaults to false.\n   */\n  readonly autofillDateWhenTimeIsPicked?: boolean;\n\n  /**\n   * Whether or not the time can be added/removed optionally.\n   *\n   * This is ignored if timeOnly is specified.\n   */\n  readonly timeMode?: DbxDateTimeFieldTimeMode;\n\n  /**\n   * Other form control for enabling/disabling whether or not it is a full day.\n   *\n   * This field is only used if time is optional.\n   *\n   * When time is off, the field is set to true.\n   */\n  readonly fullDayFieldName?: string;\n\n  /**\n   * Whether or not to pass the date value as a UTC date, or a date in the current timezone.\n   */\n  readonly fullDayInUTC?: boolean;\n\n  /**\n   * Whether or not ot hide the date hint info content.\n   *\n   * False by default\n   */\n  readonly hideDateHint?: boolean;\n\n  /**\n   * Whether or not to hide the date/calendar picker.\n   */\n  readonly hideDatePicker?: boolean;\n\n  /**\n   * Custom picker configuration\n   */\n  readonly pickerConfig?: ObservableOrValueGetter<DbxDateTimePickerConfiguration>;\n\n  /**\n   * Used for syncing with one or more fields with a Date value.\n   */\n  readonly getSyncFieldsObs?: () => Observable<ArrayOrValue<DbxDateTimeFieldSyncField>>;\n\n  /**\n   * (Optional) The input timezone to default to.\n   *\n   * Ignored if fullDayInUTC is true.\n   */\n  readonly timezone?: Maybe<ObservableOrValueGetter<Maybe<TimezoneString>>>;\n\n  /**\n   * (Optional) The date to apply the time to.\n   *\n   * The timezone abbrviation will also use this date when using the time-only mode.\n   */\n  readonly timeDate?: Maybe<ObservableOrValueGetter<Maybe<DbxDateTimeFieldTimeDateConfig | FormControlPath | DateOrDayString>>>;\n\n  /**\n   * Whether or not to display the timezone. True by default.\n   */\n  readonly showTimezone?: Maybe<boolean>;\n\n  /**\n   * Custom presets to show in the dropdown.\n   */\n  readonly presets?: ObservableOrValueGetter<DateTimePresetConfiguration[]>;\n\n  /**\n   * The time in ms to prevent output from going out when the input value changes.\n   */\n  readonly inputOutputDebounceTime?: Milliseconds;\n\n  /**\n   * Whether or not to display the clear date button. True by default.\n   */\n  readonly showClearButton?: Maybe<boolean>;\n\n  /**\n   * The number of minutes to add/subtract when using the arrow keys.\n   */\n  readonly minuteStep?: Maybe<number>;\n}\n\nexport interface DbxDateTimeFieldSyncParsedField extends Pick<DbxDateTimeFieldSyncField, 'syncType'> {\n  control: AbstractControl<Maybe<Date | ISO8601DateString>>;\n}\n\nexport function syncConfigValueObs(parseConfigsObs: Observable<DbxDateTimeFieldSyncParsedField[]>, type: DbxDateTimeFieldSyncType): Observable<Date | null> {\n  return parseConfigsObs.pipe(\n    switchMap((x) => {\n      const config = x.find((y) => y.syncType === type);\n      let result: Observable<Date | null>;\n\n      if (config) {\n        const { control } = config;\n        result = control.valueChanges.pipe(\n          startWith(control.value),\n          map((x) => safeToJsDate(x) ?? null)\n        );\n      } else {\n        result = of(null);\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n}\n\nconst TIME_OUTPUT_THROTTLE_TIME: Milliseconds = 10;\n\n/**\n * Error code used when the selected date is not in the schedule.\n */\nexport const DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR = 'dateTimeFieldDateNotInSchedule';\n\n/**\n * Error code used when the selected time/time input is not in the limited range.\n */\nexport const DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR = 'dateTimeFieldTimeNotInRange';\n\n@Component({\n  templateUrl: 'datetime.field.component.html'\n})\nexport class DbxDateTimeFieldComponent extends FieldType<FieldTypeConfig<DbxDateTimeFieldProps>> implements OnInit, OnDestroy {\n  private readonly cdRef = inject(ChangeDetectorRef);\n  private readonly dbxDateTimeFieldConfigService = inject(DbxDateTimeFieldMenuPresetsService);\n\n  private _sub = new SubscriptionObject();\n  private _valueSub = new SubscriptionObject();\n  private _autoFillDateSync = new SubscriptionObject();\n\n  private _config = new BehaviorSubject<Maybe<Observable<DbxDateTimePickerConfiguration>>>(undefined);\n  readonly latestConfig$ = this._config.pipe(switchMapMaybeDefault(), distinctUntilChanged(), shareReplay(1));\n\n  private _syncConfigObs = new BehaviorSubject<Maybe<Observable<ArrayOrValue<DbxDateTimeFieldSyncField>>>>(undefined);\n\n  private _defaultTimezone = new BehaviorSubject<Maybe<Observable<Maybe<TimezoneString>>>>(undefined);\n  private _timeDate = new BehaviorSubject<Maybe<Observable<Maybe<DbxDateTimeFieldTimeDateConfig | FormControlPath | DateOrDayString>>>>(undefined);\n  private _presets = new BehaviorSubject<Observable<DateTimePresetConfiguration[]>>(of([]));\n\n  private _fullDayInputCtrl?: FormControl;\n  private _fullDayControlObs = new BehaviorSubject<Maybe<AbstractControl<boolean>>>(undefined);\n  readonly fullDayControl$ = this._fullDayControlObs.pipe(filterMaybe());\n\n  private _offset = new BehaviorSubject<number>(0);\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl<Maybe<Date>>>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  private _cleared = new Subject<void>();\n  private _updateTime = new Subject<void>();\n\n  private _resyncTimeInputSub = new SubscriptionObject();\n  private _resyncTimeInput = new Subject<void>();\n\n  readonly timeErrorStateMatcher: ErrorStateMatcher = {\n    isErrorState: (control: AbstractControl | null, form) => {\n      if (control) {\n        return (control.invalid && (control.dirty || control.touched)) || this.errorStateMatcher.isErrorState(this.formControl, form);\n      } else {\n        return false;\n      }\n    }\n  };\n\n  readonly resyncTimeInput$ = this._resyncTimeInput.pipe(debounceTime(200), shareReplay(1));\n\n  private _configUpdateTimeSync = new SubscriptionObject(\n    this.latestConfig$.pipe(skip(1)).subscribe((x) => {\n      this._updateTime.next();\n    })\n  );\n\n  readonly timezone$: Observable<Maybe<TimezoneString>> = this._defaultTimezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(\n    map((defaultTimezone) => {\n      return defaultTimezone ?? guessCurrentTimezone();\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly timezoneInstance$: Observable<Maybe<DateTimezoneUtcNormalInstance>> = this.timezone$.pipe(\n    map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)),\n    shareReplay(1)\n  );\n\n  readonly timeDate$: Observable<Maybe<Date>> = this._timeDate.pipe(\n    switchMapMaybeDefault(),\n    switchMap((x) => {\n      let obs: Observable<Maybe<Date>>;\n\n      if (x) {\n        // if the string is not a date string, then treat it as a path\n        if ((typeof x === 'string' && !isISO8601DayStringStart(x)) || isDbxDateTimeFieldTimeDateConfig(x)) {\n          const { path, mapValue }: DbxDateTimeFieldTimeDateConfig = typeof x === 'string' ? { path: x } : x;\n          obs =\n            streamValueFromControl<DateOrDayString>(this.form, path)?.pipe(\n              map(mapValue ?? mapIdentityFunction()),\n              map((x) => (x ? toJsDayDate(x) : undefined))\n            ) ?? of(undefined);\n        } else {\n          obs = of(toJsDayDate(x));\n        }\n      } else {\n        obs = of(undefined);\n      }\n\n      return obs;\n    }),\n    distinctUntilChanged(isSameDateDay),\n    shareReplay(1)\n  );\n\n  readonly valueInSystemTimezone$: Observable<Maybe<Date>> = this.formControl$.pipe(\n    map((control) => control.valueChanges.pipe(startWith<Maybe<Date | ISO8601DayString | MinuteOfDay | UnixDateTimeNumber>>(control.value), shareReplay(1))),\n    combineLatestWith(this.timezoneInstance$),\n    switchMap(([x, timezoneInstance]) => {\n      return x.pipe(map(dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)));\n    }),\n    throttleTime(20, undefined, { leading: true, trailing: true }), // throttle incoming values and timezone changes\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly refreshInteral$ = interval(10 * 1000);\n\n  /**\n   * Used to trigger/display visual updates (specifically on timeDistance, etc.).\n   */\n  readonly displayValue$ = this.refreshInteral$.pipe(\n    // every 10 seconds, refresh w/interval\n    startWith(0),\n    map(() => new Date().getMinutes()),\n    distinctUntilChanged(),\n    tap(() => this.cdRef.markForCheck()),\n    switchMap(() => this.valueInSystemTimezone$),\n    shareReplay(1)\n  );\n\n  readonly timeString$: Observable<ReadableTimeString | ''> = this.valueInSystemTimezone$.pipe(\n    map((x) => (x ? toLocalReadableTimeString(x) : '')),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateInputCtrl = new FormControl<Maybe<Date>>(null, {\n    validators: []\n  });\n\n  readonly timeInputCtrl = new FormControl<Maybe<ReadableTimeString>>(null, {\n    validators: [Validators.pattern(/^(now)$|^([0-9]|(0[0-9])|(1[0-9])|(2[0-3]))(:)?([0-5][0-9])?(\\s)?([apAP][Mm])?(\\\\s)*$/)]\n  });\n\n  get dateLabel(): string {\n    return this.props.dateLabel ?? 'Date';\n  }\n\n  get timeLabel(): string {\n    return this.props.timeLabel ?? 'Time';\n  }\n\n  get allDayLabel(): string {\n    return this.props.allDayLabel ?? 'All Day';\n  }\n\n  get atTimeLabel(): string {\n    return this.props.atTimeLabel ?? 'At';\n  }\n\n  get dateOnly(): boolean {\n    return this.timeMode === DbxDateTimeFieldTimeMode.NONE;\n  }\n\n  get dateTimeField(): DbxDateTimeFieldProps {\n    return this.field.props;\n  }\n\n  get timeOnly(): Maybe<boolean> {\n    const timeValuesOnly = this.valueMode === DbxDateTimeValueMode.MINUTE_OF_DAY;\n\n    if (timeValuesOnly) {\n      return true;\n    } else {\n      return this.dateTimeField.timeOnly;\n    }\n  }\n\n  get alwaysShowDateInput(): boolean {\n    return this.props.alwaysShowDateInput ?? true;\n  }\n\n  get autofillDateWhenTimeIsPicked(): boolean {\n    return this.props.autofillDateWhenTimeIsPicked ?? this.alwaysShowDateInput === false;\n  }\n\n  get showDateInput(): boolean {\n    return !this.timeOnly;\n  }\n\n  get valueMode(): DbxDateTimeValueMode {\n    return this.field.props.valueMode ?? DbxDateTimeValueMode.DATE;\n  }\n\n  get timeMode(): DbxDateTimeFieldTimeMode {\n    const dateValuesOnly = this.valueMode === DbxDateTimeValueMode.DAY_STRING;\n\n    if (dateValuesOnly) {\n      return DbxDateTimeFieldTimeMode.NONE;\n    } else {\n      return this.timeOnly ? DbxDateTimeFieldTimeMode.REQUIRED : this.dateTimeField.timeMode ?? DbxDateTimeFieldTimeMode.REQUIRED;\n    }\n  }\n\n  get isDateRequired(): boolean {\n    return this.props.required ?? false;\n  }\n\n  get isTimeRequired(): boolean {\n    return this.isDateRequired && this.timeMode === DbxDateTimeFieldTimeMode.REQUIRED;\n  }\n\n  get description(): Maybe<string> {\n    return this.field.props.description;\n  }\n\n  get hideDateHint(): boolean {\n    return this.field.props.hideDateHint ?? false;\n  }\n\n  get hideDatePicker(): boolean {\n    return this.field.props.hideDatePicker ?? false;\n  }\n\n  get timezone() {\n    return this.field.props.timezone;\n  }\n\n  get timeDate() {\n    return this.field.props.timeDate;\n  }\n\n  get showTimezone() {\n    return this.field.props.showTimezone ?? true;\n  }\n\n  get presets() {\n    return this.field.props.presets;\n  }\n\n  get showClearButton() {\n    return this.field.props.showClearButton;\n  }\n\n  get minuteStep() {\n    return this.field.props.minuteStep ?? this.field.props.step ?? 5;\n  }\n\n  readonly fullDay$: Observable<boolean> = this.fullDayControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly showTimeInput$: Observable<boolean> = this.fullDay$.pipe(map((x) => !x && this.timeMode !== DbxDateTimeFieldTimeMode.NONE));\n\n  readonly showAddTime$ = this.showTimeInput$.pipe(\n    map((x) => !x && this.timeMode === DbxDateTimeFieldTimeMode.OPTIONAL),\n    shareReplay(1)\n  );\n\n  readonly currentDate$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), shareReplay(1));\n  readonly date$ = this.currentDate$.pipe(filterMaybe(), shareReplay(1));\n\n  readonly timezoneAbbreviation$ = combineLatest([this.currentDate$, this.timezone$, this.timeDate$]).pipe(\n    map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? date ?? new Date())),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateValue$: Observable<Maybe<Date>> = merge(this.date$, this.valueInSystemTimezone$.pipe(skipFirstMaybe())).pipe(\n    map((x: Maybe<Date>) => (x ? startOfDay(x) : null)),\n    distinctUntilChanged<Maybe<Date>>(isSameDateDay),\n    shareReplay(1)\n  );\n\n  readonly timeInput$: Observable<ReadableTimeString> = this._updateTime.pipe(\n    debounceTime(5),\n    map(() => this.timeInputCtrl.value || ''),\n    distinctUntilChanged()\n  );\n\n  readonly syncConfigObs$ = this._syncConfigObs.pipe(switchMapMaybeDefault(), shareReplay(1));\n\n  readonly parsedSyncConfigs$: Observable<DbxDateTimeFieldSyncParsedField[]> = this.syncConfigObs$.pipe(\n    map((x) => {\n      let parsed: DbxDateTimeFieldSyncParsedField[];\n\n      if (x) {\n        parsed = filterMaybeValues(\n          asArray(x).map((y) => {\n            const control = this.form.get(y.syncWith);\n\n            if (control) {\n              return {\n                control,\n                ...y\n              };\n            } else {\n              return undefined;\n            }\n          })\n        );\n      } else {\n        parsed = [];\n      }\n\n      return parsed;\n    }),\n    shareReplay(1)\n  );\n\n  readonly syncConfigBeforeValue$: Observable<Date | null> = syncConfigValueObs(this.parsedSyncConfigs$, 'before');\n  readonly syncConfigAfterValue$: Observable<Date | null> = syncConfigValueObs(this.parsedSyncConfigs$, 'after');\n\n  readonly isTimeCleared$ = combineLatest([this.currentDate$, this._timeDate.pipe(startWith(null))]).pipe(\n    switchMap(([date, time]) => {\n      const isTimeCleared = Boolean(!date && !time);\n      return this._cleared.pipe(\n        map(() => true),\n        startWith(isTimeCleared)\n      );\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly rawDateTime$: Observable<Maybe<Date>> = combineLatest([\n    this._config.pipe(\n      first(),\n      switchMap(() => (this.timeOnly ? of(null) : this.dateValue$))\n    ),\n    this.timeInput$.pipe(startWith(null)),\n    this.fullDay$,\n    this.timeDate$,\n    this.isTimeCleared$\n  ]).pipe(\n    map(([date, timeString, fullDay, timeDate, isTimeCleared]) => {\n      let result: Maybe<Date>;\n\n      if (!isTimeCleared) {\n        if (!date || this.timeOnly) {\n          date = timeDate ?? new Date(); // use the time date, or default to the current day\n        }\n\n        if (date) {\n          if (fullDay) {\n            if (this.dateTimeField.fullDayInUTC) {\n              result = utcDayForDate(date);\n            } else {\n              result = startOfDay(date);\n            }\n          } else if (timeString) {\n            result =\n              readableTimeStringToDate(timeString, {\n                date,\n                useSystemTimezone: true\n              }) ?? date;\n          } else if (!this.timeOnly) {\n            if (this.timeMode !== DbxDateTimeFieldTimeMode.REQUIRED) {\n              // only autofill the date if the time is marked as required (and the time string is empty)\n              result = date;\n            }\n          }\n        }\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly dateTimePickerConfig$: Observable<Maybe<DbxDateTimePickerConfiguration>> = combineLatest([this._config.pipe(switchMapMaybeObs()), this.syncConfigBeforeValue$, this.syncConfigAfterValue$]).pipe(\n    map(([x, dateInputMin, dateInputMax]) => {\n      let result: Maybe<DbxDateTimePickerConfiguration> = x;\n\n      if (dateInputMin != null || dateInputMax != null) {\n        const { min: limitMin, max: limitMax } = x?.limits ?? {};\n        const min = findMinDate([dateInputMin, dateFromLogicalDate(limitMin)]);\n        const max = findMaxDate([dateInputMax, dateFromLogicalDate(limitMax)]);\n\n        result = {\n          ...x,\n          limits: {\n            ...x?.limits,\n            min,\n            max\n          }\n        };\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateInputMin$: Observable<Date | null> = this.dateTimePickerConfig$.pipe(\n    map((x) => (x?.limits?.min ?? null) as Date | null),\n    distinctUntilChanged<Date | null>(isSameDate),\n    shareReplay(1)\n  );\n\n  readonly dateInputMax$: Observable<Date | null> = this.dateTimePickerConfig$.pipe(\n    map((x) => (x?.limits?.max ?? null) as Date | null),\n    distinctUntilChanged<Date | null>(isSameDate),\n    shareReplay(1)\n  );\n\n  /**\n   * Whether or not there is a limited min/max date range applied/available.\n   */\n  readonly hasRestrictedDateRange$: Observable<boolean> = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(\n    map(([a, b]) => Boolean(a || b)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateMinAndMaxIsSameDay$: Observable<boolean> = combineLatest([this.dateInputMin$, this.dateInputMax$]).pipe(\n    map(([a, b]) => Boolean(a && b) && isSameDateDay(a, b)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly pickerFilter$: Observable<DecisionFunction<Date | null>> = this.dateTimePickerConfig$.pipe(\n    distinctUntilChanged(),\n    map((x) => {\n      if (x) {\n        const filter = dateTimeMinuteWholeDayDecisionFunction(x, false);\n        return (x: Date | null) => (x != null ? filter(x) : true);\n      } else {\n        return () => true;\n      }\n    }),\n    shareReplay(1)\n  );\n\n  readonly defaultPickerFilter: DecisionFunction<Date | null> = () => true;\n\n  readonly timeOutput$: Observable<Maybe<Date>> = combineLatest([this.rawDateTime$, this._offset, this.dateTimePickerConfig$]).pipe(\n    throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n    distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0 && current[2] === next[2]),\n    tap(([, stepsOffset]) => (stepsOffset ? this._offset.next(0) : 0)),\n    map(([date, stepsOffset, config]) => {\n      if (date != null) {\n        const instance = new DateTimeMinuteInstance({\n          date,\n          ...config,\n          roundDownToMinute: true\n        });\n\n        // only clamp when the steps offset is set\n        if (stepsOffset) {\n          date = instance.clamp(date);\n\n          const minutes = stepsOffset * this.minuteStep;\n\n          if (minutes != 0) {\n            date = addMinutes(date, minutes);\n            date = instance.clamp(date); // clamp the date again\n          }\n        }\n      }\n\n      return date;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly dateTimePickerInstance$ = this.dateTimePickerConfig$.pipe(\n    map((config) => {\n      return new DateTimeMinuteInstance({\n        ...config,\n        roundDownToMinute: true\n      });\n    }),\n    shareReplay(1)\n  );\n\n  readonly hasEmptyDisplayValue$ = this.displayValue$.pipe(\n    map((x) => !x),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly presets$: Observable<DateTimePreset[]> = this._presets.pipe(\n    switchMapMaybeObs(),\n    map((x: DateTimePresetConfiguration[]) => x.map(dateTimePreset)),\n    shareReplay(1)\n  );\n\n  readonly showClearButton$: Observable<boolean> = this.hasEmptyDisplayValue$.pipe(\n    map((x) => Boolean(this.showClearButton && !x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly canAutofillDateWithOnlyAvailableDate$: Observable<boolean> = this.dateMinAndMaxIsSameDay$;\n\n  readonly showDateInput$: Observable<boolean> = this.dateMinAndMaxIsSameDay$.pipe(\n    map((dateMinAndMaxIsSameDay) => {\n      return this.showDateInput && (this.alwaysShowDateInput || !dateMinAndMaxIsSameDay);\n    }),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly currentErrorMessage$ = this.formControl$.pipe(\n    switchMap((formControl) =>\n      formControl.statusChanges.pipe(\n        filter((x) => x === 'INVALID' || x === 'VALID'),\n        map((x) => {\n          let currentErrorMessage: string | undefined;\n\n          if (x === 'INVALID') {\n            if (this.formControl.hasError('required')) {\n              currentErrorMessage = 'Date is required';\n            } else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR)) {\n              currentErrorMessage = 'Date does not fall on an available dates in schedule.';\n            } else if (this.formControl.hasError(DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR)) {\n              currentErrorMessage = 'Time is not valid for the given date.';\n            } else {\n              currentErrorMessage = 'The given date and time is invalid.';\n            }\n          }\n\n          return currentErrorMessage;\n        })\n      )\n    ),\n    startWith(undefined),\n    shareReplay(1)\n  );\n\n  readonly hasError$ = this.currentErrorMessage$.pipe(\n    map((x) => Boolean(x)),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    const inputPickerConfig = this.dateTimeField.pickerConfig;\n    this._config.next(inputPickerConfig ? asObservableFromGetter(inputPickerConfig) : of({}));\n    this._syncConfigObs.next(this.dateTimeField.getSyncFieldsObs?.());\n\n    this._sub.subscription = this.valueInSystemTimezone$\n      .pipe(\n        combineLatestWith(this.timezoneInstance$.pipe(map((timezoneInstance) => dbxDateTimeOutputValueFactory(this.valueMode, timezoneInstance)))),\n        throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n        switchMap(([currentValue, valueFactory]) => {\n          return this.timeOutput$.pipe(\n            throttleTime(TIME_OUTPUT_THROTTLE_TIME * 2, undefined, { leading: false, trailing: true }),\n            skipFirstMaybe(),\n            distinctUntilChanged(isSameDateHoursAndMinutes),\n            map((x) => valueFactory(x)),\n            filter((x) => !dbxDateTimeIsSameDateTimeFieldValue(x, currentValue))\n          );\n        })\n      )\n      .subscribe((value) => {\n        this.formControl.setValue(value);\n        this.formControl.markAsDirty();\n        this.formControl.markAsTouched();\n      });\n\n    let hasSetMidnightFromInput = false;\n\n    /*\n    this._valueSub.subscription = this.timeString$.subscribe((x) => {\n      this.setTime(x);\n    });\n    */\n\n    if (this.autofillDateWhenTimeIsPicked) {\n      this._autoFillDateSync.subscription = this.canAutofillDateWithOnlyAvailableDate$\n        .pipe(\n          switchMap((canAutofill) => {\n            if (canAutofill) {\n              // when the time updates the first time, set the current min date\n              return this._updateTime.pipe(\n                debounceTime(200),\n                switchMap((x) => this.dateInputMin$),\n                filterMaybe()\n              );\n            } else {\n              return of(null); // don't show anything\n            }\n          })\n        )\n        .subscribe((autoDate) => {\n          if (autoDate != null) {\n            this.dateInputCtrl.setValue(autoDate);\n          }\n        });\n    }\n\n    this._valueSub.subscription = this.valueInSystemTimezone$\n      .pipe(\n        map((x) => (x ? isSameDate(x, startOfDay(x)) : false)),\n        distinctUntilChanged(),\n        switchMap((isInputValueAtMidnight) => {\n          hasSetMidnightFromInput = false;\n          return this.timeString$.pipe(\n            // skip(1),\n            map((timeString) => [timeString, isInputValueAtMidnight] as [string, boolean])\n          );\n        })\n      )\n      .subscribe(([x, isInputValueAtMidnight]) => {\n        // Skip events where the timeInput value is cleared, unless the input value is at midnight and we've already processed it being at midnight\n        if (!this.timeInputCtrl.value && x === '12:00AM' && (!isInputValueAtMidnight || (isInputValueAtMidnight && hasSetMidnightFromInput))) {\n          return;\n        }\n\n        // update the has set flag\n        if (x === '12:00AM' && isInputValueAtMidnight) {\n          hasSetMidnightFromInput = true;\n        }\n\n        this.setTime(x);\n      });\n\n    // Set default timezone if provided.\n    if (this.timezone && !this.dateTimeField.fullDayInUTC) {\n      this._defaultTimezone.next(asObservableFromGetter(this.timezone));\n    }\n\n    this._timeDate.next(asObservableFromGetter(this.timeDate));\n\n    // Watch for disabled changes so we can propogate them properly.\n    this.formControl.registerOnDisabledChange((isDisabled) => {\n      toggleDisableFormControl(this.dateInputCtrl, isDisabled);\n      toggleDisableFormControl(this.timeInputCtrl, isDisabled);\n    });\n\n    const isFullDayField = this.dateTimeField.fullDayFieldName;\n    let fullDayFieldCtrl: Maybe<AbstractControl>;\n\n    if (isFullDayField) {\n      fullDayFieldCtrl = this.form.get(isFullDayField);\n    }\n\n    if (!fullDayFieldCtrl) {\n      const isFullDay = this.timeMode === DbxDateTimeFieldTimeMode.NONE;\n      this._fullDayInputCtrl = new FormControl(isFullDay);\n\n      // Set the control in the form too if the name is defined.\n      if (isFullDayField) {\n        (this.form as FormGroup).addControl(isFullDayField, this._fullDayInputCtrl);\n      }\n\n      fullDayFieldCtrl = this._fullDayInputCtrl;\n    }\n\n    this._fullDayControlObs.next(fullDayFieldCtrl);\n\n    switch (this.timeMode) {\n      case DbxDateTimeFieldTimeMode.OPTIONAL:\n        break;\n      case DbxDateTimeFieldTimeMode.NONE:\n        this.removeTime();\n        break;\n      case DbxDateTimeFieldTimeMode.REQUIRED:\n        this.addTime();\n        break;\n    }\n\n    if (this.presets != null) {\n      this._presets.next(asObservableFromGetter(this.presets));\n    } else {\n      this._presets.next(this.dbxDateTimeFieldConfigService.configurations$);\n    }\n\n    this._resyncTimeInputSub.subscription = this.resyncTimeInput$.pipe(switchMap((x) => combineLatest([this.currentDate$, this.timeString$]).pipe(first()))).subscribe(([currentDate, timeString]) => {\n      // only resync when the current date is set, otherwise do not change the time string.\n      // This helps in cases where the user picks a time first and we don't want it to be cleared.\n      if (currentDate != null) {\n        this.timeInputCtrl.setValue(timeString, { emitEvent: false });\n      }\n    });\n\n    // add validators/errors for the form\n    this.formControl.addAsyncValidators([\n      (x) => {\n        const formValue = x.value as Maybe<Date>;\n        let obs: Observable<ValidationErrors>;\n\n        if (formValue != null) {\n          obs = combineLatest([this.timezoneInstance$, this.dateTimePickerInstance$]).pipe(\n            map(([timezoneInstance, x]) => {\n              // the form value is going to be in the output form, so we need to parse it back to the \"input\" date before evaluating it\n              const formValueInSystemTimezone = dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)(formValue);\n\n              let errors: ValidationErrors = {\n                ...this.timeInputCtrl.errors\n              };\n\n              if (formValueInSystemTimezone) {\n                if (x.dateIsInSchedule(formValueInSystemTimezone)) {\n                  if (!x.isInValidRange(formValueInSystemTimezone)) {\n                    errors = {\n                      [DBX_DATE_TIME_FIELD_TIME_NOT_IN_RANGE_ERROR]: true\n                    };\n                  }\n                } else {\n                  errors = {\n                    [DBX_DATE_TIME_FIELD_DATE_NOT_IN_SCHEDULE_ERROR]: true\n                  };\n                }\n              }\n\n              return errors;\n            }),\n            first()\n          );\n        } else {\n          obs = of({});\n        }\n\n        return obs;\n      }\n    ]);\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._valueSub.destroy();\n    this._config.complete();\n    this._configUpdateTimeSync.destroy();\n    this._defaultTimezone.complete();\n    this._resyncTimeInputSub.destroy();\n    this._autoFillDateSync.destroy();\n    this._timeDate.complete();\n    this._presets.complete();\n    this._fullDayControlObs.complete();\n    this._offset.complete();\n    this._formControlObs.complete();\n    this._updateTime.complete();\n    this._cleared.complete();\n    this._resyncTimeInput.complete();\n    this._syncConfigObs.complete();\n  }\n\n  selectPreset(preset: DateTimePreset): void {\n    const value = preset.value();\n\n    if (value.logicalDate) {\n      this.setLogicalTime(value.logicalDate);\n    } else if (value.timeString) {\n      this.setTime(value.timeString);\n    }\n  }\n\n  datePicked(event: MatDatepickerInputEvent<Date>): void {\n    const date = event.value;\n\n    if (date) {\n      this.setDateInputValue(date);\n    }\n  }\n\n  setLogicalTime(time: LogicalDate): void {\n    const date = dateFromLogicalDate(time);\n\n    if (date) {\n      this.setTimeFromDate(date);\n    }\n  }\n\n  setDateInputValue(date: Date) {\n    this.dateInputCtrl.setValue(date);\n    this._updateTime.next();\n  }\n\n  setTimeFromDate(timeDate: Date): void {\n    const timeString = toLocalReadableTimeString(timeDate);\n    this.setTime(timeString);\n  }\n\n  setTime(time: ReadableTimeString): void {\n    if (this.timeInputCtrl.value !== time) {\n      this.timeInputCtrl.setValue(time);\n      this._offset.next(0);\n      this._updateTime.next();\n    }\n  }\n\n  keydownOnDateInput(event: KeyboardEvent): void {\n    let direction = 0;\n\n    switch (event.key?.toLowerCase()) {\n      case 'arrowup':\n        direction = 1;\n        break;\n      case 'arrowdown':\n        direction = -1;\n        break;\n    }\n\n    let offset = 1;\n\n    if (event.ctrlKey && event.shiftKey) {\n      offset = 365;\n    } else if (event.ctrlKey) {\n      offset = 30;\n    } else if (event.shiftKey) {\n      offset = 7;\n    }\n\n    if (direction !== 0) {\n      combineLatest([this.date$, this.dateTimePickerConfig$])\n        .pipe(first())\n        .subscribe(([date, config]) => {\n          const newDate = startOfDay(addDays(date, offset * direction));\n          const instance = new DateTimeMinuteInstance({\n            date: newDate,\n            ...config\n          });\n\n          const nextDate = instance.isInSchedule(newDate) ? newDate : instance.findNextAvailableDayInSchedule(newDate, direction === 1 ? 'future' : 'past');\n\n          if (nextDate != null) {\n            this.setDateInputValue(instance.clampToLimit(nextDate));\n          }\n        });\n    }\n  }\n\n  keydownOnTimeInput(event: KeyboardEvent): void {\n    let direction = 0;\n\n    switch (event.key?.toLowerCase()) {\n      case 'arrowup':\n        direction = 1;\n        break;\n      case 'arrowdown':\n        direction = -1;\n        break;\n    }\n\n    let offset = 1;\n\n    if (event.altKey && event.shiftKey) {\n      offset = 300;\n    } else if (event.altKey) {\n      offset = 60;\n    } else if (event.shiftKey) {\n      offset = 5;\n    }\n\n    if (direction !== 0) {\n      this._offset.next(this._offset.value + offset * direction);\n      this._updateTime.next();\n    }\n  }\n\n  focusTime(): void {\n    // do nothing\n  }\n\n  focusOutTime(): void {\n    // only refresh when there is not a pattern error\n    if (!this.timeInputCtrl.hasError('pattern')) {\n      this._updateTime.next();\n      this._resyncTimeInput.next();\n    }\n  }\n\n  addTime(): void {\n    this.setFullDay(false);\n  }\n\n  removeTime(): void {\n    this.setFullDay(true);\n  }\n\n  setFullDay(fullDay: boolean): void {\n    this.fullDayControl$.pipe(first()).subscribe((x) => {\n      x.setValue(fullDay);\n    });\n  }\n\n  clearValue(): void {\n    this._cleared.next();\n  }\n}\n","<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutGap=\"6px grid\" fxLayoutAlign=\"space-evenly stretch\">\n  <!-- Date -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput$ | async\">\n    <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n  </div>\n  <!-- Time -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"(showDateInput$ | async) ? '50' : '100'\">\n    <ng-container *ngIf=\"showTimeInput$ | async\">\n      <ng-container *ngTemplateOutlet=\"timeMenuAndInputTemplate\"></ng-container>\n    </ng-container>\n    <div *ngIf=\"showAddTime$ | async\" class=\"add-time-button-wrapper\">\n      <button mat-button class=\"mat-datepicker-button-highlight dbx-button-spacer add-time-button\" ngClass.lt-sm=\"add-time-button-full\" (click)=\"addTime()\">\n        <mat-icon>timer</mat-icon>\n        Add Time\n      </button>\n    </div>\n  </div>\n  <!-- Date Hint -->\n  <ng-container [ngSwitch]=\"hasError$ | async\">\n    <ng-container *ngSwitchCase=\"false\">\n      <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n        <div class=\"dbx-hint\">\n          <ng-container [ngSwitch]=\"hasEmptyDisplayValue$ | async\">\n            <ng-container *ngSwitchCase=\"true\">\n              <span class=\"dbx-small\">No date/time set</span>\n            </ng-container>\n            <ng-container *ngSwitchCase=\"false\">\n              <ng-container [ngSwitch]=\"fullDay$ | async\">\n                <small *ngSwitchCase=\"true\">\n                  <b class=\"dbx-ok\">{{ allDayLabel }}</b>\n                  {{ displayValue$ | async | date: 'fullDate' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | dateDistance }})\n                </small>\n                <small *ngSwitchCase=\"false\">\n                  <ng-container *ngIf=\"displayValue$ | async\">\n                    <b class=\"dbx-ok\">{{ atTimeLabel }}</b>\n                    {{ displayValue$ | async | date: 'medium' }} {{ timezoneAbbreviation$ | async }} ({{ displayValue$ | async | timeDistance }})\n                  </ng-container>\n                </small>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"true\">\n      <mat-error *ngIf=\"currentErrorMessage$ | async\">{{ currentErrorMessage$ | async }}</mat-error>\n    </ng-container>\n  </ng-container>\n</div>\n\n<!-- Date Input Template -->\n<ng-template #dateInputTemplate>\n  <mat-form-field class=\"dbx-datetime-row-field\">\n    <mat-label>{{ dateLabel }}</mat-label>\n    <input #dateInput matInput [disabled]=\"disabled\" [required]=\"isDateRequired\" [min]=\"dateInputMin$ | async\" [max]=\"dateInputMax$ | async\" [matDatepicker]=\"picker\" [matDatepickerFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" (dateChange)=\"datePicked($event)\" [value]=\"dateValue$ | async\" (keydown)=\"keydownOnDateInput($event)\" />\n    <mat-datepicker #picker></mat-datepicker>\n    <button matPrefix class=\"dbx-datetime-row-button\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n      <mat-icon>calendar_today</mat-icon>\n    </button>\n    <button matSuffix *ngIf=\"showClearButton$ | async\" class=\"dbx-datetime-clear-button\" mat-icon-button aria-label=\"clears the date and time menu\" [disabled]=\"disabled\" (click)=\"clearValue()\">\n      <mat-icon>clear</mat-icon>\n    </button>\n    <span matTextSuffix *ngIf=\"!(showTimeInput$ | async)\">\n      <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n    </span>\n  </mat-form-field>\n</ng-template>\n\n<!-- Time Menu/Input Template -->\n<ng-template #timeMenuAndInputTemplate>\n  <mat-menu #timemenu=\"matMenu\">\n    <ng-container *ngIf=\"timeMode === 'optional'\">\n      <button mat-menu-item (click)=\"removeTime()\">\n        <span>Remove Time</span>\n      </button>\n      <mat-divider></mat-divider>\n    </ng-container>\n    <ng-container *ngFor=\"let preset of presets$ | async\">\n      <button mat-menu-item (click)=\"selectPreset(preset)\">{{ preset.label | getValue }}</button>\n    </ng-container>\n  </mat-menu>\n  <mat-form-field class=\"dbx-datetime-row-field\">\n    <mat-label>{{ timeLabel }}</mat-label>\n    <input #timeInput [errorStateMatcher]=\"timeErrorStateMatcher\" matInput [required]=\"isTimeRequired\" [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n    <button matPrefix class=\"dbx-datetime-row-button\" mat-icon-button [matMenuTriggerFor]=\"timemenu\" aria-label=\"opens the time menu\" [disabled]=\"disabled\">\n      <mat-icon>timer</mat-icon>\n    </button>\n    <span matTextSuffix>\n      <ng-container *ngTemplateOutlet=\"timezoneSuffixTemplate\"></ng-container>\n    </span>\n    <mat-error *ngIf=\"timeInputCtrl.hasError('pattern')\">The input time is not recognizable.</mat-error>\n  </mat-form-field>\n</ng-template>\n\n<!-- Timezone Suffix -->\n<ng-template #timezoneSuffixTemplate>\n  <span *ngIf=\"showTimezone\" class=\"dbx-datetime-timezone dbx-faint\">{{ timezoneAbbreviation$ | async }}</span>\n</ng-template>\n"]}