@dereekb/dbx-form 9.25.16 → 10.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (364) hide show
  1. package/_index.scss +1 -0
  2. package/calendar/lib/calendar.module.d.ts +1 -1
  3. package/calendar/lib/calendar.schedule.selection.cell.component.d.ts +1 -1
  4. package/calendar/lib/calendar.schedule.selection.component.d.ts +4 -4
  5. package/calendar/lib/calendar.schedule.selection.d.ts +1 -1
  6. package/calendar/lib/calendar.schedule.selection.days.component.d.ts +1 -1
  7. package/calendar/lib/calendar.schedule.selection.days.form.component.d.ts +2 -2
  8. package/calendar/lib/calendar.schedule.selection.dialog.button.component.d.ts +1 -6
  9. package/calendar/lib/calendar.schedule.selection.dialog.component.d.ts +1 -11
  10. package/calendar/lib/calendar.schedule.selection.popover.button.component.d.ts +2 -2
  11. package/calendar/lib/calendar.schedule.selection.popover.component.d.ts +1 -1
  12. package/calendar/lib/calendar.schedule.selection.popover.content.component.d.ts +1 -1
  13. package/calendar/lib/calendar.schedule.selection.range.component.d.ts +1 -1
  14. package/calendar/lib/calendar.schedule.selection.store.d.ts +4 -32
  15. package/calendar/lib/calendar.schedule.selection.store.provide.d.ts +1 -1
  16. package/calendar/lib/calendar.schedule.selection.toggle.button.component.d.ts +1 -1
  17. package/calendar/lib/field/schedule/calendar.schedule.field.component.d.ts +2 -8
  18. package/esm2022/calendar/lib/calendar.module.mjs +155 -0
  19. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.cell.component.mjs +10 -10
  20. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.component.mjs +6 -6
  21. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.days.component.mjs +6 -6
  22. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.days.form.component.mjs +6 -6
  23. package/esm2022/calendar/lib/calendar.schedule.selection.dialog.button.component.mjs +36 -0
  24. package/esm2022/calendar/lib/calendar.schedule.selection.dialog.component.mjs +56 -0
  25. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.mjs +1 -1
  26. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.popover.button.component.mjs +6 -6
  27. package/esm2022/calendar/lib/calendar.schedule.selection.popover.component.mjs +38 -0
  28. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.popover.content.component.mjs +6 -6
  29. package/esm2022/calendar/lib/calendar.schedule.selection.range.component.mjs +188 -0
  30. package/esm2022/calendar/lib/calendar.schedule.selection.store.mjs +785 -0
  31. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.store.provide.mjs +7 -7
  32. package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.toggle.button.component.mjs +6 -6
  33. package/esm2022/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +158 -0
  34. package/esm2022/calendar/lib/field/schedule/calendar.schedule.field.mjs +28 -0
  35. package/esm2022/calendar/lib/field/schedule/calendar.schedule.module.mjs +58 -0
  36. package/{esm2020 → esm2022}/lib/form/action/form.action.directive.mjs +4 -4
  37. package/{esm2020 → esm2022}/lib/form/action/form.action.module.mjs +5 -5
  38. package/{esm2020 → esm2022}/lib/form/action/transition/form.action.transition.module.mjs +5 -5
  39. package/{esm2020 → esm2022}/lib/form/action/transition/form.action.transition.safety.directive.mjs +4 -4
  40. package/{esm2020 → esm2022}/lib/form/form.module.mjs +5 -5
  41. package/{esm2020 → esm2022}/lib/form/io/form.changes.directive.mjs +4 -4
  42. package/{esm2020 → esm2022}/lib/form/io/form.input.directive.mjs +4 -4
  43. package/{esm2020 → esm2022}/lib/form/io/form.io.module.mjs +5 -5
  44. package/{esm2020 → esm2022}/lib/form/io/form.loading.directive.mjs +4 -4
  45. package/{esm2020 → esm2022}/lib/form.module.mjs +5 -5
  46. package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.component.mjs +9 -9
  47. package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.content.default.component.mjs +6 -6
  48. package/esm2022/lib/formly/field/checklist/checklist.item.field.module.mjs +67 -0
  49. package/{esm2020 → esm2022}/lib/formly/field/component/component.field.component.mjs +6 -6
  50. package/esm2022/lib/formly/field/component/component.field.module.mjs +32 -0
  51. package/esm2022/lib/formly/field/field.mjs +97 -0
  52. package/{esm2020 → esm2022}/lib/formly/field/form.field.module.mjs +5 -5
  53. package/{esm2020 → esm2022}/lib/formly/field/selection/list/list.field.component.mjs +4 -4
  54. package/esm2022/lib/formly/field/selection/list/list.field.module.mjs +76 -0
  55. package/esm2022/lib/formly/field/selection/pickable/pickable.chip.field.component.mjs +33 -0
  56. package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.field.directive.mjs +4 -4
  57. package/esm2022/lib/formly/field/selection/pickable/pickable.field.module.mjs +93 -0
  58. package/esm2022/lib/formly/field/selection/pickable/pickable.list.field.component.mjs +116 -0
  59. package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.mjs +1 -1
  60. package/esm2022/lib/formly/field/selection/searchable/searchable.chip.field.component.mjs +68 -0
  61. package/esm2022/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.mjs +95 -0
  62. package/esm2022/lib/formly/field/selection/searchable/searchable.field.directive.mjs +278 -0
  63. package/esm2022/lib/formly/field/selection/searchable/searchable.field.module.mjs +91 -0
  64. package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.text.field.component.mjs +4 -4
  65. package/esm2022/lib/formly/field/selection/selection.field.mjs +39 -0
  66. package/{esm2020 → esm2022}/lib/formly/field/selection/selection.mjs +1 -1
  67. package/{esm2020 → esm2022}/lib/formly/field/selection/selection.module.mjs +5 -5
  68. package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.field.component.mjs +4 -4
  69. package/esm2022/lib/formly/field/selection/sourceselect/sourceselect.field.module.mjs +93 -0
  70. package/{esm2020 → esm2022}/lib/formly/field/texteditor/texteditor.field.component.mjs +6 -6
  71. package/esm2022/lib/formly/field/texteditor/texteditor.field.module.mjs +51 -0
  72. package/{esm2020 → esm2022}/lib/formly/field/value/array/array.field.component.mjs +8 -8
  73. package/esm2022/lib/formly/field/value/array/array.field.module.mjs +62 -0
  74. package/esm2022/lib/formly/field/value/boolean/boolean.field.mjs +47 -0
  75. package/{esm2020 → esm2022}/lib/formly/field/value/boolean/boolean.field.module.mjs +5 -5
  76. package/esm2022/lib/formly/field/value/date/date.field.module.mjs +96 -0
  77. package/esm2022/lib/formly/field/value/date/datetime.field.component.mjs +488 -0
  78. package/esm2022/lib/formly/field/value/date/datetime.field.mjs +141 -0
  79. package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.field.service.mjs +9 -9
  80. package/esm2022/lib/formly/field/value/date/fixeddaterange.field.component.mjs +506 -0
  81. package/{esm2020 → esm2022}/lib/formly/field/value/number/number.field.module.mjs +5 -5
  82. package/esm2022/lib/formly/field/value/phone/phone.field.component.mjs +100 -0
  83. package/esm2022/lib/formly/field/value/phone/phone.field.module.mjs +66 -0
  84. package/{esm2020 → esm2022}/lib/formly/field/value/text/text.field.module.mjs +5 -5
  85. package/{esm2020 → esm2022}/lib/formly/field/value/value.module.mjs +5 -5
  86. package/{esm2020 → esm2022}/lib/formly/field/wrapper/autotouch.wrapper.component.mjs +6 -6
  87. package/{esm2020 → esm2022}/lib/formly/field/wrapper/expandable.wrapper.component.mjs +6 -6
  88. package/{esm2020 → esm2022}/lib/formly/field/wrapper/expandable.wrapper.delegate.mjs +4 -4
  89. package/{esm2020 → esm2022}/lib/formly/field/wrapper/flex.wrapper.component.mjs +6 -6
  90. package/esm2022/lib/formly/field/wrapper/form.wrapper.module.mjs +86 -0
  91. package/{esm2020 → esm2022}/lib/formly/field/wrapper/info.wrapper.component.mjs +7 -7
  92. package/esm2022/lib/formly/field/wrapper/section.wrapper.component.mjs +27 -0
  93. package/{esm2020 → esm2022}/lib/formly/field/wrapper/style.wrapper.component.mjs +7 -7
  94. package/esm2022/lib/formly/field/wrapper/subsection.wrapper.component.mjs +27 -0
  95. package/{esm2020 → esm2022}/lib/formly/field/wrapper/toggle.wrapper.component.mjs +6 -6
  96. package/{esm2020 → esm2022}/lib/formly/field/wrapper/working.wrapper.component.mjs +6 -6
  97. package/esm2022/lib/formly/field/wrapper/wrapper.mjs +73 -0
  98. package/{esm2020 → esm2022}/lib/formly/form/form.form.module.mjs +5 -5
  99. package/{esm2020 → esm2022}/lib/formly/form/search.form.component.mjs +6 -6
  100. package/{esm2020 → esm2022}/lib/formly/formly.context.directive.mjs +4 -4
  101. package/esm2022/lib/formly/formly.context.mjs +100 -0
  102. package/{esm2020 → esm2022}/lib/formly/formly.directive.mjs +16 -16
  103. package/{esm2020 → esm2022}/lib/formly/formly.form.component.mjs +6 -6
  104. package/{esm2020 → esm2022}/lib/formly/formly.module.mjs +16 -16
  105. package/{esm2020 → esm2022}/lib/layout/form.layout.module.mjs +5 -5
  106. package/{esm2020 → esm2022}/lib/layout/form.spacer.component.mjs +6 -6
  107. package/{esm2020 → esm2022}/mapbox/lib/field/latlng/latlng.field.component.mjs +10 -10
  108. package/{esm2020 → esm2022}/mapbox/lib/field/latlng/latlng.field.marker.component.mjs +6 -6
  109. package/esm2022/mapbox/lib/field/latlng/latlng.field.mjs +35 -0
  110. package/esm2022/mapbox/lib/field/latlng/latlng.module.mjs +59 -0
  111. package/{mapbox/esm2020 → esm2022/mapbox}/lib/field/zoom/zoom.field.component.mjs +10 -10
  112. package/esm2022/mapbox/lib/field/zoom/zoom.field.mjs +23 -0
  113. package/esm2022/mapbox/lib/field/zoom/zoom.module.mjs +57 -0
  114. package/{mapbox/esm2020 → esm2022/mapbox}/lib/mapbox.module.mjs +5 -5
  115. package/{fesm2020 → fesm2022}/dereekb-dbx-form-calendar.mjs +188 -228
  116. package/fesm2022/dereekb-dbx-form-calendar.mjs.map +1 -0
  117. package/{mapbox/fesm2020 → fesm2022}/dereekb-dbx-form-mapbox.mjs +76 -76
  118. package/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -0
  119. package/{fesm2020 → fesm2022}/dereekb-dbx-form.mjs +820 -831
  120. package/fesm2022/dereekb-dbx-form.mjs.map +1 -0
  121. package/lib/extension/_extension.scss +11 -6
  122. package/lib/extension/calendar/_calendar.scss +7 -5
  123. package/lib/form/_form.scss +3 -2
  124. package/lib/form/action/form.action.directive.d.ts +2 -2
  125. package/lib/form/action/transition/form.action.transition.safety.directive.d.ts +1 -1
  126. package/lib/form/form.angular.util.d.ts +1 -1
  127. package/lib/form/form.d.ts +1 -1
  128. package/lib/form/io/form.changes.directive.d.ts +1 -1
  129. package/lib/form/io/form.input.directive.d.ts +2 -2
  130. package/lib/form/io/form.loading.directive.d.ts +1 -1
  131. package/lib/formly/_formly.scss +7 -9
  132. package/lib/formly/field/_field.scss +7 -7
  133. package/lib/formly/field/checklist/_checklist.scss +3 -2
  134. package/lib/formly/field/checklist/checklist.field.d.ts +4 -4
  135. package/lib/formly/field/checklist/checklist.item.d.ts +1 -1
  136. package/lib/formly/field/checklist/checklist.item.field.component.d.ts +2 -2
  137. package/lib/formly/field/checklist/checklist.item.field.content.default.component.d.ts +4 -4
  138. package/lib/formly/field/checklist/checklist.item.field.d.ts +1 -1
  139. package/lib/formly/field/component/_component.scss +3 -2
  140. package/lib/formly/field/component/component.field.component.d.ts +2 -2
  141. package/lib/formly/field/component/component.field.d.ts +1 -1
  142. package/lib/formly/field/field.d.ts +5 -11
  143. package/lib/formly/field/selection/_selection.scss +5 -5
  144. package/lib/formly/field/selection/list/_list.scss +3 -2
  145. package/lib/formly/field/selection/list/list.field.component.d.ts +1 -1
  146. package/lib/formly/field/selection/pickable/_pickable.scss +3 -9
  147. package/lib/formly/field/selection/pickable/pickable.chip.field.component.d.ts +1 -1
  148. package/lib/formly/field/selection/pickable/pickable.d.ts +6 -22
  149. package/lib/formly/field/selection/pickable/pickable.field.directive.d.ts +3 -3
  150. package/lib/formly/field/selection/pickable/pickable.list.field.component.d.ts +4 -4
  151. package/lib/formly/field/selection/pickable/pickable.util.d.ts +2 -2
  152. package/lib/formly/field/selection/searchable/_searchable.scss +5 -5
  153. package/lib/formly/field/selection/searchable/searchable.chip.field.component.d.ts +1 -1
  154. package/lib/formly/field/selection/searchable/searchable.d.ts +4 -4
  155. package/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.d.ts +3 -3
  156. package/lib/formly/field/selection/searchable/searchable.field.d.ts +1 -1
  157. package/lib/formly/field/selection/searchable/searchable.field.directive.d.ts +1 -1
  158. package/lib/formly/field/selection/searchable/searchable.text.field.component.d.ts +1 -1
  159. package/lib/formly/field/selection/selection.d.ts +1 -5
  160. package/lib/formly/field/selection/selection.field.d.ts +1 -1
  161. package/lib/formly/field/selection/sourceselect/_sourceselect.scss +6 -15
  162. package/lib/formly/field/selection/sourceselect/sourceselect.d.ts +6 -6
  163. package/lib/formly/field/selection/sourceselect/sourceselect.field.component.d.ts +1 -1
  164. package/lib/formly/field/selection/sourceselect/sourceselect.field.module.d.ts +1 -1
  165. package/lib/formly/field/texteditor/_texteditor.scss +3 -2
  166. package/lib/formly/field/texteditor/texteditor.field.component.d.ts +2 -2
  167. package/lib/formly/field/value/_value.scss +10 -6
  168. package/lib/formly/field/value/array/_array.scss +7 -2
  169. package/lib/formly/field/value/array/array.field.component.d.ts +2 -2
  170. package/lib/formly/field/value/boolean/_boolean.scss +5 -4
  171. package/lib/formly/field/value/date/_date.scss +20 -37
  172. package/lib/formly/field/value/date/date.field.module.d.ts +1 -1
  173. package/lib/formly/field/value/date/datetime.field.component.d.ts +3 -13
  174. package/lib/formly/field/value/date/datetime.field.d.ts +5 -5
  175. package/lib/formly/field/value/date/fixeddaterange.field.component.d.ts +7 -7
  176. package/lib/formly/field/value/hidden.field.d.ts +1 -1
  177. package/lib/formly/field/value/number/_number.scss +35 -0
  178. package/lib/formly/field/value/number/number.field.d.ts +3 -3
  179. package/lib/formly/field/value/phone/_phone.scss +4 -3
  180. package/lib/formly/field/value/phone/phone.field.component.d.ts +1 -1
  181. package/lib/formly/field/value/phone/phone.field.module.d.ts +1 -1
  182. package/lib/formly/field/value/text/_text.scss +3 -2
  183. package/lib/formly/field/value/text/text.additional.field.d.ts +3 -3
  184. package/lib/formly/field/value/text/text.field.d.ts +2 -2
  185. package/lib/formly/field/wrapper/_wrapper.scss +5 -4
  186. package/lib/formly/field/wrapper/autotouch.wrapper.component.d.ts +1 -1
  187. package/lib/formly/field/wrapper/expandable.wrapper.component.d.ts +2 -2
  188. package/lib/formly/field/wrapper/expandable.wrapper.delegate.d.ts +1 -1
  189. package/lib/formly/field/wrapper/flex.wrapper.component.d.ts +1 -1
  190. package/lib/formly/field/wrapper/form.wrapper.module.d.ts +1 -1
  191. package/lib/formly/field/wrapper/info.wrapper.component.d.ts +1 -1
  192. package/lib/formly/field/wrapper/section.wrapper.component.d.ts +2 -2
  193. package/lib/formly/field/wrapper/style.wrapper.component.d.ts +2 -2
  194. package/lib/formly/field/wrapper/subsection.wrapper.component.d.ts +2 -2
  195. package/lib/formly/field/wrapper/toggle.wrapper.component.d.ts +1 -1
  196. package/lib/formly/field/wrapper/working.wrapper.component.d.ts +2 -2
  197. package/lib/formly/field/wrapper/wrapper.d.ts +1 -1
  198. package/lib/formly/form/_form.scss +17 -4
  199. package/lib/formly/form/search.form.component.d.ts +1 -1
  200. package/lib/formly/formly.context.directive.d.ts +1 -1
  201. package/lib/formly/formly.directive.d.ts +4 -4
  202. package/lib/formly/formly.form.component.d.ts +1 -1
  203. package/lib/formly/template/login.d.ts +1 -1
  204. package/lib/formly/template/timezone.d.ts +1 -1
  205. package/lib/layout/_layout.scss +3 -2
  206. package/lib/layout/form.spacer.component.d.ts +1 -1
  207. package/lib/style/_all-typography.scss +11 -3
  208. package/lib/style/_core.scss +1 -2
  209. package/lib/style/_mixin.scss +10 -0
  210. package/lib/style/_theming.scss +1 -1
  211. package/lib/validator/available.d.ts +1 -1
  212. package/mapbox/{esm2020 → esm2022}/lib/field/latlng/latlng.field.component.mjs +10 -10
  213. package/mapbox/{esm2020 → esm2022}/lib/field/latlng/latlng.field.marker.component.mjs +6 -6
  214. package/mapbox/esm2022/lib/field/latlng/latlng.field.mjs +35 -0
  215. package/mapbox/esm2022/lib/field/latlng/latlng.module.mjs +59 -0
  216. package/{esm2020/mapbox → mapbox/esm2022}/lib/field/zoom/zoom.field.component.mjs +10 -10
  217. package/mapbox/esm2022/lib/field/zoom/zoom.field.mjs +23 -0
  218. package/mapbox/esm2022/lib/field/zoom/zoom.module.mjs +57 -0
  219. package/{esm2020/mapbox → mapbox/esm2022}/lib/mapbox.module.mjs +5 -5
  220. package/{fesm2020 → mapbox/fesm2022}/dereekb-dbx-form-mapbox.mjs +76 -76
  221. package/mapbox/fesm2022/dereekb-dbx-form-mapbox.mjs.map +1 -0
  222. package/mapbox/lib/field/latlng/latlng.field.component.d.ts +1 -1
  223. package/mapbox/lib/field/latlng/latlng.field.marker.component.d.ts +1 -1
  224. package/mapbox/lib/field/zoom/zoom.field.component.d.ts +1 -1
  225. package/mapbox/package.json +10 -28
  226. package/package.json +31 -31
  227. package/esm2020/calendar/lib/calendar.module.mjs +0 -155
  228. package/esm2020/calendar/lib/calendar.schedule.selection.dialog.button.component.mjs +0 -38
  229. package/esm2020/calendar/lib/calendar.schedule.selection.dialog.component.mjs +0 -65
  230. package/esm2020/calendar/lib/calendar.schedule.selection.popover.component.mjs +0 -37
  231. package/esm2020/calendar/lib/calendar.schedule.selection.range.component.mjs +0 -188
  232. package/esm2020/calendar/lib/calendar.schedule.selection.store.mjs +0 -814
  233. package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.component.mjs +0 -158
  234. package/esm2020/calendar/lib/field/schedule/calendar.schedule.field.mjs +0 -29
  235. package/esm2020/calendar/lib/field/schedule/calendar.schedule.module.mjs +0 -58
  236. package/esm2020/lib/formly/field/checklist/checklist.item.field.module.mjs +0 -67
  237. package/esm2020/lib/formly/field/component/component.field.module.mjs +0 -32
  238. package/esm2020/lib/formly/field/field.mjs +0 -103
  239. package/esm2020/lib/formly/field/selection/list/list.field.module.mjs +0 -76
  240. package/esm2020/lib/formly/field/selection/pickable/pickable.chip.field.component.mjs +0 -33
  241. package/esm2020/lib/formly/field/selection/pickable/pickable.field.module.mjs +0 -93
  242. package/esm2020/lib/formly/field/selection/pickable/pickable.list.field.component.mjs +0 -116
  243. package/esm2020/lib/formly/field/selection/searchable/searchable.chip.field.component.mjs +0 -68
  244. package/esm2020/lib/formly/field/selection/searchable/searchable.field.autocomplete.item.component.mjs +0 -95
  245. package/esm2020/lib/formly/field/selection/searchable/searchable.field.directive.mjs +0 -278
  246. package/esm2020/lib/formly/field/selection/searchable/searchable.field.module.mjs +0 -91
  247. package/esm2020/lib/formly/field/selection/selection.field.mjs +0 -39
  248. package/esm2020/lib/formly/field/selection/sourceselect/sourceselect.field.module.mjs +0 -93
  249. package/esm2020/lib/formly/field/texteditor/texteditor.field.module.mjs +0 -51
  250. package/esm2020/lib/formly/field/value/array/array.field.module.mjs +0 -62
  251. package/esm2020/lib/formly/field/value/boolean/boolean.field.mjs +0 -47
  252. package/esm2020/lib/formly/field/value/date/date.field.module.mjs +0 -96
  253. package/esm2020/lib/formly/field/value/date/datetime.field.component.mjs +0 -488
  254. package/esm2020/lib/formly/field/value/date/datetime.field.mjs +0 -143
  255. package/esm2020/lib/formly/field/value/date/fixeddaterange.field.component.mjs +0 -506
  256. package/esm2020/lib/formly/field/value/phone/phone.field.component.mjs +0 -100
  257. package/esm2020/lib/formly/field/value/phone/phone.field.module.mjs +0 -66
  258. package/esm2020/lib/formly/field/wrapper/form.wrapper.module.mjs +0 -86
  259. package/esm2020/lib/formly/field/wrapper/section.wrapper.component.mjs +0 -26
  260. package/esm2020/lib/formly/field/wrapper/subsection.wrapper.component.mjs +0 -26
  261. package/esm2020/lib/formly/field/wrapper/wrapper.mjs +0 -78
  262. package/esm2020/lib/formly/formly.context.mjs +0 -100
  263. package/esm2020/mapbox/lib/field/latlng/latlng.field.mjs +0 -35
  264. package/esm2020/mapbox/lib/field/latlng/latlng.module.mjs +0 -59
  265. package/esm2020/mapbox/lib/field/zoom/zoom.field.mjs +0 -23
  266. package/esm2020/mapbox/lib/field/zoom/zoom.module.mjs +0 -57
  267. package/fesm2015/dereekb-dbx-form-calendar.mjs +0 -1955
  268. package/fesm2015/dereekb-dbx-form-calendar.mjs.map +0 -1
  269. package/fesm2015/dereekb-dbx-form-mapbox.mjs +0 -585
  270. package/fesm2015/dereekb-dbx-form-mapbox.mjs.map +0 -1
  271. package/fesm2015/dereekb-dbx-form.mjs +0 -6205
  272. package/fesm2015/dereekb-dbx-form.mjs.map +0 -1
  273. package/fesm2020/dereekb-dbx-form-calendar.mjs.map +0 -1
  274. package/fesm2020/dereekb-dbx-form-mapbox.mjs.map +0 -1
  275. package/fesm2020/dereekb-dbx-form.mjs.map +0 -1
  276. package/mapbox/esm2020/lib/field/latlng/latlng.field.mjs +0 -35
  277. package/mapbox/esm2020/lib/field/latlng/latlng.module.mjs +0 -59
  278. package/mapbox/esm2020/lib/field/zoom/zoom.field.mjs +0 -23
  279. package/mapbox/esm2020/lib/field/zoom/zoom.module.mjs +0 -57
  280. package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs +0 -585
  281. package/mapbox/fesm2015/dereekb-dbx-form-mapbox.mjs.map +0 -1
  282. package/mapbox/fesm2020/dereekb-dbx-form-mapbox.mjs.map +0 -1
  283. /package/{esm2020 → esm2022}/calendar/dereekb-dbx-form-calendar.mjs +0 -0
  284. /package/{esm2020 → esm2022}/calendar/index.mjs +0 -0
  285. /package/{esm2020 → esm2022}/calendar/lib/calendar.schedule.selection.form.mjs +0 -0
  286. /package/{esm2020 → esm2022}/calendar/lib/field/index.mjs +0 -0
  287. /package/{esm2020 → esm2022}/calendar/lib/field/schedule/index.mjs +0 -0
  288. /package/{esm2020 → esm2022}/calendar/lib/index.mjs +0 -0
  289. /package/{esm2020 → esm2022}/dereekb-dbx-form.mjs +0 -0
  290. /package/{esm2020 → esm2022}/index.mjs +0 -0
  291. /package/{esm2020 → esm2022}/lib/form/action/index.mjs +0 -0
  292. /package/{esm2020 → esm2022}/lib/form/action/transition/index.mjs +0 -0
  293. /package/{esm2020 → esm2022}/lib/form/form.angular.util.mjs +0 -0
  294. /package/{esm2020 → esm2022}/lib/form/form.mjs +0 -0
  295. /package/{esm2020 → esm2022}/lib/form/index.mjs +0 -0
  296. /package/{esm2020 → esm2022}/lib/form/io/index.mjs +0 -0
  297. /package/{esm2020 → esm2022}/lib/formly/config/index.mjs +0 -0
  298. /package/{esm2020 → esm2022}/lib/formly/config/validation.mjs +0 -0
  299. /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.field.mjs +0 -0
  300. /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.field.mjs +0 -0
  301. /package/{esm2020 → esm2022}/lib/formly/field/checklist/checklist.item.mjs +0 -0
  302. /package/{esm2020 → esm2022}/lib/formly/field/checklist/index.mjs +0 -0
  303. /package/{esm2020 → esm2022}/lib/formly/field/component/component.field.mjs +0 -0
  304. /package/{esm2020 → esm2022}/lib/formly/field/component/index.mjs +0 -0
  305. /package/{esm2020 → esm2022}/lib/formly/field/index.mjs +0 -0
  306. /package/{esm2020 → esm2022}/lib/formly/field/selection/index.mjs +0 -0
  307. /package/{esm2020 → esm2022}/lib/formly/field/selection/list/index.mjs +0 -0
  308. /package/{esm2020 → esm2022}/lib/formly/field/selection/list/list.field.mjs +0 -0
  309. /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/index.mjs +0 -0
  310. /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.field.mjs +0 -0
  311. /package/{esm2020 → esm2022}/lib/formly/field/selection/pickable/pickable.util.mjs +0 -0
  312. /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/index.mjs +0 -0
  313. /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.field.mjs +0 -0
  314. /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/searchable.mjs +0 -0
  315. /package/{esm2020 → esm2022}/lib/formly/field/selection/searchable/text.chip.field.mjs +0 -0
  316. /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/index.mjs +0 -0
  317. /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.field.mjs +0 -0
  318. /package/{esm2020 → esm2022}/lib/formly/field/selection/sourceselect/sourceselect.mjs +0 -0
  319. /package/{esm2020 → esm2022}/lib/formly/field/texteditor/index.mjs +0 -0
  320. /package/{esm2020 → esm2022}/lib/formly/field/texteditor/texteditor.field.mjs +0 -0
  321. /package/{esm2020 → esm2022}/lib/formly/field/value/array/array.field.mjs +0 -0
  322. /package/{esm2020 → esm2022}/lib/formly/field/value/array/index.mjs +0 -0
  323. /package/{esm2020 → esm2022}/lib/formly/field/value/boolean/index.mjs +0 -0
  324. /package/{esm2020 → esm2022}/lib/formly/field/value/date/date.value.mjs +0 -0
  325. /package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.mjs +0 -0
  326. /package/{esm2020 → esm2022}/lib/formly/field/value/date/datetime.preset.mjs +0 -0
  327. /package/{esm2020 → esm2022}/lib/formly/field/value/date/index.mjs +0 -0
  328. /package/{esm2020 → esm2022}/lib/formly/field/value/hidden.field.mjs +0 -0
  329. /package/{esm2020 → esm2022}/lib/formly/field/value/index.mjs +0 -0
  330. /package/{esm2020 → esm2022}/lib/formly/field/value/number/index.mjs +0 -0
  331. /package/{esm2020 → esm2022}/lib/formly/field/value/number/number.field.mjs +0 -0
  332. /package/{esm2020 → esm2022}/lib/formly/field/value/phone/index.mjs +0 -0
  333. /package/{esm2020 → esm2022}/lib/formly/field/value/phone/phone.field.mjs +0 -0
  334. /package/{esm2020 → esm2022}/lib/formly/field/value/text/index.mjs +0 -0
  335. /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.additional.field.mjs +0 -0
  336. /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.address.field.mjs +0 -0
  337. /package/{esm2020 → esm2022}/lib/formly/field/value/text/text.field.mjs +0 -0
  338. /package/{esm2020 → esm2022}/lib/formly/field/wrapper/index.mjs +0 -0
  339. /package/{esm2020 → esm2022}/lib/formly/form/form.form.mjs +0 -0
  340. /package/{esm2020 → esm2022}/lib/formly/form/index.mjs +0 -0
  341. /package/{esm2020 → esm2022}/lib/formly/index.mjs +0 -0
  342. /package/{esm2020 → esm2022}/lib/formly/template/available.mjs +0 -0
  343. /package/{esm2020 → esm2022}/lib/formly/template/index.mjs +0 -0
  344. /package/{esm2020 → esm2022}/lib/formly/template/login.mjs +0 -0
  345. /package/{esm2020 → esm2022}/lib/formly/template/timezone.mjs +0 -0
  346. /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
  347. /package/{esm2020 → esm2022}/lib/layout/index.mjs +0 -0
  348. /package/{esm2020 → esm2022}/lib/validator/available.mjs +0 -0
  349. /package/{esm2020 → esm2022}/lib/validator/boolean.mjs +0 -0
  350. /package/{esm2020 → esm2022}/lib/validator/email.mjs +0 -0
  351. /package/{esm2020 → esm2022}/lib/validator/field.mjs +0 -0
  352. /package/{esm2020 → esm2022}/lib/validator/index.mjs +0 -0
  353. /package/{esm2020 → esm2022}/lib/validator/number.mjs +0 -0
  354. /package/{esm2020 → esm2022}/lib/validator/phone.mjs +0 -0
  355. /package/{esm2020 → esm2022}/mapbox/dereekb-dbx-form-mapbox.mjs +0 -0
  356. /package/{esm2020 → esm2022}/mapbox/index.mjs +0 -0
  357. /package/{esm2020 → esm2022}/mapbox/lib/field/index.mjs +0 -0
  358. /package/{esm2020 → esm2022}/mapbox/lib/field/latlng/index.mjs +0 -0
  359. /package/{esm2020 → esm2022}/mapbox/lib/field/zoom/index.mjs +0 -0
  360. /package/mapbox/{esm2020 → esm2022}/dereekb-dbx-form-mapbox.mjs +0 -0
  361. /package/mapbox/{esm2020 → esm2022}/index.mjs +0 -0
  362. /package/mapbox/{esm2020 → esm2022}/lib/field/index.mjs +0 -0
  363. /package/mapbox/{esm2020 → esm2022}/lib/field/latlng/index.mjs +0 -0
  364. /package/mapbox/{esm2020 → esm2022}/lib/field/zoom/index.mjs +0 -0
