@elderbyte/ngx-starter 18.12.2 → 18.12.4

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 (320) hide show
  1. package/esm2022/lib/common/data/datasource/patch/deep-partial-patcher.mjs +2 -2
  2. package/esm2022/lib/common/enums/elder-enum-translation.service.mjs +3 -3
  3. package/esm2022/lib/common/forms/elder-form-field-control-base.directive.mjs +3 -3
  4. package/esm2022/lib/common/forms/elder-from-field-base.mjs +3 -3
  5. package/esm2022/lib/common/forms/elder-from-field-customizable-base.mjs +3 -3
  6. package/esm2022/lib/common/forms/elder-from-field-entity-base.mjs +3 -3
  7. package/esm2022/lib/common/forms/elder-from-field-multi-entity-base.mjs +3 -3
  8. package/esm2022/lib/common/forms/form-field-base.component.mjs +3 -3
  9. package/esm2022/lib/common/forms/multi-model-base.component.mjs +3 -3
  10. package/esm2022/lib/common/forms/template-composite-control.mjs +3 -3
  11. package/esm2022/lib/common/forms/value-accessor-base.mjs +3 -3
  12. package/esm2022/lib/common/http/http-client-builder.service.mjs +3 -3
  13. package/esm2022/lib/common/http/http-client-pristine.mjs +3 -3
  14. package/esm2022/lib/common/http/transfer/data-transfer-factory.mjs +3 -3
  15. package/esm2022/lib/common/time/temporal-util.mjs +13 -1
  16. package/esm2022/lib/common/url/elder-router.service.mjs +3 -3
  17. package/esm2022/lib/common/url/elder-url-fragment-params.service.mjs +3 -3
  18. package/esm2022/lib/components/access-denied/elder-access-denied.component.mjs +3 -3
  19. package/esm2022/lib/components/access-denied/elder-access-denied.module.mjs +4 -4
  20. package/esm2022/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +3 -3
  21. package/esm2022/lib/components/auditing/elder-audit.module.mjs +4 -4
  22. package/esm2022/lib/components/badge/elder-badge/elder-badge.component.mjs +9 -9
  23. package/esm2022/lib/components/badge/elder-badge.directive.mjs +3 -3
  24. package/esm2022/lib/components/badge/elder-badge.module.mjs +4 -4
  25. package/esm2022/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -3
  26. package/esm2022/lib/components/button-group/elder-button-group.module.mjs +4 -4
  27. package/esm2022/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +3 -3
  28. package/esm2022/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +3 -3
  29. package/esm2022/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +3 -3
  30. package/esm2022/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -4
  31. package/esm2022/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -3
  32. package/esm2022/lib/components/cards/elder-card/elder-card.component.mjs +18 -18
  33. package/esm2022/lib/components/cards/elder-card/elder-card.module.mjs +4 -4
  34. package/esm2022/lib/components/chips/elder-chip-label.directive.mjs +3 -3
  35. package/esm2022/lib/components/chips/elder-chips.module.mjs +4 -4
  36. package/esm2022/lib/components/connectivity/elder-connectivity.module.mjs +4 -4
  37. package/esm2022/lib/components/connectivity/elder-connectivity.service.mjs +3 -3
  38. package/esm2022/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +3 -3
  39. package/esm2022/lib/components/containers/elder-containers.module.mjs +4 -4
  40. package/esm2022/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -3
  41. package/esm2022/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +3 -3
  42. package/esm2022/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +3 -3
  43. package/esm2022/lib/components/csv/elder-csv.module.mjs +4 -4
  44. package/esm2022/lib/components/currency/elder-currency.module.mjs +4 -4
  45. package/esm2022/lib/components/currency/elder-currency.pipe.mjs +3 -3
  46. package/esm2022/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -4
  47. package/esm2022/lib/components/data-transfer/elder-data-transfer.service.mjs +3 -3
  48. package/esm2022/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -3
  49. package/esm2022/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +3 -3
  50. package/esm2022/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +3 -3
  51. package/esm2022/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +3 -3
  52. package/esm2022/lib/components/data-view/base/elder-data-view-base.mjs +3 -3
  53. package/esm2022/lib/components/data-view/common/composite-sort/composite-sort-dc.directive.mjs +3 -3
  54. package/esm2022/lib/components/data-view/common/composite-sort/elder-composite-sort/elder-composite-sort.component.mjs +3 -3
  55. package/esm2022/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +3 -3
  56. package/esm2022/lib/components/data-view/common/elder-data-common.module.mjs +4 -4
  57. package/esm2022/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +6 -6
  58. package/esm2022/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +3 -3
  59. package/esm2022/lib/components/data-view/common/selection/data-context-selection.directive.mjs +3 -3
  60. package/esm2022/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -3
  61. package/esm2022/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +9 -9
  62. package/esm2022/lib/components/data-view/grid/elder-grid.module.mjs +4 -4
  63. package/esm2022/lib/components/data-view/master-detail/elder-detail-dialog/elder-detail-dialog.component.mjs +3 -3
  64. package/esm2022/lib/components/data-view/master-detail/elder-detail.directive.mjs +3 -3
  65. package/esm2022/lib/components/data-view/master-detail/elder-master-activation.directive.mjs +3 -3
  66. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.component.mjs +3 -3
  67. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.module.mjs +4 -4
  68. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.service.mjs +3 -3
  69. package/esm2022/lib/components/data-view/master-detail/elder-master.directive.mjs +3 -3
  70. package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +3 -3
  71. package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -4
  72. package/esm2022/lib/components/data-view/table/activation/elder-delete-active.directive.mjs +3 -3
  73. package/esm2022/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +3 -3
  74. package/esm2022/lib/components/data-view/table/elder-center-cell.directive.mjs +3 -3
  75. package/esm2022/lib/components/data-view/table/elder-number-cell.directive.mjs +3 -3
  76. package/esm2022/lib/components/data-view/table/elder-paginator-intl.mjs +3 -3
  77. package/esm2022/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +3 -3
  78. package/esm2022/lib/components/data-view/table/elder-table/elder-table.component.mjs +3 -3
  79. package/esm2022/lib/components/data-view/table/elder-table-column.directive.mjs +3 -3
  80. package/esm2022/lib/components/data-view/table/elder-table-extension.directive.mjs +3 -3
  81. package/esm2022/lib/components/data-view/table/elder-table-root.directive.mjs +3 -3
  82. package/esm2022/lib/components/data-view/table/elder-table-row.directive.mjs +3 -3
  83. package/esm2022/lib/components/data-view/table/elder-table-sort.directive.mjs +3 -3
  84. package/esm2022/lib/components/data-view/table/elder-table.module.mjs +4 -4
  85. package/esm2022/lib/components/data-view/table/model/elder-table-model.mjs +3 -3
  86. package/esm2022/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +3 -3
  87. package/esm2022/lib/components/dialogs/elder-dialog.module.mjs +4 -4
  88. package/esm2022/lib/components/dialogs/elder-dialog.service.mjs +3 -3
  89. package/esm2022/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +3 -3
  90. package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +3 -3
  91. package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +3 -3
  92. package/esm2022/lib/components/errors/elder-error.module.mjs +4 -4
  93. package/esm2022/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -3
  94. package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +3 -3
  95. package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -4
  96. package/esm2022/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -3
  97. package/esm2022/lib/components/files/drag-n-drop/elder-drop-zone/elder-drop-zone.component.mjs +3 -3
  98. package/esm2022/lib/components/files/drag-n-drop/global-drag-drop.service.mjs +3 -3
  99. package/esm2022/lib/components/files/elder-file-drop-zone.directive.mjs +3 -3
  100. package/esm2022/lib/components/files/elder-file-select.directive.mjs +3 -3
  101. package/esm2022/lib/components/files/elder-file.module.mjs +4 -4
  102. package/esm2022/lib/components/files/file-select/file-select.component.mjs +3 -3
  103. package/esm2022/lib/components/files/file-upload/file-upload.component.mjs +3 -3
  104. package/esm2022/lib/components/forms/clipboard/elder-clipboard.service.mjs +3 -3
  105. package/esm2022/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +3 -3
  106. package/esm2022/lib/components/forms/directives/elder-clipboard-put.directive.mjs +3 -3
  107. package/esm2022/lib/components/forms/directives/elder-delayed-focus.directive.mjs +3 -3
  108. package/esm2022/lib/components/forms/directives/elder-form-field-dense.directive.mjs +3 -3
  109. package/esm2022/lib/components/forms/directives/elder-form-field-label.directive.mjs +3 -3
  110. package/esm2022/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +3 -3
  111. package/esm2022/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +3 -3
  112. package/esm2022/lib/components/forms/directives/elder-forms-directives.module.mjs +4 -4
  113. package/esm2022/lib/components/forms/directives/elder-initial-value.directive.mjs +3 -3
  114. package/esm2022/lib/components/forms/directives/elder-input-pattern.directive.mjs +3 -3
  115. package/esm2022/lib/components/forms/directives/elder-key-event.directive.mjs +3 -3
  116. package/esm2022/lib/components/forms/directives/elder-next-focusable.directive.mjs +3 -3
  117. package/esm2022/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +3 -3
  118. package/esm2022/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +3 -3
  119. package/esm2022/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +3 -3
  120. package/esm2022/lib/components/forms/directives/elder-touched.directive.mjs +3 -3
  121. package/esm2022/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +3 -3
  122. package/esm2022/lib/components/forms/directives/validation/elder-validation-error.directive.mjs +3 -3
  123. package/esm2022/lib/components/forms/directives/validation/strategies/common-validation-message-strategy.mjs +3 -3
  124. package/esm2022/lib/components/forms/directives/validation/strategies/dynamic-validation-message-strategy.mjs +3 -3
  125. package/esm2022/lib/components/forms/directives/validation/validation-message-renderer.service.mjs +3 -3
  126. package/esm2022/lib/components/forms/directives/validation/validators/elder-max.validator.mjs +3 -3
  127. package/esm2022/lib/components/forms/directives/validation/validators/elder-min.validator.mjs +3 -3
  128. package/esm2022/lib/components/forms/directives/validation/validators/elder-multiple-of.validator.mjs +3 -3
  129. package/esm2022/lib/components/forms/directives/validation/validators/elder-required-ignore-zero.validator.mjs +3 -3
  130. package/esm2022/lib/components/forms/elder-forms.module.mjs +4 -4
  131. package/esm2022/lib/components/forms/search/domain/context/search-context.service.mjs +3 -3
  132. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.directive.mjs +3 -3
  133. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.service.mjs +3 -3
  134. package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +3 -3
  135. package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +3 -3
  136. package/esm2022/lib/components/forms/search/elder-search.module.mjs +4 -4
  137. package/esm2022/lib/components/forms/search/search-box/elder-search-box.component.mjs +3 -3
  138. package/esm2022/lib/components/forms/search/search-box/elder-search-panel.component.mjs +3 -3
  139. package/esm2022/lib/components/global-search/elder-global-search.component.mjs +3 -3
  140. package/esm2022/lib/components/global-search/elder-global-search.module.mjs +4 -4
  141. package/esm2022/lib/components/global-search/elder-global-search.service.mjs +3 -3
  142. package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -3
  143. package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -4
  144. package/esm2022/lib/components/headers/elder-header/elder-header.component.mjs +3 -3
  145. package/esm2022/lib/components/headers/elder-header.module.mjs +4 -4
  146. package/esm2022/lib/components/http-support/elder-http-client.service.mjs +3 -3
  147. package/esm2022/lib/components/i18n/entities/elder-i18n-entities.module.mjs +4 -4
  148. package/esm2022/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +3 -3
  149. package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +3 -3
  150. package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +3 -3
  151. package/esm2022/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +3 -3
  152. package/esm2022/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +3 -3
  153. package/esm2022/lib/components/i18n/entities/elder-localized-texts.directive.mjs +3 -3
  154. package/esm2022/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +3 -3
  155. package/esm2022/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +3 -3
  156. package/esm2022/lib/components/i18n/entities/picker/localisation-picker.service.mjs +3 -3
  157. package/esm2022/lib/components/i18n/language/elder-language-interceptor.mjs +3 -3
  158. package/esm2022/lib/components/i18n/language/elder-language.module.mjs +4 -4
  159. package/esm2022/lib/components/i18n/language/elder-language.service.mjs +3 -3
  160. package/esm2022/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +3 -3
  161. package/esm2022/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +4 -4
  162. package/esm2022/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +3 -3
  163. package/esm2022/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +3 -3
  164. package/esm2022/lib/components/iframes/elder-iframe.module.mjs +4 -4
  165. package/esm2022/lib/components/iframes/iframe-close.directive.mjs +3 -3
  166. package/esm2022/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +3 -3
  167. package/esm2022/lib/components/iframes/iframe-host/iframe-host.component.mjs +3 -3
  168. package/esm2022/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +3 -3
  169. package/esm2022/lib/components/iframes/iframe.service.mjs +3 -3
  170. package/esm2022/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +3 -3
  171. package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +3 -3
  172. package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +4 -4
  173. package/esm2022/lib/components/input/autocomplete/elder-autocomplete/elder-suggestion-panel.component.mjs +3 -3
  174. package/esm2022/lib/components/input/autocomplete/elder-autocomplete-many.directive.mjs +3 -3
  175. package/esm2022/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +3 -3
  176. package/esm2022/lib/components/input/autocomplete/elder-autocomplete.module.mjs +4 -4
  177. package/esm2022/lib/components/labels/elder-labels.module.mjs +4 -4
  178. package/esm2022/lib/components/labels/labels-input/labels-input.component.mjs +3 -3
  179. package/esm2022/lib/components/measures/dimensions/dimensions-input/elder-dimensions-input.component.mjs +3 -3
  180. package/esm2022/lib/components/measures/dimensions/validation/elder-required-dimensions.validator.mjs +3 -3
  181. package/esm2022/lib/components/measures/directives/elder-unit-select.directive.mjs +3 -3
  182. package/esm2022/lib/components/measures/elder-measures.module.mjs +8 -8
  183. package/esm2022/lib/components/measures/elder-quantity-transform.pipe.mjs +3 -3
  184. package/esm2022/lib/components/measures/elder-quantity.pipe.mjs +3 -3
  185. package/esm2022/lib/components/measures/elder-unit.service.mjs +3 -3
  186. package/esm2022/lib/components/measures/quantity-input/quantity-form-field/elder-quantity-form-field.component.mjs +3 -3
  187. package/esm2022/lib/components/measures/quantity-input/quantity-input-control/elder-quantity-input-control.component.mjs +3 -3
  188. package/esm2022/lib/components/measures/quantity-input/validation/elder-quantity-range.validator.mjs +3 -3
  189. package/esm2022/lib/components/measures/quantity-input/validation/elder-required-quantity.validator.mjs +3 -3
  190. package/esm2022/lib/components/measures/util/elder-quantity.service.mjs +3 -3
  191. package/esm2022/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +3 -3
  192. package/esm2022/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -4
  193. package/esm2022/lib/components/navigation/nav/elder-nav.module.mjs +4 -4
  194. package/esm2022/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -3
  195. package/esm2022/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +3 -3
  196. package/esm2022/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -3
  197. package/esm2022/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +3 -3
  198. package/esm2022/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -4
  199. package/esm2022/lib/components/navigation/toolbar/elder-toolbar.service.mjs +3 -3
  200. package/esm2022/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +3 -3
  201. package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +3 -3
  202. package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +3 -3
  203. package/esm2022/lib/components/overlays/elder-overlay-origin.directive.mjs +3 -3
  204. package/esm2022/lib/components/overlays/elder-overlay-ref.mjs +3 -3
  205. package/esm2022/lib/components/overlays/elder-overlay-trigger.directive.mjs +3 -3
  206. package/esm2022/lib/components/overlays/elder-overlay.component.mjs +3 -3
  207. package/esm2022/lib/components/overlays/elder-overlay.module.mjs +4 -4
  208. package/esm2022/lib/components/page/exit-guard/page-exit-guard.module.mjs +4 -4
  209. package/esm2022/lib/components/page/exit-guard/page-exit-guard.service.mjs +3 -3
  210. package/esm2022/lib/components/page/exit-guard/page-exit-lock/page-exit-lock.component.mjs +3 -3
  211. package/esm2022/lib/components/page/exit-guard/page-exit-lock-indicator/page-exit-lock-indicator.component.mjs +3 -3
  212. package/esm2022/lib/components/page/exit-guard/page-exit-lock-overview/page-exit-lock-overview.component.mjs +3 -3
  213. package/esm2022/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -3
  214. package/esm2022/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +3 -3
  215. package/esm2022/lib/components/panels/elder-panel.module.mjs +4 -4
  216. package/esm2022/lib/components/panels/flat/elder-panel.component.mjs +3 -3
  217. package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel-trigger.directive.mjs +3 -3
  218. package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel.component.mjs +9 -9
  219. package/esm2022/lib/components/scrollbar/elder-scrollbar.directive.mjs +3 -3
  220. package/esm2022/lib/components/scrollbar/elder-scrollbar.module.mjs +4 -4
  221. package/esm2022/lib/components/select/auto/elder-auto-select-first.directive.mjs +3 -3
  222. package/esm2022/lib/components/select/auto/elder-auto-select-first.service.mjs +3 -3
  223. package/esm2022/lib/components/select/auto/elder-auto-select-suggest-first.directive.mjs +3 -3
  224. package/esm2022/lib/components/select/elder-select-base.mjs +3 -3
  225. package/esm2022/lib/components/select/elder-select-chip.directive.mjs +9 -9
  226. package/esm2022/lib/components/select/elder-select-on-tab.directive.mjs +3 -3
  227. package/esm2022/lib/components/select/elder-select-value.directive.mjs +3 -3
  228. package/esm2022/lib/components/select/elder-select.module.mjs +4 -4
  229. package/esm2022/lib/components/select/filter/elder-chips-include-exclude.directive.mjs +3 -3
  230. package/esm2022/lib/components/select/filter/elder-filter-chip-template/elder-filter-chip-template.component.mjs +3 -3
  231. package/esm2022/lib/components/select/multi/elder-chip-select-option/elder-select-option.component.mjs +3 -3
  232. package/esm2022/lib/components/select/multi/elder-multi-select-base.mjs +3 -3
  233. package/esm2022/lib/components/select/multi/elder-multi-select-chip-options/elder-multi-select-chip-options.component.mjs +3 -3
  234. package/esm2022/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +3 -3
  235. package/esm2022/lib/components/select/multi/elder-multi-select-form-field.mjs +3 -3
  236. package/esm2022/lib/components/select/multi/elder-mutli-select-all-directive.mjs +3 -3
  237. package/esm2022/lib/components/select/multi/elder-search-include-exclude.directive.mjs +3 -3
  238. package/esm2022/lib/components/select/popup/selection-model-popup-trigger-adapter.directive.mjs +3 -3
  239. package/esm2022/lib/components/select/popup/selection-model-popup.directive.mjs +3 -3
  240. package/esm2022/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +3 -3
  241. package/esm2022/lib/components/select/single/elder-clear-select.directive.mjs +3 -3
  242. package/esm2022/lib/components/select/single/elder-select/elder-select.component.mjs +3 -3
  243. package/esm2022/lib/components/select/single/elder-select-form-field.mjs +3 -3
  244. package/esm2022/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +3 -3
  245. package/esm2022/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -4
  246. package/esm2022/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +3 -3
  247. package/esm2022/lib/components/shell/drawers/elder-router-outlet.service.mjs +3 -3
  248. package/esm2022/lib/components/shell/elder-shell-slot.directive.mjs +3 -3
  249. package/esm2022/lib/components/shell/elder-shell.module.mjs +4 -4
  250. package/esm2022/lib/components/shell/elder-shell.service.mjs +3 -3
  251. package/esm2022/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +3 -3
  252. package/esm2022/lib/components/shell/shell/elder-shell.component.mjs +12 -12
  253. package/esm2022/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +3 -3
  254. package/esm2022/lib/components/tabs/elder-tab/elder-tab.directive.mjs +3 -3
  255. package/esm2022/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +3 -3
  256. package/esm2022/lib/components/tabs/elder-tab.module.mjs +4 -4
  257. package/esm2022/lib/components/theme/elder-theme-applier.directive.mjs +3 -3
  258. package/esm2022/lib/components/theme/elder-theme-preference.service.mjs +3 -3
  259. package/esm2022/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +3 -3
  260. package/esm2022/lib/components/theme/elder-theme.directive.mjs +3 -3
  261. package/esm2022/lib/components/theme/elder-theme.module.mjs +4 -4
  262. package/esm2022/lib/components/theme/elder-theme.service.mjs +3 -3
  263. package/esm2022/lib/components/time/date-adapters/custom-date-adapter.mjs +3 -3
  264. package/esm2022/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +3 -3
  265. package/esm2022/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +3 -3
  266. package/esm2022/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +3 -3
  267. package/esm2022/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +3 -3
  268. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.mjs +7 -12
  269. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.mjs +83 -81
  270. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.component.mjs +82 -99
  271. package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.mjs +284 -0
  272. package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model.mjs +445 -0
  273. package/esm2022/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.mjs +37 -0
  274. package/esm2022/lib/components/time/elder-interval-picker/model/plain-temporal-duration-message-renderer.mjs +25 -0
  275. package/esm2022/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +3 -3
  276. package/esm2022/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +3 -3
  277. package/esm2022/lib/components/time/elder-time.module.mjs +4 -4
  278. package/esm2022/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +3 -3
  279. package/esm2022/lib/components/time/pipes/to-iso-date-string.pipe.mjs +3 -3
  280. package/esm2022/lib/components/toasts/elder-toast.module.mjs +4 -4
  281. package/esm2022/lib/components/toasts/elder-toast.service.mjs +3 -3
  282. package/esm2022/lib/components/toasts/standard-toast/standard-toast.component.mjs +3 -3
  283. package/esm2022/lib/components/url-fragment/elder-url-fragment.module.mjs +4 -4
  284. package/esm2022/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +3 -3
  285. package/esm2022/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +3 -3
  286. package/esm2022/lib/components/viewers/elder-viewers.module.mjs +4 -4
  287. package/esm2022/lib/features/event-source/fetch/reactive-fetch-event-source.service.mjs +3 -3
  288. package/esm2022/lib/features/event-source/standard/elder-event-source.service.mjs +3 -3
  289. package/esm2022/lib/features/kafent/access-token-provider.mjs +3 -3
  290. package/esm2022/lib/features/kafent/kafent-config.mjs +3 -3
  291. package/esm2022/lib/features/kafent/kafent-event-stream.mjs +3 -3
  292. package/esm2022/lib/features/kafent/kafent-event.service.mjs +3 -3
  293. package/esm2022/lib/features/kafent/kafent.module.mjs +4 -4
  294. package/esm2022/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +3 -3
  295. package/esm2022/lib/pipes/bytes.pipe.mjs +3 -3
  296. package/esm2022/lib/pipes/elder-pipes.module.mjs +10 -10
  297. package/esm2022/lib/pipes/elder-repeat.pipe.mjs +3 -3
  298. package/esm2022/lib/pipes/elder-round.pipe.mjs +3 -3
  299. package/esm2022/lib/pipes/elder-safe-url.pipe.mjs +3 -3
  300. package/esm2022/lib/pipes/elder-truncate.pipe.mjs +3 -3
  301. package/esm2022/lib/pipes/iso-duration.pipe.mjs +3 -3
  302. package/esm2022/lib/pipes/iso-interval-parse.pipe.mjs +3 -3
  303. package/esm2022/lib/pipes/iso-interval.pipe.mjs +3 -3
  304. package/esm2022/lib/pipes/time-ago.pipe.mjs +3 -3
  305. package/esm2022/lib/pipes/time-duration.pipe.mjs +3 -3
  306. package/esm2022/lib/pipes/weight.pipe.mjs +3 -3
  307. package/fesm2022/elderbyte-ngx-starter.mjs +1644 -1576
  308. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  309. package/lib/common/time/temporal-util.d.ts +2 -0
  310. package/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.d.ts +3 -6
  311. package/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +25 -18
  312. package/lib/components/time/elder-interval-picker/elder-interval-picker.component.d.ts +19 -25
  313. package/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.d.ts +77 -0
  314. package/lib/components/time/elder-interval-picker/model/interval-picker-model.d.ts +113 -0
  315. package/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.d.ts +7 -0
  316. package/lib/components/time/elder-interval-picker/model/plain-temporal-duration-message-renderer.d.ts +4 -0
  317. package/package.json +1 -1
  318. package/src/assets/i18n/fr.json +123 -0
  319. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.service.mjs +0 -708
  320. package/lib/components/time/elder-interval-picker/elder-interval-picker.service.d.ts +0 -132
