@dereekb/dbx-form 9.25.15 → 10.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.
- package/_index.scss +1 -0
- package/calendar/lib/calendar.module.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.cell.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.component.d.ts +4 -4
- package/calendar/lib/calendar.schedule.selection.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.days.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.days.form.component.d.ts +2 -2
- package/calendar/lib/calendar.schedule.selection.dialog.button.component.d.ts +1 -6
- package/calendar/lib/calendar.schedule.selection.dialog.component.d.ts +1 -11
- package/calendar/lib/calendar.schedule.selection.popover.button.component.d.ts +2 -2
- package/calendar/lib/calendar.schedule.selection.popover.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.popover.content.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.range.component.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.store.d.ts +4 -32
- package/calendar/lib/calendar.schedule.selection.store.provide.d.ts +1 -1
- package/calendar/lib/calendar.schedule.selection.toggle.button.component.d.ts +1 -1
- package/calendar/lib/field/schedule/calendar.schedule.field.component.d.ts +2 -8
- package/esm2022/calendar/lib/calendar.module.mjs +155 -0
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.cell.component.mjs +10 -10
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.component.mjs +6 -6
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.days.component.mjs +6 -6
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.days.form.component.mjs +6 -6
- package/esm2022/calendar/lib/calendar.schedule.selection.dialog.button.component.mjs +36 -0
- package/esm2022/calendar/lib/calendar.schedule.selection.dialog.component.mjs +56 -0
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.mjs +1 -1
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.popover.button.component.mjs +6 -6
- package/esm2022/calendar/lib/calendar.schedule.selection.popover.component.mjs +38 -0
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.popover.content.component.mjs +6 -6
- package/esm2022/calendar/lib/calendar.schedule.selection.range.component.mjs +188 -0
- package/esm2022/calendar/lib/calendar.schedule.selection.store.mjs +785 -0
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.store.provide.mjs +7 -7
- package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.toggle.button.component.mjs +6 -6
- package/esm2022/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +158 -0
- package/esm2022/calendar/lib/field/schedule/calendar.schedule.field.mjs +28 -0
- package/esm2022/calendar/lib/field/schedule/calendar.schedule.module.mjs +58 -0
- package/{esm2020 → esm2022}/lib/form/action/form.action.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form/action/form.action.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/form/action/transition/form.action.transition.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/form/action/transition/form.action.transition.safety.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form/form.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/form/io/form.changes.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form/io/form.input.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form/io/form.io.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/form/io/form.loading.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/form.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.component.mjs +9 -9
- package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.content.default.component.mjs +6 -6
- package/esm2022/lib/formly/field/checklist/checklist.item.field.module.mjs +67 -0
- package/{esm2020 → esm2022}/lib/formly/field/component/component.field.component.mjs +6 -6
- package/esm2022/lib/formly/field/component/component.field.module.mjs +32 -0
- package/esm2022/lib/formly/field/field.mjs +97 -0
- package/{esm2020 → esm2022}/lib/formly/field/form.field.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/field/selection/list/list.field.component.mjs +4 -4
- package/esm2022/lib/formly/field/selection/list/list.field.module.mjs +76 -0
- package/esm2022/lib/formly/field/selection/pickable/pickable.chip.field.component.mjs +33 -0
- package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.field.directive.mjs +4 -4
- package/esm2022/lib/formly/field/selection/pickable/pickable.field.module.mjs +93 -0
- package/esm2022/lib/formly/field/selection/pickable/pickable.list.field.component.mjs +116 -0
- package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.mjs +1 -1
- package/esm2022/lib/formly/field/selection/searchable/searchable.chip.field.component.mjs +68 -0
- package/esm2022/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.mjs +95 -0
- package/esm2022/lib/formly/field/selection/searchable/searchable.field.directive.mjs +278 -0
- package/esm2022/lib/formly/field/selection/searchable/searchable.field.module.mjs +91 -0
- package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.text.field.component.mjs +4 -4
- package/esm2022/lib/formly/field/selection/selection.field.mjs +39 -0
- package/{esm2020 → esm2022}/lib/formly/field/selection/selection.mjs +1 -1
- package/{esm2020 → esm2022}/lib/formly/field/selection/selection.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.field.component.mjs +4 -4
- package/esm2022/lib/formly/field/selection/sourceselect/sourceselect.field.module.mjs +93 -0
- package/{esm2020 → esm2022}/lib/formly/field/texteditor/texteditor.field.component.mjs +6 -6
- package/esm2022/lib/formly/field/texteditor/texteditor.field.module.mjs +51 -0
- package/{esm2020 → esm2022}/lib/formly/field/value/array/array.field.component.mjs +8 -8
- package/esm2022/lib/formly/field/value/array/array.field.module.mjs +62 -0
- package/esm2022/lib/formly/field/value/boolean/boolean.field.mjs +47 -0
- package/{esm2020 → esm2022}/lib/formly/field/value/boolean/boolean.field.module.mjs +5 -5
- package/esm2022/lib/formly/field/value/date/date.field.module.mjs +96 -0
- package/esm2022/lib/formly/field/value/date/datetime.field.component.mjs +488 -0
- package/esm2022/lib/formly/field/value/date/datetime.field.mjs +141 -0
- package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.field.service.mjs +9 -9
- package/esm2022/lib/formly/field/value/date/fixeddaterange.field.component.mjs +506 -0
- package/{esm2020 → esm2022}/lib/formly/field/value/number/number.field.module.mjs +5 -5
- package/esm2022/lib/formly/field/value/phone/phone.field.component.mjs +100 -0
- package/esm2022/lib/formly/field/value/phone/phone.field.module.mjs +66 -0
- package/{esm2020 → esm2022}/lib/formly/field/value/text/text.field.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/field/value/value.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/autotouch.wrapper.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/expandable.wrapper.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/expandable.wrapper.delegate.mjs +4 -4
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/flex.wrapper.component.mjs +6 -6
- package/esm2022/lib/formly/field/wrapper/form.wrapper.module.mjs +86 -0
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/info.wrapper.component.mjs +7 -7
- package/esm2022/lib/formly/field/wrapper/section.wrapper.component.mjs +27 -0
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/style.wrapper.component.mjs +7 -7
- package/esm2022/lib/formly/field/wrapper/subsection.wrapper.component.mjs +27 -0
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/toggle.wrapper.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/formly/field/wrapper/working.wrapper.component.mjs +6 -6
- package/esm2022/lib/formly/field/wrapper/wrapper.mjs +73 -0
- package/{esm2020 → esm2022}/lib/formly/form/form.form.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/formly/form/search.form.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/formly/formly.context.directive.mjs +4 -4
- package/esm2022/lib/formly/formly.context.mjs +100 -0
- package/{esm2020 → esm2022}/lib/formly/formly.directive.mjs +16 -16
- package/{esm2020 → esm2022}/lib/formly/formly.form.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/formly/formly.module.mjs +16 -16
- package/{esm2020 → esm2022}/lib/layout/form.layout.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/layout/form.spacer.component.mjs +6 -6
- package/{esm2020 → esm2022}/mapbox/lib/field/latlng/latlng.field.component.mjs +10 -10
- package/{esm2020 → esm2022}/mapbox/lib/field/latlng/latlng.field.marker.component.mjs +6 -6
- package/esm2022/mapbox/lib/field/latlng/latlng.field.mjs +35 -0
- package/esm2022/mapbox/lib/field/latlng/latlng.module.mjs +59 -0
- package/{mapbox/esm2020 → esm2022/mapbox}/lib/field/zoom/zoom.field.component.mjs +10 -10
- package/esm2022/mapbox/lib/field/zoom/zoom.field.mjs +23 -0
- package/esm2022/mapbox/lib/field/zoom/zoom.module.mjs +57 -0
- package/{mapbox/esm2020 → esm2022/mapbox}/lib/mapbox.module.mjs +5 -5
- package/{fesm2020 → fesm2022}/dereekb-dbx-form-calendar.mjs +188 -228
- package/fesm2022/dereekb-dbx-form-calendar.mjs.map +1 -0
- package/{mapbox/fesm2020 → fesm2022}/dereekb-dbx-form-mapbox.mjs +76 -76
- package/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -0
- package/{fesm2020 → fesm2022}/dereekb-dbx-form.mjs +820 -831
- package/fesm2022/dereekb-dbx-form.mjs.map +1 -0
- package/lib/extension/_extension.scss +11 -6
- package/lib/extension/calendar/_calendar.scss +7 -5
- package/lib/form/_form.scss +3 -2
- package/lib/form/action/form.action.directive.d.ts +2 -2
- package/lib/form/action/transition/form.action.transition.safety.directive.d.ts +1 -1
- package/lib/form/form.angular.util.d.ts +1 -1
- package/lib/form/form.d.ts +1 -1
- package/lib/form/io/form.changes.directive.d.ts +1 -1
- package/lib/form/io/form.input.directive.d.ts +2 -2
- package/lib/form/io/form.loading.directive.d.ts +1 -1
- package/lib/formly/_formly.scss +7 -9
- package/lib/formly/field/_field.scss +7 -7
- package/lib/formly/field/checklist/_checklist.scss +3 -2
- package/lib/formly/field/checklist/checklist.field.d.ts +4 -4
- package/lib/formly/field/checklist/checklist.item.d.ts +1 -1
- package/lib/formly/field/checklist/checklist.item.field.component.d.ts +2 -2
- package/lib/formly/field/checklist/checklist.item.field.content.default.component.d.ts +4 -4
- package/lib/formly/field/checklist/checklist.item.field.d.ts +1 -1
- package/lib/formly/field/component/_component.scss +3 -2
- package/lib/formly/field/component/component.field.component.d.ts +2 -2
- package/lib/formly/field/component/component.field.d.ts +1 -1
- package/lib/formly/field/field.d.ts +5 -11
- package/lib/formly/field/selection/_selection.scss +5 -5
- package/lib/formly/field/selection/list/_list.scss +3 -2
- package/lib/formly/field/selection/list/list.field.component.d.ts +1 -1
- package/lib/formly/field/selection/pickable/_pickable.scss +3 -9
- package/lib/formly/field/selection/pickable/pickable.chip.field.component.d.ts +1 -1
- package/lib/formly/field/selection/pickable/pickable.d.ts +6 -22
- package/lib/formly/field/selection/pickable/pickable.field.directive.d.ts +3 -3
- package/lib/formly/field/selection/pickable/pickable.list.field.component.d.ts +4 -4
- package/lib/formly/field/selection/pickable/pickable.util.d.ts +2 -2
- package/lib/formly/field/selection/searchable/_searchable.scss +5 -5
- package/lib/formly/field/selection/searchable/searchable.chip.field.component.d.ts +1 -1
- package/lib/formly/field/selection/searchable/searchable.d.ts +4 -4
- package/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.d.ts +3 -3
- package/lib/formly/field/selection/searchable/searchable.field.d.ts +1 -1
- package/lib/formly/field/selection/searchable/searchable.field.directive.d.ts +1 -1
- package/lib/formly/field/selection/searchable/searchable.text.field.component.d.ts +1 -1
- package/lib/formly/field/selection/selection.d.ts +1 -5
- package/lib/formly/field/selection/selection.field.d.ts +1 -1
- package/lib/formly/field/selection/sourceselect/_sourceselect.scss +6 -15
- package/lib/formly/field/selection/sourceselect/sourceselect.d.ts +6 -6
- package/lib/formly/field/selection/sourceselect/sourceselect.field.component.d.ts +1 -1
- package/lib/formly/field/selection/sourceselect/sourceselect.field.module.d.ts +1 -1
- package/lib/formly/field/texteditor/_texteditor.scss +3 -2
- package/lib/formly/field/texteditor/texteditor.field.component.d.ts +2 -2
- package/lib/formly/field/value/_value.scss +10 -6
- package/lib/formly/field/value/array/_array.scss +7 -2
- package/lib/formly/field/value/array/array.field.component.d.ts +2 -2
- package/lib/formly/field/value/boolean/_boolean.scss +5 -4
- package/lib/formly/field/value/date/_date.scss +20 -37
- package/lib/formly/field/value/date/date.field.module.d.ts +1 -1
- package/lib/formly/field/value/date/datetime.field.component.d.ts +3 -13
- package/lib/formly/field/value/date/datetime.field.d.ts +5 -5
- package/lib/formly/field/value/date/fixeddaterange.field.component.d.ts +7 -7
- package/lib/formly/field/value/hidden.field.d.ts +1 -1
- package/lib/formly/field/value/number/_number.scss +35 -0
- package/lib/formly/field/value/number/number.field.d.ts +3 -3
- package/lib/formly/field/value/phone/_phone.scss +4 -3
- package/lib/formly/field/value/phone/phone.field.component.d.ts +1 -1
- package/lib/formly/field/value/phone/phone.field.module.d.ts +1 -1
- package/lib/formly/field/value/text/_text.scss +3 -2
- package/lib/formly/field/value/text/text.additional.field.d.ts +3 -3
- package/lib/formly/field/value/text/text.field.d.ts +2 -2
- package/lib/formly/field/wrapper/_wrapper.scss +5 -4
- package/lib/formly/field/wrapper/autotouch.wrapper.component.d.ts +1 -1
- package/lib/formly/field/wrapper/expandable.wrapper.component.d.ts +2 -2
- package/lib/formly/field/wrapper/expandable.wrapper.delegate.d.ts +1 -1
- package/lib/formly/field/wrapper/flex.wrapper.component.d.ts +1 -1
- package/lib/formly/field/wrapper/form.wrapper.module.d.ts +1 -1
- package/lib/formly/field/wrapper/info.wrapper.component.d.ts +1 -1
- package/lib/formly/field/wrapper/section.wrapper.component.d.ts +2 -2
- package/lib/formly/field/wrapper/style.wrapper.component.d.ts +2 -2
- package/lib/formly/field/wrapper/subsection.wrapper.component.d.ts +2 -2
- package/lib/formly/field/wrapper/toggle.wrapper.component.d.ts +1 -1
- package/lib/formly/field/wrapper/working.wrapper.component.d.ts +2 -2
- package/lib/formly/field/wrapper/wrapper.d.ts +1 -1
- package/lib/formly/form/_form.scss +17 -4
- package/lib/formly/form/search.form.component.d.ts +1 -1
- package/lib/formly/formly.context.directive.d.ts +1 -1
- package/lib/formly/formly.directive.d.ts +4 -4
- package/lib/formly/formly.form.component.d.ts +1 -1
- package/lib/formly/template/login.d.ts +1 -1
- package/lib/formly/template/timezone.d.ts +1 -1
- package/lib/layout/_layout.scss +3 -2
- package/lib/layout/form.spacer.component.d.ts +1 -1
- package/lib/style/_all-typography.scss +11 -3
- package/lib/style/_core.scss +1 -2
- package/lib/style/_mixin.scss +10 -0
- package/lib/style/_theming.scss +1 -1
- package/lib/validator/available.d.ts +1 -1
- package/mapbox/{esm2020 → esm2022}/lib/field/latlng/latlng.field.component.mjs +10 -10
- package/mapbox/{esm2020 → esm2022}/lib/field/latlng/latlng.field.marker.component.mjs +6 -6
- package/mapbox/esm2022/lib/field/latlng/latlng.field.mjs +35 -0
- package/mapbox/esm2022/lib/field/latlng/latlng.module.mjs +59 -0
- package/{esm2020/mapbox → mapbox/esm2022}/lib/field/zoom/zoom.field.component.mjs +10 -10
- package/mapbox/esm2022/lib/field/zoom/zoom.field.mjs +23 -0
- package/mapbox/esm2022/lib/field/zoom/zoom.module.mjs +57 -0
- package/{esm2020/mapbox → mapbox/esm2022}/lib/mapbox.module.mjs +5 -5
- package/{fesm2020 → mapbox/fesm2022}/dereekb-dbx-form-mapbox.mjs +76 -76
- package/mapbox/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -0
- package/mapbox/lib/field/latlng/latlng.field.component.d.ts +1 -1
- package/mapbox/lib/field/latlng/latlng.field.marker.component.d.ts +1 -1
- package/mapbox/lib/field/zoom/zoom.field.component.d.ts +1 -1
- package/mapbox/package.json +10 -28
- package/package.json +31 -31
- package/esm2020/calendar/lib/calendar.module.mjs +0 -155
- package/esm2020/calendar/lib/calendar.schedule.selection.dialog.button.component.mjs +0 -38
- package/esm2020/calendar/lib/calendar.schedule.selection.dialog.component.mjs +0 -65
- package/esm2020/calendar/lib/calendar.schedule.selection.popover.component.mjs +0 -37
- package/esm2020/calendar/lib/calendar.schedule.selection.range.component.mjs +0 -188
- package/esm2020/calendar/lib/calendar.schedule.selection.store.mjs +0 -814
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +0 -158
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.mjs +0 -29
- package/esm2020/calendar/lib/field/schedule/calendar.schedule.module.mjs +0 -58
- package/esm2020/lib/formly/field/checklist/checklist.item.field.module.mjs +0 -67
- package/esm2020/lib/formly/field/component/component.field.module.mjs +0 -32
- package/esm2020/lib/formly/field/field.mjs +0 -103
- package/esm2020/lib/formly/field/selection/list/list.field.module.mjs +0 -76
- package/esm2020/lib/formly/field/selection/pickable/pickable.chip.field.component.mjs +0 -33
- package/esm2020/lib/formly/field/selection/pickable/pickable.field.module.mjs +0 -93
- package/esm2020/lib/formly/field/selection/pickable/pickable.list.field.component.mjs +0 -116
- package/esm2020/lib/formly/field/selection/searchable/searchable.chip.field.component.mjs +0 -68
- package/esm2020/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.mjs +0 -95
- package/esm2020/lib/formly/field/selection/searchable/searchable.field.directive.mjs +0 -278
- package/esm2020/lib/formly/field/selection/searchable/searchable.field.module.mjs +0 -91
- package/esm2020/lib/formly/field/selection/selection.field.mjs +0 -39
- package/esm2020/lib/formly/field/selection/sourceselect/sourceselect.field.module.mjs +0 -93
- package/esm2020/lib/formly/field/texteditor/texteditor.field.module.mjs +0 -51
- package/esm2020/lib/formly/field/value/array/array.field.module.mjs +0 -62
- package/esm2020/lib/formly/field/value/boolean/boolean.field.mjs +0 -47
- package/esm2020/lib/formly/field/value/date/date.field.module.mjs +0 -96
- package/esm2020/lib/formly/field/value/date/datetime.field.component.mjs +0 -488
- package/esm2020/lib/formly/field/value/date/datetime.field.mjs +0 -143
- package/esm2020/lib/formly/field/value/date/fixeddaterange.field.component.mjs +0 -506
- package/esm2020/lib/formly/field/value/phone/phone.field.component.mjs +0 -100
- package/esm2020/lib/formly/field/value/phone/phone.field.module.mjs +0 -66
- package/esm2020/lib/formly/field/wrapper/form.wrapper.module.mjs +0 -86
- package/esm2020/lib/formly/field/wrapper/section.wrapper.component.mjs +0 -26
- package/esm2020/lib/formly/field/wrapper/subsection.wrapper.component.mjs +0 -26
- package/esm2020/lib/formly/field/wrapper/wrapper.mjs +0 -78
- package/esm2020/lib/formly/formly.context.mjs +0 -100
- package/esm2020/mapbox/lib/field/latlng/latlng.field.mjs +0 -35
- package/esm2020/mapbox/lib/field/latlng/latlng.module.mjs +0 -59
- package/esm2020/mapbox/lib/field/zoom/zoom.field.mjs +0 -23
- package/esm2020/mapbox/lib/field/zoom/zoom.module.mjs +0 -57
- package/fesm2015/dereekb-dbx-form-calendar.mjs +0 -1955
- package/fesm2015/dereekb-dbx-form-calendar.mjs.map +0 -1
- package/fesm2015/dereekb-dbx-form-mapbox.mjs +0 -585
- package/fesm2015/dereekb-dbx-form-mapbox.mjs.map +0 -1
- package/fesm2015/dereekb-dbx-form.mjs +0 -6205
- package/fesm2015/dereekb-dbx-form.mjs.map +0 -1
- package/fesm2020/dereekb-dbx-form-calendar.mjs.map +0 -1
- package/fesm2020/dereekb-dbx-form-mapbox.mjs.map +0 -1
- package/fesm2020/dereekb-dbx-form.mjs.map +0 -1
- package/mapbox/esm2020/lib/field/latlng/latlng.field.mjs +0 -35
- package/mapbox/esm2020/lib/field/latlng/latlng.module.mjs +0 -59
- package/mapbox/esm2020/lib/field/zoom/zoom.field.mjs +0 -23
- package/mapbox/esm2020/lib/field/zoom/zoom.module.mjs +0 -57
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs +0 -585
- package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs.map +0 -1
- package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs.map +0 -1
- /package/{esm2020 → esm2022}/calendar/dereekb-dbx-form-calendar.mjs +0 -0
- /package/{esm2020 → esm2022}/calendar/index.mjs +0 -0
- /package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.form.mjs +0 -0
- /package/{esm2020 → esm2022}/calendar/lib/field/index.mjs +0 -0
- /package/{esm2020 → esm2022}/calendar/lib/field/schedule/index.mjs +0 -0
- /package/{esm2020 → esm2022}/calendar/lib/index.mjs +0 -0
- /package/{esm2020 → esm2022}/dereekb-dbx-form.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/action/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/action/transition/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/form.angular.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/form.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/form/io/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/config/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/config/validation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/checklist/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/component/component.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/component/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/list/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/list/list.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/text.chip.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/texteditor/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/texteditor/texteditor.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/array/array.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/array/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/boolean/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/date/date.value.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.preset.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/date/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/hidden.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/number/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/number/number.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/phone/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/phone/phone.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/text/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.additional.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.address.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/field/wrapper/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/form/form.form.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/form/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/template/available.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/template/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/template/login.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/formly/template/timezone.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/layout/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/available.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/boolean.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/email.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/field.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/number.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validator/phone.mjs +0 -0
- /package/{esm2020 → esm2022}/mapbox/dereekb-dbx-form-mapbox.mjs +0 -0
- /package/{esm2020 → esm2022}/mapbox/index.mjs +0 -0
- /package/{esm2020 → esm2022}/mapbox/lib/field/index.mjs +0 -0
- /package/{esm2020 → esm2022}/mapbox/lib/field/latlng/index.mjs +0 -0
- /package/{esm2020 → esm2022}/mapbox/lib/field/zoom/index.mjs +0 -0
- /package/mapbox/{esm2020 → esm2022}/dereekb-dbx-form-mapbox.mjs +0 -0
- /package/mapbox/{esm2020 → esm2022}/index.mjs +0 -0
- /package/mapbox/{esm2020 → esm2022}/lib/field/index.mjs +0 -0
- /package/mapbox/{esm2020 → esm2022}/lib/field/latlng/index.mjs +0 -0
- /package/mapbox/{esm2020 → esm2022}/lib/field/zoom/index.mjs +0 -0
|
@@ -0,0 +1,488 @@
|
|
|
1
|
+
import { asArray, filterMaybeValues, isISO8601DayStringStart, mapIdentityFunction } from '@dereekb/util';
|
|
2
|
+
import { dateFromLogicalDate, DateTimeMinuteInstance, guessCurrentTimezone, readableTimeStringToDate, toLocalReadableTimeString, utcDayForDate, safeToJsDate, findMinDate, findMaxDate, dateTimeMinuteDecisionFunction, isSameDateHoursAndMinutes, getTimezoneAbbreviation, isSameDateDay, dateTimezoneUtcNormal, toJsDayDate, isSameDate } from '@dereekb/date';
|
|
3
|
+
import { switchMap, shareReplay, map, startWith, tap, first, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, combineLatest, Subject, merge, interval, of, combineLatestWith, filter } from 'rxjs';
|
|
4
|
+
import { ChangeDetectorRef, Component } from '@angular/core';
|
|
5
|
+
import { FormControl, Validators } from '@angular/forms';
|
|
6
|
+
import { FieldType } from '@ngx-formly/material';
|
|
7
|
+
import { addMinutes, startOfDay, addDays } from 'date-fns';
|
|
8
|
+
import { asObservableFromGetter, filterMaybe, skipFirstMaybe, SubscriptionObject, switchMapMaybeDefault, switchMapMaybeObs } from '@dereekb/rxjs';
|
|
9
|
+
import { dateTimePreset } from './datetime';
|
|
10
|
+
import { DbxDateTimeFieldMenuPresetsService } from './datetime.field.service';
|
|
11
|
+
import { DbxDateTimeValueMode, dbxDateTimeInputValueParseFactory, dbxDateTimeIsSameDateTimeFieldValue, dbxDateTimeOutputValueFactory } from './date.value';
|
|
12
|
+
import { streamValueFromControl } from '../../../../form/form.angular.util';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "./datetime.field.service";
|
|
15
|
+
import * as i2 from "@angular/common";
|
|
16
|
+
import * as i3 from "@angular/forms";
|
|
17
|
+
import * as i4 from "@angular/material/input";
|
|
18
|
+
import * as i5 from "@angular/material/form-field";
|
|
19
|
+
import * as i6 from "@angular/material/divider";
|
|
20
|
+
import * as i7 from "@dereekb/dbx-web";
|
|
21
|
+
import * as i8 from "@angular/material/button";
|
|
22
|
+
import * as i9 from "@angular/material/datepicker";
|
|
23
|
+
import * as i10 from "@angular/material/menu";
|
|
24
|
+
import * as i11 from "@angular/material/icon";
|
|
25
|
+
import * as i12 from "@ngbracket/ngx-layout/flex";
|
|
26
|
+
import * as i13 from "@ngbracket/ngx-layout/extended";
|
|
27
|
+
import * as i14 from "@dereekb/dbx-core";
|
|
28
|
+
export var DbxDateTimeFieldTimeMode;
|
|
29
|
+
(function (DbxDateTimeFieldTimeMode) {
|
|
30
|
+
/**
|
|
31
|
+
* Time is required.
|
|
32
|
+
*/
|
|
33
|
+
DbxDateTimeFieldTimeMode["REQUIRED"] = "required";
|
|
34
|
+
/**
|
|
35
|
+
* Time is optional.
|
|
36
|
+
*/
|
|
37
|
+
DbxDateTimeFieldTimeMode["OPTIONAL"] = "optional";
|
|
38
|
+
/**
|
|
39
|
+
* Time is permenantly off.
|
|
40
|
+
*/
|
|
41
|
+
DbxDateTimeFieldTimeMode["NONE"] = "none";
|
|
42
|
+
})(DbxDateTimeFieldTimeMode || (DbxDateTimeFieldTimeMode = {}));
|
|
43
|
+
export function isDbxDateTimeFieldTimeDateConfig(input) {
|
|
44
|
+
return input != null && typeof input === 'object' && typeof input.path === 'string';
|
|
45
|
+
}
|
|
46
|
+
export function syncConfigValueObs(parseConfigsObs, type) {
|
|
47
|
+
return parseConfigsObs.pipe(switchMap((x) => {
|
|
48
|
+
const config = x.find((y) => y.syncType === type);
|
|
49
|
+
let result;
|
|
50
|
+
if (config) {
|
|
51
|
+
const { control } = config;
|
|
52
|
+
result = control.valueChanges.pipe(startWith(control.value), map((x) => safeToJsDate(x) ?? null));
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
result = of(null);
|
|
56
|
+
}
|
|
57
|
+
return result;
|
|
58
|
+
}), distinctUntilChanged(), shareReplay(1));
|
|
59
|
+
}
|
|
60
|
+
const TIME_OUTPUT_THROTTLE_TIME = 10;
|
|
61
|
+
export class DbxDateTimeFieldComponent extends FieldType {
|
|
62
|
+
get dateLabel() {
|
|
63
|
+
return this.props.dateLabel ?? 'Date';
|
|
64
|
+
}
|
|
65
|
+
get timeLabel() {
|
|
66
|
+
return this.props.timeLabel ?? 'Time';
|
|
67
|
+
}
|
|
68
|
+
get allDayLabel() {
|
|
69
|
+
return this.props.allDayLabel ?? 'All Day';
|
|
70
|
+
}
|
|
71
|
+
get atTimeLabel() {
|
|
72
|
+
return this.props.atTimeLabel ?? 'At';
|
|
73
|
+
}
|
|
74
|
+
get dateOnly() {
|
|
75
|
+
return this.timeMode === DbxDateTimeFieldTimeMode.NONE;
|
|
76
|
+
}
|
|
77
|
+
get dateTimeField() {
|
|
78
|
+
return this.field.props;
|
|
79
|
+
}
|
|
80
|
+
get timeOnly() {
|
|
81
|
+
return this.dateTimeField.timeOnly;
|
|
82
|
+
}
|
|
83
|
+
get showDateInput() {
|
|
84
|
+
return !this.timeOnly;
|
|
85
|
+
}
|
|
86
|
+
get valueMode() {
|
|
87
|
+
return this.field.props.valueMode ?? DbxDateTimeValueMode.DATE;
|
|
88
|
+
}
|
|
89
|
+
get timeMode() {
|
|
90
|
+
const dateValuesOnly = this.valueMode === DbxDateTimeValueMode.DAY_STRING;
|
|
91
|
+
if (dateValuesOnly) {
|
|
92
|
+
return DbxDateTimeFieldTimeMode.NONE;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
return this.timeOnly ? DbxDateTimeFieldTimeMode.REQUIRED : this.dateTimeField.timeMode ?? DbxDateTimeFieldTimeMode.REQUIRED;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
get description() {
|
|
99
|
+
return this.field.props.description;
|
|
100
|
+
}
|
|
101
|
+
get hideDateHint() {
|
|
102
|
+
return this.field.props.hideDateHint ?? false;
|
|
103
|
+
}
|
|
104
|
+
get hideDatePicker() {
|
|
105
|
+
return this.field.props.hideDatePicker ?? false;
|
|
106
|
+
}
|
|
107
|
+
get timezone() {
|
|
108
|
+
return this.field.props.timezone;
|
|
109
|
+
}
|
|
110
|
+
get timeDate() {
|
|
111
|
+
return this.field.props.timeDate;
|
|
112
|
+
}
|
|
113
|
+
get showTimezone() {
|
|
114
|
+
return this.field.props.showTimezone ?? true;
|
|
115
|
+
}
|
|
116
|
+
get presets() {
|
|
117
|
+
return this.field.props.presets;
|
|
118
|
+
}
|
|
119
|
+
constructor(cdRef, dbxDateTimeFieldConfigService) {
|
|
120
|
+
super();
|
|
121
|
+
this.cdRef = cdRef;
|
|
122
|
+
this.dbxDateTimeFieldConfigService = dbxDateTimeFieldConfigService;
|
|
123
|
+
this._sub = new SubscriptionObject();
|
|
124
|
+
this._valueSub = new SubscriptionObject();
|
|
125
|
+
this._config = new BehaviorSubject(undefined);
|
|
126
|
+
this._syncConfigObs = new BehaviorSubject(undefined);
|
|
127
|
+
this._defaultTimezone = new BehaviorSubject(undefined);
|
|
128
|
+
this._timeDate = new BehaviorSubject(undefined);
|
|
129
|
+
this._presets = new BehaviorSubject(of([]));
|
|
130
|
+
this._fullDayControlObs = new BehaviorSubject(undefined);
|
|
131
|
+
this.fullDayControl$ = this._fullDayControlObs.pipe(filterMaybe());
|
|
132
|
+
this._offset = new BehaviorSubject(0);
|
|
133
|
+
this._formControlObs = new BehaviorSubject(undefined);
|
|
134
|
+
this.formControl$ = this._formControlObs.pipe(filterMaybe());
|
|
135
|
+
this._updateTime = new Subject();
|
|
136
|
+
this.timezone$ = this._defaultTimezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(map((defaultTimezone) => {
|
|
137
|
+
return defaultTimezone ?? guessCurrentTimezone();
|
|
138
|
+
}), distinctUntilChanged(), shareReplay(1));
|
|
139
|
+
this.timezoneInstance$ = this.timezone$.pipe(map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)), shareReplay(1));
|
|
140
|
+
this.timeDate$ = this._timeDate.pipe(switchMapMaybeDefault(), switchMap((x) => {
|
|
141
|
+
let obs;
|
|
142
|
+
if (x) {
|
|
143
|
+
// if the string is not a date string, then treat it as a path
|
|
144
|
+
if ((typeof x === 'string' && !isISO8601DayStringStart(x)) || isDbxDateTimeFieldTimeDateConfig(x)) {
|
|
145
|
+
const { path, mapValue } = typeof x === 'string' ? { path: x } : x;
|
|
146
|
+
obs =
|
|
147
|
+
streamValueFromControl(this.form, path)?.pipe(map(mapValue ?? mapIdentityFunction()), map((x) => (x ? toJsDayDate(x) : undefined))) ?? of(undefined);
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
obs = of(toJsDayDate(x));
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
obs = of(undefined);
|
|
155
|
+
}
|
|
156
|
+
return obs;
|
|
157
|
+
}), distinctUntilChanged(isSameDateDay), shareReplay(1));
|
|
158
|
+
this.valueInSystemTimezone$ = this.formControl$.pipe(map((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))), combineLatestWith(this.timezoneInstance$), switchMap(([x, timezoneInstance]) => {
|
|
159
|
+
return x.pipe(map(dbxDateTimeInputValueParseFactory(this.valueMode, timezoneInstance)));
|
|
160
|
+
}), throttleTime(20, undefined, { leading: false, trailing: true }), // throttle incoming values and timezone changes
|
|
161
|
+
distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
|
|
162
|
+
/**
|
|
163
|
+
* Used to trigger/display visual updates (specifically on timeDistance, etc.).
|
|
164
|
+
*/
|
|
165
|
+
this.displayValue$ = interval(10 * 1000).pipe(startWith(0), map(() => new Date().getMinutes()), distinctUntilChanged(), tap(() => this.cdRef.markForCheck()), switchMap(() => this.valueInSystemTimezone$), shareReplay(1));
|
|
166
|
+
this.timeString$ = this.valueInSystemTimezone$.pipe(map((x) => (x ? toLocalReadableTimeString(x) : '')), distinctUntilChanged(), shareReplay(1));
|
|
167
|
+
this.dateInputCtrl = new FormControl(new Date(), {
|
|
168
|
+
validators: []
|
|
169
|
+
});
|
|
170
|
+
this.timeInputCtrl = new FormControl('', {
|
|
171
|
+
validators: [Validators.pattern(/^(now)$|^([0-9]|(0[0-9])|(1[0-9])|(2[0-3]))(:)?([0-5][0-9])?(\s)?([apAP][Mm])?(\\s)*$/)]
|
|
172
|
+
});
|
|
173
|
+
this.fullDay$ = this.fullDayControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value))), distinctUntilChanged(), shareReplay(1));
|
|
174
|
+
this.showTimeInput$ = this.fullDay$.pipe(map((x) => !x && this.timeMode !== DbxDateTimeFieldTimeMode.NONE));
|
|
175
|
+
this.showAddTime$ = this.showTimeInput$.pipe(map((x) => !x && this.timeMode === DbxDateTimeFieldTimeMode.OPTIONAL), shareReplay(1));
|
|
176
|
+
this.date$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), filterMaybe(), shareReplay(1));
|
|
177
|
+
this.timezoneAbbreviation$ = combineLatest([this.date$, this.timezone$, this.timeDate$]).pipe(map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? date)), distinctUntilChanged(), shareReplay(1));
|
|
178
|
+
this.dateValue$ = merge(this.date$, this.valueInSystemTimezone$.pipe(skipFirstMaybe())).pipe(map((x) => (x ? startOfDay(x) : null)), distinctUntilChanged(isSameDateDay), shareReplay(1));
|
|
179
|
+
this.timeInput$ = this._updateTime.pipe(debounceTime(5), map(() => this.timeInputCtrl.value || ''), distinctUntilChanged());
|
|
180
|
+
this.syncConfigObs$ = this._syncConfigObs.pipe(switchMapMaybeDefault(), shareReplay(1));
|
|
181
|
+
this.parsedSyncConfigs$ = this.syncConfigObs$.pipe(map((x) => {
|
|
182
|
+
let parsed;
|
|
183
|
+
if (x) {
|
|
184
|
+
parsed = filterMaybeValues(asArray(x).map((y) => {
|
|
185
|
+
const control = this.form.get(y.syncWith);
|
|
186
|
+
if (control) {
|
|
187
|
+
return {
|
|
188
|
+
control,
|
|
189
|
+
...y
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
return undefined;
|
|
194
|
+
}
|
|
195
|
+
}));
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
parsed = [];
|
|
199
|
+
}
|
|
200
|
+
return parsed;
|
|
201
|
+
}), shareReplay(1));
|
|
202
|
+
this.syncConfigBeforeValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'before');
|
|
203
|
+
this.syncConfigAfterValue$ = syncConfigValueObs(this.parsedSyncConfigs$, 'after');
|
|
204
|
+
// TODO: Get min/max using the DateTimePickerConfiguration too
|
|
205
|
+
this.dateInputMin$ = this.syncConfigBeforeValue$;
|
|
206
|
+
this.dateInputMax$ = this.syncConfigAfterValue$;
|
|
207
|
+
this.rawDateTime$ = combineLatest([this.dateValue$, this.timeInput$.pipe(startWith(null)), this.fullDay$, this.timeDate$]).pipe(map(([date, timeString, fullDay, timeDate]) => {
|
|
208
|
+
let result;
|
|
209
|
+
if (!date || this.timeOnly) {
|
|
210
|
+
date = timeDate ?? new Date(); // use the time date, or default to the current day
|
|
211
|
+
}
|
|
212
|
+
if (date) {
|
|
213
|
+
if (fullDay) {
|
|
214
|
+
if (this.dateTimeField.fullDayInUTC) {
|
|
215
|
+
result = utcDayForDate(date);
|
|
216
|
+
}
|
|
217
|
+
else {
|
|
218
|
+
result = startOfDay(date);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
else if (timeString) {
|
|
222
|
+
result =
|
|
223
|
+
readableTimeStringToDate(timeString, {
|
|
224
|
+
date,
|
|
225
|
+
useSystemTimezone: true
|
|
226
|
+
}) ?? date;
|
|
227
|
+
}
|
|
228
|
+
else if (!this.timeOnly) {
|
|
229
|
+
result = date;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
return result;
|
|
233
|
+
}), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
|
|
234
|
+
this.config$ = combineLatest([this._config.pipe(switchMapMaybeDefault()), this.dateInputMin$, this.dateInputMax$]).pipe(map(([x, dateInputMin, dateInputMax]) => {
|
|
235
|
+
let result = x;
|
|
236
|
+
if (dateInputMin != null || dateInputMax != null) {
|
|
237
|
+
const { min: limitMin, max: limitMax } = x?.limits ?? {};
|
|
238
|
+
const min = findMinDate([dateInputMin, dateFromLogicalDate(limitMin)]);
|
|
239
|
+
const max = findMaxDate([dateInputMax, dateFromLogicalDate(limitMax)]);
|
|
240
|
+
result = {
|
|
241
|
+
...x,
|
|
242
|
+
limits: {
|
|
243
|
+
...x?.limits,
|
|
244
|
+
min,
|
|
245
|
+
max
|
|
246
|
+
}
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
return result;
|
|
250
|
+
}), distinctUntilChanged(), shareReplay(1));
|
|
251
|
+
this.pickerFilter$ = this.config$.pipe(distinctUntilChanged(), map((x) => {
|
|
252
|
+
if (x) {
|
|
253
|
+
const filter = dateTimeMinuteDecisionFunction(x);
|
|
254
|
+
return (x) => (x != null ? filter(x) : true);
|
|
255
|
+
}
|
|
256
|
+
else {
|
|
257
|
+
return () => true;
|
|
258
|
+
}
|
|
259
|
+
}), shareReplay(1));
|
|
260
|
+
this.defaultPickerFilter = () => true;
|
|
261
|
+
this.timeOutput$ = combineLatest([this.rawDateTime$, this._offset, this.config$]).pipe(throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }), distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0), tap(([, stepsOffset]) => (stepsOffset ? this._offset.next(0) : 0)), map(([date, stepsOffset, config]) => {
|
|
262
|
+
if (date != null) {
|
|
263
|
+
const instance = new DateTimeMinuteInstance({
|
|
264
|
+
date,
|
|
265
|
+
...config,
|
|
266
|
+
roundDownToMinute: true
|
|
267
|
+
});
|
|
268
|
+
date = instance.clamp(date);
|
|
269
|
+
const minutes = stepsOffset * 5;
|
|
270
|
+
date = addMinutes(date, minutes);
|
|
271
|
+
}
|
|
272
|
+
return date;
|
|
273
|
+
}), distinctUntilChanged(isSameDateHoursAndMinutes), shareReplay(1));
|
|
274
|
+
this.presets$ = this._presets.pipe(switchMapMaybeObs(), map((x) => x.map(dateTimePreset)), shareReplay(1));
|
|
275
|
+
}
|
|
276
|
+
ngOnInit() {
|
|
277
|
+
this._formControlObs.next(this.formControl);
|
|
278
|
+
const inputPickerConfig = this.dateTimeField.pickerConfig;
|
|
279
|
+
this._config.next(inputPickerConfig ? asObservableFromGetter(inputPickerConfig) : undefined);
|
|
280
|
+
this._syncConfigObs.next(this.dateTimeField.getSyncFieldsObs?.());
|
|
281
|
+
this._sub.subscription = this.valueInSystemTimezone$
|
|
282
|
+
.pipe(combineLatestWith(this.timezoneInstance$.pipe(map((timezoneInstance) => dbxDateTimeOutputValueFactory(this.valueMode, timezoneInstance)))), throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }), switchMap(([currentValue, valueFactory]) => {
|
|
283
|
+
return this.timeOutput$.pipe(throttleTime(TIME_OUTPUT_THROTTLE_TIME * 2, undefined, { leading: false, trailing: true }), skipFirstMaybe(), distinctUntilChanged(isSameDateHoursAndMinutes), map((x) => valueFactory(x)), filter((x) => !dbxDateTimeIsSameDateTimeFieldValue(x, currentValue)));
|
|
284
|
+
}))
|
|
285
|
+
.subscribe((value) => {
|
|
286
|
+
this.formControl.setValue(value);
|
|
287
|
+
this.formControl.markAsDirty();
|
|
288
|
+
this.formControl.markAsTouched();
|
|
289
|
+
});
|
|
290
|
+
let hasSetMidnightFromInput = false;
|
|
291
|
+
/*
|
|
292
|
+
this._valueSub.subscription = this.timeString$.subscribe((x) => {
|
|
293
|
+
this.setTime(x);
|
|
294
|
+
});
|
|
295
|
+
*/
|
|
296
|
+
this._valueSub.subscription = this.valueInSystemTimezone$
|
|
297
|
+
.pipe(map((x) => (x ? isSameDate(x, startOfDay(x)) : false)), distinctUntilChanged(), switchMap((isInputValueAtMidnight) => {
|
|
298
|
+
hasSetMidnightFromInput = false;
|
|
299
|
+
return this.timeString$.pipe(
|
|
300
|
+
// skip(1),
|
|
301
|
+
map((timeString) => [timeString, isInputValueAtMidnight]));
|
|
302
|
+
}))
|
|
303
|
+
.subscribe(([x, isInputValueAtMidnight]) => {
|
|
304
|
+
// Skip events where the timeInput value is cleared, unless the input value is at midnight and we've already processed it being at midnight
|
|
305
|
+
if (!this.timeInputCtrl.value && x === '12:00AM' && (!isInputValueAtMidnight || (isInputValueAtMidnight && hasSetMidnightFromInput))) {
|
|
306
|
+
return;
|
|
307
|
+
}
|
|
308
|
+
// update the has set flag
|
|
309
|
+
if (x === '12:00AM' && isInputValueAtMidnight) {
|
|
310
|
+
hasSetMidnightFromInput = true;
|
|
311
|
+
}
|
|
312
|
+
this.setTime(x);
|
|
313
|
+
});
|
|
314
|
+
// Set default timezone if provided.
|
|
315
|
+
if (this.timezone && !this.dateTimeField.fullDayInUTC) {
|
|
316
|
+
this._defaultTimezone.next(asObservableFromGetter(this.timezone));
|
|
317
|
+
}
|
|
318
|
+
this._timeDate.next(asObservableFromGetter(this.timeDate));
|
|
319
|
+
// Watch for disabled changes so we can propogate them properly.
|
|
320
|
+
this.formControl.registerOnDisabledChange((disabled) => {
|
|
321
|
+
if (disabled) {
|
|
322
|
+
this.dateInputCtrl.disable({ emitEvent: false });
|
|
323
|
+
this.timeInputCtrl.disable({ emitEvent: false });
|
|
324
|
+
}
|
|
325
|
+
else {
|
|
326
|
+
this.dateInputCtrl.enable({ emitEvent: false });
|
|
327
|
+
this.timeInputCtrl.enable({ emitEvent: false });
|
|
328
|
+
}
|
|
329
|
+
});
|
|
330
|
+
const isFullDayField = this.dateTimeField.fullDayFieldName;
|
|
331
|
+
let fullDayFieldCtrl;
|
|
332
|
+
if (isFullDayField) {
|
|
333
|
+
fullDayFieldCtrl = this.form.get(isFullDayField);
|
|
334
|
+
}
|
|
335
|
+
if (!fullDayFieldCtrl) {
|
|
336
|
+
const isFullDay = this.timeMode === DbxDateTimeFieldTimeMode.NONE;
|
|
337
|
+
this._fullDayInputCtrl = new FormControl(isFullDay);
|
|
338
|
+
// Set the control in the form too if the name is defined.
|
|
339
|
+
if (isFullDayField) {
|
|
340
|
+
this.form.addControl(isFullDayField, this._fullDayInputCtrl);
|
|
341
|
+
}
|
|
342
|
+
fullDayFieldCtrl = this._fullDayInputCtrl;
|
|
343
|
+
}
|
|
344
|
+
this._fullDayControlObs.next(fullDayFieldCtrl);
|
|
345
|
+
switch (this.timeMode) {
|
|
346
|
+
case DbxDateTimeFieldTimeMode.OPTIONAL:
|
|
347
|
+
break;
|
|
348
|
+
case DbxDateTimeFieldTimeMode.NONE:
|
|
349
|
+
this.removeTime();
|
|
350
|
+
break;
|
|
351
|
+
case DbxDateTimeFieldTimeMode.REQUIRED:
|
|
352
|
+
this.addTime();
|
|
353
|
+
break;
|
|
354
|
+
}
|
|
355
|
+
if (this.presets != null) {
|
|
356
|
+
this._presets.next(asObservableFromGetter(this.presets));
|
|
357
|
+
}
|
|
358
|
+
else {
|
|
359
|
+
this._presets.next(this.dbxDateTimeFieldConfigService.configurations$);
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
ngOnDestroy() {
|
|
363
|
+
super.ngOnDestroy();
|
|
364
|
+
this._sub.destroy();
|
|
365
|
+
this._valueSub.destroy();
|
|
366
|
+
this._config.complete();
|
|
367
|
+
this._defaultTimezone.complete();
|
|
368
|
+
this._timeDate.complete();
|
|
369
|
+
this._presets.complete();
|
|
370
|
+
this._fullDayControlObs.complete();
|
|
371
|
+
this._offset.complete();
|
|
372
|
+
this._formControlObs.complete();
|
|
373
|
+
this._updateTime.complete();
|
|
374
|
+
this._syncConfigObs.complete();
|
|
375
|
+
}
|
|
376
|
+
selectPreset(preset) {
|
|
377
|
+
const value = preset.value();
|
|
378
|
+
if (value.logicalDate) {
|
|
379
|
+
this.setLogicalTime(value.logicalDate);
|
|
380
|
+
}
|
|
381
|
+
else if (value.timeString) {
|
|
382
|
+
this.setTime(value.timeString);
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
datePicked(event) {
|
|
386
|
+
const date = event.value;
|
|
387
|
+
if (date) {
|
|
388
|
+
this.setDateInputValue(date);
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
setLogicalTime(time) {
|
|
392
|
+
const date = dateFromLogicalDate(time);
|
|
393
|
+
if (date) {
|
|
394
|
+
this.setTimeFromDate(date);
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
setDateInputValue(date) {
|
|
398
|
+
this.dateInputCtrl.setValue(date);
|
|
399
|
+
this._updateTime.next();
|
|
400
|
+
}
|
|
401
|
+
setTimeFromDate(timeDate) {
|
|
402
|
+
const timeString = toLocalReadableTimeString(timeDate);
|
|
403
|
+
this.setTime(timeString);
|
|
404
|
+
}
|
|
405
|
+
setTime(time) {
|
|
406
|
+
if (this.timeInputCtrl.value !== time) {
|
|
407
|
+
this.timeInputCtrl.setValue(time);
|
|
408
|
+
this._offset.next(0);
|
|
409
|
+
this._updateTime.next();
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
keydownOnDateInput(event) {
|
|
413
|
+
let direction = 0;
|
|
414
|
+
switch (event.key?.toLowerCase()) {
|
|
415
|
+
case 'arrowup':
|
|
416
|
+
direction = 1;
|
|
417
|
+
break;
|
|
418
|
+
case 'arrowdown':
|
|
419
|
+
direction = -1;
|
|
420
|
+
break;
|
|
421
|
+
}
|
|
422
|
+
let offset = 1;
|
|
423
|
+
if (event.ctrlKey && event.shiftKey) {
|
|
424
|
+
offset = 365;
|
|
425
|
+
}
|
|
426
|
+
else if (event.ctrlKey) {
|
|
427
|
+
offset = 30;
|
|
428
|
+
}
|
|
429
|
+
else if (event.shiftKey) {
|
|
430
|
+
offset = 7;
|
|
431
|
+
}
|
|
432
|
+
if (direction !== 0) {
|
|
433
|
+
this.date$.pipe(first()).subscribe((date) => {
|
|
434
|
+
const newDate = addDays(date, offset * direction);
|
|
435
|
+
this.setDateInputValue(newDate);
|
|
436
|
+
});
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
keydownOnTimeInput(event) {
|
|
440
|
+
let direction = 0;
|
|
441
|
+
switch (event.key?.toLowerCase()) {
|
|
442
|
+
case 'arrowup':
|
|
443
|
+
direction = 1;
|
|
444
|
+
break;
|
|
445
|
+
case 'arrowdown':
|
|
446
|
+
direction = -1;
|
|
447
|
+
break;
|
|
448
|
+
}
|
|
449
|
+
let offset = 1;
|
|
450
|
+
if (event.altKey && event.shiftKey) {
|
|
451
|
+
offset = 300;
|
|
452
|
+
}
|
|
453
|
+
else if (event.altKey) {
|
|
454
|
+
offset = 60;
|
|
455
|
+
}
|
|
456
|
+
else if (event.shiftKey) {
|
|
457
|
+
offset = 5;
|
|
458
|
+
}
|
|
459
|
+
if (direction !== 0) {
|
|
460
|
+
this._offset.next(this._offset.value + offset * direction);
|
|
461
|
+
this._updateTime.next();
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
focusTime() {
|
|
465
|
+
// do nothing
|
|
466
|
+
}
|
|
467
|
+
focusOutTime() {
|
|
468
|
+
this._updateTime.next();
|
|
469
|
+
}
|
|
470
|
+
addTime() {
|
|
471
|
+
this.setFullDay(false);
|
|
472
|
+
}
|
|
473
|
+
removeTime() {
|
|
474
|
+
this.setFullDay(true);
|
|
475
|
+
}
|
|
476
|
+
setFullDay(fullDay) {
|
|
477
|
+
this.fullDayControl$.pipe(first()).subscribe((x) => {
|
|
478
|
+
x.setValue(fullDay);
|
|
479
|
+
});
|
|
480
|
+
}
|
|
481
|
+
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 }); }
|
|
482
|
+
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\" fxLayoutAlign=\"space-evenly stretch\">\n <!-- Date -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput\">\n <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n <!-- Additional spacing -->\n <dbx-button-spacer *ngIf=\"!dateOnly\"></dbx-button-spacer>\n </div>\n <!-- Time -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"showDateInput ? '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 <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n <div class=\"dbx-hint\" [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 </div>\n </div>\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 [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=\"mat-datepicker-button-highlight dbx-button-spacer\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n <mat-icon>calendar_today</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 matInput [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n <button matPrefix class=\"mat-datepicker-button-highlight dbx-button-spacer\" 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-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: 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.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: "directive", type: i7.DbxButtonSpacerDirective, selector: "dbx-button-spacer,[dbxButtonSpacer]" }, { kind: "component", type: i8.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: i8.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i9.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.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: i11.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i12.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: i12.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: i12.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: i13.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: i14.DateDistancePipe, name: "dateDistance" }, { kind: "pipe", type: i14.TimeDistancePipe, name: "timeDistance" }, { kind: "pipe", type: i14.GetValuePipe, name: "getValue" }] }); }
|
|
483
|
+
}
|
|
484
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxDateTimeFieldComponent, decorators: [{
|
|
485
|
+
type: Component,
|
|
486
|
+
args: [{ template: "<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutAlign=\"space-evenly stretch\">\n <!-- Date -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput\">\n <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n <!-- Additional spacing -->\n <dbx-button-spacer *ngIf=\"!dateOnly\"></dbx-button-spacer>\n </div>\n <!-- Time -->\n <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"showDateInput ? '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 <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n <div class=\"dbx-hint\" [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 </div>\n </div>\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 [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=\"mat-datepicker-button-highlight dbx-button-spacer\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n <mat-icon>calendar_today</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 matInput [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n <button matPrefix class=\"mat-datepicker-button-highlight dbx-button-spacer\" 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-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" }]
|
|
487
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DbxDateTimeFieldMenuPresetsService }]; } });
|
|
488
|
+
//# 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 { Maybe, ReadableTimeString, ArrayOrValue, ISO8601DateString, asArray, filterMaybeValues, DecisionFunction, Milliseconds, TimezoneString, LogicalDate, DateOrDayString, isISO8601DayStringStart, MapFunction, mapIdentityFunction } from '@dereekb/util';\nimport { dateFromLogicalDate, DateTimeMinuteConfig, DateTimeMinuteInstance, guessCurrentTimezone, readableTimeStringToDate, toLocalReadableTimeString, utcDayForDate, safeToJsDate, findMinDate, findMaxDate, dateTimeMinuteDecisionFunction, isSameDateHoursAndMinutes, getTimezoneAbbreviation, isSameDateDay, dateTimezoneUtcNormal, DateTimezoneUtcNormalInstance, toJsDayDate, isSameDate } from '@dereekb/date';\nimport { switchMap, shareReplay, map, startWith, tap, first, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, Observable, combineLatest, Subject, merge, interval, of, combineLatestWith, filter } from 'rxjs';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\nimport { AbstractControl, FormControl, Validators, FormGroup } 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';\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  syncWith: string;\n  /**\n   * How to sync against the other field.\n   */\n  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  dateLabel?: string;\n\n  /**\n   * Custom time label.\n   *\n   * Defaults to Time\n   */\n  timeLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"All Day\". Defaults to \"All Day\".\n   */\n  allDayLabel?: string;\n\n  /**\n   * Label to use for the date hint for \"At\". Defaults to \"At\".\n   */\n  atTimeLabel?: string;\n\n  /**\n   * Value mode.\n   *\n   * Defaults to DATE\n   */\n  valueMode?: DbxDateTimeValueMode;\n\n  /**\n   * Whether or not the date is hidden, and automatically uses today/input date.\n   */\n  timeOnly?: 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  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  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  fullDayInUTC?: boolean;\n\n  /**\n   * Whether or not ot hide the date hint info content.\n   *\n   * False by default\n   */\n  hideDateHint?: boolean;\n\n  /**\n   * Whether or not to hide the date/calendar picker.\n   */\n  hideDatePicker?: boolean;\n\n  /**\n   * Custom picker configuration\n   */\n  pickerConfig?: ObservableOrValueGetter<DbxDateTimePickerConfiguration>;\n\n  /**\n   * Used for syncing with one or more fields with a Date value.\n   */\n  getSyncFieldsObs?: () => Observable<ArrayOrValue<DbxDateTimeFieldSyncField>>;\n\n  /**\n   * (Optional) The input timezone to default to.\n   *\n   * Ignored if fullDayInUTC is true.\n   */\n  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  timeDate?: Maybe<ObservableOrValueGetter<Maybe<DbxDateTimeFieldTimeDateConfig | FormControlPath | DateOrDayString>>>;\n\n  /**\n   * Whether or not to display the timezone. True by default.\n   */\n  showTimezone?: boolean;\n\n  /**\n   * Custom presets to show in the dropdown.\n   */\n  presets?: ObservableOrValueGetter<DateTimePresetConfiguration[]>;\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@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\n  private _config = new BehaviorSubject<Maybe<Observable<DbxDateTimePickerConfiguration>>>(undefined);\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 _updateTime = new Subject<void>();\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\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$ = this.formControl$.pipe(\n    map((control) => control.valueChanges.pipe(startWith<Maybe<Date>>(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: false, trailing: true }), // throttle incoming values and timezone changes\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  /**\n   * Used to trigger/display visual updates (specifically on timeDistance, etc.).\n   */\n  readonly displayValue$ = interval(10 * 1000).pipe(\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(new Date(), {\n    validators: []\n  });\n\n  readonly timeInputCtrl = new FormControl('', {\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    return this.dateTimeField.timeOnly;\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 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  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 date$ = this.dateInputCtrl.valueChanges.pipe(startWith(this.dateInputCtrl.value), filterMaybe(), shareReplay(1));\n\n  readonly timezoneAbbreviation$ = combineLatest([this.date$, this.timezone$, this.timeDate$]).pipe(\n    map(([date, timezone, timeDate]) => getTimezoneAbbreviation(timezone, timeDate ?? 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  // TODO: Get min/max using the DateTimePickerConfiguration too\n\n  readonly dateInputMin$: Observable<Date | null> = this.syncConfigBeforeValue$;\n  readonly dateInputMax$: Observable<Date | null> = this.syncConfigAfterValue$;\n\n  readonly rawDateTime$: Observable<Maybe<Date>> = combineLatest([this.dateValue$, this.timeInput$.pipe(startWith(null)), this.fullDay$, this.timeDate$]).pipe(\n    map(([date, timeString, fullDay, timeDate]) => {\n      let result: Maybe<Date>;\n\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          result = date;\n        }\n      }\n\n      return result;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\n    shareReplay(1)\n  );\n\n  readonly config$ = combineLatest([this._config.pipe(switchMapMaybeDefault()), this.dateInputMin$, this.dateInputMax$]).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 pickerFilter$: Observable<DecisionFunction<Date | null>> = this.config$.pipe(\n    distinctUntilChanged(),\n    map((x) => {\n      if (x) {\n        const filter = dateTimeMinuteDecisionFunction(x);\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.config$]).pipe(\n    throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n    distinctUntilChanged((current, next) => current[0] === next[0] && next[1] === 0),\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        date = instance.clamp(date);\n        const minutes = stepsOffset * 5;\n        date = addMinutes(date, minutes);\n      }\n\n      return date;\n    }),\n    distinctUntilChanged(isSameDateHoursAndMinutes),\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  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) : undefined);\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    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((disabled) => {\n      if (disabled) {\n        this.dateInputCtrl.disable({ emitEvent: false });\n        this.timeInputCtrl.disable({ emitEvent: false });\n      } else {\n        this.dateInputCtrl.enable({ emitEvent: false });\n        this.timeInputCtrl.enable({ emitEvent: false });\n      }\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\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._valueSub.destroy();\n    this._config.complete();\n    this._defaultTimezone.complete();\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._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      this.date$.pipe(first()).subscribe((date) => {\n        const newDate = addDays(date, offset * direction);\n        this.setDateInputValue(newDate);\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    this._updateTime.next();\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","<div class=\"dbx-datetime-field\" fxLayout=\"row wrap\" fxLayout.xs=\"column wrap\" fxLayoutAlign=\"space-evenly stretch\">\n  <!-- Date -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"dateOnly ? '100' : '50'\" *ngIf=\"showDateInput\">\n    <ng-container *ngTemplateOutlet=\"dateInputTemplate\"></ng-container>\n    <!-- Additional spacing -->\n    <dbx-button-spacer *ngIf=\"!dateOnly\"></dbx-button-spacer>\n  </div>\n  <!-- Time -->\n  <div class=\"dbx-datetime-row\" fxFlex.lt-sm=\"100\" [fxFlex]=\"showDateInput ? '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  <div *ngIf=\"!hideDateHint\" class=\"dbx-datetime-row dbx-datetime-hint-row\" fxFlex=\"100\">\n    <div class=\"dbx-hint\" [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    </div>\n  </div>\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 [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=\"mat-datepicker-button-highlight dbx-button-spacer\" *ngIf=\"!hideDatePicker\" mat-icon-button (click)=\"picker.open()\" [disabled]=\"disabled\">\n      <mat-icon>calendar_today</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 matInput [formControl]=\"timeInputCtrl\" (focus)=\"focusTime()\" (focusout)=\"focusOutTime()\" (keydown)=\"keydownOnTimeInput($event)\" />\n    <button matPrefix class=\"mat-datepicker-button-highlight dbx-button-spacer\" 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-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"]}
|