@@ -0,0 +1,506 @@
1
+ import { isMonthDaySlashDate, MS_IN_MINUTE } from '@dereekb/util';
2
+ import { guessCurrentTimezone, dateTimeMinuteDecisionFunction, dateTimezoneUtcNormal, isSameDateDayRange, dateRange, isDateInDateRange, clampDateRangeToDateRange, isSameDateRange, isSameDateDay, limitDateTimeInstance } from '@dereekb/date';
3
+ import { switchMap, shareReplay, map, startWith, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, Subject, of, combineLatestWith, filter, combineLatest, scan, first, timer } from 'rxjs';
4
+ import { Component, ElementRef, Injectable, ViewChild, forwardRef } from '@angular/core';
5
+ import { FormControl, FormGroup } from '@angular/forms';
6
+ import { FieldType } from '@ngx-formly/material';
7
+ import { MAT_DATE_RANGE_SELECTION_STRATEGY, DateRange as DatePickerDateRange, MatCalendar } from '@angular/material/datepicker';
8
+ import { asObservableFromGetter, filterMaybe, skipFirstMaybe, SubscriptionObject, switchMapMaybeDefault } from '@dereekb/rxjs';
9
+ import { DbxDateTimeValueMode, dbxDateRangeIsSameDateRangeFieldValue, dbxDateTimeInputValueParseFactory, dbxDateTimeOutputValueFactory } from './date.value';
10
+ import { DbxDateTimeFieldMenuPresetsService } from './datetime.field.service';
11
+ import { DateAdapter } from '@angular/material/core';
12
+ import { isAfter } from 'date-fns';
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/form-field";
18
+ import * as i5 from "@angular/material/datepicker";
19
+ import * as i6 from "@ngbracket/ngx-layout/extended";
20
+ import * as i7 from "@angular/material/core";
21
+ function dbxFixedDateRangeInputValueFactory(mode, timezoneInstance) {
22
+ const dateInputTransformer = dbxDateTimeInputValueParseFactory(mode, timezoneInstance);
23
+ return (y) => {
24
+ let result;
25
+ if (y) {
26
+ result = {
27
+ start: dateInputTransformer(y.start),
28
+ end: dateInputTransformer(y.end)
29
+ };
30
+ }
31
+ return result;
32
+ };
33
+ }
34
+ function dbxFixedDateRangeOutputValueFactory(mode, timezoneInstance) {
35
+ const dateOutputTransformer = dbxDateTimeOutputValueFactory(mode, timezoneInstance);
36
+ return (y) => {
37
+ let result;
38
+ if (y) {
39
+ result = {
40
+ start: dateOutputTransformer(y.start),
41
+ end: dateOutputTransformer(y.end)
42
+ };
43
+ }
44
+ return result;
45
+ };
46
+ }
47
+ const TIME_OUTPUT_THROTTLE_TIME = 10;
48
+ export class DbxFixedDateRangeFieldComponent extends FieldType {
49
+ get currentDateRangeInput() {
50
+ return this._currentDateRangeInput;
51
+ }
52
+ get currentSelectionMode() {
53
+ return this._currentSelectionMode;
54
+ }
55
+ get latestBoundary() {
56
+ return this._latestBoundary;
57
+ }
58
+ dateRangeSelectionForMode(mode) {
59
+ const result = combineLatest([this.dateRangeInput$, this.limitDateTimeInstance$]).pipe(switchMap(([dateRangeInput, limitInstance]) => {
60
+ const hasDateRangeConfiguration = Boolean(dateRangeInput);
61
+ const minMaxClamp = (dateRange) => limitInstance.clampDateRange(dateRange);
62
+ if (mode === 'single') {
63
+ // only use the start date.
64
+ return this.selectedDateRange$.pipe(distinctUntilChanged(isSameDateDayRange), map((inputDateRange) => {
65
+ const date = inputDateRange?.start;
66
+ return date ? minMaxClamp(dateRange({ ...dateRangeInput, date })) : null;
67
+ }));
68
+ }
69
+ else {
70
+ // take the first date, then wait unless the date is outside of the range.
71
+ return this.selectedDateRange$.pipe(scan((acc, nextDateRange) => {
72
+ let result;
73
+ let pickType = 'start';
74
+ if (nextDateRange && nextDateRange.start != null) {
75
+ const { start: startOrNextDate, end } = nextDateRange;
76
+ const potentialBoundary = dateRange({ ...dateRangeInput, date: startOrNextDate });
77
+ // only comes through when passed by the text inputs
78
+ if (startOrNextDate && end) {
79
+ const range = clampDateRangeToDateRange(nextDateRange, potentialBoundary);
80
+ result = {
81
+ lastDateRange: nextDateRange,
82
+ boundary: range,
83
+ range
84
+ };
85
+ }
86
+ else {
87
+ let range = undefined;
88
+ let boundary = potentialBoundary;
89
+ if (mode === 'normal') {
90
+ if (!hasDateRangeConfiguration) {
91
+ // if there is no configured range/boundary, then just set the pick type based on the last type
92
+ boundary = undefined;
93
+ pickType = acc.lastPickType === 'start' ? 'end' : 'start';
94
+ }
95
+ else {
96
+ // if the pick is outside the boundary, then consider it a start pick type.
97
+ pickType = acc.lastPickType === 'start' && acc.boundary && isDateInDateRange(startOrNextDate, acc.boundary) ? 'end' : 'start';
98
+ }
99
+ // assert the start exists from the previous click, otherwise clear it.
100
+ if (pickType === 'end') {
101
+ const lastStart = acc.lastDateRange?.start;
102
+ if (!lastStart || !isAfter(startOrNextDate, lastStart)) {
103
+ pickType = 'start';
104
+ }
105
+ }
106
+ // react based on how this
107
+ switch (pickType) {
108
+ case 'end':
109
+ // if we're picking the end then set the range.
110
+ range = {
111
+ start: acc.lastDateRange?.start,
112
+ end: startOrNextDate
113
+ };
114
+ boundary = range;
115
+ break;
116
+ case 'start':
117
+ // retain the boundary as potential boundary, and set our new range from the single date.
118
+ range = {
119
+ start: startOrNextDate,
120
+ end: startOrNextDate
121
+ };
122
+ break;
123
+ }
124
+ }
125
+ else if (acc.boundary && isDateInDateRange(startOrNextDate, acc.boundary)) {
126
+ // if in the date range, uses the pick as the last date.
127
+ range = {
128
+ start: acc.boundary.start,
129
+ end: startOrNextDate
130
+ };
131
+ if (mode === 'arbitrary_quick') {
132
+ // modify boundary to match range
133
+ if (isSameDateRange(acc.range, range) && isSameDateDay(range.end, startOrNextDate)) {
134
+ // if we clicked on the end range, then expand the boundary again to the full range.
135
+ range = dateRange({ ...dateRangeInput, date: range.start });
136
+ boundary = range;
137
+ }
138
+ else {
139
+ boundary = range;
140
+ }
141
+ }
142
+ else {
143
+ // retain same boundary
144
+ boundary = acc.boundary;
145
+ }
146
+ }
147
+ else if (mode === 'arbitrary_quick') {
148
+ range = potentialBoundary;
149
+ }
150
+ result = {
151
+ lastDateRange: nextDateRange,
152
+ boundary,
153
+ range
154
+ };
155
+ }
156
+ }
157
+ else {
158
+ result = {
159
+ lastDateRange: nextDateRange
160
+ };
161
+ }
162
+ if (result) {
163
+ result = {
164
+ lastPickType: pickType,
165
+ lastDateRange: result.lastDateRange,
166
+ boundary: result.boundary ? minMaxClamp(result.boundary) : undefined,
167
+ range: result.range ? minMaxClamp(result.range) : undefined
168
+ };
169
+ }
170
+ return result;
171
+ }, {}), filter((x) => !x.lastDateRange || x.range != null), // pass through null/date clearings or ranges
172
+ map((x) => x.range ?? null) // return the range
173
+ );
174
+ }
175
+ }));
176
+ return result;
177
+ }
178
+ get fixedDateRangeField() {
179
+ return this.field.props;
180
+ }
181
+ get selectionMode() {
182
+ return this.field.props.selectionMode;
183
+ }
184
+ get valueMode() {
185
+ return this.field.props.valueMode ?? DbxDateTimeValueMode.DATE;
186
+ }
187
+ get description() {
188
+ return this.field.props.description;
189
+ }
190
+ get timezone() {
191
+ return this.field.props.timezone;
192
+ }
193
+ get showTimezone() {
194
+ return this.field.props.showTimezone ?? true;
195
+ }
196
+ get presets() {
197
+ return this.field.props.presets;
198
+ }
199
+ get showRangeInput() {
200
+ return this.field.props.showRangeInput ?? true;
201
+ }
202
+ constructor(dbxDateTimeFieldConfigService) {
203
+ super();
204
+ this.dbxDateTimeFieldConfigService = dbxDateTimeFieldConfigService;
205
+ this._sub = new SubscriptionObject();
206
+ this._inputRangeFormSub = new SubscriptionObject();
207
+ this._inputRangeFormValueSub = new SubscriptionObject();
208
+ this._dateRangeInputSub = new SubscriptionObject();
209
+ this._currentSelectionModeSub = new SubscriptionObject();
210
+ this._latestBoundarySub = new SubscriptionObject();
211
+ this._disableEndSub = new SubscriptionObject();
212
+ this._activeDateSub = new SubscriptionObject();
213
+ this._currentDateRangeInput = {};
214
+ this._currentSelectionMode = 'single';
215
+ this._latestBoundary = null;
216
+ this._config = new BehaviorSubject(undefined);
217
+ this._selectionMode = new BehaviorSubject(undefined);
218
+ this._dateRangeInput = new BehaviorSubject(undefined);
219
+ this._timezone = new BehaviorSubject(undefined);
220
+ this._presets = new BehaviorSubject(of([]));
221
+ this._selectionEvent = new Subject();
222
+ this.selectedDateRange$ = this._selectionEvent.pipe(map((x) => x.range));
223
+ this._formControlObs = new BehaviorSubject(undefined);
224
+ this.formControl$ = this._formControlObs.pipe(filterMaybe());
225
+ this.config$ = this._config.pipe(filterMaybe(), switchMap((x) => x), distinctUntilChanged(), shareReplay(1));
226
+ this.limitDateTimeInstance$ = this.config$.pipe(map(limitDateTimeInstance), shareReplay(1));
227
+ this.selectionMode$ = this._selectionMode.pipe(switchMapMaybeDefault('single'), map((x) => x ?? 'single'), distinctUntilChanged(), shareReplay(1));
228
+ this.dateRangeInput$ = this._dateRangeInput.pipe(switchMapMaybeDefault(), shareReplay(1));
229
+ this.timezone$ = this._timezone.pipe(switchMapMaybeDefault(), distinctUntilChanged()).pipe(map((defaultTimezone) => {
230
+ return defaultTimezone ?? guessCurrentTimezone();
231
+ }), distinctUntilChanged(), shareReplay(1));
232
+ this.timezoneInstance$ = this.timezone$.pipe(map((timezone) => (timezone ? dateTimezoneUtcNormal({ timezone }) : undefined)), shareReplay(1));
233
+ this.valueInSystemTimezone$ = this.formControl$.pipe(map((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))), combineLatestWith(this.timezoneInstance$), switchMap(([x, timezoneInstance]) => {
234
+ return x.pipe(map(dbxFixedDateRangeInputValueFactory(this.valueMode, timezoneInstance)));
235
+ }), throttleTime(20, undefined, { leading: false, trailing: true }), // throttle incoming values and timezone changes
236
+ distinctUntilChanged(isSameDateDayRange), shareReplay(1));
237
+ this.fullBoundary$ = this.dateRangeSelectionForMode('single').pipe(shareReplay(1));
238
+ this.latestBoundary$ = this.selectionMode$.pipe(switchMap((mode) => {
239
+ if (mode === 'arbitrary_quick') {
240
+ // in arbitrary_quick mode, the latest value is the boundary, since we always set the value immediately.
241
+ return this.valueInSystemTimezone$;
242
+ }
243
+ else {
244
+ return this.fullBoundary$;
245
+ }
246
+ }));
247
+ /**
248
+ * Focuses on the date any time the selection event from the picker occured, otherwise use the system value
249
+ */
250
+ this.calendarFocusDate$ = this._selectionEvent.pipe(startWith(null)).pipe(switchMap((selectionEvent) => {
251
+ if (selectionEvent && selectionEvent.type === 'calendar' && selectionEvent.range?.start) {
252
+ return of(selectionEvent.range.start);
253
+ }
254
+ else {
255
+ return this.fullBoundary$.pipe(first(), map((fullBoundary) => {
256
+ return fullBoundary?.start ?? selectionEvent?.range?.start;
257
+ }));
258
+ }
259
+ }), filterMaybe(), shareReplay(1));
260
+ this.dateRangeSelection$ = this.selectionMode$.pipe(switchMap((mode) => this.dateRangeSelectionForMode(mode)));
261
+ this.calendarSelection$ = this.valueInSystemTimezone$.pipe(map((x) => (x ? new DatePickerDateRange(x.start, x.end) : null)), shareReplay(1));
262
+ this.endDisabled$ = this.selectionMode$.pipe(map((x) => x === 'single'), distinctUntilChanged(), shareReplay(1));
263
+ this.inputRangeForm = new FormGroup({
264
+ start: new FormControl(null),
265
+ end: new FormControl(null)
266
+ });
267
+ this.minMaxRange$ = this.limitDateTimeInstance$.pipe(combineLatestWith(timer(MS_IN_MINUTE)), // refresh every minute
268
+ map(([x]) => x.dateRange()), distinctUntilChanged(isSameDateDayRange), shareReplay(1));
269
+ this.min$ = this.minMaxRange$.pipe(map((x) => x?.start ?? null), distinctUntilChanged(), shareReplay(1));
270
+ this.max$ = this.minMaxRange$.pipe(map((x) => x?.end ?? null), distinctUntilChanged(), shareReplay(1));
271
+ this.pickerFilter$ = this.config$.pipe(distinctUntilChanged(), map((x) => {
272
+ if (x) {
273
+ const filter = dateTimeMinuteDecisionFunction(x);
274
+ return (x) => (x != null ? filter(x) : true);
275
+ }
276
+ else {
277
+ return () => true;
278
+ }
279
+ }), shareReplay(1));
280
+ this.defaultPickerFilter = () => true;
281
+ }
282
+ ngOnInit() {
283
+ this._formControlObs.next(this.formControl);
284
+ const dateRangeSelection = this.dateRangeSelection$.pipe(shareReplay(1));
285
+ const setInputFormValue = (value) => {
286
+ if (!isSameDateDayRange(value, this.inputRangeForm.value)) {
287
+ this.inputRangeForm.setValue({
288
+ start: value?.start ?? null,
289
+ end: value?.end ?? null
290
+ });
291
+ }
292
+ };
293
+ this._sub.subscription = this.valueInSystemTimezone$
294
+ .pipe(combineLatestWith(this.timezoneInstance$.pipe(map((timezoneInstance) => dbxFixedDateRangeOutputValueFactory(this.valueMode, timezoneInstance)))), throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }), switchMap(([currentValue, valueFactory]) => {
295
+ return dateRangeSelection.pipe(skipFirstMaybe(), distinctUntilChanged(isSameDateDayRange), map((x) => [x, currentValue, valueFactory]));
296
+ }))
297
+ .subscribe(([rawValue, currentValue, valueFactory]) => {
298
+ const value = rawValue ? valueFactory(rawValue) : null;
299
+ const isSameRange = dbxDateRangeIsSameDateRangeFieldValue(value, currentValue);
300
+ if (!isSameRange) {
301
+ this.formControl.setValue(value);
302
+ this.formControl.markAsDirty();
303
+ this.formControl.markAsTouched();
304
+ }
305
+ else if (rawValue != null) {
306
+ // update the input text again
307
+ setInputFormValue(rawValue);
308
+ }
309
+ });
310
+ if (this.selectionMode) {
311
+ this._selectionMode.next(asObservableFromGetter(this.selectionMode));
312
+ }
313
+ this._currentSelectionModeSub.subscription = this.selectionMode$.subscribe((x) => (this._currentSelectionMode = x));
314
+ this._dateRangeInputSub.subscription = this.dateRangeInput$.subscribe((x) => (this._currentDateRangeInput = x));
315
+ this._inputRangeFormSub.subscription = this.valueInSystemTimezone$.subscribe((x) => {
316
+ setInputFormValue(x);
317
+ });
318
+ if (this.showRangeInput) {
319
+ this._inputRangeFormValueSub.subscription = this.valueInSystemTimezone$
320
+ .pipe(throttleTime(100), // throttle to prevent the value from changing too fast
321
+ switchMap(() => {
322
+ return this.inputRangeForm.valueChanges.pipe(debounceTime(500), filter(() => {
323
+ const startString = this.startDateInputElement.nativeElement?.value;
324
+ let valid = isMonthDaySlashDate(startString);
325
+ if (valid && this._currentSelectionMode !== 'single') {
326
+ const endString = this.endDateInputElement.nativeElement?.value;
327
+ valid = isMonthDaySlashDate(endString);
328
+ }
329
+ return valid; // must be a valid text input
330
+ }), map((x) => x));
331
+ }), distinctUntilChanged(isSameDateRange))
332
+ .subscribe((x) => {
333
+ if (this._currentSelectionMode === 'single') {
334
+ this.setDateRange(x?.start ? { start: x.start } : null, 'input');
335
+ }
336
+ else {
337
+ let rangeToSet = x;
338
+ if (this._currentSelectionMode === 'arbitrary_quick' && this._latestBoundary && x?.start && x?.end) {
339
+ if (!isDateInDateRange(x.start, this._latestBoundary)) {
340
+ // if the end date it outside of the current range (i.e. a range was typed in only to the start date) then set the end to the boundary end
341
+ const boundary = dateRange({ ...this._currentDateRangeInput, date: x.start });
342
+ rangeToSet = { start: x.start, end: boundary.end };
343
+ }
344
+ }
345
+ this.setDateRange(rangeToSet, 'input');
346
+ }
347
+ });
348
+ }
349
+ this._latestBoundarySub.subscription = this.latestBoundary$.subscribe((x) => (this._latestBoundary = x));
350
+ this._dateRangeInput.next(asObservableFromGetter(this.fixedDateRangeField.dateRangeInput));
351
+ this._disableEndSub.subscription = this.endDisabled$.subscribe((disabled) => {
352
+ const end = this.inputRangeForm.get('end');
353
+ if (end) {
354
+ if (disabled) {
355
+ end.disable();
356
+ }
357
+ else {
358
+ end.enable();
359
+ }
360
+ }
361
+ });
362
+ const inputPickerConfig = this.fixedDateRangeField.pickerConfig;
363
+ this._config.next(inputPickerConfig ? asObservableFromGetter(inputPickerConfig) : undefined);
364
+ // Set default timezone if provided.
365
+ if (this.timezone && !this.fixedDateRangeField.fullDayInUTC) {
366
+ this._timezone.next(asObservableFromGetter(this.timezone));
367
+ }
368
+ // Watch for disabled changes so we can propogate them properly.
369
+ this.formControl.registerOnDisabledChange((disabled) => {
370
+ if (disabled) {
371
+ this.inputRangeForm.disable();
372
+ }
373
+ else {
374
+ this.inputRangeForm.enable();
375
+ this.endDisabled$.pipe(first()).subscribe((disabled) => {
376
+ const end = this.inputRangeForm.get('end');
377
+ if (end) {
378
+ if (disabled) {
379
+ end.disable();
380
+ }
381
+ else {
382
+ end.enable();
383
+ }
384
+ }
385
+ });
386
+ }
387
+ });
388
+ if (this.presets != null) {
389
+ this._presets.next(asObservableFromGetter(this.presets));
390
+ }
391
+ else {
392
+ this._presets.next(this.dbxDateTimeFieldConfigService.configurations$);
393
+ }
394
+ this._activeDateSub.subscription = this.calendarFocusDate$.subscribe((x) => {
395
+ this.calendar.activeDate = x;
396
+ });
397
+ }
398
+ ngOnDestroy() {
399
+ super.ngOnDestroy();
400
+ this._sub.destroy();
401
+ this._inputRangeFormSub.destroy();
402
+ this._inputRangeFormValueSub.destroy();
403
+ this._dateRangeInputSub.destroy();
404
+ this._currentSelectionModeSub.destroy();
405
+ this._latestBoundarySub.destroy();
406
+ this._disableEndSub.destroy();
407
+ this._activeDateSub.destroy();
408
+ this._config.complete();
409
+ this._selectionMode.complete();
410
+ this._dateRangeInput.complete();
411
+ this._timezone.complete();
412
+ this._presets.complete();
413
+ this._selectionEvent.complete();
414
+ this._formControlObs.complete();
415
+ }
416
+ selectedChange(date) {
417
+ this.setDateRange(date ? { start: date } : null, 'calendar');
418
+ }
419
+ setDateRange(range, type) {
420
+ this._selectionEvent.next({ type, range });
421
+ }
422
+ _createDateRange(date) {
423
+ return date ? dateRange({ ...this._currentDateRangeInput, date }) : undefined;
424
+ }
425
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxFixedDateRangeFieldComponent, deps: [{ token: i1.DbxDateTimeFieldMenuPresetsService }], target: i0.ɵɵFactoryTarget.Component }); }
426
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DbxFixedDateRangeFieldComponent, selector: "ng-component", providers: [
427
+ {
428
+ provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
429
+ useClass: forwardRef(() => DbxFixedDateRangeFieldSelectionStrategy)
430
+ }
431
+ ], viewQueries: [{ propertyName: "calendar", first: true, predicate: MatCalendar, descendants: true }, { propertyName: "startDateInputElement", first: true, predicate: ["startDateInput"], descendants: true, read: ElementRef }, { propertyName: "endDateInputElement", first: true, predicate: ["endDateInput"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-fixeddaterange-field\">\n <mat-calendar #calendarView [selected]=\"calendarSelection$ | async\" [dateFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" [minDate]=\"min$ | async\" [maxDate]=\"max$ | async\" (selectedChange)=\"selectedChange($event)\"></mat-calendar>\n <mat-form-field class=\"dbx-fixeddaterange-field-input\" appearance=\"fill\">\n <mat-date-range-input *ngIf=\"showRangeInput\" [formGroup]=\"inputRangeForm\">\n <input #startDateInput matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n <input #endDateInput [ngClass]=\"(endDisabled$ | async) ? 'dbx-fixeddaterange-field-input-end' : ''\" [attr.tabindex]=\"(endDisabled$ | async) ? -1 : 0\" matEndDate formControlName=\"end\" placeholder=\"End date\" />\n </mat-date-range-input>\n </mat-form-field>\n <mat-error *ngIf=\"formControl.hasError('required')\">Date range is required</mat-error>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i5.MatCalendar, selector: "mat-calendar", inputs: ["headerComponent", "startAt", "startView", "selected", "minDate", "maxDate", "dateFilter", "dateClass", "comparisonStart", "comparisonEnd", "startDateAccessibleName", "endDateAccessibleName"], outputs: ["selectedChange", "yearSelected", "monthSelected", "viewChanged", "_userSelection", "_userDragDrop"], exportAs: ["matCalendar"] }, { kind: "component", type: i5.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i5.MatStartDate, selector: "input[matStartDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i5.MatEndDate, selector: "input[matEndDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i6.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" }] }); }
432
+ }
433
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxFixedDateRangeFieldComponent, decorators: [{
434
+ type: Component,
435
+ args: [{ providers: [
436
+ {
437
+ provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
438
+ useClass: forwardRef(() => DbxFixedDateRangeFieldSelectionStrategy)
439
+ }
440
+ ], template: "<div class=\"dbx-fixeddaterange-field\">\n <mat-calendar #calendarView [selected]=\"calendarSelection$ | async\" [dateFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" [minDate]=\"min$ | async\" [maxDate]=\"max$ | async\" (selectedChange)=\"selectedChange($event)\"></mat-calendar>\n <mat-form-field class=\"dbx-fixeddaterange-field-input\" appearance=\"fill\">\n <mat-date-range-input *ngIf=\"showRangeInput\" [formGroup]=\"inputRangeForm\">\n <input #startDateInput matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n <input #endDateInput [ngClass]=\"(endDisabled$ | async) ? 'dbx-fixeddaterange-field-input-end' : ''\" [attr.tabindex]=\"(endDisabled$ | async) ? -1 : 0\" matEndDate formControlName=\"end\" placeholder=\"End date\" />\n </mat-date-range-input>\n </mat-form-field>\n <mat-error *ngIf=\"formControl.hasError('required')\">Date range is required</mat-error>\n</div>\n" }]
441
+ }], ctorParameters: function () { return [{ type: i1.DbxDateTimeFieldMenuPresetsService }]; }, propDecorators: { calendar: [{
442
+ type: ViewChild,
443
+ args: [MatCalendar]
444
+ }], startDateInputElement: [{
445
+ type: ViewChild,
446
+ args: ['startDateInput', { read: ElementRef }]
447
+ }], endDateInputElement: [{
448
+ type: ViewChild,
449
+ args: ['endDateInput', { read: ElementRef }]
450
+ }] } });
451
+ export class DbxFixedDateRangeFieldSelectionStrategy {
452
+ constructor(_dateAdapter, dbxFixedDateRangeFieldComponent) {
453
+ this._dateAdapter = _dateAdapter;
454
+ this.dbxFixedDateRangeFieldComponent = dbxFixedDateRangeFieldComponent;
455
+ }
456
+ selectionFinished(date, currentRange, event) {
457
+ // unused
458
+ return currentRange;
459
+ }
460
+ createPreview(activeDate, currentRange, event) {
461
+ const { currentSelectionMode } = this.dbxFixedDateRangeFieldComponent;
462
+ if (activeDate != null && currentSelectionMode !== 'single') {
463
+ const latestBoundary = this.dbxFixedDateRangeFieldComponent.latestBoundary;
464
+ const date = this.dateFromAdapterDate(activeDate);
465
+ if (latestBoundary && (currentSelectionMode === 'normal' || isDateInDateRange(date, latestBoundary))) {
466
+ const exampleDateRange = this._createDateRange(latestBoundary);
467
+ return exampleDateRange;
468
+ }
469
+ }
470
+ return this._createDateRangeWithDate(activeDate);
471
+ }
472
+ _createDateRangeWithDate(input) {
473
+ let dateRange;
474
+ if (input) {
475
+ const date = this.dateFromAdapterDate(input);
476
+ dateRange = this.dbxFixedDateRangeFieldComponent._createDateRange(date);
477
+ }
478
+ return this._createDateRange(dateRange);
479
+ }
480
+ _createDateRange(input) {
481
+ if (input) {
482
+ return new DatePickerDateRange(this.adapterDateFromDate(input.start), this.adapterDateFromDate(input.end));
483
+ }
484
+ else {
485
+ return new DatePickerDateRange(null, null);
486
+ }
487
+ }
488
+ dateFromAdapterDate(input) {
489
+ const day = this._dateAdapter.getDate(input);
490
+ const monthIndex = this._dateAdapter.getMonth(input);
491
+ const year = this._dateAdapter.getYear(input);
492
+ return new Date(year, monthIndex, day);
493
+ }
494
+ adapterDateFromDate(date) {
495
+ const day = date.getDate();
496
+ const monthIndex = date.getMonth();
497
+ const year = date.getFullYear();
498
+ return this._dateAdapter.createDate(year, monthIndex, day);
499
+ }
500
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxFixedDateRangeFieldSelectionStrategy, deps: [{ token: i7.DateAdapter }, { token: DbxFixedDateRangeFieldComponent }], target: i0.ɵɵFactoryTarget.Injectable }); }
501
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxFixedDateRangeFieldSelectionStrategy }); }
502
+ }
503
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DbxFixedDateRangeFieldSelectionStrategy, decorators: [{
504
+ type: Injectable
505
+ }], ctorParameters: function () { return [{ type: i7.DateAdapter }, { type: DbxFixedDateRangeFieldComponent }]; } });
506
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fixeddaterange.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/fixeddaterange.field.component.ts","../../../../../../../../../packages/dbx-form/src/lib/formly/field/value/date/fixeddaterange.field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Maybe, DecisionFunction, Milliseconds, TimezoneString, DateMonth, DayOfMonth, YearNumber, isMonthDaySlashDate, MS_IN_MINUTE } from '@dereekb/util';\nimport { guessCurrentTimezone, DateTimezoneUtcNormalInstance, dateTimeMinuteDecisionFunction, dateTimezoneUtcNormal, DateRangeInput, DateRange, isSameDateDayRange, DateRangeWithDateOrStringValue, DateTimeMinuteConfig, dateRange, isDateInDateRange, clampDateRangeToDateRange, isSameDateRange, isSameDateDay, limitDateTimeInstance } from '@dereekb/date';\nimport { switchMap, shareReplay, map, startWith, distinctUntilChanged, debounceTime, throttleTime, BehaviorSubject, Observable, Subject, of, combineLatestWith, filter, combineLatest, scan, first, timer } from 'rxjs';\nimport { Component, ElementRef, Injectable, OnDestroy, OnInit, ViewChild, forwardRef } from '@angular/core';\nimport { AbstractControl, FormControl, FormGroup } from '@angular/forms';\nimport { FieldType } from '@ngx-formly/material';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { MatDateRangeSelectionStrategy, MAT_DATE_RANGE_SELECTION_STRATEGY, DateRange as DatePickerDateRange, MatCalendar } from '@angular/material/datepicker';\nimport { asObservableFromGetter, filterMaybe, ObservableOrValueGetter, skipFirstMaybe, SubscriptionObject, switchMapMaybeDefault } from '@dereekb/rxjs';\nimport { DbxDateTimeValueMode, dbxDateRangeIsSameDateRangeFieldValue, dbxDateTimeInputValueParseFactory, dbxDateTimeOutputValueFactory } from './date.value';\nimport { DateTimePresetConfiguration } from './datetime';\nimport { DbxDateTimeFieldMenuPresetsService } from './datetime.field.service';\nimport { DateAdapter } from '@angular/material/core';\nimport { isAfter } from 'date-fns';\n\nexport type DbxFixedDateRangeDateRangeInput = Omit<DateRangeInput, 'date'>;\n\nexport type DbxFixedDateRangePickerConfiguration = Omit<DateTimeMinuteConfig, 'date'>;\n\nexport type DbxFixedDateRangeSelectionMode = 'single' | 'normal' | 'arbitrary' | 'arbitrary_quick';\nexport type DbxFixedDateRangePicking = 'start' | 'end';\n\nexport interface DbxFixedDateRangeFieldProps extends FormlyFieldProps {\n  /**\n   * Date range input to build the date range.\n   */\n  dateRangeInput: ObservableOrValueGetter<DbxFixedDateRangeDateRangeInput>;\n\n  /**\n   * Selection mode to use when picking dates on the calendar.\n   */\n  selectionMode?: Maybe<ObservableOrValueGetter<DbxFixedDateRangeSelectionMode>>;\n\n  /**\n   * Value mode for the dates in the output DateRange.\n   *\n   * Defaults to DATE\n   */\n  valueMode?: DbxDateTimeValueMode;\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   * Custom picker configuration\n   */\n  pickerConfig?: ObservableOrValueGetter<DbxFixedDateRangePickerConfiguration>;\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   * 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  /**\n   * Whether or not to show the range input. Defaults to true.\n   */\n  showRangeInput?: boolean;\n}\n\nfunction dbxFixedDateRangeInputValueFactory(mode: DbxDateTimeValueMode, timezoneInstance: Maybe<DateTimezoneUtcNormalInstance>): (input: Maybe<DateRangeWithDateOrStringValue>) => Maybe<DateRange> {\n  const dateInputTransformer = dbxDateTimeInputValueParseFactory(mode, timezoneInstance);\n\n  return (y) => {\n    let result: Maybe<DateRange>;\n\n    if (y) {\n      result = {\n        start: dateInputTransformer(y.start) as Date,\n        end: dateInputTransformer(y.end) as Date\n      };\n    }\n\n    return result;\n  };\n}\n\nfunction dbxFixedDateRangeOutputValueFactory(mode: DbxDateTimeValueMode, timezoneInstance: Maybe<DateTimezoneUtcNormalInstance>): (date: Maybe<DateRange>) => Maybe<DateRangeWithDateOrStringValue> {\n  const dateOutputTransformer = dbxDateTimeOutputValueFactory(mode, timezoneInstance);\n\n  return (y) => {\n    let result: Maybe<DateRange>;\n\n    if (y) {\n      result = {\n        start: dateOutputTransformer(y.start) as Date,\n        end: dateOutputTransformer(y.end) as Date\n      };\n    }\n\n    return result;\n  };\n}\n\nconst TIME_OUTPUT_THROTTLE_TIME: Milliseconds = 10;\n\nexport type FixedDateRangeScanType = 'start' | 'end';\n\nexport interface FixedDateRangeScan {\n  /**\n   * Picked the start or end of the range on the last pick.\n   */\n  lastPickType?: Maybe<FixedDateRangeScanType>;\n  /**\n   * The latest date passed, if applicable.\n   */\n  lastDateRange?: Maybe<Partial<DateRange>>;\n  /**\n   * The generated boundary range.\n   */\n  boundary?: DateRange;\n  /**\n   * New Date Range\n   */\n  range?: DateRange;\n}\n\ntype SelectedDateEventType = 'calendar' | 'input';\n\ninterface SelectedDateEvent {\n  type: SelectedDateEventType;\n  range?: Maybe<Partial<DateRange>>;\n}\n\n@Component({\n  templateUrl: 'fixeddaterange.field.component.html',\n  providers: [\n    {\n      provide: MAT_DATE_RANGE_SELECTION_STRATEGY,\n      useClass: forwardRef(() => DbxFixedDateRangeFieldSelectionStrategy)\n    }\n  ]\n})\nexport class DbxFixedDateRangeFieldComponent extends FieldType<FieldTypeConfig<DbxFixedDateRangeFieldProps>> implements OnInit, OnDestroy {\n  private _sub = new SubscriptionObject();\n\n  private _inputRangeFormSub = new SubscriptionObject();\n  private _inputRangeFormValueSub = new SubscriptionObject();\n\n  private _dateRangeInputSub = new SubscriptionObject();\n  private _currentSelectionModeSub = new SubscriptionObject();\n  private _latestBoundarySub = new SubscriptionObject();\n  private _disableEndSub = new SubscriptionObject();\n  private _activeDateSub = new SubscriptionObject();\n\n  private _currentDateRangeInput: Maybe<DbxFixedDateRangeDateRangeInput> = {};\n  private _currentSelectionMode: DbxFixedDateRangeSelectionMode = 'single';\n  private _latestBoundary: Maybe<DateRange> = null;\n\n  private _config = new BehaviorSubject<Maybe<Observable<DbxFixedDateRangePickerConfiguration>>>(undefined);\n  private _selectionMode = new BehaviorSubject<Maybe<Observable<DbxFixedDateRangeSelectionMode>>>(undefined);\n  private _dateRangeInput = new BehaviorSubject<Maybe<Observable<DbxFixedDateRangeDateRangeInput>>>(undefined);\n\n  private _timezone = new BehaviorSubject<Maybe<Observable<Maybe<TimezoneString>>>>(undefined);\n  private _presets = new BehaviorSubject<Observable<DateTimePresetConfiguration[]>>(of([]));\n\n  private _selectionEvent = new Subject<SelectedDateEvent>();\n  readonly selectedDateRange$: Observable<Maybe<Partial<DateRange>>> = this._selectionEvent.pipe(map((x) => x.range));\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl<Maybe<DateRange>>>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  @ViewChild(MatCalendar)\n  calendar!: MatCalendar<Date>;\n\n  @ViewChild('startDateInput', { read: ElementRef })\n  startDateInputElement!: ElementRef;\n\n  @ViewChild('endDateInput', { read: ElementRef })\n  endDateInputElement!: ElementRef;\n\n  get currentDateRangeInput() {\n    return this._currentDateRangeInput;\n  }\n\n  get currentSelectionMode() {\n    return this._currentSelectionMode;\n  }\n\n  get latestBoundary() {\n    return this._latestBoundary;\n  }\n\n  readonly config$: Observable<DbxFixedDateRangePickerConfiguration> = this._config.pipe(\n    filterMaybe(),\n    switchMap((x) => x),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly limitDateTimeInstance$ = this.config$.pipe(map(limitDateTimeInstance), shareReplay(1));\n\n  readonly selectionMode$: Observable<DbxFixedDateRangeSelectionMode> = this._selectionMode.pipe(\n    switchMapMaybeDefault<DbxFixedDateRangeSelectionMode>('single'),\n    map((x) => x ?? 'single'),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly dateRangeInput$ = this._dateRangeInput.pipe(switchMapMaybeDefault(), shareReplay(1));\n\n  readonly timezone$: Observable<Maybe<TimezoneString>> = this._timezone.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 valueInSystemTimezone$: Observable<Maybe<DateRange>> = this.formControl$.pipe(\n    map((control) => control.valueChanges.pipe(startWith<Maybe<DateRangeWithDateOrStringValue>>(control.value), shareReplay(1))),\n    combineLatestWith(this.timezoneInstance$),\n    switchMap(([x, timezoneInstance]) => {\n      return x.pipe(map(dbxFixedDateRangeInputValueFactory(this.valueMode, timezoneInstance)));\n    }),\n    throttleTime(20, undefined, { leading: false, trailing: true }), // throttle incoming values and timezone changes\n    distinctUntilChanged<Maybe<DateRange>>(isSameDateDayRange),\n    shareReplay(1)\n  );\n\n  dateRangeSelectionForMode(mode: DbxFixedDateRangeSelectionMode) {\n    const result: Observable<Maybe<DateRange>> = combineLatest([this.dateRangeInput$, this.limitDateTimeInstance$]).pipe(\n      switchMap(([dateRangeInput, limitInstance]) => {\n        const hasDateRangeConfiguration = Boolean(dateRangeInput);\n        const minMaxClamp = (dateRange: DateRange) => limitInstance.clampDateRange(dateRange);\n\n        if (mode === 'single') {\n          // only use the start date.\n          return this.selectedDateRange$.pipe(\n            distinctUntilChanged(isSameDateDayRange),\n            map((inputDateRange) => {\n              const date = inputDateRange?.start;\n              return date ? (minMaxClamp(dateRange({ ...dateRangeInput, date } as DateRangeInput)) as DateRange) : null;\n            })\n          );\n        } else {\n          // take the first date, then wait unless the date is outside of the range.\n          return this.selectedDateRange$.pipe(\n            scan((acc: FixedDateRangeScan, nextDateRange: Maybe<Partial<DateRange>>) => {\n              let result: FixedDateRangeScan;\n              let pickType: Maybe<FixedDateRangeScanType> = 'start';\n\n              if (nextDateRange && nextDateRange.start != null) {\n                const { start: startOrNextDate, end } = nextDateRange;\n                const potentialBoundary = dateRange({ ...dateRangeInput, date: startOrNextDate } as DateRangeInput);\n\n                // only comes through when passed by the text inputs\n                if (startOrNextDate && end) {\n                  const range = clampDateRangeToDateRange(nextDateRange, potentialBoundary) as DateRange;\n                  result = {\n                    lastDateRange: nextDateRange,\n                    boundary: range,\n                    range\n                  };\n                } else {\n                  let range: Maybe<DateRange> = undefined;\n                  let boundary: Maybe<DateRange> = potentialBoundary;\n\n                  if (mode === 'normal') {\n                    if (!hasDateRangeConfiguration) {\n                      // if there is no configured range/boundary, then just set the pick type based on the last type\n                      boundary = undefined;\n                      pickType = acc.lastPickType === 'start' ? 'end' : 'start';\n                    } else {\n                      // if the pick is outside the boundary, then consider it a start pick type.\n                      pickType = acc.lastPickType === 'start' && acc.boundary && isDateInDateRange(startOrNextDate, acc.boundary) ? 'end' : 'start';\n                    }\n\n                    // assert the start exists from the previous click, otherwise clear it.\n                    if (pickType === 'end') {\n                      const lastStart = acc.lastDateRange?.start;\n\n                      if (!lastStart || !isAfter(startOrNextDate, lastStart)) {\n                        pickType = 'start';\n                      }\n                    }\n\n                    // react based on how this\n                    switch (pickType) {\n                      case 'end':\n                        // if we're picking the end then set the range.\n                        range = {\n                          start: acc.lastDateRange?.start as Date,\n                          end: startOrNextDate\n                        };\n                        boundary = range;\n                        break;\n                      case 'start':\n                        // retain the boundary as potential boundary, and set our new range from the single date.\n                        range = {\n                          start: startOrNextDate as Date,\n                          end: startOrNextDate as Date\n                        };\n                        break;\n                    }\n                  } else if (acc.boundary && isDateInDateRange(startOrNextDate, acc.boundary)) {\n                    // if in the date range, uses the pick as the last date.\n                    range = {\n                      start: acc.boundary.start,\n                      end: startOrNextDate\n                    };\n\n                    if (mode === 'arbitrary_quick') {\n                      // modify boundary to match range\n                      if (isSameDateRange(acc.range, range) && isSameDateDay(range.end, startOrNextDate)) {\n                        // if we clicked on the end range, then expand the boundary again to the full range.\n                        range = dateRange({ ...dateRangeInput, date: range.start } as DateRangeInput);\n                        boundary = range;\n                      } else {\n                        boundary = range;\n                      }\n                    } else {\n                      // retain same boundary\n                      boundary = acc.boundary;\n                    }\n                  } else if (mode === 'arbitrary_quick') {\n                    range = potentialBoundary;\n                  }\n\n                  result = {\n                    lastDateRange: nextDateRange,\n                    boundary,\n                    range\n                  };\n                }\n              } else {\n                result = {\n                  lastDateRange: nextDateRange\n                };\n              }\n\n              if (result) {\n                result = {\n                  lastPickType: pickType,\n                  lastDateRange: result.lastDateRange,\n                  boundary: result.boundary ? (minMaxClamp(result.boundary) as DateRange) : undefined,\n                  range: result.range ? (minMaxClamp(result.range) as DateRange) : undefined\n                };\n              }\n\n              return result;\n            }, {}),\n            filter((x) => !x.lastDateRange || x.range != null), // pass through null/date clearings or ranges\n            map((x) => x.range ?? null) // return the range\n          );\n        }\n      })\n    );\n\n    return result;\n  }\n\n  readonly fullBoundary$: Observable<Maybe<DateRange>> = this.dateRangeSelectionForMode('single').pipe(shareReplay(1));\n  readonly latestBoundary$: Observable<Maybe<DateRange>> = this.selectionMode$.pipe(\n    switchMap((mode) => {\n      if (mode === 'arbitrary_quick') {\n        // in arbitrary_quick mode, the latest value is the boundary, since we always set the value immediately.\n        return this.valueInSystemTimezone$;\n      } else {\n        return this.fullBoundary$;\n      }\n    })\n  );\n\n  /**\n   * Focuses on the date any time the selection event from the picker occured, otherwise use the system value\n   */\n  readonly calendarFocusDate$: Observable<Date> = this._selectionEvent.pipe(startWith(null)).pipe(\n    switchMap((selectionEvent) => {\n      if (selectionEvent && selectionEvent.type === 'calendar' && selectionEvent.range?.start) {\n        return of(selectionEvent.range.start);\n      } else {\n        return this.fullBoundary$.pipe(\n          first(),\n          map((fullBoundary) => {\n            return fullBoundary?.start ?? selectionEvent?.range?.start;\n          })\n        );\n      }\n    }),\n    filterMaybe(),\n    shareReplay(1)\n  );\n\n  readonly dateRangeSelection$: Observable<Maybe<DateRange>> = this.selectionMode$.pipe(switchMap((mode) => this.dateRangeSelectionForMode(mode)));\n\n  readonly calendarSelection$: Observable<DatePickerDateRange<Date> | null> = this.valueInSystemTimezone$.pipe(\n    map((x) => (x ? new DatePickerDateRange<Date>(x.start, x.end) : null)),\n    shareReplay(1)\n  );\n\n  readonly endDisabled$ = this.selectionMode$.pipe(\n    map((x) => x === 'single'),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly inputRangeForm = new FormGroup({\n    start: new FormControl<Maybe<Date>>(null),\n    end: new FormControl<Maybe<Date>>(null)\n  });\n\n  get fixedDateRangeField(): DbxFixedDateRangeFieldProps {\n    return this.field.props;\n  }\n\n  get selectionMode() {\n    return this.field.props.selectionMode;\n  }\n\n  get valueMode(): DbxDateTimeValueMode {\n    return this.field.props.valueMode ?? DbxDateTimeValueMode.DATE;\n  }\n\n  get description(): Maybe<string> {\n    return this.field.props.description;\n  }\n\n  get timezone() {\n    return this.field.props.timezone;\n  }\n\n  get showTimezone() {\n    return this.field.props.showTimezone ?? true;\n  }\n\n  get presets() {\n    return this.field.props.presets;\n  }\n\n  get showRangeInput() {\n    return this.field.props.showRangeInput ?? true;\n  }\n\n  readonly minMaxRange$ = this.limitDateTimeInstance$.pipe(\n    combineLatestWith(timer(MS_IN_MINUTE)), // refresh every minute\n    map(([x]) => x.dateRange()),\n    distinctUntilChanged(isSameDateDayRange),\n    shareReplay(1)\n  );\n\n  readonly min$ = this.minMaxRange$.pipe(\n    map((x) => x?.start ?? null),\n    distinctUntilChanged(),\n    shareReplay(1)\n  );\n\n  readonly max$ = this.minMaxRange$.pipe(\n    map((x) => x?.end ?? null),\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  constructor(private readonly dbxDateTimeFieldConfigService: DbxDateTimeFieldMenuPresetsService) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    const dateRangeSelection = this.dateRangeSelection$.pipe(shareReplay(1));\n\n    const setInputFormValue = (value: Maybe<DateRange>) => {\n      if (!isSameDateDayRange(value, this.inputRangeForm.value as Partial<DateRange>)) {\n        this.inputRangeForm.setValue({\n          start: value?.start ?? null,\n          end: value?.end ?? null\n        });\n      }\n    };\n\n    this._sub.subscription = this.valueInSystemTimezone$\n      .pipe(\n        combineLatestWith(this.timezoneInstance$.pipe(map((timezoneInstance) => dbxFixedDateRangeOutputValueFactory(this.valueMode, timezoneInstance)))),\n        throttleTime(TIME_OUTPUT_THROTTLE_TIME, undefined, { leading: false, trailing: true }),\n        switchMap(([currentValue, valueFactory]) => {\n          return dateRangeSelection.pipe(\n            skipFirstMaybe(),\n            distinctUntilChanged<Maybe<DateRange>>(isSameDateDayRange),\n            map((x) => [x, currentValue, valueFactory] as [typeof x, typeof currentValue, typeof valueFactory])\n          );\n        })\n      )\n      .subscribe(([rawValue, currentValue, valueFactory]) => {\n        const value = rawValue ? valueFactory(rawValue) : null;\n        const isSameRange = dbxDateRangeIsSameDateRangeFieldValue(value, currentValue);\n\n        if (!isSameRange) {\n          this.formControl.setValue(value);\n          this.formControl.markAsDirty();\n          this.formControl.markAsTouched();\n        } else if (rawValue != null) {\n          // update the input text again\n          setInputFormValue(rawValue);\n        }\n      });\n\n    if (this.selectionMode) {\n      this._selectionMode.next(asObservableFromGetter(this.selectionMode));\n    }\n\n    this._currentSelectionModeSub.subscription = this.selectionMode$.subscribe((x) => (this._currentSelectionMode = x));\n    this._dateRangeInputSub.subscription = this.dateRangeInput$.subscribe((x) => (this._currentDateRangeInput = x));\n\n    this._inputRangeFormSub.subscription = this.valueInSystemTimezone$.subscribe((x: Maybe<DateRange>) => {\n      setInputFormValue(x);\n    });\n\n    if (this.showRangeInput) {\n      this._inputRangeFormValueSub.subscription = this.valueInSystemTimezone$\n        .pipe(\n          throttleTime(100), // throttle to prevent the value from changing too fast\n          switchMap(() => {\n            return this.inputRangeForm.valueChanges.pipe(\n              debounceTime(500),\n              filter(() => {\n                const startString = this.startDateInputElement.nativeElement?.value;\n                let valid = isMonthDaySlashDate(startString);\n\n                if (valid && this._currentSelectionMode !== 'single') {\n                  const endString = this.endDateInputElement.nativeElement?.value;\n                  valid = isMonthDaySlashDate(endString);\n                }\n\n                return valid; // must be a valid text input\n              }),\n              map((x) => x as Maybe<Partial<DateRange>>)\n            );\n          }),\n          distinctUntilChanged(isSameDateRange)\n        )\n        .subscribe((x: Maybe<Partial<DateRange>>) => {\n          if (this._currentSelectionMode === 'single') {\n            this.setDateRange(x?.start ? { start: x.start } : null, 'input');\n          } else {\n            let rangeToSet: Maybe<Partial<DateRange>> = x;\n\n            if (this._currentSelectionMode === 'arbitrary_quick' && this._latestBoundary && x?.start && x?.end) {\n              if (!isDateInDateRange(x.start, this._latestBoundary)) {\n                // if the end date it outside of the current range (i.e. a range was typed in only to the start date) then set the end to the boundary end\n                const boundary = dateRange({ ...this._currentDateRangeInput, date: x.start } as DateRangeInput);\n                rangeToSet = { start: x.start, end: boundary.end };\n              }\n            }\n\n            this.setDateRange(rangeToSet, 'input');\n          }\n        });\n    }\n\n    this._latestBoundarySub.subscription = this.latestBoundary$.subscribe((x) => (this._latestBoundary = x));\n    this._dateRangeInput.next(asObservableFromGetter(this.fixedDateRangeField.dateRangeInput));\n\n    this._disableEndSub.subscription = this.endDisabled$.subscribe((disabled) => {\n      const end = this.inputRangeForm.get('end');\n\n      if (end) {\n        if (disabled) {\n          end.disable();\n        } else {\n          end.enable();\n        }\n      }\n    });\n\n    const inputPickerConfig = this.fixedDateRangeField.pickerConfig;\n    this._config.next(inputPickerConfig ? asObservableFromGetter(inputPickerConfig) : undefined);\n\n    // Set default timezone if provided.\n    if (this.timezone && !this.fixedDateRangeField.fullDayInUTC) {\n      this._timezone.next(asObservableFromGetter(this.timezone));\n    }\n\n    // Watch for disabled changes so we can propogate them properly.\n    this.formControl.registerOnDisabledChange((disabled) => {\n      if (disabled) {\n        this.inputRangeForm.disable();\n      } else {\n        this.inputRangeForm.enable();\n\n        this.endDisabled$.pipe(first()).subscribe((disabled) => {\n          const end = this.inputRangeForm.get('end');\n\n          if (end) {\n            if (disabled) {\n              end.disable();\n            } else {\n              end.enable();\n            }\n          }\n        });\n      }\n    });\n\n    if (this.presets != null) {\n      this._presets.next(asObservableFromGetter(this.presets));\n    } else {\n      this._presets.next(this.dbxDateTimeFieldConfigService.configurations$);\n    }\n\n    this._activeDateSub.subscription = this.calendarFocusDate$.subscribe((x) => {\n      this.calendar.activeDate = x;\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._inputRangeFormSub.destroy();\n    this._inputRangeFormValueSub.destroy();\n    this._dateRangeInputSub.destroy();\n    this._currentSelectionModeSub.destroy();\n    this._latestBoundarySub.destroy();\n    this._disableEndSub.destroy();\n    this._activeDateSub.destroy();\n    this._config.complete();\n    this._selectionMode.complete();\n    this._dateRangeInput.complete();\n    this._timezone.complete();\n    this._presets.complete();\n    this._selectionEvent.complete();\n    this._formControlObs.complete();\n  }\n\n  selectedChange(date: Maybe<Date>): void {\n    this.setDateRange(date ? { start: date } : null, 'calendar');\n  }\n\n  setDateRange(range: Maybe<Partial<DateRange>>, type: SelectedDateEventType) {\n    this._selectionEvent.next({ type, range });\n  }\n\n  _createDateRange(date: Maybe<Date>): Maybe<DateRange> {\n    return date ? dateRange({ ...this._currentDateRangeInput, date } as DateRangeInput) : undefined;\n  }\n}\n\n@Injectable()\nexport class DbxFixedDateRangeFieldSelectionStrategy<D> implements MatDateRangeSelectionStrategy<D> {\n  constructor(private _dateAdapter: DateAdapter<D>, readonly dbxFixedDateRangeFieldComponent: DbxFixedDateRangeFieldComponent) {}\n\n  selectionFinished(date: D | null, currentRange: DatePickerDateRange<D>, event: Event): DatePickerDateRange<D> {\n    // unused\n    return currentRange;\n  }\n\n  createPreview(activeDate: D | null, currentRange: DatePickerDateRange<D>, event: Event): DatePickerDateRange<D> {\n    const { currentSelectionMode } = this.dbxFixedDateRangeFieldComponent;\n    if (activeDate != null && currentSelectionMode !== 'single') {\n      const latestBoundary = this.dbxFixedDateRangeFieldComponent.latestBoundary;\n      const date = this.dateFromAdapterDate(activeDate);\n\n      if (latestBoundary && (currentSelectionMode === 'normal' || isDateInDateRange(date, latestBoundary))) {\n        const exampleDateRange = this._createDateRange(latestBoundary);\n        return exampleDateRange;\n      }\n    }\n\n    return this._createDateRangeWithDate(activeDate);\n  }\n\n  private _createDateRangeWithDate(input: D | null): DatePickerDateRange<D> {\n    let dateRange: Maybe<DateRange>;\n\n    if (input) {\n      const date = this.dateFromAdapterDate(input);\n      dateRange = this.dbxFixedDateRangeFieldComponent._createDateRange(date);\n    }\n\n    return this._createDateRange(dateRange);\n  }\n\n  private _createDateRange(input: Maybe<DateRange>): DatePickerDateRange<D> {\n    if (input) {\n      return new DatePickerDateRange<D>(this.adapterDateFromDate(input.start), this.adapterDateFromDate(input.end));\n    } else {\n      return new DatePickerDateRange<D>(null, null);\n    }\n  }\n\n  dateFromAdapterDate(input: D) {\n    const day: DayOfMonth = this._dateAdapter.getDate(input);\n    const monthIndex: DateMonth = this._dateAdapter.getMonth(input);\n    const year: YearNumber = this._dateAdapter.getYear(input);\n    return new Date(year, monthIndex, day);\n  }\n\n  adapterDateFromDate(date: Date): D {\n    const day: DayOfMonth = date.getDate();\n    const monthIndex: DateMonth = date.getMonth();\n    const year: YearNumber = date.getFullYear();\n\n    return this._dateAdapter.createDate(year, monthIndex, day);\n  }\n}\n","<div class=\"dbx-fixeddaterange-field\">\n  <mat-calendar #calendarView [selected]=\"calendarSelection$ | async\" [dateFilter]=\"(pickerFilter$ | async) || defaultPickerFilter\" [minDate]=\"min$ | async\" [maxDate]=\"max$ | async\" (selectedChange)=\"selectedChange($event)\"></mat-calendar>\n  <mat-form-field class=\"dbx-fixeddaterange-field-input\" appearance=\"fill\">\n    <mat-date-range-input *ngIf=\"showRangeInput\" [formGroup]=\"inputRangeForm\">\n      <input #startDateInput matStartDate formControlName=\"start\" placeholder=\"Start date\" />\n      <input #endDateInput [ngClass]=\"(endDisabled$ | async) ? 'dbx-fixeddaterange-field-input-end' : ''\" [attr.tabindex]=\"(endDisabled$ | async) ? -1 : 0\" matEndDate formControlName=\"end\" placeholder=\"End date\" />\n    </mat-date-range-input>\n  </mat-form-field>\n  <mat-error *ngIf=\"formControl.hasError('required')\">Date range is required</mat-error>\n</div>\n"]}