@@ -1,5 +1,5 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, effect, ElementRef, EventEmitter, input, Input, Output, ViewChild, } from '@angular/core';
2
+ import { booleanAttribute, ChangeDetectionStrategy, Component, effect, ElementRef, EventEmitter, Input, input, Output, ViewChild, } from '@angular/core';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { MatButtonModule } from '@angular/material/button';
5
5
  import { DateAdapter } from '@angular/material/core';
@@ -12,11 +12,11 @@ import { MatTooltip } from '@angular/material/tooltip';
12
12
  import { LoggerFactory } from '@elderbyte/ts-logger';
13
13
  import { TranslateModule } from '@ngx-translate/core';
14
14
  import { TemporalUtil } from '../../../common/time/temporal-util';
15
- import { CustomDateAdapter } from '../../../components/time/date-adapters/custom-date-adapter';
16
- import { ElderLocalDateInputComponent } from '../../../components/time/elder-local-date-input/elder-local-date-input.component';
17
- import { ElderIntervalPickerService } from './elder-interval-picker.service';
15
+ import { CustomDateAdapter } from '../date-adapters/custom-date-adapter';
16
+ import { ElderLocalDateInputComponent } from '../elder-local-date-input/elder-local-date-input.component';
17
+ import { IntervalPickerModel } from './model/interval-picker-model';
18
18
  import * as i0 from "@angular/core";
19
- import * as i1 from "./elder-interval-picker.service";
19
+ import * as i1 from "./model/interval-picker-model";
20
20
  import * as i2 from "@angular/material/datepicker";
21
21
  import * as i3 from "@angular/material/form-field";
22
22
  import * as i4 from "@angular/material/input";
@@ -27,87 +27,57 @@ import * as i8 from "@angular/material/button";
27
27
  import * as i9 from "@ngx-translate/core";
28
28
  import * as i10 from "@angular/material/menu";
29
29
  export class ElderIntervalPickerComponent {
30
+ set interval(value) {
31
+ this.model.setInterval(value);
32
+ }
33
+ set anchorDateTime(value) {
34
+ this.model.setAnchorDateTime(value);
35
+ }
30
36
  /***************************************************************************
31
37
  * *
32
38
  * Constructor *
33
39
  * *
34
40
  **************************************************************************/
35
- constructor(svc) {
36
- this.svc = svc;
41
+ constructor(model) {
42
+ this.model = model;
37
43
  /***************************************************************************
38
44
  * *
39
45
  * Fields *
40
46
  * *
41
47
  **************************************************************************/
42
48
  this.log = LoggerFactory.getLogger(this.constructor.name);
49
+ this.emitOnChange = input(true, { transform: (v) => booleanAttribute(v) });
50
+ this.intervalInputMode = input('date-range');
51
+ this.showAnchor = input(false, { transform: (v) => booleanAttribute(v) });
52
+ this.anchorReadOnly = input(false, { transform: (v) => booleanAttribute(v) });
53
+ this.showResultText = input(true, { transform: (v) => booleanAttribute(v) });
54
+ this.showHelpText = input(false, { transform: (v) => booleanAttribute(v) });
55
+ this.lastExcludesToday = input(false, { transform: (v) => booleanAttribute(v) });
56
+ this.dateChange = new EventEmitter();
43
57
  this.calendarAnchorDateCssClassFn = (cellDate, view) => {
44
58
  return this.calendarAnchorDateCssClassFnBody(cellDate, view);
45
59
  };
46
- this.isEmittingOnChange = true;
47
- this.intervalInputMode = 'date-range';
48
- this.showAnchor = false;
49
- this.isAnchorReadOnly = false;
50
- this.isResultTextVisible = true;
51
- this.isHelpTextsVisible = false;
52
- this.isSelectLastModeExcludingToday = false;
53
- this.dateChange = new EventEmitter();
54
- this.inputInterval = input(null);
55
- this.inputAnchorDateTime = input(null);
56
- /***************************************************************************
57
- * *
58
- * Effects *
59
- * *
60
- **************************************************************************/
61
- this._updateMatCalendarElAnchorCssClassEffect = effect(() => {
62
- const anchorDate = this.svc.anchorDate();
63
- if (anchorDate) {
64
- this.calendarStart.updateTodaysDate();
65
- this.calendarEnd.updateTodaysDate();
60
+ this.model.setupEventEmitter(this.dateChange);
61
+ effect(() => {
62
+ if (this.model.anchorDate()) {
63
+ this.updateMatCalendarTodayDate();
66
64
  }
67
65
  });
68
- this._updateMatCalendarElSelectionEffect = effect(() => {
69
- const startDate = this.svc.startDate();
70
- const endDate = this.svc.endDate();
71
- if (!this.calendarStart || !this.calendarEnd) {
72
- return;
73
- }
74
- if (!startDate && !endDate) {
75
- return;
76
- }
77
- const calendar1 = this.calendarStart;
78
- const calendar2 = this.calendarEnd;
79
- setTimeout(() => {
80
- // timeout is needed to run run calendar update last, otherwise there are issues
81
- if (startDate) {
82
- const startJsDate = TemporalUtil.getJSDateFromPlainDateTime(startDate);
83
- calendar1.activeDate = startJsDate;
84
- }
85
- if (endDate) {
86
- const endJsDate = TemporalUtil.getJSDateFromPlainDateTime(endDate);
87
- calendar2.activeDate = endJsDate;
88
- }
89
- }, 0);
66
+ effect(() => {
67
+ this.updateMatCalendarActiveDate(this.model.startDate(), this.model.endDate());
90
68
  });
91
- this.svc.setupInputInterval(this.inputInterval);
92
- this.svc.setupInputAnchorDateTime(this.inputAnchorDateTime);
93
- this.svc.setupEventEmitter(this.dateChange);
94
69
  }
95
70
  /***************************************************************************
96
71
  * *
97
72
  * Life Cycle *
98
73
  * *
99
74
  **************************************************************************/
100
- ngOnInit() {
101
- if (this.inputInterval) {
102
- this.svc.pullInputInterval();
103
- }
104
- if (this.inputAnchorDateTime()) {
105
- this.svc.pullInputAnchorDateTime();
106
- }
107
- }
108
75
  ngAfterViewInit() {
109
- this.svc.isEmittingOnChange.set(this.isEmittingOnChange);
76
+ this.model.isEmittingOnChange.set(this.emitOnChange());
110
77
  this.setupDateInputCalendarFocusPrevention();
78
+ setTimeout(() => {
79
+ this.model.setInitialized();
80
+ }, 0);
111
81
  }
112
82
  ngOnDestroy() {
113
83
  this.removeEventListeners();
@@ -140,36 +110,36 @@ export class ElderIntervalPickerComponent {
140
110
  nativeElementEnd.addEventListener('focus', this.calendarElFocusEventHandler, true);
141
111
  }
142
112
  clearStartDateTime() {
143
- this.svc.clearStartDateTime();
144
- this.svc.resetCalendarMode();
145
- if (this.isEmittingOnChange) {
146
- this.svc.emitMainDates();
113
+ this.model.clearStartDateTime();
114
+ this.model.resetCalendarMode();
115
+ if (this.emitOnChange()) {
116
+ this.model.emitMainDates();
147
117
  }
148
118
  }
149
119
  clearEndDateTime() {
150
- this.svc.clearEndDateTime();
151
- this.svc.resetCalendarMode();
152
- if (this.isEmittingOnChange) {
153
- this.svc.emitMainDates();
120
+ this.model.clearEndDateTime();
121
+ this.model.resetCalendarMode();
122
+ if (this.emitOnChange()) {
123
+ this.model.emitMainDates();
154
124
  }
155
125
  }
156
126
  clearStartAndEndDateTimes() {
157
- this.svc.clearStartDateTime();
158
- this.svc.clearEndDateTime();
159
- this.svc.resetCalendarMode();
160
- if (this.isEmittingOnChange) {
161
- this.svc.emitMainDates();
127
+ this.model.clearStartDateTime();
128
+ this.model.clearEndDateTime();
129
+ this.model.resetCalendarMode();
130
+ if (this.emitOnChange()) {
131
+ this.model.emitMainDates();
162
132
  }
163
133
  }
164
134
  handleStartCalendarChange(changedDate) {
165
- this.svc.calendarMode.set('days');
135
+ this.model.calendarMode.set('days');
166
136
  const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate);
167
- this.svc.startDate.set(newPlainDate);
137
+ this.model.setStartDate(newPlainDate);
168
138
  }
169
139
  handleEndCalendarChange(changedDate) {
170
- this.svc.calendarMode.set('days');
140
+ this.model.calendarMode.set('days');
171
141
  const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate);
172
- this.svc.endDate.set(newPlainDate);
142
+ this.model.setEndDate(newPlainDate);
173
143
  }
174
144
  /***************************************************************************
175
145
  * *
@@ -189,7 +159,7 @@ export class ElderIntervalPickerComponent {
189
159
  nativeElementEnd.removeEventListener('focus', this.calendarElFocusEventHandler, true);
190
160
  }
191
161
  calendarAnchorDateCssClassFnBody(cellDate, view) {
192
- const anchorDate = this.svc.fixedAnchorDate();
162
+ const anchorDate = this.model.fixedAnchorDate();
193
163
  if (!anchorDate) {
194
164
  return '';
195
165
  }
@@ -204,10 +174,33 @@ export class ElderIntervalPickerComponent {
204
174
  }
205
175
  return '';
206
176
  }
207
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ElderIntervalPickerComponent, deps: [{ token: i1.ElderIntervalPickerService }], target: i0.ɵɵFactoryTarget.Component }); }
208
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ElderIntervalPickerComponent, isStandalone: true, selector: "elder-interval-picker", inputs: { isEmittingOnChange: { classPropertyName: "isEmittingOnChange", publicName: "isEmittingOnChange", isSignal: false, isRequired: false, transformFunction: null }, intervalInputMode: { classPropertyName: "intervalInputMode", publicName: "intervalInputMode", isSignal: false, isRequired: false, transformFunction: null }, showAnchor: { classPropertyName: "showAnchor", publicName: "showAnchor", isSignal: false, isRequired: false, transformFunction: null }, isAnchorReadOnly: { classPropertyName: "isAnchorReadOnly", publicName: "isAnchorReadOnly", isSignal: false, isRequired: false, transformFunction: null }, isResultTextVisible: { classPropertyName: "isResultTextVisible", publicName: "isResultTextVisible", isSignal: false, isRequired: false, transformFunction: null }, isHelpTextsVisible: { classPropertyName: "isHelpTextsVisible", publicName: "isHelpTextsVisible", isSignal: false, isRequired: false, transformFunction: null }, isSelectLastModeExcludingToday: { classPropertyName: "isSelectLastModeExcludingToday", publicName: "isSelectLastModeExcludingToday", isSignal: false, isRequired: false, transformFunction: null }, inputInterval: { classPropertyName: "inputInterval", publicName: "inputInterval", isSignal: true, isRequired: false, transformFunction: null }, inputAnchorDateTime: { classPropertyName: "inputAnchorDateTime", publicName: "inputAnchorDateTime", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { dateChange: "dateChange" }, providers: [ElderIntervalPickerService, { provide: DateAdapter, useClass: CustomDateAdapter }], viewQueries: [{ propertyName: "calendarStart", first: true, predicate: ["rangeCalendarStart"], descendants: true }, { propertyName: "calendarEnd", first: true, predicate: ["rangeCalendarEnd"], descendants: true }, { propertyName: "calendarStartElRef", first: true, predicate: ["rangeCalendarStart"], descendants: true, read: ElementRef }, { propertyName: "calendarEndElRef", first: true, predicate: ["rangeCalendarEnd"], descendants: true, read: ElementRef }, { propertyName: "startDateInput", first: true, predicate: ["startDateInput"], descendants: true }, { propertyName: "endDateInput", first: true, predicate: ["endDateInput"], descendants: true }], ngImport: i0, template: "<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n <div class=\"layout-col gap-md pt-xs\">\n <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n </div>\n <div class=\"layout-col\">\n <!-- smart shift -->\n <div class=\"layout-row place-around-center\">\n <button mat-icon-button (click)=\"svc.smartShift(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ svc.viewIntervalMessage() }}</span>\n <button mat-icon-button (click)=\"svc.smartShift(1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- calendars and input controls -->\n <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n </div>\n <div class=\"pt-xs\" style=\"width: 25%\">\n <div class=\"layout-col gap-lg\">\n <div class=\"layout-col gap-xs place-start-start\">\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n }\n <!-- select current -->\n <button mat-button (click)=\"svc.selectCurrentWeek()\">\n {{ 'intervalPicker.currentPeriod.week' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentMonth()\">\n {{ 'intervalPicker.currentPeriod.month' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentQuarter()\">\n {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentYear()\">\n {{ 'intervalPicker.currentPeriod.year' | translate }}\n </button>\n </div>\n <div class=\"fixed-shifts-container\">\n <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n <div>\n @if (showAnchor) {\n <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n }\n </div>\n @if (isResultTextVisible) {\n <!-- result interval -->\n <div class=\"layout-col place-center-center\">\n <div class=\"date-interval mat-caption pt-xs\">\n @if (svc.startDateTimeAsJSDate()) {\n {{ svc.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.startDateNotSet' | translate }}\n }\n <span> - </span>\n @if (svc.endDateTimeAsJSDate()) {\n {{ svc.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.endDateNotSet' | translate }}\n }\n </div>\n <div>\n <span class=\"mat-caption\">{{ svc.deltaHumanReadable() || '&nbsp;' }}</span>\n </div>\n </div>\n }\n <div class=\"layout-row gap-lg\">\n <button\n mat-raised-button\n color=\"primary\"\n (click)=\"clearStartAndEndDateTimes()\"\n [disabled]=\"svc.isStartAndEndDatesEmpty()\"\n >\n {{ 'intervalPicker.clear' | translate }}\n </button>\n\n @if (!this.isEmittingOnChange) {\n <button color=\"primary\" mat-raised-button (click)=\"svc.emitMainDates()\">\n {{ 'actions.ok' | translate }}\n </button>\n }\n </div>\n </div>\n</div>\n\n<ng-template #intervalSelector>\n <div class=\"layout-col\">\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n }\n <div class=\"layout-row select-buttons-container gap-sm\">\n <div class=\"layout-col gap-xs place-start-stretch\">\n <button mat-button (click)=\"svc.selectCurrentDay()\">\n @if (svc.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.anchorDay' | translate }}\n } @else {\n {{ 'intervalPicker.today' | translate }}\n }\n </button>\n <button mat-button (click)=\"svc.selectYesterday()\">\n @if (svc.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n } @else {\n {{ 'intervalPicker.yesterday' | translate }}\n }\n </button>\n @if (isSelectLastModeExcludingToday) {\n <button mat-button (click)=\"svc.selectLastSevenDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastThirtyDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n } @else {\n <button mat-button (click)=\"svc.selectLastSevenDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastThirtyDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n }\n @if (intervalInputMode === 'date-time-range') {\n <div class=\"pt-sm\"></div>\n <button mat-button (click)=\"svc.selectLastFiveMinutes()\">\n {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastHour()\">\n {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLast24Hours()\">\n {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n </button>\n }\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n <mat-calendar\n #rangeCalendarStart\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"svc.dateRangeForCalendar()\"\n (selectedChange)=\"handleStartCalendarChange($event)\"\n [maxDate]=\"svc.endDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n <mat-calendar\n #rangeCalendarEnd\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"svc.dateRangeForCalendar()\"\n (selectedChange)=\"handleEndCalendarChange($event)\"\n [minDate]=\"svc.startDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n </div>\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n <input\n #startDateInput\n name=\"startDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"svc.startDateHtmlString()\"\n (ngModelChange)=\"svc.setStartDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearStartDateTime()\"\n [disabled]=\"!this.svc.startDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n <input\n #endDateInput\n name=\"endDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"svc.endDateHtmlString()\"\n (ngModelChange)=\"svc.setEndDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearEndDateTime()\"\n [disabled]=\"!this.svc.endDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n <br />\n @if (intervalInputMode === 'date-time-range') {\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n <input\n name=\"startTimeInput\"\n matInput\n type=\"time\"\n #startTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"svc.getStartTimeString()\"\n (ngModelChange)=\"svc.setStartTimeFromString($event, startTimeControl)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.clearStartTime()\"\n [disabled]=\"!this.svc.isStartTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n <input\n name=\"endTimeInput\"\n matInput\n type=\"time\"\n #endTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"svc.getEndTimeString()\"\n (ngModelChange)=\"svc.setEndTimeFromString($event, endTimeControl)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.clearEndTime()\"\n [disabled]=\"!this.svc.isEndTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n }\n</ng-template>\n\n<ng-template #fixedShifts>\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n }\n <div class=\"layout-col place-start-stretch\">\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftDay(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.day' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftDay(1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftMonth(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.month' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftMonth(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftYear(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.year' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftYear(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n\n @if (intervalInputMode === 'date-time-range') {\n <!-- shift minute -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(-1, 'minutes')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.minute' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(1, 'minutes')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- shift hour -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(-1, 'hours')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.hour' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(1, 'hours')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n <div class=\"layout-row flex-none gap-md\">\n <mat-menu #anchorMenu=\"matMenu\">\n @if (svc.startDate()) {\n <button\n mat-menu-item\n (click)=\"svc.setFixedAnchorPointToEndDateTime()\"\n [disabled]=\"!svc.endDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n <span>{{ 'intervalPicker.endDate' | translate }}</span>\n </button>\n }\n @if (svc.endDate()) {\n <button\n mat-menu-item\n (click)=\"svc.setFixedAnchorPointToStartDateTime()\"\n [disabled]=\"!svc.startDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n <span>{{ 'intervalPicker.startDate' | translate }}</span>\n </button>\n }\n @if (svc.fixedAnchorDate()) {\n <button\n mat-menu-item\n (click)=\"this.svc.resetFixedAnchorPoint()\"\n [disabled]=\"!svc.fixedAnchorDate() || isAnchorReadOnly\"\n >\n <mat-icon>close</mat-icon>\n <span>{{ 'intervalPicker.clear' | translate }}</span>\n </button>\n }\n </mat-menu>\n\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n <elder-local-date-input\n name=\"anchorDateInput\"\n (valueUpdated)=\"svc.setAnchorDateFromForm($event)\"\n [value]=\"svc.getAnchorPointAsLocaleDate()\"\n [readonly]=\"isAnchorReadOnly\"\n >\n </elder-local-date-input>\n @if (!isAnchorReadOnly) {\n <button\n mat-icon-button\n matSuffix\n [matMenuTriggerFor]=\"anchorMenu\"\n [disabled]=\"svc.isStartAndEndDatesEmpty() && !svc.fixedAnchorDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n </button>\n }\n </mat-form-field>\n @if (intervalInputMode === 'date-time-range') {\n <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n <input\n matInput\n name=\"anchorTimeInput\"\n type=\"time\"\n #anchorTimeControl=\"ngModel\"\n step=\"1\"\n [readonly]=\"isAnchorReadOnly\"\n [ngModel]=\"svc.getAnchorTimeString()\"\n (ngModelChange)=\"svc.setAnchorTimeFromForm($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.resetFixedAnchorTime()\"\n [disabled]=\"!svc.isFixedAnchorTimeSetAndNotMidnight() || isAnchorReadOnly\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n }\n </div>\n</ng-template>\n", styles: [".interval-picker-component{min-width:840px;max-width:100%}.fixed-shifts-container{max-width:160px}.input-control-container{width:192px;max-width:100%}.input-control-container-short{width:140px;max-width:100%}.select-buttons-container button{white-space:nowrap;text-align:left;justify-content:flex-start}::ng-deep .interval-picker-component .mat-calendar-body-cell.elder-custom-anchor-date .mat-calendar-body-cell-content{border-radius:50%;background-color:#def;background-color:#b4d2ebbf}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.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: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: ElderLocalDateInputComponent, selector: "elder-local-date-input", inputs: ["zone", "autoDatePicker", "arrows", "today", "center", "datePickerTouchUi", "allowNull", "datePickerEnabled", "isoValue", "dateValue", "isoDateValue"], outputs: ["blurred", "valueUpdatedBlur", "isoValueChange", "dateValueChange", "isoDateValueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
177
+ updateMatCalendarActiveDate(startDate, endDate) {
178
+ if (!this.calendarStart || !this.calendarEnd) {
179
+ return;
180
+ }
181
+ if (!startDate && !endDate) {
182
+ return;
183
+ }
184
+ const calendarStart = this.calendarStart;
185
+ const calendarEnd = this.calendarEnd;
186
+ setTimeout(() => {
187
+ // timeout is needed to run calendar update last, otherwise there are issues
188
+ if (startDate) {
189
+ calendarStart.activeDate = TemporalUtil.getJSDateFromPlainDateTime(startDate);
190
+ }
191
+ if (endDate) {
192
+ calendarEnd.activeDate = TemporalUtil.getJSDateFromPlainDateTime(endDate);
193
+ }
194
+ }, 0);
195
+ }
196
+ updateMatCalendarTodayDate() {
197
+ this.calendarStart.updateTodaysDate();
198
+ this.calendarEnd.updateTodaysDate();
199
+ }
200
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerComponent, deps: [{ token: i1.IntervalPickerModel }], target: i0.ɵɵFactoryTarget.Component }); }
201
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.5", type: ElderIntervalPickerComponent, isStandalone: true, selector: "elder-interval-picker", inputs: { emitOnChange: { classPropertyName: "emitOnChange", publicName: "emitOnChange", isSignal: true, isRequired: false, transformFunction: null }, intervalInputMode: { classPropertyName: "intervalInputMode", publicName: "intervalInputMode", isSignal: true, isRequired: false, transformFunction: null }, showAnchor: { classPropertyName: "showAnchor", publicName: "showAnchor", isSignal: true, isRequired: false, transformFunction: null }, anchorReadOnly: { classPropertyName: "anchorReadOnly", publicName: "anchorReadOnly", isSignal: true, isRequired: false, transformFunction: null }, showResultText: { classPropertyName: "showResultText", publicName: "showResultText", isSignal: true, isRequired: false, transformFunction: null }, showHelpText: { classPropertyName: "showHelpText", publicName: "showHelpText", isSignal: true, isRequired: false, transformFunction: null }, lastExcludesToday: { classPropertyName: "lastExcludesToday", publicName: "lastExcludesToday", isSignal: true, isRequired: false, transformFunction: null }, interval: { classPropertyName: "interval", publicName: "interval", isSignal: false, isRequired: false, transformFunction: null }, anchorDateTime: { classPropertyName: "anchorDateTime", publicName: "anchorDateTime", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { dateChange: "dateChange" }, providers: [IntervalPickerModel, { provide: DateAdapter, useClass: CustomDateAdapter }], viewQueries: [{ propertyName: "calendarStart", first: true, predicate: ["rangeCalendarStart"], descendants: true }, { propertyName: "calendarEnd", first: true, predicate: ["rangeCalendarEnd"], descendants: true }, { propertyName: "calendarStartElRef", first: true, predicate: ["rangeCalendarStart"], descendants: true, read: ElementRef }, { propertyName: "calendarEndElRef", first: true, predicate: ["rangeCalendarEnd"], descendants: true, read: ElementRef }, { propertyName: "startDateInput", first: true, predicate: ["startDateInput"], descendants: true }, { propertyName: "endDateInput", first: true, predicate: ["endDateInput"], descendants: true }], ngImport: i0, template: "<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n <div class=\"layout-col gap-md pt-xs\">\n <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n </div>\n <div class=\"layout-col\">\n <!-- smart shift -->\n <div class=\"layout-row place-around-center\">\n <button mat-icon-button (click)=\"model.editor.smartShift(-1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ model.viewIntervalMessage() }}</span>\n <button mat-icon-button (click)=\"model.editor.smartShift(1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- calendars and input controls -->\n <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n </div>\n <div class=\"pt-xs\" style=\"width: 25%\">\n <div class=\"layout-col gap-lg\">\n <div class=\"layout-col gap-xs place-start-start\">\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n }\n <!-- select current -->\n <button mat-button (click)=\"model.editor.selectCurrentWeek()\">\n {{ 'intervalPicker.currentPeriod.week' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentMonth()\">\n {{ 'intervalPicker.currentPeriod.month' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentQuarter()\">\n {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentYear()\">\n {{ 'intervalPicker.currentPeriod.year' | translate }}\n </button>\n </div>\n <div class=\"fixed-shifts-container\">\n <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n <div>\n @if (showAnchor()) {\n <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n }\n </div>\n @if (showResultText()) {\n <!-- result interval -->\n <div class=\"layout-col place-center-center\">\n <div class=\"date-interval mat-caption pt-xs\">\n @if (model.startDateTimeAsJSDate()) {\n {{ model.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.startDateNotSet' | translate }}\n }\n <span> - </span>\n @if (model.endDateTimeAsJSDate()) {\n {{ model.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.endDateNotSet' | translate }}\n }\n </div>\n <div>\n <span class=\"mat-caption\">{{ model.deltaHumanReadable() || '&nbsp;' }}</span>\n </div>\n </div>\n }\n <div class=\"layout-row gap-lg\">\n <button\n mat-raised-button\n color=\"primary\"\n (click)=\"clearStartAndEndDateTimes()\"\n [disabled]=\"model.isStartAndEndDatesEmpty()\"\n >\n {{ 'intervalPicker.clear' | translate }}\n </button>\n\n @if (!this.emitOnChange()) {\n <button color=\"primary\" mat-raised-button (click)=\"model.emitMainDates()\">\n {{ 'actions.ok' | translate }}\n </button>\n }\n </div>\n </div>\n</div>\n\n<ng-template #intervalSelector>\n <div class=\"layout-col\">\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n }\n <div class=\"layout-row select-buttons-container gap-sm\">\n <div class=\"layout-col gap-xs place-start-stretch\">\n <button mat-button (click)=\"model.editor.selectCurrentDay()\">\n @if (model.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.anchorDay' | translate }}\n } @else {\n {{ 'intervalPicker.today' | translate }}\n }\n </button>\n <button mat-button (click)=\"model.editor.selectYesterday()\">\n @if (model.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n } @else {\n {{ 'intervalPicker.yesterday' | translate }}\n }\n </button>\n @if (lastExcludesToday()) {\n <button mat-button (click)=\"model.editor.selectLastSevenDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastThirtyDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n } @else {\n <button mat-button (click)=\"model.editor.selectLastSevenDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastThirtyDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n }\n @if (intervalInputMode() === 'date-time-range') {\n <div class=\"pt-sm\"></div>\n <button mat-button (click)=\"model.editor.selectLastFiveMinutes()\">\n {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastHour()\">\n {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLast24Hours()\">\n {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n </button>\n }\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n <mat-calendar\n #rangeCalendarStart\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"model.dateRangeForCalendar()\"\n (selectedChange)=\"handleStartCalendarChange($event)\"\n [maxDate]=\"model.endDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n <mat-calendar\n #rangeCalendarEnd\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"model.dateRangeForCalendar()\"\n (selectedChange)=\"handleEndCalendarChange($event)\"\n [minDate]=\"model.startDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n </div>\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n <input\n #startDateInput\n name=\"startDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"model.startDateHtmlString()\"\n (ngModelChange)=\"model.setStartDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearStartDateTime()\"\n [disabled]=\"!this.model.startDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n <input\n #endDateInput\n name=\"endDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"model.endDateHtmlString()\"\n (ngModelChange)=\"model.setEndDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearEndDateTime()\"\n [disabled]=\"!this.model.endDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n <br />\n @if (intervalInputMode() === 'date-time-range') {\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n <input\n name=\"startTimeInput\"\n matInput\n type=\"time\"\n #startTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"model.getStartTimeString()\"\n (ngModelChange)=\"model.setStartTimeFromString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.clearStartTime()\"\n [disabled]=\"!this.model.isStartTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n <input\n name=\"endTimeInput\"\n matInput\n type=\"time\"\n #endTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"model.getEndTimeString()\"\n (ngModelChange)=\"model.setEndTimeFromString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.clearEndTime()\"\n [disabled]=\"!this.model.isEndTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n }\n</ng-template>\n\n<ng-template #fixedShifts>\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n }\n <div class=\"layout-col place-start-stretch\">\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftDay(-1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.day' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftDay(1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftMonth(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.month' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftMonth(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftYear(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.year' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftYear(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n\n @if (intervalInputMode() === 'date-time-range') {\n <!-- shift minute -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(-1, 'minutes')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.minute' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(1, 'minutes')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- shift hour -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(-1, 'hours')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.hour' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(1, 'hours')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n <div class=\"layout-row flex-none gap-md\">\n <mat-menu #anchorMenu=\"matMenu\">\n @if (model.startDate()) {\n <button\n mat-menu-item\n (click)=\"model.setFixedAnchorPointToEndDateTime()\"\n [disabled]=\"!model.endDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n <span>{{ 'intervalPicker.endDate' | translate }}</span>\n </button>\n }\n @if (model.endDate()) {\n <button\n mat-menu-item\n (click)=\"model.setFixedAnchorPointToStartDateTime()\"\n [disabled]=\"!model.startDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n <span>{{ 'intervalPicker.startDate' | translate }}</span>\n </button>\n }\n @if (model.fixedAnchorDate()) {\n <button\n mat-menu-item\n (click)=\"this.model.resetFixedAnchorPoint()\"\n [disabled]=\"!model.fixedAnchorDate() || anchorReadOnly()\"\n >\n <mat-icon>close</mat-icon>\n <span>{{ 'intervalPicker.clear' | translate }}</span>\n </button>\n }\n </mat-menu>\n\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n <elder-local-date-input\n name=\"anchorDateInput\"\n (valueUpdated)=\"model.setAnchorDateFromForm($event)\"\n [value]=\"model.getAnchorPointAsLocaleDate()\"\n [readonly]=\"anchorReadOnly()\"\n >\n </elder-local-date-input>\n @if (!anchorReadOnly()) {\n <button\n mat-icon-button\n matSuffix\n [matMenuTriggerFor]=\"anchorMenu\"\n [disabled]=\"model.isStartAndEndDatesEmpty() && !model.fixedAnchorDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n </button>\n }\n </mat-form-field>\n @if (intervalInputMode() === 'date-time-range') {\n <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n <input\n matInput\n name=\"anchorTimeInput\"\n type=\"time\"\n #anchorTimeControl=\"ngModel\"\n step=\"1\"\n [readonly]=\"anchorReadOnly()\"\n [ngModel]=\"model.getAnchorTimeString()\"\n (ngModelChange)=\"model.setAnchorTimeFromForm($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.resetFixedAnchorTime()\"\n [disabled]=\"!model.isFixedAnchorTimeSetAndNotMidnight() || anchorReadOnly()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n }\n </div>\n</ng-template>\n", styles: [".interval-picker-component{min-width:840px;max-width:100%}.fixed-shifts-container{max-width:160px}.input-control-container{width:192px;max-width:100%}.input-control-container-short{width:140px;max-width:100%}.select-buttons-container button{white-space:nowrap;text-align:left;justify-content:flex-start}::ng-deep .interval-picker-component .mat-calendar-body-cell.elder-custom-anchor-date .mat-calendar-body-cell-content{border-radius:50%;background-color:#def;background-color:#b4d2ebbf}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.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: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i5.DatePipe, name: "date" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.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: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: ElderLocalDateInputComponent, selector: "elder-local-date-input", inputs: ["zone", "autoDatePicker", "arrows", "today", "center", "datePickerTouchUi", "allowNull", "datePickerEnabled", "isoValue", "dateValue", "isoDateValue"], outputs: ["blurred", "valueUpdatedBlur", "isoValueChange", "dateValueChange", "isoDateValueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i10.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
209
202
  }
210
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ElderIntervalPickerComponent, decorators: [{
203
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerComponent, decorators: [{
211
204
  type: Component,
212
205
  args: [{ selector: 'elder-interval-picker', standalone: true, imports: [
213
206
  MatDateRangePicker,
@@ -227,8 +220,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
227
220
  MatTooltip,
228
221
  TranslateModule,
229
222
  MatMenuModule,
230
- ], providers: [ElderIntervalPickerService, { provide: DateAdapter, useClass: CustomDateAdapter }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n <div class=\"layout-col gap-md pt-xs\">\n <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n </div>\n <div class=\"layout-col\">\n <!-- smart shift -->\n <div class=\"layout-row place-around-center\">\n <button mat-icon-button (click)=\"svc.smartShift(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ svc.viewIntervalMessage() }}</span>\n <button mat-icon-button (click)=\"svc.smartShift(1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- calendars and input controls -->\n <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n </div>\n <div class=\"pt-xs\" style=\"width: 25%\">\n <div class=\"layout-col gap-lg\">\n <div class=\"layout-col gap-xs place-start-start\">\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n }\n <!-- select current -->\n <button mat-button (click)=\"svc.selectCurrentWeek()\">\n {{ 'intervalPicker.currentPeriod.week' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentMonth()\">\n {{ 'intervalPicker.currentPeriod.month' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentQuarter()\">\n {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectCurrentYear()\">\n {{ 'intervalPicker.currentPeriod.year' | translate }}\n </button>\n </div>\n <div class=\"fixed-shifts-container\">\n <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n <div>\n @if (showAnchor) {\n <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n }\n </div>\n @if (isResultTextVisible) {\n <!-- result interval -->\n <div class=\"layout-col place-center-center\">\n <div class=\"date-interval mat-caption pt-xs\">\n @if (svc.startDateTimeAsJSDate()) {\n {{ svc.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.startDateNotSet' | translate }}\n }\n <span> - </span>\n @if (svc.endDateTimeAsJSDate()) {\n {{ svc.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.endDateNotSet' | translate }}\n }\n </div>\n <div>\n <span class=\"mat-caption\">{{ svc.deltaHumanReadable() || '&nbsp;' }}</span>\n </div>\n </div>\n }\n <div class=\"layout-row gap-lg\">\n <button\n mat-raised-button\n color=\"primary\"\n (click)=\"clearStartAndEndDateTimes()\"\n [disabled]=\"svc.isStartAndEndDatesEmpty()\"\n >\n {{ 'intervalPicker.clear' | translate }}\n </button>\n\n @if (!this.isEmittingOnChange) {\n <button color=\"primary\" mat-raised-button (click)=\"svc.emitMainDates()\">\n {{ 'actions.ok' | translate }}\n </button>\n }\n </div>\n </div>\n</div>\n\n<ng-template #intervalSelector>\n <div class=\"layout-col\">\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n }\n <div class=\"layout-row select-buttons-container gap-sm\">\n <div class=\"layout-col gap-xs place-start-stretch\">\n <button mat-button (click)=\"svc.selectCurrentDay()\">\n @if (svc.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.anchorDay' | translate }}\n } @else {\n {{ 'intervalPicker.today' | translate }}\n }\n </button>\n <button mat-button (click)=\"svc.selectYesterday()\">\n @if (svc.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n } @else {\n {{ 'intervalPicker.yesterday' | translate }}\n }\n </button>\n @if (isSelectLastModeExcludingToday) {\n <button mat-button (click)=\"svc.selectLastSevenDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastThirtyDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n } @else {\n <button mat-button (click)=\"svc.selectLastSevenDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastThirtyDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n }\n @if (intervalInputMode === 'date-time-range') {\n <div class=\"pt-sm\"></div>\n <button mat-button (click)=\"svc.selectLastFiveMinutes()\">\n {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLastHour()\">\n {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n </button>\n <button mat-button (click)=\"svc.selectLast24Hours()\">\n {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n </button>\n }\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n <mat-calendar\n #rangeCalendarStart\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"svc.dateRangeForCalendar()\"\n (selectedChange)=\"handleStartCalendarChange($event)\"\n [maxDate]=\"svc.endDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n <mat-calendar\n #rangeCalendarEnd\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"svc.dateRangeForCalendar()\"\n (selectedChange)=\"handleEndCalendarChange($event)\"\n [minDate]=\"svc.startDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n </div>\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n <input\n #startDateInput\n name=\"startDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"svc.startDateHtmlString()\"\n (ngModelChange)=\"svc.setStartDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearStartDateTime()\"\n [disabled]=\"!this.svc.startDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n <input\n #endDateInput\n name=\"endDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"svc.endDateHtmlString()\"\n (ngModelChange)=\"svc.setEndDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearEndDateTime()\"\n [disabled]=\"!this.svc.endDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n <br />\n @if (intervalInputMode === 'date-time-range') {\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n <input\n name=\"startTimeInput\"\n matInput\n type=\"time\"\n #startTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"svc.getStartTimeString()\"\n (ngModelChange)=\"svc.setStartTimeFromString($event, startTimeControl)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.clearStartTime()\"\n [disabled]=\"!this.svc.isStartTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n <input\n name=\"endTimeInput\"\n matInput\n type=\"time\"\n #endTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"svc.getEndTimeString()\"\n (ngModelChange)=\"svc.setEndTimeFromString($event, endTimeControl)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.clearEndTime()\"\n [disabled]=\"!this.svc.isEndTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n }\n</ng-template>\n\n<ng-template #fixedShifts>\n @if (isHelpTextsVisible) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n }\n <div class=\"layout-col place-start-stretch\">\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftDay(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.day' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftDay(1)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftMonth(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.month' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftMonth(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"svc.shiftYear(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.year' | translate }}</span>\n <button mat-icon-button (click)=\"svc.shiftYear(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n\n @if (intervalInputMode === 'date-time-range') {\n <!-- shift minute -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(-1, 'minutes')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.minute' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(1, 'minutes')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- shift hour -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(-1, 'hours')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.hour' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"svc.shiftTime(1, 'hours')\"\n [disabled]=\"svc.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n <div class=\"layout-row flex-none gap-md\">\n <mat-menu #anchorMenu=\"matMenu\">\n @if (svc.startDate()) {\n <button\n mat-menu-item\n (click)=\"svc.setFixedAnchorPointToEndDateTime()\"\n [disabled]=\"!svc.endDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n <span>{{ 'intervalPicker.endDate' | translate }}</span>\n </button>\n }\n @if (svc.endDate()) {\n <button\n mat-menu-item\n (click)=\"svc.setFixedAnchorPointToStartDateTime()\"\n [disabled]=\"!svc.startDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n <span>{{ 'intervalPicker.startDate' | translate }}</span>\n </button>\n }\n @if (svc.fixedAnchorDate()) {\n <button\n mat-menu-item\n (click)=\"this.svc.resetFixedAnchorPoint()\"\n [disabled]=\"!svc.fixedAnchorDate() || isAnchorReadOnly\"\n >\n <mat-icon>close</mat-icon>\n <span>{{ 'intervalPicker.clear' | translate }}</span>\n </button>\n }\n </mat-menu>\n\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n <elder-local-date-input\n name=\"anchorDateInput\"\n (valueUpdated)=\"svc.setAnchorDateFromForm($event)\"\n [value]=\"svc.getAnchorPointAsLocaleDate()\"\n [readonly]=\"isAnchorReadOnly\"\n >\n </elder-local-date-input>\n @if (!isAnchorReadOnly) {\n <button\n mat-icon-button\n matSuffix\n [matMenuTriggerFor]=\"anchorMenu\"\n [disabled]=\"svc.isStartAndEndDatesEmpty() && !svc.fixedAnchorDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n </button>\n }\n </mat-form-field>\n @if (intervalInputMode === 'date-time-range') {\n <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n <input\n matInput\n name=\"anchorTimeInput\"\n type=\"time\"\n #anchorTimeControl=\"ngModel\"\n step=\"1\"\n [readonly]=\"isAnchorReadOnly\"\n [ngModel]=\"svc.getAnchorTimeString()\"\n (ngModelChange)=\"svc.setAnchorTimeFromForm($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.svc.resetFixedAnchorTime()\"\n [disabled]=\"!svc.isFixedAnchorTimeSetAndNotMidnight() || isAnchorReadOnly\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n }\n </div>\n</ng-template>\n", styles: [".interval-picker-component{min-width:840px;max-width:100%}.fixed-shifts-container{max-width:160px}.input-control-container{width:192px;max-width:100%}.input-control-container-short{width:140px;max-width:100%}.select-buttons-container button{white-space:nowrap;text-align:left;justify-content:flex-start}::ng-deep .interval-picker-component .mat-calendar-body-cell.elder-custom-anchor-date .mat-calendar-body-cell-content{border-radius:50%;background-color:#def;background-color:#b4d2ebbf}\n"] }]
231
- }], ctorParameters: () => [{ type: i1.ElderIntervalPickerService }], propDecorators: { calendarStart: [{
223
+ ], providers: [IntervalPickerModel, { provide: DateAdapter, useClass: CustomDateAdapter }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n <div class=\"layout-col gap-md pt-xs\">\n <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n </div>\n <div class=\"layout-col\">\n <!-- smart shift -->\n <div class=\"layout-row place-around-center\">\n <button mat-icon-button (click)=\"model.editor.smartShift(-1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ model.viewIntervalMessage() }}</span>\n <button mat-icon-button (click)=\"model.editor.smartShift(1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- calendars and input controls -->\n <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n </div>\n <div class=\"pt-xs\" style=\"width: 25%\">\n <div class=\"layout-col gap-lg\">\n <div class=\"layout-col gap-xs place-start-start\">\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n }\n <!-- select current -->\n <button mat-button (click)=\"model.editor.selectCurrentWeek()\">\n {{ 'intervalPicker.currentPeriod.week' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentMonth()\">\n {{ 'intervalPicker.currentPeriod.month' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentQuarter()\">\n {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectCurrentYear()\">\n {{ 'intervalPicker.currentPeriod.year' | translate }}\n </button>\n </div>\n <div class=\"fixed-shifts-container\">\n <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n <div>\n @if (showAnchor()) {\n <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n }\n </div>\n @if (showResultText()) {\n <!-- result interval -->\n <div class=\"layout-col place-center-center\">\n <div class=\"date-interval mat-caption pt-xs\">\n @if (model.startDateTimeAsJSDate()) {\n {{ model.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.startDateNotSet' | translate }}\n }\n <span> - </span>\n @if (model.endDateTimeAsJSDate()) {\n {{ model.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n } @else {\n {{ 'intervalPicker.endDateNotSet' | translate }}\n }\n </div>\n <div>\n <span class=\"mat-caption\">{{ model.deltaHumanReadable() || '&nbsp;' }}</span>\n </div>\n </div>\n }\n <div class=\"layout-row gap-lg\">\n <button\n mat-raised-button\n color=\"primary\"\n (click)=\"clearStartAndEndDateTimes()\"\n [disabled]=\"model.isStartAndEndDatesEmpty()\"\n >\n {{ 'intervalPicker.clear' | translate }}\n </button>\n\n @if (!this.emitOnChange()) {\n <button color=\"primary\" mat-raised-button (click)=\"model.emitMainDates()\">\n {{ 'actions.ok' | translate }}\n </button>\n }\n </div>\n </div>\n</div>\n\n<ng-template #intervalSelector>\n <div class=\"layout-col\">\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n }\n <div class=\"layout-row select-buttons-container gap-sm\">\n <div class=\"layout-col gap-xs place-start-stretch\">\n <button mat-button (click)=\"model.editor.selectCurrentDay()\">\n @if (model.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.anchorDay' | translate }}\n } @else {\n {{ 'intervalPicker.today' | translate }}\n }\n </button>\n <button mat-button (click)=\"model.editor.selectYesterday()\">\n @if (model.isFixedAnchorDateSet()) {\n {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n } @else {\n {{ 'intervalPicker.yesterday' | translate }}\n }\n </button>\n @if (lastExcludesToday()) {\n <button mat-button (click)=\"model.editor.selectLastSevenDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastThirtyDaysExcludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n } @else {\n <button mat-button (click)=\"model.editor.selectLastSevenDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastThirtyDaysIncludingToday()\">\n {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n </button>\n }\n @if (intervalInputMode() === 'date-time-range') {\n <div class=\"pt-sm\"></div>\n <button mat-button (click)=\"model.editor.selectLastFiveMinutes()\">\n {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLastHour()\">\n {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n </button>\n <button mat-button (click)=\"model.editor.selectLast24Hours()\">\n {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n </button>\n }\n </div>\n </div>\n </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n <mat-calendar\n #rangeCalendarStart\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"model.dateRangeForCalendar()\"\n (selectedChange)=\"handleStartCalendarChange($event)\"\n [maxDate]=\"model.endDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n <mat-calendar\n #rangeCalendarEnd\n style=\"width: 210px; max-width: 100%\"\n [selected]=\"model.dateRangeForCalendar()\"\n (selectedChange)=\"handleEndCalendarChange($event)\"\n [minDate]=\"model.startDateAsJSDate()\"\n [dateClass]=\"calendarAnchorDateCssClassFn\"\n >\n </mat-calendar>\n </div>\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n <input\n #startDateInput\n name=\"startDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"model.startDateHtmlString()\"\n (ngModelChange)=\"model.setStartDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearStartDateTime()\"\n [disabled]=\"!this.model.startDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n <div class=\"layout-row place-around-center\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n <input\n #endDateInput\n name=\"endDateInput\"\n matInput\n type=\"date\"\n [ngModel]=\"model.endDateHtmlString()\"\n (ngModelChange)=\"model.setEndDateFromHtmlString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.clearEndDateTime()\"\n [disabled]=\"!this.model.endDate()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n </div>\n <br />\n @if (intervalInputMode() === 'date-time-range') {\n <div class=\"layout-row place-around-center gap-xl pt-sm\">\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n <input\n name=\"startTimeInput\"\n matInput\n type=\"time\"\n #startTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"model.getStartTimeString()\"\n (ngModelChange)=\"model.setStartTimeFromString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.clearStartTime()\"\n [disabled]=\"!this.model.isStartTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n <input\n name=\"endTimeInput\"\n matInput\n type=\"time\"\n #endTimeControl=\"ngModel\"\n step=\"1\"\n [ngModel]=\"model.getEndTimeString()\"\n (ngModelChange)=\"model.setEndTimeFromString($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.clearEndTime()\"\n [disabled]=\"!this.model.isEndTimeSetAndNotMidnight()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n </div>\n }\n</ng-template>\n\n<ng-template #fixedShifts>\n @if (showHelpText()) {\n <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n }\n <div class=\"layout-col place-start-stretch\">\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftDay(-1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.day' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftDay(1)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftMonth(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.month' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftMonth(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <div class=\"layout-row place-between-center\">\n <button mat-icon-button (click)=\"model.editor.shiftYear(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.year' | translate }}</span>\n <button mat-icon-button (click)=\"model.editor.shiftYear(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n\n @if (intervalInputMode() === 'date-time-range') {\n <!-- shift minute -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(-1, 'minutes')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.minute' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(1, 'minutes')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n <!-- shift hour -->\n <div class=\"layout-row place-between-center\">\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(-1, 'hours')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_left</mat-icon>\n </button>\n <span>{{ 'intervalPicker.hour' | translate }}</span>\n <button\n mat-icon-button\n (click)=\"model.editor.shiftTime(1, 'hours')\"\n [disabled]=\"model.isRangeNotSet()\"\n >\n <mat-icon>keyboard_double_arrow_right</mat-icon>\n </button>\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n <div class=\"layout-row flex-none gap-md\">\n <mat-menu #anchorMenu=\"matMenu\">\n @if (model.startDate()) {\n <button\n mat-menu-item\n (click)=\"model.setFixedAnchorPointToEndDateTime()\"\n [disabled]=\"!model.endDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n <span>{{ 'intervalPicker.endDate' | translate }}</span>\n </button>\n }\n @if (model.endDate()) {\n <button\n mat-menu-item\n (click)=\"model.setFixedAnchorPointToStartDateTime()\"\n [disabled]=\"!model.startDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n <span>{{ 'intervalPicker.startDate' | translate }}</span>\n </button>\n }\n @if (model.fixedAnchorDate()) {\n <button\n mat-menu-item\n (click)=\"this.model.resetFixedAnchorPoint()\"\n [disabled]=\"!model.fixedAnchorDate() || anchorReadOnly()\"\n >\n <mat-icon>close</mat-icon>\n <span>{{ 'intervalPicker.clear' | translate }}</span>\n </button>\n }\n </mat-menu>\n\n <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n <elder-local-date-input\n name=\"anchorDateInput\"\n (valueUpdated)=\"model.setAnchorDateFromForm($event)\"\n [value]=\"model.getAnchorPointAsLocaleDate()\"\n [readonly]=\"anchorReadOnly()\"\n >\n </elder-local-date-input>\n @if (!anchorReadOnly()) {\n <button\n mat-icon-button\n matSuffix\n [matMenuTriggerFor]=\"anchorMenu\"\n [disabled]=\"model.isStartAndEndDatesEmpty() && !model.fixedAnchorDate()\"\n >\n <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n </button>\n }\n </mat-form-field>\n @if (intervalInputMode() === 'date-time-range') {\n <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n <input\n matInput\n name=\"anchorTimeInput\"\n type=\"time\"\n #anchorTimeControl=\"ngModel\"\n step=\"1\"\n [readonly]=\"anchorReadOnly()\"\n [ngModel]=\"model.getAnchorTimeString()\"\n (ngModelChange)=\"model.setAnchorTimeFromForm($event)\"\n />\n <button\n mat-icon-button\n matSuffix\n (click)=\"this.model.resetFixedAnchorTime()\"\n [disabled]=\"!model.isFixedAnchorTimeSetAndNotMidnight() || anchorReadOnly()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n }\n </div>\n</ng-template>\n", styles: [".interval-picker-component{min-width:840px;max-width:100%}.fixed-shifts-container{max-width:160px}.input-control-container{width:192px;max-width:100%}.input-control-container-short{width:140px;max-width:100%}.select-buttons-container button{white-space:nowrap;text-align:left;justify-content:flex-start}::ng-deep .interval-picker-component .mat-calendar-body-cell.elder-custom-anchor-date .mat-calendar-body-cell-content{border-radius:50%;background-color:#def;background-color:#b4d2ebbf}\n"] }]
224
+ }], ctorParameters: () => [{ type: i1.IntervalPickerModel }], propDecorators: { calendarStart: [{
232
225
  type: ViewChild,
233
226
  args: ['rangeCalendarStart']
234
227
  }], calendarEnd: [{
@@ -246,21 +239,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
246
239
  }], endDateInput: [{
247
240
  type: ViewChild,
248
241
  args: ['endDateInput']
249
- }], isEmittingOnChange: [{
250
- type: Input
251
- }], intervalInputMode: [{
252
- type: Input
253
- }], showAnchor: [{
254
- type: Input
255
- }], isAnchorReadOnly: [{
256
- type: Input
257
- }], isResultTextVisible: [{
258
- type: Input
259
- }], isHelpTextsVisible: [{
260
- type: Input
261
- }], isSelectLastModeExcludingToday: [{
262
- type: Input
263
242
  }], dateChange: [{
264
243
  type: Output
244
+ }], interval: [{
245
+ type: Input
246
+ }], anchorDateTime: [{
247
+ type: Input
265
248
  }] } });
266
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-interval-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/elder-interval-picker.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/elder-interval-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  effect,\n  EffectRef,\n  ElementRef,\n  EventEmitter,\n  input,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { FormsModule } from '@angular/forms'\nimport { MatButtonModule } from '@angular/material/button'\nimport { DateAdapter } from '@angular/material/core'\nimport {\n  MatCalendar,\n  MatCalendarCellClassFunction,\n  MatDatepickerModule,\n  MatDatepickerToggle,\n  MatDateRangeInput,\n  MatDateRangePicker,\n} from '@angular/material/datepicker'\nimport { MatFormFieldModule, MatHint, MatLabel } from '@angular/material/form-field'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatInputModule } from '@angular/material/input'\nimport { MatMenuModule } from '@angular/material/menu'\nimport { MatTooltip } from '@angular/material/tooltip'\nimport { LoggerFactory } from '@elderbyte/ts-logger'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { Interval } from '../../../common/time/interval'\nimport { TemporalUtil } from '../../../common/time/temporal-util'\nimport { CustomDateAdapter } from '../../../components/time/date-adapters/custom-date-adapter'\nimport { IntervalInputMode } from '../../../components/time/elder-interval-input/elder-interval-input.component'\nimport { ElderLocalDateInputComponent } from '../../../components/time/elder-local-date-input/elder-local-date-input.component'\nimport { ElderIntervalPickerService } from './elder-interval-picker.service'\n\n@Component({\n  selector: 'elder-interval-picker',\n  standalone: true,\n  imports: [\n    MatDateRangePicker,\n    MatDatepickerModule,\n    MatDateRangeInput,\n    MatFormFieldModule,\n    MatLabel,\n    MatHint,\n    MatDatepickerToggle,\n    MatInputModule,\n    CommonModule,\n    MatIconModule,\n    FormsModule,\n    MatButtonModule,\n    MatCalendar,\n    ElderLocalDateInputComponent,\n    MatTooltip,\n    TranslateModule,\n    MatMenuModule,\n  ],\n  providers: [ElderIntervalPickerService, { provide: DateAdapter, useClass: CustomDateAdapter }],\n  templateUrl: './elder-interval-picker.component.html',\n  styleUrl: './elder-interval-picker.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderIntervalPickerComponent {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n  public readonly calendarAnchorDateCssClassFn: MatCalendarCellClassFunction<Date> = (\n    cellDate: Date,\n    view: string\n  ): string => {\n    return this.calendarAnchorDateCssClassFnBody(cellDate, view)\n  }\n\n  @ViewChild('rangeCalendarStart') calendarStart!: MatCalendar<Date>\n  @ViewChild('rangeCalendarEnd') calendarEnd!: MatCalendar<Date>\n\n  @ViewChild('rangeCalendarStart', { read: ElementRef }) calendarStartElRef!: ElementRef\n  @ViewChild('rangeCalendarEnd', { read: ElementRef }) calendarEndElRef!: ElementRef\n\n  @ViewChild('startDateInput') startDateInput!: ElementRef\n  @ViewChild('endDateInput') endDateInput!: ElementRef\n\n  @Input() isEmittingOnChange = true\n  @Input() intervalInputMode: IntervalInputMode = 'date-range'\n  @Input() showAnchor = false\n  @Input() isAnchorReadOnly = false\n  @Input() isResultTextVisible = true\n  @Input() isHelpTextsVisible = false\n  @Input() isSelectLastModeExcludingToday = false\n  @Output() dateChange = new EventEmitter<Interval>()\n  inputInterval = input<Interval>(null)\n  inputAnchorDateTime = input<Date>(null)\n\n  private calendarElFocusEventHandler: (event: FocusEvent) => void\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(public svc: ElderIntervalPickerService) {\n    this.svc.setupInputInterval(this.inputInterval)\n    this.svc.setupInputAnchorDateTime(this.inputAnchorDateTime)\n    this.svc.setupEventEmitter(this.dateChange)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {\n    if (this.inputInterval) {\n      this.svc.pullInputInterval()\n    }\n    if (this.inputAnchorDateTime()) {\n      this.svc.pullInputAnchorDateTime()\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.svc.isEmittingOnChange.set(this.isEmittingOnChange)\n    this.setupDateInputCalendarFocusPrevention()\n  }\n\n  ngOnDestroy(): void {\n    this.removeEventListeners()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  setupDateInputCalendarFocusPrevention(): void {\n    // Prevents the focus on the calendar when the input field is changed via the keyboard\n    this.calendarElFocusEventHandler = (event: FocusEvent): void => {\n      if (!event || !event.relatedTarget) {\n        return\n      }\n      event.preventDefault()\n      const relTarget = event.relatedTarget as HTMLInputElement\n\n      if (relTarget.name === 'startDateInput') {\n        this.startDateInput.nativeElement.focus()\n        return\n      }\n      if (relTarget.name === 'endDateInput') {\n        this.endDateInput.nativeElement.focus()\n        return\n      }\n    }\n\n    const nativeElementStart = this.calendarStartElRef.nativeElement as HTMLElement\n    const nativeElementEnd = this.calendarEndElRef.nativeElement as HTMLElement\n\n    nativeElementStart.addEventListener('focus', this.calendarElFocusEventHandler, true)\n    nativeElementEnd.addEventListener('focus', this.calendarElFocusEventHandler, true)\n  }\n\n  clearStartDateTime(): void {\n    this.svc.clearStartDateTime()\n\n    this.svc.resetCalendarMode()\n\n    if (this.isEmittingOnChange) {\n      this.svc.emitMainDates()\n    }\n  }\n\n  clearEndDateTime(): void {\n    this.svc.clearEndDateTime()\n\n    this.svc.resetCalendarMode()\n\n    if (this.isEmittingOnChange) {\n      this.svc.emitMainDates()\n    }\n  }\n\n  clearStartAndEndDateTimes(): void {\n    this.svc.clearStartDateTime()\n    this.svc.clearEndDateTime()\n\n    this.svc.resetCalendarMode()\n\n    if (this.isEmittingOnChange) {\n      this.svc.emitMainDates()\n    }\n  }\n\n  handleStartCalendarChange(changedDate: Date): void {\n    this.svc.calendarMode.set('days')\n    const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate)\n    this.svc.startDate.set(newPlainDate)\n  }\n\n  handleEndCalendarChange(changedDate: Date): void {\n    this.svc.calendarMode.set('days')\n    const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate)\n    this.svc.endDate.set(newPlainDate)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private removeEventListeners(): void {\n    if (!this.calendarStartElRef || !this.calendarEndElRef) {\n      return\n    }\n\n    if (!this.calendarStartElRef.nativeElement || !this.calendarEndElRef.nativeElement) {\n      return\n    }\n\n    const nativeElementStart = this.calendarStartElRef.nativeElement as HTMLElement\n    const nativeElementEnd = this.calendarEndElRef.nativeElement as HTMLElement\n\n    nativeElementStart.removeEventListener('focus', this.calendarElFocusEventHandler, true)\n    nativeElementEnd.removeEventListener('focus', this.calendarElFocusEventHandler, true)\n  }\n\n  private calendarAnchorDateCssClassFnBody(cellDate: Date, view: string): string {\n    const anchorDate = this.svc.fixedAnchorDate()\n\n    if (!anchorDate) {\n      return ''\n    }\n\n    const date = TemporalUtil.getJSDateFromPlainDateTime(anchorDate)\n\n    if (!date) {\n      return ''\n    }\n\n    if (\n      cellDate.getDate() === date.getDate() &&\n      cellDate.getMonth() === date.getMonth() &&\n      cellDate.getFullYear() === date.getFullYear()\n    ) {\n      return 'elder-custom-anchor-date'\n    }\n\n    return ''\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Effects                                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _updateMatCalendarElAnchorCssClassEffect: EffectRef = effect((): void => {\n    const anchorDate = this.svc.anchorDate()\n\n    if (anchorDate) {\n      this.calendarStart.updateTodaysDate()\n      this.calendarEnd.updateTodaysDate()\n    }\n  })\n\n  private readonly _updateMatCalendarElSelectionEffect: EffectRef = effect((): void => {\n    const startDate = this.svc.startDate()\n    const endDate = this.svc.endDate()\n\n    if (!this.calendarStart || !this.calendarEnd) {\n      return\n    }\n\n    if (!startDate && !endDate) {\n      return\n    }\n\n    const calendar1 = this.calendarStart\n    const calendar2 = this.calendarEnd\n\n    setTimeout(() => {\n      // timeout is needed to run run calendar update last, otherwise there are issues\n      if (startDate) {\n        const startJsDate = TemporalUtil.getJSDateFromPlainDateTime(startDate)\n        calendar1.activeDate = startJsDate\n      }\n\n      if (endDate) {\n        const endJsDate = TemporalUtil.getJSDateFromPlainDateTime(endDate)\n        calendar2.activeDate = endJsDate\n      }\n    }, 0)\n  })\n}\n","<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n  <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n    <div class=\"layout-col gap-md pt-xs\">\n      <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n    </div>\n    <div class=\"layout-col\">\n      <!-- smart shift -->\n      <div class=\"layout-row place-around-center\">\n        <button mat-icon-button (click)=\"svc.smartShift(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ svc.viewIntervalMessage() }}</span>\n        <button mat-icon-button (click)=\"svc.smartShift(1)\" [disabled]=\"svc.isRangeNotSet()\">\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n      <!-- calendars and input controls -->\n      <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n    </div>\n    <div class=\"pt-xs\" style=\"width: 25%\">\n      <div class=\"layout-col gap-lg\">\n        <div class=\"layout-col gap-xs place-start-start\">\n          @if (isHelpTextsVisible) {\n            <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n          }\n          <!-- select current -->\n          <button mat-button (click)=\"svc.selectCurrentWeek()\">\n            {{ 'intervalPicker.currentPeriod.week' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectCurrentMonth()\">\n            {{ 'intervalPicker.currentPeriod.month' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectCurrentQuarter()\">\n            {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectCurrentYear()\">\n            {{ 'intervalPicker.currentPeriod.year' | translate }}\n          </button>\n        </div>\n        <div class=\"fixed-shifts-container\">\n          <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n    <div>\n      @if (showAnchor) {\n        <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n      }\n    </div>\n    @if (isResultTextVisible) {\n      <!-- result interval -->\n      <div class=\"layout-col place-center-center\">\n        <div class=\"date-interval mat-caption pt-xs\">\n          @if (svc.startDateTimeAsJSDate()) {\n            {{ svc.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n          } @else {\n            {{ 'intervalPicker.startDateNotSet' | translate }}\n          }\n          <span> - </span>\n          @if (svc.endDateTimeAsJSDate()) {\n            {{ svc.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n          } @else {\n            {{ 'intervalPicker.endDateNotSet' | translate }}\n          }\n        </div>\n        <div>\n          <span class=\"mat-caption\">{{ svc.deltaHumanReadable() || '&nbsp;' }}</span>\n        </div>\n      </div>\n    }\n    <div class=\"layout-row gap-lg\">\n      <button\n        mat-raised-button\n        color=\"primary\"\n        (click)=\"clearStartAndEndDateTimes()\"\n        [disabled]=\"svc.isStartAndEndDatesEmpty()\"\n      >\n        {{ 'intervalPicker.clear' | translate }}\n      </button>\n\n      @if (!this.isEmittingOnChange) {\n        <button color=\"primary\" mat-raised-button (click)=\"svc.emitMainDates()\">\n          {{ 'actions.ok' | translate }}\n        </button>\n      }\n    </div>\n  </div>\n</div>\n\n<ng-template #intervalSelector>\n  <div class=\"layout-col\">\n    @if (isHelpTextsVisible) {\n      <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n    }\n    <div class=\"layout-row select-buttons-container gap-sm\">\n      <div class=\"layout-col gap-xs place-start-stretch\">\n        <button mat-button (click)=\"svc.selectCurrentDay()\">\n          @if (svc.isFixedAnchorDateSet()) {\n            {{ 'intervalPicker.anchorDay' | translate }}\n          } @else {\n            {{ 'intervalPicker.today' | translate }}\n          }\n        </button>\n        <button mat-button (click)=\"svc.selectYesterday()\">\n          @if (svc.isFixedAnchorDateSet()) {\n            {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n          } @else {\n            {{ 'intervalPicker.yesterday' | translate }}\n          }\n        </button>\n        @if (isSelectLastModeExcludingToday) {\n          <button mat-button (click)=\"svc.selectLastSevenDaysExcludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectLastThirtyDaysExcludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n          </button>\n        } @else {\n          <button mat-button (click)=\"svc.selectLastSevenDaysIncludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectLastThirtyDaysIncludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n          </button>\n        }\n        @if (intervalInputMode === 'date-time-range') {\n          <div class=\"pt-sm\"></div>\n          <button mat-button (click)=\"svc.selectLastFiveMinutes()\">\n            {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectLastHour()\">\n            {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n          </button>\n          <button mat-button (click)=\"svc.selectLast24Hours()\">\n            {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n          </button>\n        }\n      </div>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n  <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n    <mat-calendar\n      #rangeCalendarStart\n      style=\"width: 210px; max-width: 100%\"\n      [selected]=\"svc.dateRangeForCalendar()\"\n      (selectedChange)=\"handleStartCalendarChange($event)\"\n      [maxDate]=\"svc.endDateAsJSDate()\"\n      [dateClass]=\"calendarAnchorDateCssClassFn\"\n    >\n    </mat-calendar>\n    <mat-calendar\n      #rangeCalendarEnd\n      style=\"width: 210px; max-width: 100%\"\n      [selected]=\"svc.dateRangeForCalendar()\"\n      (selectedChange)=\"handleEndCalendarChange($event)\"\n      [minDate]=\"svc.startDateAsJSDate()\"\n      [dateClass]=\"calendarAnchorDateCssClassFn\"\n    >\n    </mat-calendar>\n  </div>\n  <div class=\"layout-row place-around-center gap-xl pt-sm\">\n    <div class=\"layout-row place-around-center\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n        <input\n          #startDateInput\n          name=\"startDateInput\"\n          matInput\n          type=\"date\"\n          [ngModel]=\"svc.startDateHtmlString()\"\n          (ngModelChange)=\"svc.setStartDateFromHtmlString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.clearStartDateTime()\"\n          [disabled]=\"!this.svc.startDate()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n    <div class=\"layout-row place-around-center\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n        <input\n          #endDateInput\n          name=\"endDateInput\"\n          matInput\n          type=\"date\"\n          [ngModel]=\"svc.endDateHtmlString()\"\n          (ngModelChange)=\"svc.setEndDateFromHtmlString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.clearEndDateTime()\"\n          [disabled]=\"!this.svc.endDate()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n  </div>\n  <br />\n  @if (intervalInputMode === 'date-time-range') {\n    <div class=\"layout-row place-around-center gap-xl pt-sm\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n        <input\n          name=\"startTimeInput\"\n          matInput\n          type=\"time\"\n          #startTimeControl=\"ngModel\"\n          step=\"1\"\n          [ngModel]=\"svc.getStartTimeString()\"\n          (ngModelChange)=\"svc.setStartTimeFromString($event, startTimeControl)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.svc.clearStartTime()\"\n          [disabled]=\"!this.svc.isStartTimeSetAndNotMidnight()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n        <input\n          name=\"endTimeInput\"\n          matInput\n          type=\"time\"\n          #endTimeControl=\"ngModel\"\n          step=\"1\"\n          [ngModel]=\"svc.getEndTimeString()\"\n          (ngModelChange)=\"svc.setEndTimeFromString($event, endTimeControl)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.svc.clearEndTime()\"\n          [disabled]=\"!this.svc.isEndTimeSetAndNotMidnight()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n  }\n</ng-template>\n\n<ng-template #fixedShifts>\n  @if (isHelpTextsVisible) {\n    <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n  }\n  <div class=\"layout-col place-start-stretch\">\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"svc.shiftDay(-1)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.day' | translate }}</span>\n      <button mat-icon-button (click)=\"svc.shiftDay(1)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"svc.shiftMonth(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.month' | translate }}</span>\n      <button mat-icon-button (click)=\"svc.shiftMonth(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"svc.shiftYear(-1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.year' | translate }}</span>\n      <button mat-icon-button (click)=\"svc.shiftYear(1, true)\" [disabled]=\"svc.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n\n    @if (intervalInputMode === 'date-time-range') {\n      <!-- shift minute -->\n      <div class=\"layout-row place-between-center\">\n        <button\n          mat-icon-button\n          (click)=\"svc.shiftTime(-1, 'minutes')\"\n          [disabled]=\"svc.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ 'intervalPicker.minute' | translate }}</span>\n        <button\n          mat-icon-button\n          (click)=\"svc.shiftTime(1, 'minutes')\"\n          [disabled]=\"svc.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n      <!-- shift hour -->\n      <div class=\"layout-row place-between-center\">\n        <button\n          mat-icon-button\n          (click)=\"svc.shiftTime(-1, 'hours')\"\n          [disabled]=\"svc.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ 'intervalPicker.hour' | translate }}</span>\n        <button\n          mat-icon-button\n          (click)=\"svc.shiftTime(1, 'hours')\"\n          [disabled]=\"svc.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n    }\n  </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n  <div class=\"layout-row flex-none gap-md\">\n    <mat-menu #anchorMenu=\"matMenu\">\n      @if (svc.startDate()) {\n        <button\n          mat-menu-item\n          (click)=\"svc.setFixedAnchorPointToEndDateTime()\"\n          [disabled]=\"!svc.endDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n          <span>{{ 'intervalPicker.endDate' | translate }}</span>\n        </button>\n      }\n      @if (svc.endDate()) {\n        <button\n          mat-menu-item\n          (click)=\"svc.setFixedAnchorPointToStartDateTime()\"\n          [disabled]=\"!svc.startDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n          <span>{{ 'intervalPicker.startDate' | translate }}</span>\n        </button>\n      }\n      @if (svc.fixedAnchorDate()) {\n        <button\n          mat-menu-item\n          (click)=\"this.svc.resetFixedAnchorPoint()\"\n          [disabled]=\"!svc.fixedAnchorDate() || isAnchorReadOnly\"\n        >\n          <mat-icon>close</mat-icon>\n          <span>{{ 'intervalPicker.clear' | translate }}</span>\n        </button>\n      }\n    </mat-menu>\n\n    <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n      <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n      <elder-local-date-input\n        name=\"anchorDateInput\"\n        (valueUpdated)=\"svc.setAnchorDateFromForm($event)\"\n        [value]=\"svc.getAnchorPointAsLocaleDate()\"\n        [readonly]=\"isAnchorReadOnly\"\n      >\n      </elder-local-date-input>\n      @if (!isAnchorReadOnly) {\n        <button\n          mat-icon-button\n          matSuffix\n          [matMenuTriggerFor]=\"anchorMenu\"\n          [disabled]=\"svc.isStartAndEndDatesEmpty() && !svc.fixedAnchorDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n        </button>\n      }\n    </mat-form-field>\n    @if (intervalInputMode === 'date-time-range') {\n      <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n        <input\n          matInput\n          name=\"anchorTimeInput\"\n          type=\"time\"\n          #anchorTimeControl=\"ngModel\"\n          step=\"1\"\n          [readonly]=\"isAnchorReadOnly\"\n          [ngModel]=\"svc.getAnchorTimeString()\"\n          (ngModelChange)=\"svc.setAnchorTimeFromForm($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.svc.resetFixedAnchorTime()\"\n          [disabled]=\"!svc.isFixedAnchorTimeSetAndNotMidnight() || isAnchorReadOnly\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    }\n  </div>\n</ng-template>\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-interval-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/elder-interval-picker.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/elder-interval-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  effect,\n  ElementRef,\n  EventEmitter,\n  Input,\n  input,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { FormsModule } from '@angular/forms'\nimport { MatButtonModule } from '@angular/material/button'\nimport { DateAdapter } from '@angular/material/core'\nimport {\n  MatCalendar,\n  MatCalendarCellClassFunction,\n  MatDatepickerModule,\n  MatDatepickerToggle,\n  MatDateRangeInput,\n  MatDateRangePicker,\n} from '@angular/material/datepicker'\nimport { MatFormFieldModule, MatHint, MatLabel } from '@angular/material/form-field'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatInputModule } from '@angular/material/input'\nimport { MatMenuModule } from '@angular/material/menu'\nimport { MatTooltip } from '@angular/material/tooltip'\nimport { LoggerFactory } from '@elderbyte/ts-logger'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { Interval } from '../../../common/time/interval'\nimport { TemporalUtil } from '../../../common/time/temporal-util'\nimport { CustomDateAdapter } from '../date-adapters/custom-date-adapter'\nimport { IntervalInputMode } from '../elder-interval-input/elder-interval-input.component'\nimport { ElderLocalDateInputComponent } from '../elder-local-date-input/elder-local-date-input.component'\nimport { IntervalPickerModel } from './model/interval-picker-model'\nimport { Temporal } from '@js-temporal/polyfill'\n\n@Component({\n  selector: 'elder-interval-picker',\n  standalone: true,\n  imports: [\n    MatDateRangePicker,\n    MatDatepickerModule,\n    MatDateRangeInput,\n    MatFormFieldModule,\n    MatLabel,\n    MatHint,\n    MatDatepickerToggle,\n    MatInputModule,\n    CommonModule,\n    MatIconModule,\n    FormsModule,\n    MatButtonModule,\n    MatCalendar,\n    ElderLocalDateInputComponent,\n    MatTooltip,\n    TranslateModule,\n    MatMenuModule,\n  ],\n  providers: [IntervalPickerModel, { provide: DateAdapter, useClass: CustomDateAdapter }],\n  templateUrl: './elder-interval-picker.component.html',\n  styleUrl: './elder-interval-picker.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderIntervalPickerComponent implements AfterViewInit, OnDestroy {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  @ViewChild('rangeCalendarStart') calendarStart!: MatCalendar<Date>\n  @ViewChild('rangeCalendarEnd') calendarEnd!: MatCalendar<Date>\n\n  @ViewChild('rangeCalendarStart', { read: ElementRef }) calendarStartElRef!: ElementRef\n  @ViewChild('rangeCalendarEnd', { read: ElementRef }) calendarEndElRef!: ElementRef\n\n  @ViewChild('startDateInput') startDateInput!: ElementRef\n  @ViewChild('endDateInput') endDateInput!: ElementRef\n\n  public readonly emitOnChange = input(true, { transform: (v) => booleanAttribute(v) })\n  public readonly intervalInputMode = input<IntervalInputMode>('date-range')\n  public readonly showAnchor = input(false, { transform: (v) => booleanAttribute(v) })\n  public readonly anchorReadOnly = input(false, { transform: (v) => booleanAttribute(v) })\n  public readonly showResultText = input(true, { transform: (v) => booleanAttribute(v) })\n  public readonly showHelpText = input(false, { transform: (v) => booleanAttribute(v) })\n  public readonly lastExcludesToday = input(false, { transform: (v) => booleanAttribute(v) })\n\n  @Output() dateChange = new EventEmitter<Interval>()\n\n  private calendarElFocusEventHandler: (event: FocusEvent) => void\n\n  @Input()\n  public set interval(value: Interval) {\n    this.model.setInterval(value)\n  }\n\n  @Input()\n  public set anchorDateTime(value: Date) {\n    this.model.setAnchorDateTime(value)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(public model: IntervalPickerModel) {\n    this.model.setupEventEmitter(this.dateChange)\n\n    effect((): void => {\n      if (this.model.anchorDate()) {\n        this.updateMatCalendarTodayDate()\n      }\n    })\n\n    effect((): void => {\n      this.updateMatCalendarActiveDate(this.model.startDate(), this.model.endDate())\n    })\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n    this.model.isEmittingOnChange.set(this.emitOnChange())\n    this.setupDateInputCalendarFocusPrevention()\n    setTimeout(() => {\n      this.model.setInitialized()\n    }, 0)\n  }\n\n  public ngOnDestroy(): void {\n    this.removeEventListeners()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public setupDateInputCalendarFocusPrevention(): void {\n    // Prevents the focus on the calendar when the input field is changed via the keyboard\n    this.calendarElFocusEventHandler = (event: FocusEvent): void => {\n      if (!event || !event.relatedTarget) {\n        return\n      }\n      event.preventDefault()\n      const relTarget = event.relatedTarget as HTMLInputElement\n\n      if (relTarget.name === 'startDateInput') {\n        this.startDateInput.nativeElement.focus()\n        return\n      }\n      if (relTarget.name === 'endDateInput') {\n        this.endDateInput.nativeElement.focus()\n        return\n      }\n    }\n\n    const nativeElementStart = this.calendarStartElRef.nativeElement as HTMLElement\n    const nativeElementEnd = this.calendarEndElRef.nativeElement as HTMLElement\n\n    nativeElementStart.addEventListener('focus', this.calendarElFocusEventHandler, true)\n    nativeElementEnd.addEventListener('focus', this.calendarElFocusEventHandler, true)\n  }\n\n  public clearStartDateTime(): void {\n    this.model.clearStartDateTime()\n\n    this.model.resetCalendarMode()\n\n    if (this.emitOnChange()) {\n      this.model.emitMainDates()\n    }\n  }\n\n  public clearEndDateTime(): void {\n    this.model.clearEndDateTime()\n\n    this.model.resetCalendarMode()\n\n    if (this.emitOnChange()) {\n      this.model.emitMainDates()\n    }\n  }\n\n  public clearStartAndEndDateTimes(): void {\n    this.model.clearStartDateTime()\n    this.model.clearEndDateTime()\n\n    this.model.resetCalendarMode()\n\n    if (this.emitOnChange()) {\n      this.model.emitMainDates()\n    }\n  }\n\n  public handleStartCalendarChange(changedDate: Date): void {\n    this.model.calendarMode.set('days')\n    const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate)\n    this.model.setStartDate(newPlainDate)\n  }\n\n  public handleEndCalendarChange(changedDate: Date): void {\n    this.model.calendarMode.set('days')\n    const newPlainDate = TemporalUtil.getPlainDateFromJSDate(changedDate)\n    this.model.setEndDate(newPlainDate)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private removeEventListeners(): void {\n    if (!this.calendarStartElRef || !this.calendarEndElRef) {\n      return\n    }\n\n    if (!this.calendarStartElRef.nativeElement || !this.calendarEndElRef.nativeElement) {\n      return\n    }\n\n    const nativeElementStart = this.calendarStartElRef.nativeElement as HTMLElement\n    const nativeElementEnd = this.calendarEndElRef.nativeElement as HTMLElement\n\n    nativeElementStart.removeEventListener('focus', this.calendarElFocusEventHandler, true)\n    nativeElementEnd.removeEventListener('focus', this.calendarElFocusEventHandler, true)\n  }\n\n  public readonly calendarAnchorDateCssClassFn: MatCalendarCellClassFunction<Date> = (\n    cellDate: Date,\n    view: string\n  ): string => {\n    return this.calendarAnchorDateCssClassFnBody(cellDate, view)\n  }\n\n  private calendarAnchorDateCssClassFnBody(cellDate: Date, view: string): string {\n    const anchorDate = this.model.fixedAnchorDate()\n\n    if (!anchorDate) {\n      return ''\n    }\n\n    const date = TemporalUtil.getJSDateFromPlainDateTime(anchorDate)\n\n    if (!date) {\n      return ''\n    }\n\n    if (\n      cellDate.getDate() === date.getDate() &&\n      cellDate.getMonth() === date.getMonth() &&\n      cellDate.getFullYear() === date.getFullYear()\n    ) {\n      return 'elder-custom-anchor-date'\n    }\n\n    return ''\n  }\n\n  private updateMatCalendarActiveDate(startDate: Temporal.PlainDate, endDate: Temporal.PlainDate) {\n    if (!this.calendarStart || !this.calendarEnd) {\n      return\n    }\n\n    if (!startDate && !endDate) {\n      return\n    }\n\n    const calendarStart = this.calendarStart\n    const calendarEnd = this.calendarEnd\n\n    setTimeout(() => {\n      // timeout is needed to run calendar update last, otherwise there are issues\n      if (startDate) {\n        calendarStart.activeDate = TemporalUtil.getJSDateFromPlainDateTime(startDate)\n      }\n\n      if (endDate) {\n        calendarEnd.activeDate = TemporalUtil.getJSDateFromPlainDateTime(endDate)\n      }\n    }, 0)\n  }\n\n  private updateMatCalendarTodayDate(): void {\n    this.calendarStart.updateTodaysDate()\n    this.calendarEnd.updateTodaysDate()\n  }\n}\n","<div class=\"interval-picker-component p-md layout-col gap-xxl\">\n  <div class=\"layout-row gap-xxl place-between-start\" style=\"gap: 5%\">\n    <div class=\"layout-col gap-md pt-xs\">\n      <ng-container *ngTemplateOutlet=\"intervalSelector\"></ng-container>\n    </div>\n    <div class=\"layout-col\">\n      <!-- smart shift -->\n      <div class=\"layout-row place-around-center\">\n        <button mat-icon-button (click)=\"model.editor.smartShift(-1)\" [disabled]=\"model.isRangeNotSet()\">\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ model.viewIntervalMessage() }}</span>\n        <button mat-icon-button (click)=\"model.editor.smartShift(1)\" [disabled]=\"model.isRangeNotSet()\">\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n      <!-- calendars and input controls -->\n      <ng-container *ngTemplateOutlet=\"calendarsTemplate\"></ng-container>\n    </div>\n    <div class=\"pt-xs\" style=\"width: 25%\">\n      <div class=\"layout-col gap-lg\">\n        <div class=\"layout-col gap-xs place-start-start\">\n          @if (showHelpText()) {\n            <h5 class=\"mat-h5\">{{ 'intervalPicker.selectSmartInterval' | translate }}</h5>\n          }\n          <!-- select current -->\n          <button mat-button (click)=\"model.editor.selectCurrentWeek()\">\n            {{ 'intervalPicker.currentPeriod.week' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectCurrentMonth()\">\n            {{ 'intervalPicker.currentPeriod.month' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectCurrentQuarter()\">\n            {{ 'intervalPicker.currentPeriod.quarter' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectCurrentYear()\">\n            {{ 'intervalPicker.currentPeriod.year' | translate }}\n          </button>\n        </div>\n        <div class=\"fixed-shifts-container\">\n          <ng-container *ngTemplateOutlet=\"fixedShifts\"></ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"layout-row place-between-center gap-xxl pt-sm\">\n    <div>\n      @if (showAnchor()) {\n        <ng-container *ngTemplateOutlet=\"anchorInputField\"></ng-container>\n      }\n    </div>\n    @if (showResultText()) {\n      <!-- result interval -->\n      <div class=\"layout-col place-center-center\">\n        <div class=\"date-interval mat-caption pt-xs\">\n          @if (model.startDateTimeAsJSDate()) {\n            {{ model.startDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n          } @else {\n            {{ 'intervalPicker.startDateNotSet' | translate }}\n          }\n          <span> - </span>\n          @if (model.endDateTimeAsJSDate()) {\n            {{ model.endDateTimeAsJSDate() | date: 'dd.MM. y, HH:mm:ss' }}\n          } @else {\n            {{ 'intervalPicker.endDateNotSet' | translate }}\n          }\n        </div>\n        <div>\n          <span class=\"mat-caption\">{{ model.deltaHumanReadable() || '&nbsp;' }}</span>\n        </div>\n      </div>\n    }\n    <div class=\"layout-row gap-lg\">\n      <button\n        mat-raised-button\n        color=\"primary\"\n        (click)=\"clearStartAndEndDateTimes()\"\n        [disabled]=\"model.isStartAndEndDatesEmpty()\"\n      >\n        {{ 'intervalPicker.clear' | translate }}\n      </button>\n\n      @if (!this.emitOnChange()) {\n        <button color=\"primary\" mat-raised-button (click)=\"model.emitMainDates()\">\n          {{ 'actions.ok' | translate }}\n        </button>\n      }\n    </div>\n  </div>\n</div>\n\n<ng-template #intervalSelector>\n  <div class=\"layout-col\">\n    @if (showHelpText()) {\n      <h5 class=\"mat-h5\">{{ 'intervalPicker.selectAbsoluteInterval' | translate }}</h5>\n    }\n    <div class=\"layout-row select-buttons-container gap-sm\">\n      <div class=\"layout-col gap-xs place-start-stretch\">\n        <button mat-button (click)=\"model.editor.selectCurrentDay()\">\n          @if (model.isFixedAnchorDateSet()) {\n            {{ 'intervalPicker.anchorDay' | translate }}\n          } @else {\n            {{ 'intervalPicker.today' | translate }}\n          }\n        </button>\n        <button mat-button (click)=\"model.editor.selectYesterday()\">\n          @if (model.isFixedAnchorDateSet()) {\n            {{ 'intervalPicker.last' | translate }} 1 {{ 'intervalPicker.day' | translate }}\n          } @else {\n            {{ 'intervalPicker.yesterday' | translate }}\n          }\n        </button>\n        @if (lastExcludesToday()) {\n          <button mat-button (click)=\"model.editor.selectLastSevenDaysExcludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectLastThirtyDaysExcludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n          </button>\n        } @else {\n          <button mat-button (click)=\"model.editor.selectLastSevenDaysIncludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 7 {{ 'intervalPicker.days' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectLastThirtyDaysIncludingToday()\">\n            {{ 'intervalPicker.last' | translate }} 30 {{ 'intervalPicker.days' | translate }}\n          </button>\n        }\n        @if (intervalInputMode() === 'date-time-range') {\n          <div class=\"pt-sm\"></div>\n          <button mat-button (click)=\"model.editor.selectLastFiveMinutes()\">\n            {{ 'intervalPicker.last' | translate }} 5 {{ 'intervalPicker.minutes' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectLastHour()\">\n            {{ 'intervalPicker.last' | translate }} {{ 'intervalPicker.hour' | translate }}\n          </button>\n          <button mat-button (click)=\"model.editor.selectLast24Hours()\">\n            {{ 'intervalPicker.last' | translate }} 24 {{ 'intervalPicker.hours' | translate }}\n          </button>\n        }\n      </div>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #calendarsTemplate>\n  <div class=\"layout-row place-around-center\" style=\"align-items: flex-start; min-height: 280px\">\n    <mat-calendar\n      #rangeCalendarStart\n      style=\"width: 210px; max-width: 100%\"\n      [selected]=\"model.dateRangeForCalendar()\"\n      (selectedChange)=\"handleStartCalendarChange($event)\"\n      [maxDate]=\"model.endDateAsJSDate()\"\n      [dateClass]=\"calendarAnchorDateCssClassFn\"\n    >\n    </mat-calendar>\n    <mat-calendar\n      #rangeCalendarEnd\n      style=\"width: 210px; max-width: 100%\"\n      [selected]=\"model.dateRangeForCalendar()\"\n      (selectedChange)=\"handleEndCalendarChange($event)\"\n      [minDate]=\"model.startDateAsJSDate()\"\n      [dateClass]=\"calendarAnchorDateCssClassFn\"\n    >\n    </mat-calendar>\n  </div>\n  <div class=\"layout-row place-around-center gap-xl pt-sm\">\n    <div class=\"layout-row place-around-center\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.startDate' | translate }}</mat-label>\n        <input\n          #startDateInput\n          name=\"startDateInput\"\n          matInput\n          type=\"date\"\n          [ngModel]=\"model.startDateHtmlString()\"\n          (ngModelChange)=\"model.setStartDateFromHtmlString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.clearStartDateTime()\"\n          [disabled]=\"!this.model.startDate()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n    <div class=\"layout-row place-around-center\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.endDate' | translate }}</mat-label>\n        <input\n          #endDateInput\n          name=\"endDateInput\"\n          matInput\n          type=\"date\"\n          [ngModel]=\"model.endDateHtmlString()\"\n          (ngModelChange)=\"model.setEndDateFromHtmlString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.clearEndDateTime()\"\n          [disabled]=\"!this.model.endDate()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n  </div>\n  <br />\n  @if (intervalInputMode() === 'date-time-range') {\n    <div class=\"layout-row place-around-center gap-xl pt-sm\">\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.startTime' | translate }}</mat-label>\n        <input\n          name=\"startTimeInput\"\n          matInput\n          type=\"time\"\n          #startTimeControl=\"ngModel\"\n          step=\"1\"\n          [ngModel]=\"model.getStartTimeString()\"\n          (ngModelChange)=\"model.setStartTimeFromString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.model.clearStartTime()\"\n          [disabled]=\"!this.model.isStartTimeSetAndNotMidnight()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n      <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.endTime' | translate }}</mat-label>\n        <input\n          name=\"endTimeInput\"\n          matInput\n          type=\"time\"\n          #endTimeControl=\"ngModel\"\n          step=\"1\"\n          [ngModel]=\"model.getEndTimeString()\"\n          (ngModelChange)=\"model.setEndTimeFromString($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.model.clearEndTime()\"\n          [disabled]=\"!this.model.isEndTimeSetAndNotMidnight()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    </div>\n  }\n</ng-template>\n\n<ng-template #fixedShifts>\n  @if (showHelpText()) {\n    <h5 class=\"mat-h5\">{{ 'intervalPicker.shiftInterval' | translate }}</h5>\n  }\n  <div class=\"layout-col place-start-stretch\">\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"model.editor.shiftDay(-1)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.day' | translate }}</span>\n      <button mat-icon-button (click)=\"model.editor.shiftDay(1)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"model.editor.shiftMonth(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.month' | translate }}</span>\n      <button mat-icon-button (click)=\"model.editor.shiftMonth(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n    <div class=\"layout-row place-between-center\">\n      <button mat-icon-button (click)=\"model.editor.shiftYear(-1, true)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_left</mat-icon>\n      </button>\n      <span>{{ 'intervalPicker.year' | translate }}</span>\n      <button mat-icon-button (click)=\"model.editor.shiftYear(1, true)\" [disabled]=\"model.isRangeNotSet()\">\n        <mat-icon>keyboard_double_arrow_right</mat-icon>\n      </button>\n    </div>\n\n    @if (intervalInputMode() === 'date-time-range') {\n      <!-- shift minute -->\n      <div class=\"layout-row place-between-center\">\n        <button\n          mat-icon-button\n          (click)=\"model.editor.shiftTime(-1, 'minutes')\"\n          [disabled]=\"model.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ 'intervalPicker.minute' | translate }}</span>\n        <button\n          mat-icon-button\n          (click)=\"model.editor.shiftTime(1, 'minutes')\"\n          [disabled]=\"model.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n      <!-- shift hour -->\n      <div class=\"layout-row place-between-center\">\n        <button\n          mat-icon-button\n          (click)=\"model.editor.shiftTime(-1, 'hours')\"\n          [disabled]=\"model.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_left</mat-icon>\n        </button>\n        <span>{{ 'intervalPicker.hour' | translate }}</span>\n        <button\n          mat-icon-button\n          (click)=\"model.editor.shiftTime(1, 'hours')\"\n          [disabled]=\"model.isRangeNotSet()\"\n        >\n          <mat-icon>keyboard_double_arrow_right</mat-icon>\n        </button>\n      </div>\n    }\n  </div>\n</ng-template>\n\n<ng-template #anchorInputField>\n  <div class=\"layout-row flex-none gap-md\">\n    <mat-menu #anchorMenu=\"matMenu\">\n      @if (model.startDate()) {\n        <button\n          mat-menu-item\n          (click)=\"model.setFixedAnchorPointToEndDateTime()\"\n          [disabled]=\"!model.endDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">login</mat-icon>\n          <span>{{ 'intervalPicker.endDate' | translate }}</span>\n        </button>\n      }\n      @if (model.endDate()) {\n        <button\n          mat-menu-item\n          (click)=\"model.setFixedAnchorPointToStartDateTime()\"\n          [disabled]=\"!model.startDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">logout</mat-icon>\n          <span>{{ 'intervalPicker.startDate' | translate }}</span>\n        </button>\n      }\n      @if (model.fixedAnchorDate()) {\n        <button\n          mat-menu-item\n          (click)=\"this.model.resetFixedAnchorPoint()\"\n          [disabled]=\"!model.fixedAnchorDate() || anchorReadOnly()\"\n        >\n          <mat-icon>close</mat-icon>\n          <span>{{ 'intervalPicker.clear' | translate }}</span>\n        </button>\n      }\n    </mat-menu>\n\n    <mat-form-field class=\"input-control-container\" [subscriptSizing]=\"'dynamic'\">\n      <mat-label>{{ 'intervalPicker.anchorDate' | translate }}</mat-label>\n      <elder-local-date-input\n        name=\"anchorDateInput\"\n        (valueUpdated)=\"model.setAnchorDateFromForm($event)\"\n        [value]=\"model.getAnchorPointAsLocaleDate()\"\n        [readonly]=\"anchorReadOnly()\"\n      >\n      </elder-local-date-input>\n      @if (!anchorReadOnly()) {\n        <button\n          mat-icon-button\n          matSuffix\n          [matMenuTriggerFor]=\"anchorMenu\"\n          [disabled]=\"model.isStartAndEndDatesEmpty() && !model.fixedAnchorDate()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">more_horiz</mat-icon>\n        </button>\n      }\n    </mat-form-field>\n    @if (intervalInputMode() === 'date-time-range') {\n      <mat-form-field class=\"input-control-container-short\" [subscriptSizing]=\"'dynamic'\">\n        <mat-label>{{ 'intervalPicker.anchorTime' | translate }}</mat-label>\n        <input\n          matInput\n          name=\"anchorTimeInput\"\n          type=\"time\"\n          #anchorTimeControl=\"ngModel\"\n          step=\"1\"\n          [readonly]=\"anchorReadOnly()\"\n          [ngModel]=\"model.getAnchorTimeString()\"\n          (ngModelChange)=\"model.setAnchorTimeFromForm($event)\"\n        />\n        <button\n          mat-icon-button\n          matSuffix\n          (click)=\"this.model.resetFixedAnchorTime()\"\n          [disabled]=\"!model.isFixedAnchorTimeSetAndNotMidnight() || anchorReadOnly()\"\n        >\n          <mat-icon>close</mat-icon>\n        </button>\n      </mat-form-field>\n    }\n  </div>\n</ng-template>\n"]}