@kirbydesign/designsystem 10.1.3 → 10.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (385) hide show
  1. package/avatar/avatar.component.d.ts +2 -1
  2. package/button/button.component.d.ts +1 -0
  3. package/calendar/calendar.component.d.ts +28 -18
  4. package/calendar/interfaces/calendar-day.d.ts +17 -0
  5. package/calendar/public_api.d.ts +1 -1
  6. package/empty-state/empty-state.component.d.ts +10 -3
  7. package/esm2022/accordion/accordion-item.component.mjs +4 -4
  8. package/esm2022/accordion/accordion.directive.mjs +4 -4
  9. package/esm2022/accordion/accordion.module.mjs +5 -5
  10. package/esm2022/action-group/action-group.component.mjs +4 -4
  11. package/esm2022/avatar/avatar.component.mjs +7 -5
  12. package/esm2022/badge/badge.component.mjs +4 -4
  13. package/esm2022/button/button.component.mjs +18 -6
  14. package/esm2022/calendar/calendar.component.mjs +163 -96
  15. package/esm2022/calendar/interfaces/calendar-day.mjs +2 -0
  16. package/esm2022/calendar/interfaces/calendar-year-navigator-config.mjs +2 -0
  17. package/esm2022/calendar/public_api.mjs +1 -1
  18. package/esm2022/card/card-as-button/card-as-button.directive.mjs +4 -4
  19. package/esm2022/card/card-footer/card-footer.component.mjs +4 -4
  20. package/esm2022/card/card-header/card-header.component.mjs +4 -4
  21. package/esm2022/card/card.component.mjs +4 -4
  22. package/esm2022/card/card.module.mjs +5 -5
  23. package/esm2022/chart/chart/chart.component.mjs +4 -4
  24. package/esm2022/chart/charts.module.mjs +5 -5
  25. package/esm2022/chart/shared/base-chart/base-chart.component.mjs +4 -4
  26. package/esm2022/chart/shared/chart-config-service/chart-config.service.mjs +4 -4
  27. package/esm2022/chart/shared/chart-js-service/chart-js.service.mjs +4 -4
  28. package/esm2022/chart/stock-chart/stock-chart-js.service.mjs +4 -4
  29. package/esm2022/chart/stock-chart/stock-chart.component.mjs +4 -4
  30. package/esm2022/checkbox/checkbox.component.mjs +4 -4
  31. package/esm2022/data-table/data-table.module.mjs +5 -5
  32. package/esm2022/data-table/sortable/sortable.component.mjs +4 -4
  33. package/esm2022/divider/divider.component.mjs +4 -4
  34. package/esm2022/dropdown/dropdown.component.mjs +6 -6
  35. package/esm2022/dropdown/dropdown.module.mjs +5 -5
  36. package/esm2022/dropdown/keyboard-handler.service.mjs +4 -4
  37. package/esm2022/empty-state/empty-state.component.mjs +31 -7
  38. package/esm2022/empty-state/empty-state.module.mjs +5 -5
  39. package/esm2022/fab-sheet/fab-sheet.component.mjs +4 -4
  40. package/esm2022/flag/flag.component.mjs +4 -4
  41. package/esm2022/form-field/directives/affix/affix.directive.mjs +4 -4
  42. package/esm2022/form-field/directives/date/date-input.directive.mjs +4 -4
  43. package/esm2022/form-field/directives/decimal-mask/decimal-mask.directive.mjs +4 -4
  44. package/esm2022/form-field/form-field-message/form-field-message.component.mjs +4 -4
  45. package/esm2022/form-field/form-field.component.mjs +4 -4
  46. package/esm2022/form-field/form-field.module.mjs +8 -7
  47. package/esm2022/form-field/input/input.component.mjs +4 -4
  48. package/esm2022/form-field/input-counter/input-counter.component.mjs +4 -4
  49. package/esm2022/form-field/textarea/textarea.component.mjs +4 -4
  50. package/esm2022/header/header.component.mjs +16 -16
  51. package/esm2022/header/header.module.mjs +5 -5
  52. package/esm2022/helpers/content-mutation-observer.mjs +50 -0
  53. package/esm2022/helpers/element-ancestor-utils.mjs +33 -0
  54. package/esm2022/helpers/ionic-element-part-helper.mjs +4 -4
  55. package/esm2022/helpers/line-clamp-helper.mjs +4 -4
  56. package/esm2022/helpers/platform.service.mjs +4 -4
  57. package/esm2022/helpers/public_api.mjs +3 -2
  58. package/esm2022/icon/icon-registry.service.mjs +4 -4
  59. package/esm2022/icon/icon.component.mjs +4 -4
  60. package/esm2022/icon/icon.module.mjs +5 -5
  61. package/esm2022/item/item.component.mjs +13 -9
  62. package/esm2022/item/item.module.mjs +5 -5
  63. package/esm2022/item/label/label.component.mjs +5 -5
  64. package/esm2022/item-group/item-group.component.mjs +4 -4
  65. package/esm2022/item-sliding/item-sliding.component.mjs +4 -4
  66. package/esm2022/kirby-app/kirby-app.component.mjs +4 -4
  67. package/esm2022/kirby-app/kirby-app.module.mjs +5 -5
  68. package/esm2022/kirby-ionic-module/kirby-ionic.module.mjs +5 -5
  69. package/esm2022/lib/components/segmented-control/segmented-control.component.mjs +34 -7
  70. package/esm2022/lib/directives/key-handler/key-handler.directive.mjs +4 -4
  71. package/esm2022/lib/directives/modal-router-link/modal-router-link.directive.mjs +4 -4
  72. package/esm2022/lib/kirby.module.mjs +5 -5
  73. package/esm2022/list/directives/infinite-scroll.directive.mjs +4 -4
  74. package/esm2022/list/directives/list-item-color.directive.mjs +4 -4
  75. package/esm2022/list/helpers/list-helper.mjs +4 -4
  76. package/esm2022/list/list-experimental/list-experimental.component.mjs +4 -4
  77. package/esm2022/list/list-header/list-header.component.mjs +4 -4
  78. package/esm2022/list/list-item/list-item.component.mjs +5 -5
  79. package/esm2022/list/list-section-header/list-section-header.component.mjs +4 -4
  80. package/esm2022/list/list.component.mjs +5 -5
  81. package/esm2022/list/list.directive.mjs +13 -13
  82. package/esm2022/list/list.module.mjs +5 -5
  83. package/esm2022/loading-overlay/loading-overlay.component.mjs +4 -4
  84. package/esm2022/loading-overlay/loading-overlay.service.mjs +4 -4
  85. package/esm2022/menu/menu.component.mjs +215 -12
  86. package/esm2022/modal/modal/action-sheet/action-sheet.component.mjs +4 -4
  87. package/esm2022/modal/modal/alert/alert.component.mjs +4 -4
  88. package/esm2022/modal/modal/footer/modal-footer.component.mjs +4 -4
  89. package/esm2022/modal/modal/modal-component/modal.component.mjs +18 -8
  90. package/esm2022/modal/modal/services/action-sheet.helper.mjs +4 -4
  91. package/esm2022/modal/modal/services/alert.helper.mjs +4 -4
  92. package/esm2022/modal/modal/services/can-dismiss.helper.mjs +4 -4
  93. package/esm2022/modal/modal/services/modal-animation-builder.service.mjs +4 -4
  94. package/esm2022/modal/modal/services/modal.controller.mjs +4 -4
  95. package/esm2022/modal/modal/services/modal.helper.mjs +5 -4
  96. package/esm2022/modal/modal-navigation.service.mjs +4 -4
  97. package/esm2022/modal/modal-wrapper/compact/modal-compact-wrapper.component.mjs +19 -10
  98. package/esm2022/modal/modal-wrapper/config/modal-config.mjs +1 -1
  99. package/esm2022/modal/modal-wrapper/modal-elements-mover.delegate.mjs +1 -1
  100. package/esm2022/modal/modal-wrapper/modal-wrapper.component.mjs +35 -12
  101. package/esm2022/modal/modal.interfaces.mjs +4 -4
  102. package/esm2022/page/page-footer/page-footer.component.mjs +4 -4
  103. package/esm2022/page/page.component.mjs +39 -38
  104. package/esm2022/page/page.module.mjs +5 -5
  105. package/esm2022/popover/popover.component.mjs +4 -4
  106. package/esm2022/progress-circle/progress-circle-ring.component.mjs +4 -4
  107. package/esm2022/progress-circle/progress-circle.component.mjs +4 -4
  108. package/esm2022/radio/radio-group/radio-group.component.mjs +4 -4
  109. package/esm2022/radio/radio-module.mjs +5 -5
  110. package/esm2022/radio/radio.component.mjs +4 -4
  111. package/esm2022/range/range.component.mjs +4 -4
  112. package/esm2022/reorder-list/reorder-list.component.mjs +5 -5
  113. package/esm2022/router-outlet/router-outlet.component.mjs +4 -4
  114. package/esm2022/router-outlet/router-outlet.module.mjs +5 -5
  115. package/esm2022/section-header/section-header.component.mjs +4 -4
  116. package/esm2022/shared/component-loader.directive.mjs +4 -4
  117. package/esm2022/shared/fit-heading/fit-heading.directive.mjs +4 -4
  118. package/esm2022/shared/floating/floating.directive.mjs +4 -4
  119. package/esm2022/shared/portal/portal.directive.mjs +4 -4
  120. package/esm2022/shared/public_api.mjs +2 -1
  121. package/esm2022/shared/resize-observer/resize-observer.factory.mjs +4 -4
  122. package/esm2022/shared/resize-observer/resize-observer.service.mjs +4 -4
  123. package/esm2022/shared/theme-color/theme-color.directive.mjs +4 -4
  124. package/esm2022/shared/translation/translation.interface.mjs +2 -0
  125. package/esm2022/shared/translation/translation.service.mjs +37 -0
  126. package/esm2022/shared/translation/translations/da.mjs +11 -0
  127. package/esm2022/shared/translation/translations/en.mjs +11 -0
  128. package/esm2022/slide/slide-stretch-height.directive.mjs +4 -4
  129. package/esm2022/slide/slide.directive.mjs +4 -4
  130. package/esm2022/slide/slide.module.mjs +5 -5
  131. package/esm2022/slide/slides.component.mjs +16 -9
  132. package/esm2022/slide-button/slide-button.component.mjs +4 -4
  133. package/esm2022/spinner/spinner.component.mjs +4 -4
  134. package/esm2022/spinner/spinner.module.mjs +5 -5
  135. package/esm2022/tab-navigation/tab-navigation/tab-navigation.component.mjs +4 -4
  136. package/esm2022/tab-navigation/tab-navigation-item/tab-navigation-item.component.mjs +4 -4
  137. package/esm2022/tab-navigation/tab-navigation.module.mjs +5 -5
  138. package/esm2022/tabs/tab-button/tab-button.component.mjs +4 -4
  139. package/esm2022/tabs/tabs.component.mjs +4 -4
  140. package/esm2022/tabs/tabs.module.mjs +5 -5
  141. package/esm2022/tabs/tabs.service.mjs +4 -4
  142. package/esm2022/testing/test-helper.mjs +8 -5
  143. package/esm2022/testing-base/lib/components/mock.accordion-item.component.mjs +4 -4
  144. package/esm2022/testing-base/lib/components/mock.action-group.component.mjs +4 -4
  145. package/esm2022/testing-base/lib/components/mock.action-sheet.component.mjs +4 -4
  146. package/esm2022/testing-base/lib/components/mock.alert.component.mjs +4 -4
  147. package/esm2022/testing-base/lib/components/mock.avatar.component.mjs +4 -4
  148. package/esm2022/testing-base/lib/components/mock.badge.component.mjs +4 -4
  149. package/esm2022/testing-base/lib/components/mock.base-chart.component.mjs +4 -4
  150. package/esm2022/testing-base/lib/components/mock.button.component.mjs +4 -4
  151. package/esm2022/testing-base/lib/components/mock.calendar.component.mjs +4 -4
  152. package/esm2022/testing-base/lib/components/mock.card-footer.component.mjs +4 -4
  153. package/esm2022/testing-base/lib/components/mock.card-header.component.mjs +4 -4
  154. package/esm2022/testing-base/lib/components/mock.card.component.mjs +4 -4
  155. package/esm2022/testing-base/lib/components/mock.chart.component.mjs +4 -4
  156. package/esm2022/testing-base/lib/components/mock.checkbox.component.mjs +4 -4
  157. package/esm2022/testing-base/lib/components/mock.divider.component.mjs +4 -4
  158. package/esm2022/testing-base/lib/components/mock.dropdown.component.mjs +4 -4
  159. package/esm2022/testing-base/lib/components/mock.empty-state.component.mjs +4 -4
  160. package/esm2022/testing-base/lib/components/mock.fab-sheet.component.mjs +4 -4
  161. package/esm2022/testing-base/lib/components/mock.flag.component.mjs +4 -4
  162. package/esm2022/testing-base/lib/components/mock.form-field-message.component.mjs +4 -4
  163. package/esm2022/testing-base/lib/components/mock.form-field.component.mjs +4 -4
  164. package/esm2022/testing-base/lib/components/mock.header.component.mjs +10 -10
  165. package/esm2022/testing-base/lib/components/mock.icon.component.mjs +4 -4
  166. package/esm2022/testing-base/lib/components/mock.input-counter.component.mjs +4 -4
  167. package/esm2022/testing-base/lib/components/mock.input.component.mjs +4 -4
  168. package/esm2022/testing-base/lib/components/mock.item-group.component.mjs +4 -4
  169. package/esm2022/testing-base/lib/components/mock.item-sliding.component.mjs +4 -4
  170. package/esm2022/testing-base/lib/components/mock.item.component.mjs +4 -4
  171. package/esm2022/testing-base/lib/components/mock.kirby-app.component.mjs +4 -4
  172. package/esm2022/testing-base/lib/components/mock.label.component.mjs +4 -4
  173. package/esm2022/testing-base/lib/components/mock.list-experimental.component.mjs +4 -4
  174. package/esm2022/testing-base/lib/components/mock.list-header.component.mjs +4 -4
  175. package/esm2022/testing-base/lib/components/mock.list-item.component.mjs +4 -4
  176. package/esm2022/testing-base/lib/components/mock.list-section-header.component.mjs +4 -4
  177. package/esm2022/testing-base/lib/components/mock.list.component.mjs +4 -4
  178. package/esm2022/testing-base/lib/components/mock.loading-overlay.component.mjs +4 -4
  179. package/esm2022/testing-base/lib/components/mock.menu.component.mjs +4 -4
  180. package/esm2022/testing-base/lib/components/mock.modal-compact-wrapper.component.mjs +4 -4
  181. package/esm2022/testing-base/lib/components/mock.modal-footer.component.mjs +4 -4
  182. package/esm2022/testing-base/lib/components/mock.modal-wrapper.component.mjs +4 -4
  183. package/esm2022/testing-base/lib/components/mock.page-footer.component.mjs +4 -4
  184. package/esm2022/testing-base/lib/components/mock.page.component.mjs +34 -34
  185. package/esm2022/testing-base/lib/components/mock.popover.component.mjs +4 -4
  186. package/esm2022/testing-base/lib/components/mock.progress-circle-ring.component.mjs +4 -4
  187. package/esm2022/testing-base/lib/components/mock.progress-circle.component.mjs +4 -4
  188. package/esm2022/testing-base/lib/components/mock.radio-group.component.mjs +4 -4
  189. package/esm2022/testing-base/lib/components/mock.radio.component.mjs +4 -4
  190. package/esm2022/testing-base/lib/components/mock.range.component.mjs +4 -4
  191. package/esm2022/testing-base/lib/components/mock.reorder-list.component.mjs +4 -4
  192. package/esm2022/testing-base/lib/components/mock.router-outlet.component.mjs +4 -4
  193. package/esm2022/testing-base/lib/components/mock.section-header.component.mjs +4 -4
  194. package/esm2022/testing-base/lib/components/mock.segmented-control.component.mjs +4 -4
  195. package/esm2022/testing-base/lib/components/mock.slide-button.component.mjs +4 -4
  196. package/esm2022/testing-base/lib/components/mock.slides.component.mjs +4 -4
  197. package/esm2022/testing-base/lib/components/mock.spinner.component.mjs +4 -4
  198. package/esm2022/testing-base/lib/components/mock.stock-chart.component.mjs +4 -4
  199. package/esm2022/testing-base/lib/components/mock.tab-button.component.mjs +4 -4
  200. package/esm2022/testing-base/lib/components/mock.tab-navigation-item.component.mjs +4 -4
  201. package/esm2022/testing-base/lib/components/mock.tab-navigation.component.mjs +4 -4
  202. package/esm2022/testing-base/lib/components/mock.tabs.component.mjs +4 -4
  203. package/esm2022/testing-base/lib/components/mock.textarea.component.mjs +4 -4
  204. package/esm2022/testing-base/lib/components/mock.toggle-button.component.mjs +4 -4
  205. package/esm2022/testing-base/lib/components/mock.toggle.component.mjs +4 -4
  206. package/esm2022/testing-base/lib/directives/mock.accordion.directive.mjs +4 -4
  207. package/esm2022/testing-base/lib/directives/mock.affix.directive.mjs +4 -4
  208. package/esm2022/testing-base/lib/directives/mock.card-as-button.directive.mjs +4 -4
  209. package/esm2022/testing-base/lib/directives/mock.component-loader.directive.mjs +4 -4
  210. package/esm2022/testing-base/lib/directives/mock.date-input.directive.mjs +4 -4
  211. package/esm2022/testing-base/lib/directives/mock.decimal-mask.directive.mjs +4 -4
  212. package/esm2022/testing-base/lib/directives/mock.fit-heading.directive.mjs +4 -4
  213. package/esm2022/testing-base/lib/directives/mock.floating.directive.mjs +4 -4
  214. package/esm2022/testing-base/lib/directives/mock.infinite-scroll.directive.mjs +4 -4
  215. package/esm2022/testing-base/lib/directives/mock.key-handler.directive.mjs +4 -4
  216. package/esm2022/testing-base/lib/directives/mock.list-item-color.directive.mjs +4 -4
  217. package/esm2022/testing-base/lib/directives/mock.list.directive.mjs +13 -13
  218. package/esm2022/testing-base/lib/directives/mock.modal-router-link.directive.mjs +4 -4
  219. package/esm2022/testing-base/lib/directives/mock.portal.directive.mjs +4 -4
  220. package/esm2022/testing-base/lib/directives/mock.slide.directive.mjs +4 -4
  221. package/esm2022/testing-base/lib/directives/mock.theme-color.directive.mjs +4 -4
  222. package/esm2022/testing-base/lib/kirby-testing-base.module.mjs +5 -5
  223. package/esm2022/testing-jasmine/lib/kirby-testing.module.mjs +5 -5
  224. package/esm2022/testing-jest/lib/kirby-testing.module.mjs +5 -5
  225. package/esm2022/toast/services/toast.controller.mjs +4 -4
  226. package/esm2022/toast/services/toast.helper.mjs +4 -4
  227. package/esm2022/toggle/toggle.component.mjs +4 -4
  228. package/esm2022/toggle-button/toggle-button.component.mjs +4 -4
  229. package/esm2022/toggle-button/toggle-button.module.mjs +5 -5
  230. package/esm2022/types/public_api.mjs +2 -1
  231. package/esm2022/types/unobserve-fn.mjs +2 -0
  232. package/esm2022/types/window-ref.mjs +4 -4
  233. package/fesm2022/kirbydesign-designsystem-accordion.mjs +10 -10
  234. package/fesm2022/kirbydesign-designsystem-accordion.mjs.map +1 -1
  235. package/fesm2022/kirbydesign-designsystem-action-group.mjs +3 -3
  236. package/fesm2022/kirbydesign-designsystem-action-group.mjs.map +1 -1
  237. package/fesm2022/kirbydesign-designsystem-avatar.mjs +6 -4
  238. package/fesm2022/kirbydesign-designsystem-avatar.mjs.map +1 -1
  239. package/fesm2022/kirbydesign-designsystem-badge.mjs +3 -3
  240. package/fesm2022/kirbydesign-designsystem-badge.mjs.map +1 -1
  241. package/fesm2022/kirbydesign-designsystem-button.mjs +17 -5
  242. package/fesm2022/kirbydesign-designsystem-button.mjs.map +1 -1
  243. package/fesm2022/kirbydesign-designsystem-calendar.mjs +163 -172
  244. package/fesm2022/kirbydesign-designsystem-calendar.mjs.map +1 -1
  245. package/fesm2022/kirbydesign-designsystem-card.mjs +16 -16
  246. package/fesm2022/kirbydesign-designsystem-card.mjs.map +1 -1
  247. package/fesm2022/kirbydesign-designsystem-chart.mjs +22 -22
  248. package/fesm2022/kirbydesign-designsystem-chart.mjs.map +1 -1
  249. package/fesm2022/kirbydesign-designsystem-checkbox.mjs +3 -3
  250. package/fesm2022/kirbydesign-designsystem-checkbox.mjs.map +1 -1
  251. package/fesm2022/kirbydesign-designsystem-data-table.mjs +7 -7
  252. package/fesm2022/kirbydesign-designsystem-data-table.mjs.map +1 -1
  253. package/fesm2022/kirbydesign-designsystem-divider.mjs +3 -3
  254. package/fesm2022/kirbydesign-designsystem-divider.mjs.map +1 -1
  255. package/fesm2022/kirbydesign-designsystem-dropdown.mjs +12 -12
  256. package/fesm2022/kirbydesign-designsystem-dropdown.mjs.map +1 -1
  257. package/fesm2022/kirbydesign-designsystem-empty-state.mjs +33 -9
  258. package/fesm2022/kirbydesign-designsystem-empty-state.mjs.map +1 -1
  259. package/fesm2022/kirbydesign-designsystem-fab-sheet.mjs +3 -3
  260. package/fesm2022/kirbydesign-designsystem-fab-sheet.mjs.map +1 -1
  261. package/fesm2022/kirbydesign-designsystem-flag.mjs +3 -3
  262. package/fesm2022/kirbydesign-designsystem-flag.mjs.map +1 -1
  263. package/fesm2022/kirbydesign-designsystem-form-field.mjs +30 -30
  264. package/fesm2022/kirbydesign-designsystem-form-field.mjs.map +1 -1
  265. package/fesm2022/kirbydesign-designsystem-header.mjs +19 -19
  266. package/fesm2022/kirbydesign-designsystem-header.mjs.map +1 -1
  267. package/fesm2022/kirbydesign-designsystem-helpers.mjs +69 -10
  268. package/fesm2022/kirbydesign-designsystem-helpers.mjs.map +1 -1
  269. package/fesm2022/kirbydesign-designsystem-icon.mjs +10 -10
  270. package/fesm2022/kirbydesign-designsystem-icon.mjs.map +1 -1
  271. package/fesm2022/kirbydesign-designsystem-item-group.mjs +3 -3
  272. package/fesm2022/kirbydesign-designsystem-item-group.mjs.map +1 -1
  273. package/fesm2022/kirbydesign-designsystem-item-sliding.mjs +3 -3
  274. package/fesm2022/kirbydesign-designsystem-item-sliding.mjs.map +1 -1
  275. package/fesm2022/kirbydesign-designsystem-item.mjs +20 -16
  276. package/fesm2022/kirbydesign-designsystem-item.mjs.map +1 -1
  277. package/fesm2022/kirbydesign-designsystem-kirby-app.mjs +7 -7
  278. package/fesm2022/kirbydesign-designsystem-kirby-app.mjs.map +1 -1
  279. package/fesm2022/kirbydesign-designsystem-kirby-ionic-module.mjs +4 -4
  280. package/fesm2022/kirbydesign-designsystem-kirby-ionic-module.mjs.map +1 -1
  281. package/fesm2022/kirbydesign-designsystem-list.mjs +42 -42
  282. package/fesm2022/kirbydesign-designsystem-list.mjs.map +1 -1
  283. package/fesm2022/kirbydesign-designsystem-loading-overlay.mjs +6 -6
  284. package/fesm2022/kirbydesign-designsystem-loading-overlay.mjs.map +1 -1
  285. package/fesm2022/kirbydesign-designsystem-menu.mjs +214 -11
  286. package/fesm2022/kirbydesign-designsystem-menu.mjs.map +1 -1
  287. package/fesm2022/kirbydesign-designsystem-modal.mjs +99 -57
  288. package/fesm2022/kirbydesign-designsystem-modal.mjs.map +1 -1
  289. package/fesm2022/kirbydesign-designsystem-page.mjs +44 -43
  290. package/fesm2022/kirbydesign-designsystem-page.mjs.map +1 -1
  291. package/fesm2022/kirbydesign-designsystem-popover.mjs +3 -3
  292. package/fesm2022/kirbydesign-designsystem-popover.mjs.map +1 -1
  293. package/fesm2022/kirbydesign-designsystem-progress-circle.mjs +6 -6
  294. package/fesm2022/kirbydesign-designsystem-progress-circle.mjs.map +1 -1
  295. package/fesm2022/kirbydesign-designsystem-radio.mjs +10 -10
  296. package/fesm2022/kirbydesign-designsystem-radio.mjs.map +1 -1
  297. package/fesm2022/kirbydesign-designsystem-range.mjs +3 -3
  298. package/fesm2022/kirbydesign-designsystem-range.mjs.map +1 -1
  299. package/fesm2022/kirbydesign-designsystem-reorder-list.mjs +4 -4
  300. package/fesm2022/kirbydesign-designsystem-reorder-list.mjs.map +1 -1
  301. package/fesm2022/kirbydesign-designsystem-router-outlet.mjs +7 -7
  302. package/fesm2022/kirbydesign-designsystem-router-outlet.mjs.map +1 -1
  303. package/fesm2022/kirbydesign-designsystem-section-header.mjs +3 -3
  304. package/fesm2022/kirbydesign-designsystem-section-header.mjs.map +1 -1
  305. package/fesm2022/kirbydesign-designsystem-shared-floating.mjs +3 -3
  306. package/fesm2022/kirbydesign-designsystem-shared-floating.mjs.map +1 -1
  307. package/fesm2022/kirbydesign-designsystem-shared-portal.mjs +3 -3
  308. package/fesm2022/kirbydesign-designsystem-shared-portal.mjs.map +1 -1
  309. package/fesm2022/kirbydesign-designsystem-shared.mjs +71 -17
  310. package/fesm2022/kirbydesign-designsystem-shared.mjs.map +1 -1
  311. package/fesm2022/kirbydesign-designsystem-slide-button.mjs +3 -3
  312. package/fesm2022/kirbydesign-designsystem-slide-button.mjs.map +1 -1
  313. package/fesm2022/kirbydesign-designsystem-slide.mjs +24 -18
  314. package/fesm2022/kirbydesign-designsystem-slide.mjs.map +1 -1
  315. package/fesm2022/kirbydesign-designsystem-spinner.mjs +7 -7
  316. package/fesm2022/kirbydesign-designsystem-spinner.mjs.map +1 -1
  317. package/fesm2022/kirbydesign-designsystem-tab-navigation.mjs +10 -10
  318. package/fesm2022/kirbydesign-designsystem-tab-navigation.mjs.map +1 -1
  319. package/fesm2022/kirbydesign-designsystem-tabs.mjs +13 -13
  320. package/fesm2022/kirbydesign-designsystem-tabs.mjs.map +1 -1
  321. package/fesm2022/kirbydesign-designsystem-testing-base.mjs +286 -286
  322. package/fesm2022/kirbydesign-designsystem-testing-base.mjs.map +1 -1
  323. package/fesm2022/kirbydesign-designsystem-testing-jasmine.mjs +4 -4
  324. package/fesm2022/kirbydesign-designsystem-testing-jasmine.mjs.map +1 -1
  325. package/fesm2022/kirbydesign-designsystem-testing-jest.mjs +4 -4
  326. package/fesm2022/kirbydesign-designsystem-testing-jest.mjs.map +1 -1
  327. package/fesm2022/kirbydesign-designsystem-testing.mjs +7 -4
  328. package/fesm2022/kirbydesign-designsystem-testing.mjs.map +1 -1
  329. package/fesm2022/kirbydesign-designsystem-toast.mjs +6 -6
  330. package/fesm2022/kirbydesign-designsystem-toast.mjs.map +1 -1
  331. package/fesm2022/kirbydesign-designsystem-toggle-button.mjs +7 -7
  332. package/fesm2022/kirbydesign-designsystem-toggle-button.mjs.map +1 -1
  333. package/fesm2022/kirbydesign-designsystem-toggle.mjs +3 -3
  334. package/fesm2022/kirbydesign-designsystem-toggle.mjs.map +1 -1
  335. package/fesm2022/kirbydesign-designsystem-types.mjs +3 -3
  336. package/fesm2022/kirbydesign-designsystem-types.mjs.map +1 -1
  337. package/fesm2022/kirbydesign-designsystem.mjs +43 -16
  338. package/fesm2022/kirbydesign-designsystem.mjs.map +1 -1
  339. package/form-field/form-field.module.d.ts +2 -1
  340. package/helpers/content-mutation-observer.d.ts +8 -0
  341. package/helpers/{element-has-ancestor.d.ts → element-ancestor-utils.d.ts} +1 -0
  342. package/helpers/public_api.d.ts +2 -1
  343. package/icons/svg/accounts-outline.svg +0 -2
  344. package/icons/svg/accounts.svg +0 -2
  345. package/icons/svg/backspace.svg +0 -2
  346. package/icons/svg/camera.svg +0 -2
  347. package/icons/svg/copy.svg +0 -2
  348. package/icons/svg/flag.svg +0 -2
  349. package/icons/svg/inbox-outline.svg +0 -2
  350. package/icons/svg/inbox.svg +0 -2
  351. package/icons/svg/information.svg +0 -2
  352. package/icons/svg/menu-outline.svg +0 -2
  353. package/icons/svg/menu.svg +0 -2
  354. package/icons/svg/person-outline.svg +0 -2
  355. package/icons/svg/person.svg +0 -2
  356. package/icons/svg/reorder.svg +0 -2
  357. package/icons/svg/support.svg +0 -2
  358. package/item/item.component.d.ts +3 -2
  359. package/lib/components/segmented-control/segmented-control.component.d.ts +4 -0
  360. package/menu/menu.component.d.ts +32 -8
  361. package/modal/modal/modal-component/modal.component.d.ts +6 -3
  362. package/modal/modal-wrapper/compact/modal-compact-wrapper.component.d.ts +4 -2
  363. package/modal/modal-wrapper/config/modal-config.d.ts +3 -0
  364. package/modal/modal-wrapper/modal-wrapper.component.d.ts +8 -3
  365. package/package.json +2 -2
  366. package/page/page.component.d.ts +4 -3
  367. package/scss/base/_item-typography.scss +1 -0
  368. package/shared/public_api.d.ts +1 -0
  369. package/shared/translation/translation.interface.d.ts +10 -0
  370. package/shared/translation/translation.service.d.ts +12 -0
  371. package/shared/translation/translations/da.d.ts +2 -0
  372. package/shared/translation/translations/en.d.ts +2 -0
  373. package/slide/slides.component.d.ts +3 -1
  374. package/testing/test-helper.d.ts +1 -0
  375. package/types/public_api.d.ts +1 -0
  376. package/types/unobserve-fn.d.ts +1 -0
  377. package/calendar/helpers/calendar-cell.model.d.ts +0 -9
  378. package/calendar/helpers/calendar-options.model.d.ts +0 -9
  379. package/calendar/helpers/calendar.helper.d.ts +0 -24
  380. package/esm2022/calendar/helpers/calendar-cell.model.mjs +0 -2
  381. package/esm2022/calendar/helpers/calendar-options.model.mjs +0 -2
  382. package/esm2022/calendar/helpers/calendar.helper.mjs +0 -80
  383. package/esm2022/calendar/options/calendar-year-navigator-config.mjs +0 -2
  384. package/esm2022/helpers/element-has-ancestor.mjs +0 -24
  385. /package/calendar/{options → interfaces}/calendar-year-navigator-config.d.ts +0 -0
@@ -1,15 +1,16 @@
1
- import { Component, ElementRef, EventEmitter, HostBinding, Inject, Input, LOCALE_ID, Output, ViewChild, } from '@angular/core';
2
- import { add, eachDayOfInterval, endOfWeek, format, getYear, isAfter, isBefore, isSameDay, isSameMonth, isWeekend, startOfDay, startOfMonth, startOfWeek, } from 'date-fns';
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, Inject, Input, LOCALE_ID, Output, } from '@angular/core';
3
+ import { add, eachDayOfInterval, endOfWeek, format, getYear, isAfter, isBefore, isSameDay, isSameMonth, isWeekend, lastDayOfWeek, startOfDay, startOfMonth, startOfWeek, } from 'date-fns';
3
4
  import { utcToZonedTime, zonedTimeToUtc } from 'date-fns-tz';
4
5
  import { da, enGB, enUS } from 'date-fns/locale';
5
6
  import { capitalizeFirstLetter } from '@kirbydesign/core';
6
- import { CommonModule } from '@angular/common';
7
- import { IconModule } from '@kirbydesign/designsystem/icon';
8
- import { DropdownModule } from '@kirbydesign/designsystem/dropdown';
9
7
  import { ButtonComponent } from '@kirbydesign/designsystem/button';
10
- import { CalendarHelper } from './helpers/calendar.helper';
8
+ import { DropdownModule } from '@kirbydesign/designsystem/dropdown';
9
+ import { UniqueIdGenerator } from '@kirbydesign/designsystem/helpers';
10
+ import { IconModule } from '@kirbydesign/designsystem/icon';
11
+ import { TranslationService } from '@kirbydesign/designsystem/shared';
11
12
  import * as i0 from "@angular/core";
12
- import * as i1 from "./helpers/calendar.helper";
13
+ import * as i1 from "@kirbydesign/designsystem/shared";
13
14
  import * as i2 from "@kirbydesign/designsystem/dropdown";
14
15
  import * as i3 from "@kirbydesign/designsystem/icon";
15
16
  import * as i4 from "@angular/common";
@@ -39,6 +40,7 @@ export class CalendarComponent {
39
40
  }
40
41
  if (this.hasDateChanged(value, this._selectedDate)) {
41
42
  this.onSelectedDateChange(value);
43
+ this.focusDate(value);
42
44
  this._selectedDate = value;
43
45
  }
44
46
  }
@@ -98,8 +100,13 @@ export class CalendarComponent {
98
100
  get _hasYearNavigator() {
99
101
  return !!this.yearNavigatorOptions;
100
102
  }
101
- constructor(calendarHelper, locale) {
102
- this.calendarHelper = calendarHelper;
103
+ getTodayDate() {
104
+ return startOfDay(this.todayDate ?? new Date());
105
+ }
106
+ constructor(locale, elementRef, cdr, translations) {
107
+ this.elementRef = elementRef;
108
+ this.cdr = cdr;
109
+ this.translations = translations;
103
110
  this.dateChange = new EventEmitter();
104
111
  this.dateSelect = new EventEmitter();
105
112
  this.yearSelect = new EventEmitter();
@@ -116,6 +123,7 @@ export class CalendarComponent {
116
123
  For context see: https://github.com/kirbydesign/designsystem/issues/2087
117
124
  */
118
125
  this.usePopover = false;
126
+ this._tableMonthId = UniqueIdGenerator.scopedTo('kirby-calendar-month').next();
119
127
  this._disabledDates = [];
120
128
  this._enabledDates = [];
121
129
  this.includedLocales = { da, enGB, enUS };
@@ -135,13 +143,21 @@ export class CalendarComponent {
135
143
  const availableLocales = { ...this.includedLocales, ...this.locales, ...this.customLocales };
136
144
  return availableLocales[locale] || this.includedLocales.enGB; // Default to enGB if injected locale doesnt exist
137
145
  }
146
+ formatDateLabel() {
147
+ const localeDateFormats = {
148
+ da: 'd. MMMM',
149
+ 'en-GB': 'd MMMM',
150
+ 'en-US': 'MMMM d',
151
+ };
152
+ const defaultDateFormat = localeDateFormats['en-US'];
153
+ const dateFormat = localeDateFormats[this.locale.code] || defaultDateFormat;
154
+ return dateFormat;
155
+ }
138
156
  ngOnInit() {
157
+ this.focussedDate = this.getTodayDate();
139
158
  this._weekDays = this.getWeekDays();
140
159
  this.setActiveMonth(this.selectedDate);
141
160
  }
142
- ngAfterViewInit() {
143
- this.calendarHelper.init(this.calendarContainer, this.getHelperOptions(), this._onDateSelected.bind(this), this.onChangeMonth.bind(this));
144
- }
145
161
  ngOnChanges(changes) {
146
162
  if (!this.activeMonth)
147
163
  return;
@@ -155,14 +171,12 @@ export class CalendarComponent {
155
171
  changes.todayDate ||
156
172
  changes.timezone) {
157
173
  this.refreshActiveMonth();
158
- this.calendarHelper.update(this.getHelperOptions());
159
174
  }
160
175
  }
161
176
  setActiveMonth(date = new Date()) {
162
177
  if (!this.activeMonth || !isSameMonth(this.activeMonth, date)) {
163
178
  this.activeMonth = startOfMonth(date);
164
179
  this.refreshActiveMonth();
165
- this.calendarHelper.update(this.getHelperOptions());
166
180
  }
167
181
  }
168
182
  // For leniency, the component will accept any Date that points to either UTC midnight
@@ -192,10 +206,12 @@ export class CalendarComponent {
192
206
  start: startOfWeek(now, { locale: this.locale }),
193
207
  end: endOfWeek(now, { locale: this.locale }),
194
208
  });
195
- return week.map((date) => this.getFirstLetterOfWeekDayCapitalized(date));
196
- }
197
- getFirstLetterOfWeekDayCapitalized(date) {
198
- return this.formatWithLocale(date, 'EEEEE');
209
+ const weekdayNarrowFormat = 'EEEEE';
210
+ const weekdayWideFormat = 'EEEE';
211
+ return week.map((date) => ({
212
+ firstLetterCapitalized: this.formatWithLocale(date, weekdayNarrowFormat),
213
+ fullName: this.formatWithLocale(date, weekdayWideFormat),
214
+ }));
199
215
  }
200
216
  hasDateChanged(newDate, previousDate) {
201
217
  if (!newDate && !previousDate) {
@@ -218,66 +234,64 @@ export class CalendarComponent {
218
234
  return;
219
235
  const monthStart = startOfMonth(this.activeMonth);
220
236
  const startOfFirstWeek = startOfWeek(monthStart, { locale: this.locale });
221
- const today = this.todayDate ? startOfDay(this.todayDate) : startOfDay(new Date());
222
237
  const totalNumberOfDays = 42; // Always show 42 days (6 weeks) in calendar
223
238
  const daysArray = Array.from(Array(totalNumberOfDays).keys());
224
- const days = daysArray.map((number) => {
225
- const cellDate = add(startOfFirstWeek, { [TimeUnit.days]: number });
226
- const day = this.getCalendarDay(cellDate, today, monthStart);
227
- const isSelectable = this.isSelectable(day, cellDate);
228
- const isSelected = isSameDay(this.selectedDate, cellDate);
229
- const cell = {
230
- date: cellDate.getDate(),
231
- monthIndex: cellDate.getMonth(),
232
- year: cellDate.getFullYear(),
233
- isCurrentMonth: day.isCurrentMonth,
234
- isSelectable,
235
- isSelected,
236
- cssClasses: this.getCssClasses(day, isSelectable, isSelected),
239
+ const today = this.getTodayDate();
240
+ const calendarDays = daysArray.map((number) => {
241
+ const dateOfCalendarDay = add(startOfFirstWeek, { [TimeUnit.days]: number });
242
+ const calendarDay = {
243
+ date: dateOfCalendarDay.getDate(),
244
+ monthIndex: dateOfCalendarDay.getMonth(),
245
+ year: dateOfCalendarDay.getFullYear(),
246
+ ariaLabel: this.formatWithLocale(dateOfCalendarDay, this.formatDateLabel()),
247
+ ...this.getCalendarDayMetadata(dateOfCalendarDay, today, monthStart),
237
248
  };
238
- if (isSelected) {
239
- this.selectedDay = cell;
249
+ if (calendarDay.isSelected) {
250
+ this.selectedDay = calendarDay;
240
251
  }
241
- return cell;
252
+ if (calendarDay.isFocussed) {
253
+ this.focussedDay = calendarDay;
254
+ }
255
+ return calendarDay;
242
256
  });
243
- this._month = this.chunk(days, 7);
257
+ this._month = this.chunk(calendarDays, 7);
244
258
  }
245
- getCalendarDay(date, today, monthStart) {
259
+ getCalendarDayMetadata(date, today, monthStart) {
246
260
  return {
247
261
  isToday: isSameDay(today, date),
248
262
  isPast: isBefore(date, today),
249
263
  isFuture: isAfter(date, today),
250
264
  isWeekend: isWeekend(date),
251
265
  isCurrentMonth: isSameMonth(date, monthStart),
252
- isDisabled: this.isDisabledDate(date) || !this.isEnabledDate(date),
266
+ isSelectable: this.isSelectable(date, today),
267
+ isFocusable: this.isWithinAllowedRange(date, today),
268
+ isSelected: isSameDay(this.selectedDate, date),
269
+ isFocussed: isSameDay(this.focussedDate, date),
253
270
  };
254
271
  }
255
- isSelectable(day, date) {
256
- return ((this.alwaysEnableToday && day.isToday) ||
257
- (!day.isDisabled &&
258
- !(this.disableWeekends && day.isWeekend) &&
259
- !(this.disablePastDates && day.isPast) &&
260
- !(this.disableFutureDates && day.isFuture) &&
261
- !(this.minDate && isBefore(date, this.minDate)) &&
262
- !(this.maxDate && isAfter(date, this.maxDate))));
263
- }
264
- getCssClasses(day, isSelectable, isSelected) {
265
- const cssClasses = {
266
- 'current-month': day.isCurrentMonth,
267
- weekend: day.isWeekend,
268
- today: day.isToday,
269
- selectable: isSelectable,
270
- selected: isSelected,
271
- past: day.isPast,
272
- disabled: day.isDisabled,
273
- };
274
- let cssClassString = 'day';
275
- for (const key in cssClasses) {
276
- if (cssClasses[key]) {
277
- cssClassString += ' ' + key;
278
- }
279
- }
280
- return cssClassString;
272
+ isSelectable(date, today) {
273
+ if (this.alwaysEnableToday && isSameDay(today, date))
274
+ return true;
275
+ if (!this.isWithinAllowedRange(date, today))
276
+ return false;
277
+ if (this.isDisabledDate(date))
278
+ return false;
279
+ if (!this.isEnabledDate(date))
280
+ return false;
281
+ if (this.disableWeekends && isWeekend(date))
282
+ return false;
283
+ return true;
284
+ }
285
+ isWithinAllowedRange(date, today) {
286
+ if (this.disablePastDates && isBefore(date, today))
287
+ return false;
288
+ if (this.disableFutureDates && isAfter(date, today))
289
+ return false;
290
+ if (this.minDate && isBefore(date, this.minDate))
291
+ return false;
292
+ if (this.maxDate && isAfter(date, this.maxDate))
293
+ return false;
294
+ return true;
281
295
  }
282
296
  chunk(array, size) {
283
297
  const results = [];
@@ -290,14 +304,11 @@ export class CalendarComponent {
290
304
  if (this.selectedDay) {
291
305
  this.selectedDay.isSelected = false;
292
306
  }
293
- const newDay = this.getCell(newDate);
307
+ const newDay = this.getDay(newDate);
294
308
  if (newDay) {
295
309
  newDay.isSelected = true;
296
310
  this.selectedDay = newDay;
297
311
  }
298
- if (newDate) {
299
- this.calendarHelper.setSelectedDay(newDate.getDate());
300
- }
301
312
  }
302
313
  _onDateSelected(newDay) {
303
314
  if (!newDay.isSelectable)
@@ -310,16 +321,16 @@ export class CalendarComponent {
310
321
  if (this.hasDateChanged(newDate, this._selectedDate)) {
311
322
  this.setActiveMonth(newDate);
312
323
  this.onSelectedDateChange(newDate);
313
- this._selectedDate = newDate;
324
+ this.selectedDate = newDate;
314
325
  this.dateChange.emit(dateToEmit);
315
326
  }
316
327
  this.dateSelect.emit(dateToEmit);
317
328
  }
318
- onChangeMonth(direction) {
319
- this._changeMonth(direction);
320
- this.calendarHelper.update(this.getHelperOptions());
321
- }
322
329
  _changeMonth(index) {
330
+ if (index > 0 && !this._canNavigateForward)
331
+ return;
332
+ if (index < 0 && !this._canNavigateBack)
333
+ return;
323
334
  this.changeActiveView(index, TimeUnit.months);
324
335
  index > 0
325
336
  ? this.nextMonthClicked.emit(this.activeMonth)
@@ -334,21 +345,24 @@ export class CalendarComponent {
334
345
  if (index === 0)
335
346
  return;
336
347
  this.activeMonth = add(this.activeMonth, { [unit]: index });
348
+ this.focussedDate = add(this.focussedDate, { [unit]: index });
337
349
  this.refreshActiveMonth();
338
350
  }
339
351
  get _canNavigateBack() {
340
- const reachedPastDatesLimit = this.disablePastDates && isSameMonth(this.activeMonth, this.todayDate);
352
+ const today = this.getTodayDate();
353
+ const reachedPastDatesLimit = this.disablePastDates && isSameMonth(this.activeMonth, today);
341
354
  const reachedOrExceededMinDate = this.minDate &&
342
355
  (isSameMonth(this.activeMonth, this.minDate) || isBefore(this.activeMonth, this.minDate));
343
356
  return !reachedPastDatesLimit && !reachedOrExceededMinDate;
344
357
  }
345
358
  get _canNavigateForward() {
346
- const reachedFutureDatesLimit = this.disableFutureDates && isSameMonth(this.activeMonth, this.todayDate);
359
+ const today = this.getTodayDate();
360
+ const reachedFutureDatesLimit = this.disableFutureDates && isSameMonth(this.activeMonth, today);
347
361
  const reachedOrExceededMaxDate = this.maxDate &&
348
362
  (isSameMonth(this.activeMonth, this.maxDate) || isAfter(this.activeMonth, this.maxDate));
349
363
  return !reachedFutureDatesLimit && !reachedOrExceededMaxDate;
350
364
  }
351
- getCell(date) {
365
+ getDay(date) {
352
366
  let foundDay = null;
353
367
  if (date) {
354
368
  for (const week of this._month) {
@@ -362,16 +376,6 @@ export class CalendarComponent {
362
376
  }
363
377
  return foundDay;
364
378
  }
365
- getHelperOptions() {
366
- return {
367
- canNavigateBack: this._canNavigateBack,
368
- canNavigateForward: this._canNavigateForward,
369
- year: this.activeYear,
370
- monthName: this.activeMonthName,
371
- weekDays: this._weekDays,
372
- month: this._month,
373
- };
374
- }
375
379
  subtractTimezoneOffset(date) {
376
380
  const timezoneOffsetInMs = date.getTimezoneOffset() * 60 * 1000;
377
381
  return new Date(date.getTime() - timezoneOffsetInMs);
@@ -388,19 +392,82 @@ export class CalendarComponent {
388
392
  const numberOfYears = endYear - startYear;
389
393
  return Array.from({ length: numberOfYears + 1 }, (_, i) => (startYear + i).toString());
390
394
  }
391
- /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CalendarComponent, deps: [{ token: i1.CalendarHelper }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component }); }
392
- /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: CalendarComponent, isStandalone: true, selector: "kirby-calendar", inputs: { timezone: "timezone", disableWeekends: "disableWeekends", disablePastDates: "disablePastDates", disableFutureDates: "disableFutureDates", alwaysEnableToday: "alwaysEnableToday", locales: "locales", customLocales: "customLocales", usePopover: "usePopover", yearNavigatorOptions: "yearNavigatorOptions", selectedDate: "selectedDate", disabledDates: "disabledDates", enabledDates: "enabledDates", todayDate: "todayDate", minDate: "minDate", maxDate: "maxDate" }, outputs: { dateChange: "dateChange", dateSelect: "dateSelect", yearSelect: "yearSelect", previousMonthClicked: "previousMonthClicked", nextMonthClicked: "nextMonthClicked" }, host: { properties: { "class.has-year-navigator": "this._hasYearNavigator" } }, providers: [CalendarHelper], viewQueries: [{ propertyName: "calendarContainer", first: true, predicate: ["calendarContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"header\">\n <div class=\"month-navigator\">\n <button\n type=\"button\"\n [disabled]=\"!_canNavigateBack\"\n (click)=\"_changeMonth(-1)\"\n kirby-button\n [noDecoration]=\"true\"\n class=\"no-margin\"\n >\n <kirby-icon name=\"arrow-back\"></kirby-icon>\n </button>\n\n <div class=\"month-and-year\">\n <span class=\"month\">{{ activeMonthName }}</span>\n <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n </div>\n\n <button\n type=\"button\"\n [disabled]=\"!_canNavigateForward\"\n (click)=\"_changeMonth(1)\"\n kirby-button\n [noDecoration]=\"true\"\n class=\"no-margin\"\n >\n <kirby-icon name=\"arrow-more\"></kirby-icon>\n </button>\n </div>\n <kirby-dropdown\n *ngIf=\"_hasYearNavigator\"\n [usePopover]=\"usePopover\"\n [selectedIndex]=\"navigatedYear\"\n [items]=\"navigableYears\"\n popout=\"left\"\n (change)=\"_changeYear($event)\"\n ></kirby-dropdown>\n</div>\n\n<table>\n <thead>\n <tr>\n <th *ngFor=\"let weekDay of _weekDays\">{{ weekDay }}</th>\n </tr>\n </thead>\n\n <tbody>\n <tr *ngFor=\"let week of _month\">\n <td *ngFor=\"let day of week\">\n <div\n (click)=\"_onDateSelected(day)\"\n class=\"{{ day.cssClasses }} contain-state-layer\"\n [class.selected]=\"day.isSelected\"\n >\n <span class=\"state-layer\" aria-hidden=\"true\"></span>\n <span class=\"content-layer\">{{ day.date }}</span>\n </div>\n </td>\n </tr>\n </tbody>\n</table>\n\n<!-- <iframe src=\"kirby/components/calendar/calendar.webview.html\" #calendarContainer style=\"width: 320px; height: 304px; border: 0\"> -->\n", styles: ["table{width:100%;border-collapse:collapse;-webkit-user-select:none;user-select:none;margin-bottom:8px}th,td{text-align:center;padding:0}th:first-child,td:first-child{padding-left:8px}th:last-child,td:last-child{padding-right:8px}th{height:50px;border-bottom:1px solid var(--kirby-background-color)}.header,th,td{background-color:transparent}.header{display:flex;justify-content:space-between;margin:8px 8px 0}.month-navigator{display:flex;flex-grow:1;align-items:center;justify-content:space-between}.month-navigator button:disabled{opacity:.5;pointer-events:none}.month-and-year{-webkit-user-select:none;user-select:none}.month-and-year .month{font-weight:700;margin-right:8px}:host(.has-year-navigator) .month-navigator{flex-grow:0}:host(.has-year-navigator) .month-and-year{width:80px;margin:0 8px;text-align:center}:host(.has-year-navigator) .month{margin-right:0}.day{display:inline-flex;align-items:center;justify-content:center;border-radius:20px;width:40px;height:40px;margin:4px 0;color:var(--color, var(--kirby-black));background-color:var(--background-color, transparent)}.day.disabled,.day:not(.selectable){--color: #b4b4b4;pointer-events:none}.day.selectable:not(.current-month){--color: var(--kirby-text-color-semi-dark)}@media (hover: hover){.day.today:hover{--state-layer-opacity: .08;--state-layer-background-color: var(--kirby-black);cursor:pointer}}.day.today:active,.day.today.interaction-state-active{--state-layer-opacity: .16;--state-layer-background-color: var(--kirby-black)}.day.today{color:var(--kirby-medium-contrast);background-color:var(--kirby-medium)}@media (hover: hover){.day.selected:hover{--state-layer-opacity: .24;--state-layer-background-color: var(--kirby-black-contrast);cursor:pointer}}.day.selected:active,.day.selected.interaction-state-active{--state-layer-opacity: .36;--state-layer-background-color: var(--kirby-black-contrast)}.day.selected{color:var(--kirby-black-contrast);background-color:var(--kirby-black)}.contain-state-layer{--state-layer-opacity: 0;--state-layer-background-color: var(--kirby-black);position:relative}.contain-state-layer .content-layer{position:relative;z-index:var(--content-layer-z-index, 1)}.contain-state-layer .state-layer{position:absolute;inset:0;overflow:hidden;pointer-events:none;border-radius:inherit;z-index:2}.contain-state-layer .state-layer:before{transition:all 80ms linear 0ms;content:\"\";position:absolute;pointer-events:none;inset:-50%;opacity:var(--state-layer-opacity, 0);background-color:var(--state-layer-background-color, var(--kirby-black))}@media (hover: hover){.contain-state-layer:hover{--state-layer-opacity: .08;--state-layer-background-color: var(--kirby-black);cursor:pointer}}.contain-state-layer:active,.contain-state-layer.interaction-state-active{--state-layer-opacity: .16;--state-layer-background-color: var(--kirby-black)}\n"], dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i2.DropdownComponent, selector: "kirby-dropdown", inputs: ["items", "selectedIndex", "focusedIndex", "itemTextProperty", "placeholder", "popout", "attentionLevel", "expand", "disabled", "hasError", "size", "tabindex", "usePopover"], outputs: ["change"] }, { kind: "component", type: ButtonComponent, selector: "button[kirby-button],Button[kirby-button],a[kirby-button]", inputs: ["attentionLevel", "noDecoration", "themeColor", "expand", "isFloating", "size", "showIconOnly"] }, { kind: "ngmodule", type: IconModule }, { kind: "component", type: i3.IconComponent, selector: "kirby-icon", inputs: ["size", "name"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
395
+ setFocussedDay(newDate) {
396
+ const newDay = this.getDay(newDate);
397
+ if (!newDay)
398
+ return;
399
+ if (this.focussedDay) {
400
+ this.focussedDay.isFocussed = false;
401
+ }
402
+ newDay.isFocussed = true;
403
+ this.focussedDay = newDay;
404
+ }
405
+ focusDate(newDate) {
406
+ if (!newDate)
407
+ return;
408
+ if (this.timezone === 'UTC') {
409
+ newDate = zonedTimeToUtc(this.subtractTimezoneOffset(newDate), this.timeZoneName);
410
+ }
411
+ const today = this.getTodayDate();
412
+ if (!this.isWithinAllowedRange(newDate, today))
413
+ return;
414
+ if (!this.hasDateChanged(newDate, this.focussedDate))
415
+ return;
416
+ this.setActiveMonth(newDate);
417
+ this.setFocussedDay(newDate);
418
+ this.focussedDate = newDate;
419
+ this.cdr.detectChanges(); //sync focussed class to template before setting focus
420
+ const elementMarkedForFocus = this.elementRef.nativeElement.querySelector('.focussed');
421
+ elementMarkedForFocus.focus();
422
+ }
423
+ _onDateKeydown(event) {
424
+ const { key, shiftKey } = event;
425
+ let newDate;
426
+ switch (key) {
427
+ case 'ArrowUp':
428
+ newDate = add(this.focussedDate, { days: -7 });
429
+ break;
430
+ case 'ArrowDown':
431
+ newDate = add(this.focussedDate, { days: 7 });
432
+ break;
433
+ case 'ArrowRight':
434
+ newDate = add(this.focussedDate, { days: 1 });
435
+ break;
436
+ case 'ArrowLeft':
437
+ newDate = add(this.focussedDate, { days: -1 });
438
+ break;
439
+ case 'Home':
440
+ newDate = startOfWeek(this.focussedDate, { locale: this.locale });
441
+ break;
442
+ case 'End':
443
+ newDate = lastDayOfWeek(this.focussedDate, { locale: this.locale });
444
+ break;
445
+ case 'PageUp':
446
+ newDate = shiftKey
447
+ ? add(this.focussedDate, { years: -1 })
448
+ : add(this.focussedDate, { months: -1 });
449
+ break;
450
+ case 'PageDown':
451
+ newDate = shiftKey
452
+ ? add(this.focussedDate, { years: 1 })
453
+ : add(this.focussedDate, { months: 1 });
454
+ break;
455
+ default:
456
+ return;
457
+ }
458
+ event.preventDefault();
459
+ this.focusDate(newDate);
460
+ }
461
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarComponent, deps: [{ token: LOCALE_ID }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.TranslationService }], target: i0.ɵɵFactoryTarget.Component }); }
462
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CalendarComponent, isStandalone: true, selector: "kirby-calendar", inputs: { timezone: "timezone", disableWeekends: "disableWeekends", disablePastDates: "disablePastDates", disableFutureDates: "disableFutureDates", alwaysEnableToday: "alwaysEnableToday", locales: "locales", customLocales: "customLocales", usePopover: "usePopover", yearNavigatorOptions: "yearNavigatorOptions", selectedDate: "selectedDate", disabledDates: "disabledDates", enabledDates: "enabledDates", todayDate: "todayDate", minDate: "minDate", maxDate: "maxDate" }, outputs: { dateChange: "dateChange", dateSelect: "dateSelect", yearSelect: "yearSelect", previousMonthClicked: "previousMonthClicked", nextMonthClicked: "nextMonthClicked" }, host: { properties: { "class.has-year-navigator": "this._hasYearNavigator" } }, usesOnChanges: true, ngImport: i0, template: "<div class=\"header\">\n <div class=\"month-navigator\">\n <button\n kirby-button\n type=\"button\"\n class=\"no-margin\"\n [attr.aria-label]=\"translations.get('previousMonth')\"\n [attr.aria-disabled]=\"_canNavigateBack ? null : true\"\n [noDecoration]=\"true\"\n (click)=\"_changeMonth(-1)\"\n >\n <kirby-icon name=\"arrow-back\" aria-hidden=\"true\"></kirby-icon>\n </button>\n\n <div class=\"month-and-year\" [id]=\"_tableMonthId\" aria-live=\"polite\" aria-atomic=\"true\">\n <span class=\"month\">{{ activeMonthName }}</span>\n <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n </div>\n\n <button\n kirby-button\n type=\"button\"\n class=\"no-margin\"\n [attr.aria-label]=\"translations.get('nextMonth')\"\n [attr.aria-disabled]=\"_canNavigateForward ? null : true\"\n [noDecoration]=\"true\"\n (click)=\"_changeMonth(1)\"\n >\n <kirby-icon name=\"arrow-more\" aria-hidden=\"true\"></kirby-icon>\n </button>\n </div>\n <kirby-dropdown\n *ngIf=\"_hasYearNavigator\"\n [usePopover]=\"usePopover\"\n [selectedIndex]=\"navigatedYear\"\n [items]=\"navigableYears\"\n [attr.aria-label]=\"translations.get('selectYear')\"\n popout=\"left\"\n (change)=\"_changeYear($event)\"\n ></kirby-dropdown>\n</div>\n\n<table [attr.aria-labelledby]=\"_tableMonthId\" role=\"grid\">\n <thead>\n <tr>\n <th *ngFor=\"let weekDay of _weekDays\" scope=\"col\">\n <span aria-hidden=\"true\">{{ weekDay.firstLetterCapitalized }}</span>\n <span class=\"visually-hidden\">{{ weekDay.fullName }}</span>\n </th>\n </tr>\n </thead>\n\n <tbody>\n <tr *ngFor=\"let week of _month\">\n <td *ngFor=\"let day of week\" [attr.aria-selected]=\"day.isSelected ? true : false\">\n <button\n kirby-button\n type=\"button\"\n (click)=\"_onDateSelected(day)\"\n (keydown)=\"_onDateKeydown($event)\"\n class=\"day\"\n [class.current-month]=\"day.isCurrentMonth\"\n [class.weekend]=\"day.isWeekend\"\n [class.today]=\"day.isToday\"\n [class.selectable]=\"day.isSelectable\"\n [class.selected]=\"day.isSelected\"\n [class.focussed]=\"day.isFocussed\"\n [class.past]=\"day.isPast\"\n [attr.aria-label]=\"day.ariaLabel\"\n [attr.aria-disabled]=\"day.isSelectable ? null : true\"\n [noDecoration]=\"true\"\n [disabled]=\"day.isFocusable ? null : true\"\n [tabIndex]=\"day.isFocussed ? 0 : -1\"\n >\n {{ day.date }}\n </button>\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [":host{font-size:16px}table{width:100%;border-collapse:collapse;-webkit-user-select:none;user-select:none;margin-bottom:8px}th,td{text-align:center;padding:0}th:first-child,td:first-child{padding-left:8px}th:last-child,td:last-child{padding-right:8px}th{height:50px;border-bottom:1px solid var(--kirby-background-color)}.header,th,td{background-color:transparent}.header{display:flex;justify-content:space-between;margin:8px 8px 0}.month-navigator{display:flex;flex-grow:1;align-items:center;justify-content:space-between}.month-and-year{-webkit-user-select:none;user-select:none;font-weight:700}.month-and-year .month{margin-right:8px}:host(.has-year-navigator) .month-navigator{flex-grow:0}:host(.has-year-navigator) .month-and-year{width:80px;margin:0 8px;text-align:center}:host(.has-year-navigator) .month{margin-right:0}.day{display:inline-flex;align-items:center;justify-content:center;border-radius:20px;min-width:40px;min-height:40px;width:40px;height:40px;margin:4px 0;font-size:16px}.day:focus{z-index:1}button[aria-disabled=true]{color:#b4b4b4}.day.selectable:not(.current-month,.selected){color:var(--kirby-text-color-semi-dark)}.day.today{color:var(--kirby-medium-contrast);background-color:var(--kirby-medium)}.day.selected{color:var(--kirby-black-contrast);background-color:var(--kirby-black)}.visually-hidden{position:absolute;scale:0}\n"], dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i2.DropdownComponent, selector: "kirby-dropdown", inputs: ["items", "selectedIndex", "focusedIndex", "itemTextProperty", "placeholder", "popout", "attentionLevel", "expand", "disabled", "hasError", "size", "tabindex", "usePopover"], outputs: ["change"] }, { kind: "component", type: ButtonComponent, selector: "button[kirby-button],Button[kirby-button],a[kirby-button]", inputs: ["attentionLevel", "noDecoration", "themeColor", "expand", "isFloating", "size", "showIconOnly"] }, { kind: "ngmodule", type: IconModule }, { kind: "component", type: i3.IconComponent, selector: "kirby-icon", inputs: ["size", "name"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
393
463
  }
394
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CalendarComponent, decorators: [{
464
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarComponent, decorators: [{
395
465
  type: Component,
396
- args: [{ standalone: true, imports: [DropdownModule, ButtonComponent, IconModule, CommonModule], selector: 'kirby-calendar', providers: [CalendarHelper], template: "<div class=\"header\">\n <div class=\"month-navigator\">\n <button\n type=\"button\"\n [disabled]=\"!_canNavigateBack\"\n (click)=\"_changeMonth(-1)\"\n kirby-button\n [noDecoration]=\"true\"\n class=\"no-margin\"\n >\n <kirby-icon name=\"arrow-back\"></kirby-icon>\n </button>\n\n <div class=\"month-and-year\">\n <span class=\"month\">{{ activeMonthName }}</span>\n <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n </div>\n\n <button\n type=\"button\"\n [disabled]=\"!_canNavigateForward\"\n (click)=\"_changeMonth(1)\"\n kirby-button\n [noDecoration]=\"true\"\n class=\"no-margin\"\n >\n <kirby-icon name=\"arrow-more\"></kirby-icon>\n </button>\n </div>\n <kirby-dropdown\n *ngIf=\"_hasYearNavigator\"\n [usePopover]=\"usePopover\"\n [selectedIndex]=\"navigatedYear\"\n [items]=\"navigableYears\"\n popout=\"left\"\n (change)=\"_changeYear($event)\"\n ></kirby-dropdown>\n</div>\n\n<table>\n <thead>\n <tr>\n <th *ngFor=\"let weekDay of _weekDays\">{{ weekDay }}</th>\n </tr>\n </thead>\n\n <tbody>\n <tr *ngFor=\"let week of _month\">\n <td *ngFor=\"let day of week\">\n <div\n (click)=\"_onDateSelected(day)\"\n class=\"{{ day.cssClasses }} contain-state-layer\"\n [class.selected]=\"day.isSelected\"\n >\n <span class=\"state-layer\" aria-hidden=\"true\"></span>\n <span class=\"content-layer\">{{ day.date }}</span>\n </div>\n </td>\n </tr>\n </tbody>\n</table>\n\n<!-- <iframe src=\"kirby/components/calendar/calendar.webview.html\" #calendarContainer style=\"width: 320px; height: 304px; border: 0\"> -->\n", styles: ["table{width:100%;border-collapse:collapse;-webkit-user-select:none;user-select:none;margin-bottom:8px}th,td{text-align:center;padding:0}th:first-child,td:first-child{padding-left:8px}th:last-child,td:last-child{padding-right:8px}th{height:50px;border-bottom:1px solid var(--kirby-background-color)}.header,th,td{background-color:transparent}.header{display:flex;justify-content:space-between;margin:8px 8px 0}.month-navigator{display:flex;flex-grow:1;align-items:center;justify-content:space-between}.month-navigator button:disabled{opacity:.5;pointer-events:none}.month-and-year{-webkit-user-select:none;user-select:none}.month-and-year .month{font-weight:700;margin-right:8px}:host(.has-year-navigator) .month-navigator{flex-grow:0}:host(.has-year-navigator) .month-and-year{width:80px;margin:0 8px;text-align:center}:host(.has-year-navigator) .month{margin-right:0}.day{display:inline-flex;align-items:center;justify-content:center;border-radius:20px;width:40px;height:40px;margin:4px 0;color:var(--color, var(--kirby-black));background-color:var(--background-color, transparent)}.day.disabled,.day:not(.selectable){--color: #b4b4b4;pointer-events:none}.day.selectable:not(.current-month){--color: var(--kirby-text-color-semi-dark)}@media (hover: hover){.day.today:hover{--state-layer-opacity: .08;--state-layer-background-color: var(--kirby-black);cursor:pointer}}.day.today:active,.day.today.interaction-state-active{--state-layer-opacity: .16;--state-layer-background-color: var(--kirby-black)}.day.today{color:var(--kirby-medium-contrast);background-color:var(--kirby-medium)}@media (hover: hover){.day.selected:hover{--state-layer-opacity: .24;--state-layer-background-color: var(--kirby-black-contrast);cursor:pointer}}.day.selected:active,.day.selected.interaction-state-active{--state-layer-opacity: .36;--state-layer-background-color: var(--kirby-black-contrast)}.day.selected{color:var(--kirby-black-contrast);background-color:var(--kirby-black)}.contain-state-layer{--state-layer-opacity: 0;--state-layer-background-color: var(--kirby-black);position:relative}.contain-state-layer .content-layer{position:relative;z-index:var(--content-layer-z-index, 1)}.contain-state-layer .state-layer{position:absolute;inset:0;overflow:hidden;pointer-events:none;border-radius:inherit;z-index:2}.contain-state-layer .state-layer:before{transition:all 80ms linear 0ms;content:\"\";position:absolute;pointer-events:none;inset:-50%;opacity:var(--state-layer-opacity, 0);background-color:var(--state-layer-background-color, var(--kirby-black))}@media (hover: hover){.contain-state-layer:hover{--state-layer-opacity: .08;--state-layer-background-color: var(--kirby-black);cursor:pointer}}.contain-state-layer:active,.contain-state-layer.interaction-state-active{--state-layer-opacity: .16;--state-layer-background-color: var(--kirby-black)}\n"] }]
397
- }], ctorParameters: () => [{ type: i1.CalendarHelper }, { type: undefined, decorators: [{
466
+ args: [{ standalone: true, imports: [DropdownModule, ButtonComponent, IconModule, CommonModule], selector: 'kirby-calendar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"header\">\n <div class=\"month-navigator\">\n <button\n kirby-button\n type=\"button\"\n class=\"no-margin\"\n [attr.aria-label]=\"translations.get('previousMonth')\"\n [attr.aria-disabled]=\"_canNavigateBack ? null : true\"\n [noDecoration]=\"true\"\n (click)=\"_changeMonth(-1)\"\n >\n <kirby-icon name=\"arrow-back\" aria-hidden=\"true\"></kirby-icon>\n </button>\n\n <div class=\"month-and-year\" [id]=\"_tableMonthId\" aria-live=\"polite\" aria-atomic=\"true\">\n <span class=\"month\">{{ activeMonthName }}</span>\n <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n </div>\n\n <button\n kirby-button\n type=\"button\"\n class=\"no-margin\"\n [attr.aria-label]=\"translations.get('nextMonth')\"\n [attr.aria-disabled]=\"_canNavigateForward ? null : true\"\n [noDecoration]=\"true\"\n (click)=\"_changeMonth(1)\"\n >\n <kirby-icon name=\"arrow-more\" aria-hidden=\"true\"></kirby-icon>\n </button>\n </div>\n <kirby-dropdown\n *ngIf=\"_hasYearNavigator\"\n [usePopover]=\"usePopover\"\n [selectedIndex]=\"navigatedYear\"\n [items]=\"navigableYears\"\n [attr.aria-label]=\"translations.get('selectYear')\"\n popout=\"left\"\n (change)=\"_changeYear($event)\"\n ></kirby-dropdown>\n</div>\n\n<table [attr.aria-labelledby]=\"_tableMonthId\" role=\"grid\">\n <thead>\n <tr>\n <th *ngFor=\"let weekDay of _weekDays\" scope=\"col\">\n <span aria-hidden=\"true\">{{ weekDay.firstLetterCapitalized }}</span>\n <span class=\"visually-hidden\">{{ weekDay.fullName }}</span>\n </th>\n </tr>\n </thead>\n\n <tbody>\n <tr *ngFor=\"let week of _month\">\n <td *ngFor=\"let day of week\" [attr.aria-selected]=\"day.isSelected ? true : false\">\n <button\n kirby-button\n type=\"button\"\n (click)=\"_onDateSelected(day)\"\n (keydown)=\"_onDateKeydown($event)\"\n class=\"day\"\n [class.current-month]=\"day.isCurrentMonth\"\n [class.weekend]=\"day.isWeekend\"\n [class.today]=\"day.isToday\"\n [class.selectable]=\"day.isSelectable\"\n [class.selected]=\"day.isSelected\"\n [class.focussed]=\"day.isFocussed\"\n [class.past]=\"day.isPast\"\n [attr.aria-label]=\"day.ariaLabel\"\n [attr.aria-disabled]=\"day.isSelectable ? null : true\"\n [noDecoration]=\"true\"\n [disabled]=\"day.isFocusable ? null : true\"\n [tabIndex]=\"day.isFocussed ? 0 : -1\"\n >\n {{ day.date }}\n </button>\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [":host{font-size:16px}table{width:100%;border-collapse:collapse;-webkit-user-select:none;user-select:none;margin-bottom:8px}th,td{text-align:center;padding:0}th:first-child,td:first-child{padding-left:8px}th:last-child,td:last-child{padding-right:8px}th{height:50px;border-bottom:1px solid var(--kirby-background-color)}.header,th,td{background-color:transparent}.header{display:flex;justify-content:space-between;margin:8px 8px 0}.month-navigator{display:flex;flex-grow:1;align-items:center;justify-content:space-between}.month-and-year{-webkit-user-select:none;user-select:none;font-weight:700}.month-and-year .month{margin-right:8px}:host(.has-year-navigator) .month-navigator{flex-grow:0}:host(.has-year-navigator) .month-and-year{width:80px;margin:0 8px;text-align:center}:host(.has-year-navigator) .month{margin-right:0}.day{display:inline-flex;align-items:center;justify-content:center;border-radius:20px;min-width:40px;min-height:40px;width:40px;height:40px;margin:4px 0;font-size:16px}.day:focus{z-index:1}button[aria-disabled=true]{color:#b4b4b4}.day.selectable:not(.current-month,.selected){color:var(--kirby-text-color-semi-dark)}.day.today{color:var(--kirby-medium-contrast);background-color:var(--kirby-medium)}.day.selected{color:var(--kirby-black-contrast);background-color:var(--kirby-black)}.visually-hidden{position:absolute;scale:0}\n"] }]
467
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
398
468
  type: Inject,
399
469
  args: [LOCALE_ID]
400
- }] }], propDecorators: { calendarContainer: [{
401
- type: ViewChild,
402
- args: ['calendarContainer', { static: false }]
403
- }], dateChange: [{
470
+ }] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.TranslationService }], propDecorators: { dateChange: [{
404
471
  type: Output
405
472
  }], dateSelect: [{
406
473
  type: Output
@@ -444,4 +511,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
444
511
  type: HostBinding,
445
512
  args: ['class.has-year-navigator']
446
513
  }] } });
447
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../calendar/src/calendar.component.ts","../../../calendar/src/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  LOCALE_ID,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport {\n  add,\n  eachDayOfInterval,\n  endOfWeek,\n  format,\n  getYear,\n  isAfter,\n  isBefore,\n  isSameDay,\n  isSameMonth,\n  isWeekend,\n  Locale as LocaleDateFns,\n  startOfDay,\n  startOfMonth,\n  startOfWeek,\n} from 'date-fns';\nimport { utcToZonedTime, zonedTimeToUtc } from 'date-fns-tz';\nimport { da, enGB, enUS } from 'date-fns/locale';\n\nimport { capitalizeFirstLetter } from '@kirbydesign/core';\n\nimport { CommonModule } from '@angular/common';\nimport { IconModule } from '@kirbydesign/designsystem/icon';\n\nimport { DropdownModule } from '@kirbydesign/designsystem/dropdown';\nimport { ButtonComponent } from '@kirbydesign/designsystem/button';\nimport { CalendarCell } from './helpers/calendar-cell.model';\nimport { CalendarOptions } from './helpers/calendar-options.model';\nimport { CalendarHelper } from './helpers/calendar.helper';\nimport { CalendarYearNavigatorConfig } from './options/calendar-year-navigator-config';\n\nexport type Locale = LocaleDateFns;\ninterface CalendarDay {\n  isCurrentMonth: boolean;\n  isToday: boolean;\n  isWeekend: boolean;\n  isPast: boolean;\n  isFuture: boolean;\n  isDisabled: boolean;\n}\n\nenum TimeUnit {\n  years = 'years',\n  months = 'months',\n  weeks = 'weeks',\n  days = 'days',\n  hours = 'hours',\n  minutes = 'minutes',\n  seconds = 'seconds',\n  milliseconds = 'milliseconds',\n}\n\n@Component({\n  standalone: true,\n  imports: [DropdownModule, ButtonComponent, IconModule, CommonModule],\n  selector: 'kirby-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  providers: [CalendarHelper],\n})\nexport class CalendarComponent implements OnInit, AfterViewInit, OnChanges {\n  @ViewChild('calendarContainer', { static: false }) calendarContainer: ElementRef;\n  @Output() dateChange = new EventEmitter<Date>();\n  @Output() dateSelect = new EventEmitter<Date>();\n  @Output() yearSelect = new EventEmitter<number>();\n  @Output() previousMonthClicked = new EventEmitter<Date>();\n  @Output() nextMonthClicked = new EventEmitter<Date>();\n  @Input() timezone: 'local' | 'UTC' = 'local';\n  @Input() disableWeekends = false;\n  @Input() disablePastDates = false;\n  @Input() disableFutureDates = false;\n  @Input() alwaysEnableToday = false;\n\n  @Input() set locales(locales: { [key: string]: Locale }) {\n    console.warn(\n      `Supplying additional locales to the Kirby Calendar Component via an input property is deprecated and should not be used. \n        A future update will allow injecting additional locales via a provider instead.`\n    );\n  }\n  @Input() customLocales: { [key: string]: Locale } = {};\n  /* \n    Experimental: Input property not documented on purpose. \n    For context see: https://github.com/kirbydesign/designsystem/issues/2087\n  */\n  @Input() usePopover = false;\n  /**\n   * Configuration for the year navigator.\n   *\n   * Internally, calendar component:\n   * - bases yearNavigatorOptions.from and yearNavigatorOptions.to on todayDate if a number is provided\n   * - prioritizes minDate and maxDate over yearNavigatorOptions.from and yearNavigatorOptions.to\n   */\n  @Input() yearNavigatorOptions: CalendarYearNavigatorConfig;\n\n  _month: CalendarCell[][];\n  _weekDays: string[];\n  private selectedDay: CalendarCell;\n  // NOTE: Internally, all Dates\n  // are normalized to point to local timezone midnight, regardless of the timezone\n  // setting.\n  private activeMonth: Date;\n  private _selectedDate: Date;\n  private _disabledDates: Date[] = [];\n  private _enabledDates: Date[] = [];\n  private _todayDate: Date;\n  private _minDate: Date;\n  private _maxDate: Date;\n  private locale: Locale;\n  private timeZoneName: string;\n  private includedLocales = { da, enGB, enUS };\n\n  get selectedDate(): Date {\n    return this._selectedDate;\n  }\n\n  @Input() set selectedDate(valueLocalOrUTC: Date | null) {\n    const value = this.normalizeDate(valueLocalOrUTC);\n\n    if (valueLocalOrUTC) {\n      this.setActiveMonth(value);\n    }\n\n    if (this.hasDateChanged(value, this._selectedDate)) {\n      this.onSelectedDateChange(value);\n      this._selectedDate = value;\n    }\n  }\n\n  get disabledDates(): Date[] {\n    return this._disabledDates;\n  }\n\n  @Input() set disabledDates(value: Date[]) {\n    this._disabledDates = (value || []).map((date) => this.normalizeDate(date));\n  }\n\n  get enabledDates(): Date[] {\n    return this._enabledDates;\n  }\n\n  @Input() set enabledDates(value: Date[]) {\n    this._enabledDates = (value || []).map((date) => this.normalizeDate(date));\n  }\n\n  get todayDate(): Date {\n    return this._todayDate;\n  }\n\n  @Input() set todayDate(value: Date) {\n    this._todayDate = this.normalizeDate(value);\n  }\n\n  get minDate(): Date {\n    return this._minDate;\n  }\n\n  @Input() set minDate(value: Date) {\n    if (value && this.activeMonth && isBefore(this.activeMonth, value)) {\n      this.setActiveMonth(value);\n    }\n    this._minDate = this.normalizeDate(value);\n  }\n\n  get maxDate(): Date {\n    return this._maxDate;\n  }\n\n  @Input() set maxDate(value: Date) {\n    if (value && this.activeMonth && isAfter(this.activeMonth, value)) {\n      this.setActiveMonth(value);\n    }\n    this._maxDate = this.normalizeDate(value);\n  }\n\n  get activeMonthName(): string {\n    return capitalizeFirstLetter(this.formatWithLocale(this.activeMonth, 'MMMM'));\n  }\n\n  get activeYear(): string {\n    return this.formatWithLocale(this.activeMonth, 'yyyy');\n  }\n\n  /**\n   * Gets navigable years for year navigator based on yearNavigatorOptions.\n   */\n  get navigableYears(): string[] {\n    const dateOfFirstNavigableYear =\n      this.minDate || this.getDateFromNavigableYear(this.yearNavigatorOptions.from);\n\n    const dateOfLastNavigableYear =\n      this.maxDate || this.getDateFromNavigableYear(this.yearNavigatorOptions.to);\n\n    return this.getYearsBetweenDates(dateOfFirstNavigableYear, dateOfLastNavigableYear);\n  }\n\n  get navigatedYear(): number {\n    return this.navigableYears.indexOf(this.activeYear);\n  }\n\n  @HostBinding('class.has-year-navigator')\n  get _hasYearNavigator() {\n    return !!this.yearNavigatorOptions;\n  }\n\n  constructor(private calendarHelper: CalendarHelper, @Inject(LOCALE_ID) locale: string) {\n    this.locale = this.mapLocale(locale);\n    this.timeZoneName = Intl.DateTimeFormat().resolvedOptions().timeZone;\n  }\n\n  private formatWithLocale(date: Date, formatString: string): string {\n    return format(date, formatString, {\n      locale: this.locale,\n    });\n  }\n\n  private mapLocale(locale: string): Locale {\n    if (locale === 'en') {\n      locale = 'enGB'; // if english locale is provided without region, we default to GB\n    }\n    locale = locale.replace('-', '');\n    const availableLocales = { ...this.includedLocales, ...this.locales, ...this.customLocales };\n    return availableLocales[locale] || this.includedLocales.enGB; // Default to enGB if injected locale doesnt exist\n  }\n\n  ngOnInit() {\n    this._weekDays = this.getWeekDays();\n    this.setActiveMonth(this.selectedDate);\n  }\n\n  ngAfterViewInit() {\n    this.calendarHelper.init(\n      this.calendarContainer,\n      this.getHelperOptions(),\n      this._onDateSelected.bind(this),\n      this.onChangeMonth.bind(this)\n    );\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!this.activeMonth) return;\n    if (\n      changes.disableWeekends ||\n      changes.disablePastDates ||\n      changes.disableFutureDates ||\n      changes.disabledDates ||\n      changes.enabledDates ||\n      changes.minDate ||\n      changes.maxDate ||\n      changes.todayDate ||\n      changes.timezone\n    ) {\n      this.refreshActiveMonth();\n      this.calendarHelper.update(this.getHelperOptions());\n    }\n  }\n\n  private setActiveMonth(date: Date = new Date()) {\n    if (!this.activeMonth || !isSameMonth(this.activeMonth, date)) {\n      this.activeMonth = startOfMonth(date);\n      this.refreshActiveMonth();\n      this.calendarHelper.update(this.getHelperOptions());\n    }\n  }\n\n  // For leniency, the component will accept any Date that points to either UTC midnight\n  // or to local timezone midnight although we will internally normalize the representation\n  // of all received dates to point to local timezone midnight.\n  // We currently log no warnings if the date doesn't match the timezone setting or\n  // if it doesn't point to midnight.\n  private normalizeDate(dateLocalOrUTC: Date) {\n    if (!dateLocalOrUTC) return;\n\n    if (startOfDay(dateLocalOrUTC).getTime() === dateLocalOrUTC.getTime()) {\n      // date is local timezone midnight\n      return dateLocalOrUTC;\n    }\n    if (\n      startOfDay(utcToZonedTime(dateLocalOrUTC, this.timeZoneName)).getTime() ===\n      utcToZonedTime(dateLocalOrUTC, this.timeZoneName).getTime()\n    ) {\n      // the date is a UTC midnight; create the equivalent local timezone midnight date\n      const normalizedUTCdate = utcToZonedTime(dateLocalOrUTC, this.timeZoneName);\n      return normalizedUTCdate;\n    }\n    // does not point to midnight so we make it\n    return startOfDay(dateLocalOrUTC);\n  }\n\n  private getWeekDays(): string[] {\n    const now = new Date();\n    const week = eachDayOfInterval({\n      start: startOfWeek(now, { locale: this.locale }),\n      end: endOfWeek(now, { locale: this.locale }),\n    });\n\n    return week.map((date) => this.getFirstLetterOfWeekDayCapitalized(date));\n  }\n\n  private getFirstLetterOfWeekDayCapitalized(date: Date) {\n    return this.formatWithLocale(date, 'EEEEE');\n  }\n\n  private hasDateChanged(newDate: Date, previousDate: Date): boolean {\n    if (!newDate && !previousDate) {\n      return false;\n    }\n    if (newDate instanceof Date && !previousDate) {\n      return true;\n    }\n    return !isSameDay(newDate, previousDate);\n  }\n\n  private isDisabledDate(date: Date): boolean {\n    return this.disabledDates.some((disabledDate) => isSameDay(disabledDate, date));\n  }\n\n  private isEnabledDate(date: Date): boolean {\n    return (\n      this._enabledDates.length === 0 ||\n      this.enabledDates.some((enabledDate) => isSameDay(enabledDate, date))\n    );\n  }\n\n  refreshActiveMonth() {\n    if (!this.activeMonth) return;\n\n    const monthStart = startOfMonth(this.activeMonth);\n    const startOfFirstWeek = startOfWeek(monthStart, { locale: this.locale });\n    const today = this.todayDate ? startOfDay(this.todayDate) : startOfDay(new Date());\n\n    const totalNumberOfDays = 42; // Always show 42 days (6 weeks) in calendar\n    const daysArray = Array.from(Array(totalNumberOfDays).keys());\n\n    const days: CalendarCell[] = daysArray.map((number) => {\n      const cellDate = add(startOfFirstWeek, { [TimeUnit.days]: number });\n      const day = this.getCalendarDay(cellDate, today, monthStart);\n\n      const isSelectable = this.isSelectable(day, cellDate);\n      const isSelected = isSameDay(this.selectedDate, cellDate);\n      const cell: CalendarCell = {\n        date: cellDate.getDate(),\n        monthIndex: cellDate.getMonth(),\n        year: cellDate.getFullYear(),\n        isCurrentMonth: day.isCurrentMonth,\n        isSelectable,\n        isSelected,\n        cssClasses: this.getCssClasses(day, isSelectable, isSelected),\n      };\n      if (isSelected) {\n        this.selectedDay = cell;\n      }\n      return cell;\n    });\n    this._month = this.chunk(days, 7);\n  }\n\n  private getCalendarDay(date: Date, today: Date, monthStart: Date): CalendarDay {\n    return {\n      isToday: isSameDay(today, date),\n      isPast: isBefore(date, today),\n      isFuture: isAfter(date, today),\n      isWeekend: isWeekend(date),\n      isCurrentMonth: isSameMonth(date, monthStart),\n      isDisabled: this.isDisabledDate(date) || !this.isEnabledDate(date),\n    };\n  }\n\n  private isSelectable(day: CalendarDay, date: Date) {\n    return (\n      (this.alwaysEnableToday && day.isToday) ||\n      (!day.isDisabled &&\n        !(this.disableWeekends && day.isWeekend) &&\n        !(this.disablePastDates && day.isPast) &&\n        !(this.disableFutureDates && day.isFuture) &&\n        !(this.minDate && isBefore(date, this.minDate)) &&\n        !(this.maxDate && isAfter(date, this.maxDate)))\n    );\n  }\n\n  private getCssClasses(day: CalendarDay, isSelectable: boolean, isSelected: boolean) {\n    const cssClasses = {\n      'current-month': day.isCurrentMonth,\n      weekend: day.isWeekend,\n      today: day.isToday,\n      selectable: isSelectable,\n      selected: isSelected,\n      past: day.isPast,\n      disabled: day.isDisabled,\n    };\n    let cssClassString = 'day';\n    for (const key in cssClasses) {\n      if (cssClasses[key]) {\n        cssClassString += ' ' + key;\n      }\n    }\n    return cssClassString;\n  }\n\n  private chunk(array: any[], size: number) {\n    const results = [];\n    while (array.length) {\n      results.push(array.splice(0, size));\n    }\n    return results;\n  }\n\n  private onSelectedDateChange(newDate: Date): void {\n    if (this.selectedDay) {\n      this.selectedDay.isSelected = false;\n    }\n\n    const newDay = this.getCell(newDate);\n    if (newDay) {\n      newDay.isSelected = true;\n      this.selectedDay = newDay;\n    }\n\n    if (newDate) {\n      this.calendarHelper.setSelectedDay(newDate.getDate());\n    }\n  }\n\n  _onDateSelected(newDay: CalendarCell) {\n    if (!newDay.isSelectable) return;\n\n    let newDate = new Date(newDay.year, newDay.monthIndex, newDay.date);\n\n    if (this.timezone === 'UTC') {\n      newDate = zonedTimeToUtc(this.subtractTimezoneOffset(newDate), this.timeZoneName);\n    }\n\n    const dateToEmit = newDate;\n\n    if (this.hasDateChanged(newDate, this._selectedDate)) {\n      this.setActiveMonth(newDate);\n      this.onSelectedDateChange(newDate);\n      this._selectedDate = newDate;\n      this.dateChange.emit(dateToEmit);\n    }\n    this.dateSelect.emit(dateToEmit);\n  }\n\n  private onChangeMonth(direction: number) {\n    this._changeMonth(direction);\n    this.calendarHelper.update(this.getHelperOptions());\n  }\n\n  _changeMonth(index: number) {\n    this.changeActiveView(index, TimeUnit.months);\n    index > 0\n      ? this.nextMonthClicked.emit(this.activeMonth)\n      : this.previousMonthClicked.emit(this.activeMonth);\n  }\n\n  _changeYear(year: string) {\n    const yearNumeric = Number(year);\n    this.changeActiveView(yearNumeric - getYear(this.activeMonth), TimeUnit.years);\n    this.yearSelect.emit(yearNumeric);\n  }\n\n  private changeActiveView(index: number, unit: TimeUnit) {\n    if (index === 0) return;\n    this.activeMonth = add(this.activeMonth, { [unit]: index });\n\n    this.refreshActiveMonth();\n  }\n\n  get _canNavigateBack(): boolean {\n    const reachedPastDatesLimit =\n      this.disablePastDates && isSameMonth(this.activeMonth, this.todayDate);\n\n    const reachedOrExceededMinDate =\n      this.minDate &&\n      (isSameMonth(this.activeMonth, this.minDate) || isBefore(this.activeMonth, this.minDate));\n\n    return !reachedPastDatesLimit && !reachedOrExceededMinDate;\n  }\n\n  get _canNavigateForward(): boolean {\n    const reachedFutureDatesLimit =\n      this.disableFutureDates && isSameMonth(this.activeMonth, this.todayDate);\n\n    const reachedOrExceededMaxDate =\n      this.maxDate &&\n      (isSameMonth(this.activeMonth, this.maxDate) || isAfter(this.activeMonth, this.maxDate));\n\n    return !reachedFutureDatesLimit && !reachedOrExceededMaxDate;\n  }\n\n  private getCell(date: Date) {\n    let foundDay: CalendarCell = null;\n    if (date) {\n      for (const week of this._month) {\n        foundDay = week.find((day) => {\n          return day.isCurrentMonth && day.date === date.getDate();\n        });\n        if (foundDay) {\n          break;\n        }\n      }\n    }\n    return foundDay;\n  }\n\n  private getHelperOptions(): CalendarOptions {\n    return {\n      canNavigateBack: this._canNavigateBack,\n      canNavigateForward: this._canNavigateForward,\n      year: this.activeYear,\n      monthName: this.activeMonthName,\n      weekDays: this._weekDays,\n      month: this._month,\n    };\n  }\n\n  private subtractTimezoneOffset(date: Date): Date {\n    const timezoneOffsetInMs = date.getTimezoneOffset() * 60 * 1000;\n    return new Date(date.getTime() - timezoneOffsetInMs);\n  }\n\n  private getDateFromNavigableYear(navigableYear: number | Date): Date {\n    if (navigableYear instanceof Date) return navigableYear;\n    const today = this.todayDate || new Date();\n    return new Date(today.getFullYear() + navigableYear, 0, 1);\n  }\n\n  private getYearsBetweenDates(startDate: Date, endDate: Date): string[] {\n    // Ensure years are ordered correctly if parameters are switched:\n    const [startYear, endYear] = [startDate.getFullYear(), endDate.getFullYear()].sort();\n    const numberOfYears = endYear - startYear;\n    return Array.from({ length: numberOfYears + 1 }, (_, i) => (startYear + i).toString());\n  }\n}\n","<div class=\"header\">\n  <div class=\"month-navigator\">\n    <button\n      type=\"button\"\n      [disabled]=\"!_canNavigateBack\"\n      (click)=\"_changeMonth(-1)\"\n      kirby-button\n      [noDecoration]=\"true\"\n      class=\"no-margin\"\n    >\n      <kirby-icon name=\"arrow-back\"></kirby-icon>\n    </button>\n\n    <div class=\"month-and-year\">\n      <span class=\"month\">{{ activeMonthName }}</span>\n      <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n    </div>\n\n    <button\n      type=\"button\"\n      [disabled]=\"!_canNavigateForward\"\n      (click)=\"_changeMonth(1)\"\n      kirby-button\n      [noDecoration]=\"true\"\n      class=\"no-margin\"\n    >\n      <kirby-icon name=\"arrow-more\"></kirby-icon>\n    </button>\n  </div>\n  <kirby-dropdown\n    *ngIf=\"_hasYearNavigator\"\n    [usePopover]=\"usePopover\"\n    [selectedIndex]=\"navigatedYear\"\n    [items]=\"navigableYears\"\n    popout=\"left\"\n    (change)=\"_changeYear($event)\"\n  ></kirby-dropdown>\n</div>\n\n<table>\n  <thead>\n    <tr>\n      <th *ngFor=\"let weekDay of _weekDays\">{{ weekDay }}</th>\n    </tr>\n  </thead>\n\n  <tbody>\n    <tr *ngFor=\"let week of _month\">\n      <td *ngFor=\"let day of week\">\n        <div\n          (click)=\"_onDateSelected(day)\"\n          class=\"{{ day.cssClasses }} contain-state-layer\"\n          [class.selected]=\"day.isSelected\"\n        >\n          <span class=\"state-layer\" aria-hidden=\"true\"></span>\n          <span class=\"content-layer\">{{ day.date }}</span>\n        </div>\n      </td>\n    </tr>\n  </tbody>\n</table>\n\n<!-- <iframe src=\"kirby/components/calendar/calendar.webview.html\" #calendarContainer style=\"width: 320px; height: 304px; border: 0\"> -->\n"]}
514
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../calendar/src/calendar.component.ts","../../../calendar/src/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  LOCALE_ID,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport {\n  add,\n  eachDayOfInterval,\n  endOfWeek,\n  format,\n  getYear,\n  isAfter,\n  isBefore,\n  isSameDay,\n  isSameMonth,\n  isWeekend,\n  lastDayOfWeek,\n  Locale as LocaleDateFns,\n  startOfDay,\n  startOfMonth,\n  startOfWeek,\n} from 'date-fns';\nimport { utcToZonedTime, zonedTimeToUtc } from 'date-fns-tz';\nimport { da, enGB, enUS } from 'date-fns/locale';\n\nimport { capitalizeFirstLetter } from '@kirbydesign/core';\nimport { ButtonComponent } from '@kirbydesign/designsystem/button';\nimport { DropdownModule } from '@kirbydesign/designsystem/dropdown';\nimport { UniqueIdGenerator } from '@kirbydesign/designsystem/helpers';\nimport { IconModule } from '@kirbydesign/designsystem/icon';\n\nimport { TranslationService } from '@kirbydesign/designsystem/shared';\nimport { CalendarDay, CalendarDayMetadata } from './interfaces/calendar-day';\nimport { CalendarYearNavigatorConfig } from './interfaces/calendar-year-navigator-config';\n\nexport type Locale = LocaleDateFns;\n\ninterface WeekDay {\n  firstLetterCapitalized: string;\n  fullName: string;\n}\n\nenum TimeUnit {\n  years = 'years',\n  months = 'months',\n  weeks = 'weeks',\n  days = 'days',\n  hours = 'hours',\n  minutes = 'minutes',\n  seconds = 'seconds',\n  milliseconds = 'milliseconds',\n}\n\n@Component({\n  standalone: true,\n  imports: [DropdownModule, ButtonComponent, IconModule, CommonModule],\n  selector: 'kirby-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CalendarComponent implements OnInit, OnChanges {\n  @Output() dateChange = new EventEmitter<Date>();\n  @Output() dateSelect = new EventEmitter<Date>();\n  @Output() yearSelect = new EventEmitter<number>();\n  @Output() previousMonthClicked = new EventEmitter<Date>();\n  @Output() nextMonthClicked = new EventEmitter<Date>();\n  @Input() timezone: 'local' | 'UTC' = 'local';\n  @Input() disableWeekends = false;\n  @Input() disablePastDates = false;\n  @Input() disableFutureDates = false;\n  @Input() alwaysEnableToday = false;\n\n  @Input() set locales(locales: { [key: string]: Locale }) {\n    console.warn(\n      `Supplying additional locales to the Kirby Calendar Component via an input property is deprecated and should not be used. \n        A future update will allow injecting additional locales via a provider instead.`\n    );\n  }\n  @Input() customLocales: { [key: string]: Locale } = {};\n  /* \n    Experimental: Input property not documented on purpose. \n    For context see: https://github.com/kirbydesign/designsystem/issues/2087\n  */\n  @Input() usePopover = false;\n  /**\n   * Configuration for the year navigator.\n   *\n   * Internally, calendar component:\n   * - bases yearNavigatorOptions.from and yearNavigatorOptions.to on todayDate if a number is provided\n   * - prioritizes minDate and maxDate over yearNavigatorOptions.from and yearNavigatorOptions.to\n   */\n  @Input() yearNavigatorOptions: CalendarYearNavigatorConfig;\n\n  _tableMonthId = UniqueIdGenerator.scopedTo('kirby-calendar-month').next();\n  _month: CalendarDay[][];\n  _weekDays: WeekDay[];\n  private selectedDay: CalendarDay;\n  private focussedDay: CalendarDay;\n  // NOTE: Internally, all Dates\n  // are normalized to point to local timezone midnight, regardless of the timezone\n  // setting.\n  private activeMonth: Date;\n  private _selectedDate: Date;\n  private _disabledDates: Date[] = [];\n  private _enabledDates: Date[] = [];\n  private _todayDate: Date;\n  private _minDate: Date;\n  private _maxDate: Date;\n  private focussedDate: Date;\n  private locale: Locale;\n  private timeZoneName: string;\n  private includedLocales = { da, enGB, enUS };\n\n  get selectedDate(): Date {\n    return this._selectedDate;\n  }\n\n  @Input() set selectedDate(valueLocalOrUTC: Date | null) {\n    const value = this.normalizeDate(valueLocalOrUTC);\n\n    if (valueLocalOrUTC) {\n      this.setActiveMonth(value);\n    }\n\n    if (this.hasDateChanged(value, this._selectedDate)) {\n      this.onSelectedDateChange(value);\n      this.focusDate(value);\n      this._selectedDate = value;\n    }\n  }\n\n  get disabledDates(): Date[] {\n    return this._disabledDates;\n  }\n\n  @Input() set disabledDates(value: Date[]) {\n    this._disabledDates = (value || []).map((date) => this.normalizeDate(date));\n  }\n\n  get enabledDates(): Date[] {\n    return this._enabledDates;\n  }\n\n  @Input() set enabledDates(value: Date[]) {\n    this._enabledDates = (value || []).map((date) => this.normalizeDate(date));\n  }\n\n  get todayDate(): Date {\n    return this._todayDate;\n  }\n\n  @Input() set todayDate(value: Date) {\n    this._todayDate = this.normalizeDate(value);\n  }\n\n  get minDate(): Date {\n    return this._minDate;\n  }\n\n  @Input() set minDate(value: Date) {\n    if (value && this.activeMonth && isBefore(this.activeMonth, value)) {\n      this.setActiveMonth(value);\n    }\n    this._minDate = this.normalizeDate(value);\n  }\n\n  get maxDate(): Date {\n    return this._maxDate;\n  }\n\n  @Input() set maxDate(value: Date) {\n    if (value && this.activeMonth && isAfter(this.activeMonth, value)) {\n      this.setActiveMonth(value);\n    }\n    this._maxDate = this.normalizeDate(value);\n  }\n\n  get activeMonthName(): string {\n    return capitalizeFirstLetter(this.formatWithLocale(this.activeMonth, 'MMMM'));\n  }\n\n  get activeYear(): string {\n    return this.formatWithLocale(this.activeMonth, 'yyyy');\n  }\n\n  /**\n   * Gets navigable years for year navigator based on yearNavigatorOptions.\n   */\n  get navigableYears(): string[] {\n    const dateOfFirstNavigableYear =\n      this.minDate || this.getDateFromNavigableYear(this.yearNavigatorOptions.from);\n\n    const dateOfLastNavigableYear =\n      this.maxDate || this.getDateFromNavigableYear(this.yearNavigatorOptions.to);\n\n    return this.getYearsBetweenDates(dateOfFirstNavigableYear, dateOfLastNavigableYear);\n  }\n\n  get navigatedYear(): number {\n    return this.navigableYears.indexOf(this.activeYear);\n  }\n\n  @HostBinding('class.has-year-navigator')\n  get _hasYearNavigator() {\n    return !!this.yearNavigatorOptions;\n  }\n\n  private getTodayDate() {\n    return startOfDay(this.todayDate ?? new Date());\n  }\n\n  constructor(\n    @Inject(LOCALE_ID) locale: string,\n    private elementRef: ElementRef,\n    private cdr: ChangeDetectorRef,\n    public translations: TranslationService\n  ) {\n    this.locale = this.mapLocale(locale);\n    this.timeZoneName = Intl.DateTimeFormat().resolvedOptions().timeZone;\n  }\n\n  private formatWithLocale(date: Date, formatString: string): string {\n    return format(date, formatString, {\n      locale: this.locale,\n    });\n  }\n\n  private mapLocale(locale: string): Locale {\n    if (locale === 'en') {\n      locale = 'enGB'; // if english locale is provided without region, we default to GB\n    }\n    locale = locale.replace('-', '');\n    const availableLocales = { ...this.includedLocales, ...this.locales, ...this.customLocales };\n    return availableLocales[locale] || this.includedLocales.enGB; // Default to enGB if injected locale doesnt exist\n  }\n\n  private formatDateLabel(): string {\n    const localeDateFormats = {\n      da: 'd. MMMM',\n      'en-GB': 'd MMMM',\n      'en-US': 'MMMM d',\n    };\n\n    const defaultDateFormat = localeDateFormats['en-US'];\n    const dateFormat = localeDateFormats[this.locale.code] || defaultDateFormat;\n    return dateFormat;\n  }\n\n  ngOnInit() {\n    this.focussedDate = this.getTodayDate();\n    this._weekDays = this.getWeekDays();\n    this.setActiveMonth(this.selectedDate);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!this.activeMonth) return;\n    if (\n      changes.disableWeekends ||\n      changes.disablePastDates ||\n      changes.disableFutureDates ||\n      changes.disabledDates ||\n      changes.enabledDates ||\n      changes.minDate ||\n      changes.maxDate ||\n      changes.todayDate ||\n      changes.timezone\n    ) {\n      this.refreshActiveMonth();\n    }\n  }\n\n  private setActiveMonth(date: Date = new Date()) {\n    if (!this.activeMonth || !isSameMonth(this.activeMonth, date)) {\n      this.activeMonth = startOfMonth(date);\n      this.refreshActiveMonth();\n    }\n  }\n\n  // For leniency, the component will accept any Date that points to either UTC midnight\n  // or to local timezone midnight although we will internally normalize the representation\n  // of all received dates to point to local timezone midnight.\n  // We currently log no warnings if the date doesn't match the timezone setting or\n  // if it doesn't point to midnight.\n  private normalizeDate(dateLocalOrUTC: Date) {\n    if (!dateLocalOrUTC) return;\n\n    if (startOfDay(dateLocalOrUTC).getTime() === dateLocalOrUTC.getTime()) {\n      // date is local timezone midnight\n      return dateLocalOrUTC;\n    }\n    if (\n      startOfDay(utcToZonedTime(dateLocalOrUTC, this.timeZoneName)).getTime() ===\n      utcToZonedTime(dateLocalOrUTC, this.timeZoneName).getTime()\n    ) {\n      // the date is a UTC midnight; create the equivalent local timezone midnight date\n      const normalizedUTCdate = utcToZonedTime(dateLocalOrUTC, this.timeZoneName);\n      return normalizedUTCdate;\n    }\n    // does not point to midnight so we make it\n    return startOfDay(dateLocalOrUTC);\n  }\n\n  private getWeekDays(): WeekDay[] {\n    const now = new Date();\n    const week = eachDayOfInterval({\n      start: startOfWeek(now, { locale: this.locale }),\n      end: endOfWeek(now, { locale: this.locale }),\n    });\n\n    const weekdayNarrowFormat = 'EEEEE';\n    const weekdayWideFormat = 'EEEE';\n\n    return week.map((date) => ({\n      firstLetterCapitalized: this.formatWithLocale(date, weekdayNarrowFormat),\n      fullName: this.formatWithLocale(date, weekdayWideFormat),\n    }));\n  }\n\n  private hasDateChanged(newDate: Date, previousDate: Date): boolean {\n    if (!newDate && !previousDate) {\n      return false;\n    }\n    if (newDate instanceof Date && !previousDate) {\n      return true;\n    }\n    return !isSameDay(newDate, previousDate);\n  }\n\n  private isDisabledDate(date: Date): boolean {\n    return this.disabledDates.some((disabledDate) => isSameDay(disabledDate, date));\n  }\n\n  private isEnabledDate(date: Date): boolean {\n    return (\n      this._enabledDates.length === 0 ||\n      this.enabledDates.some((enabledDate) => isSameDay(enabledDate, date))\n    );\n  }\n\n  refreshActiveMonth() {\n    if (!this.activeMonth) return;\n\n    const monthStart = startOfMonth(this.activeMonth);\n    const startOfFirstWeek = startOfWeek(monthStart, { locale: this.locale });\n\n    const totalNumberOfDays = 42; // Always show 42 days (6 weeks) in calendar\n    const daysArray = Array.from(Array(totalNumberOfDays).keys());\n    const today = this.getTodayDate();\n\n    const calendarDays: CalendarDay[] = daysArray.map((number) => {\n      const dateOfCalendarDay = add(startOfFirstWeek, { [TimeUnit.days]: number });\n\n      const calendarDay: CalendarDay = {\n        date: dateOfCalendarDay.getDate(),\n        monthIndex: dateOfCalendarDay.getMonth(),\n        year: dateOfCalendarDay.getFullYear(),\n        ariaLabel: this.formatWithLocale(dateOfCalendarDay, this.formatDateLabel()),\n        ...this.getCalendarDayMetadata(dateOfCalendarDay, today, monthStart),\n      };\n      if (calendarDay.isSelected) {\n        this.selectedDay = calendarDay;\n      }\n      if (calendarDay.isFocussed) {\n        this.focussedDay = calendarDay;\n      }\n      return calendarDay;\n    });\n    this._month = this.chunk(calendarDays, 7);\n  }\n\n  private getCalendarDayMetadata(date: Date, today: Date, monthStart: Date): CalendarDayMetadata {\n    return {\n      isToday: isSameDay(today, date),\n      isPast: isBefore(date, today),\n      isFuture: isAfter(date, today),\n      isWeekend: isWeekend(date),\n      isCurrentMonth: isSameMonth(date, monthStart),\n      isSelectable: this.isSelectable(date, today),\n      isFocusable: this.isWithinAllowedRange(date, today),\n      isSelected: isSameDay(this.selectedDate, date),\n      isFocussed: isSameDay(this.focussedDate, date),\n    };\n  }\n\n  private isSelectable(date: Date, today: Date): boolean {\n    if (this.alwaysEnableToday && isSameDay(today, date)) return true;\n\n    if (!this.isWithinAllowedRange(date, today)) return false;\n    if (this.isDisabledDate(date)) return false;\n    if (!this.isEnabledDate(date)) return false;\n    if (this.disableWeekends && isWeekend(date)) return false;\n\n    return true;\n  }\n\n  private isWithinAllowedRange(date: Date, today: Date): boolean {\n    if (this.disablePastDates && isBefore(date, today)) return false;\n    if (this.disableFutureDates && isAfter(date, today)) return false;\n    if (this.minDate && isBefore(date, this.minDate)) return false;\n    if (this.maxDate && isAfter(date, this.maxDate)) return false;\n\n    return true;\n  }\n\n  private chunk(array: any[], size: number) {\n    const results = [];\n    while (array.length) {\n      results.push(array.splice(0, size));\n    }\n    return results;\n  }\n\n  private onSelectedDateChange(newDate: Date): void {\n    if (this.selectedDay) {\n      this.selectedDay.isSelected = false;\n    }\n\n    const newDay = this.getDay(newDate);\n    if (newDay) {\n      newDay.isSelected = true;\n      this.selectedDay = newDay;\n    }\n  }\n\n  _onDateSelected(newDay: CalendarDay) {\n    if (!newDay.isSelectable) return;\n\n    let newDate = new Date(newDay.year, newDay.monthIndex, newDay.date);\n\n    if (this.timezone === 'UTC') {\n      newDate = zonedTimeToUtc(this.subtractTimezoneOffset(newDate), this.timeZoneName);\n    }\n\n    const dateToEmit = newDate;\n\n    if (this.hasDateChanged(newDate, this._selectedDate)) {\n      this.setActiveMonth(newDate);\n      this.onSelectedDateChange(newDate);\n      this.selectedDate = newDate;\n      this.dateChange.emit(dateToEmit);\n    }\n    this.dateSelect.emit(dateToEmit);\n  }\n\n  _changeMonth(index: number) {\n    if (index > 0 && !this._canNavigateForward) return;\n    if (index < 0 && !this._canNavigateBack) return;\n\n    this.changeActiveView(index, TimeUnit.months);\n    index > 0\n      ? this.nextMonthClicked.emit(this.activeMonth)\n      : this.previousMonthClicked.emit(this.activeMonth);\n  }\n\n  _changeYear(year: string) {\n    const yearNumeric = Number(year);\n    this.changeActiveView(yearNumeric - getYear(this.activeMonth), TimeUnit.years);\n    this.yearSelect.emit(yearNumeric);\n  }\n\n  private changeActiveView(index: number, unit: TimeUnit) {\n    if (index === 0) return;\n    this.activeMonth = add(this.activeMonth, { [unit]: index });\n    this.focussedDate = add(this.focussedDate, { [unit]: index });\n\n    this.refreshActiveMonth();\n  }\n\n  get _canNavigateBack(): boolean {\n    const today = this.getTodayDate();\n    const reachedPastDatesLimit = this.disablePastDates && isSameMonth(this.activeMonth, today);\n\n    const reachedOrExceededMinDate =\n      this.minDate &&\n      (isSameMonth(this.activeMonth, this.minDate) || isBefore(this.activeMonth, this.minDate));\n\n    return !reachedPastDatesLimit && !reachedOrExceededMinDate;\n  }\n\n  get _canNavigateForward(): boolean {\n    const today = this.getTodayDate();\n    const reachedFutureDatesLimit = this.disableFutureDates && isSameMonth(this.activeMonth, today);\n\n    const reachedOrExceededMaxDate =\n      this.maxDate &&\n      (isSameMonth(this.activeMonth, this.maxDate) || isAfter(this.activeMonth, this.maxDate));\n\n    return !reachedFutureDatesLimit && !reachedOrExceededMaxDate;\n  }\n\n  private getDay(date: Date) {\n    let foundDay: CalendarDay = null;\n    if (date) {\n      for (const week of this._month) {\n        foundDay = week.find((day) => {\n          return day.isCurrentMonth && day.date === date.getDate();\n        });\n        if (foundDay) {\n          break;\n        }\n      }\n    }\n    return foundDay;\n  }\n\n  private subtractTimezoneOffset(date: Date): Date {\n    const timezoneOffsetInMs = date.getTimezoneOffset() * 60 * 1000;\n    return new Date(date.getTime() - timezoneOffsetInMs);\n  }\n\n  private getDateFromNavigableYear(navigableYear: number | Date): Date {\n    if (navigableYear instanceof Date) return navigableYear;\n    const today = this.todayDate || new Date();\n    return new Date(today.getFullYear() + navigableYear, 0, 1);\n  }\n\n  private getYearsBetweenDates(startDate: Date, endDate: Date): string[] {\n    // Ensure years are ordered correctly if parameters are switched:\n    const [startYear, endYear] = [startDate.getFullYear(), endDate.getFullYear()].sort();\n    const numberOfYears = endYear - startYear;\n    return Array.from({ length: numberOfYears + 1 }, (_, i) => (startYear + i).toString());\n  }\n\n  private setFocussedDay(newDate: Date) {\n    const newDay = this.getDay(newDate);\n    if (!newDay) return;\n\n    if (this.focussedDay) {\n      this.focussedDay.isFocussed = false;\n    }\n    newDay.isFocussed = true;\n    this.focussedDay = newDay;\n  }\n\n  private focusDate(newDate: Date | null) {\n    if (!newDate) return;\n\n    if (this.timezone === 'UTC') {\n      newDate = zonedTimeToUtc(this.subtractTimezoneOffset(newDate), this.timeZoneName);\n    }\n\n    const today = this.getTodayDate();\n    if (!this.isWithinAllowedRange(newDate, today)) return;\n\n    if (!this.hasDateChanged(newDate, this.focussedDate)) return;\n\n    this.setActiveMonth(newDate);\n    this.setFocussedDay(newDate);\n    this.focussedDate = newDate;\n\n    this.cdr.detectChanges(); //sync focussed class to template before setting focus\n    const elementMarkedForFocus = this.elementRef.nativeElement.querySelector('.focussed');\n    elementMarkedForFocus.focus();\n  }\n\n  _onDateKeydown(event: KeyboardEvent) {\n    const { key, shiftKey } = event;\n    let newDate;\n\n    switch (key) {\n      case 'ArrowUp':\n        newDate = add(this.focussedDate, { days: -7 });\n        break;\n      case 'ArrowDown':\n        newDate = add(this.focussedDate, { days: 7 });\n        break;\n      case 'ArrowRight':\n        newDate = add(this.focussedDate, { days: 1 });\n        break;\n      case 'ArrowLeft':\n        newDate = add(this.focussedDate, { days: -1 });\n        break;\n      case 'Home':\n        newDate = startOfWeek(this.focussedDate, { locale: this.locale });\n        break;\n      case 'End':\n        newDate = lastDayOfWeek(this.focussedDate, { locale: this.locale });\n        break;\n      case 'PageUp':\n        newDate = shiftKey\n          ? add(this.focussedDate, { years: -1 })\n          : add(this.focussedDate, { months: -1 });\n        break;\n      case 'PageDown':\n        newDate = shiftKey\n          ? add(this.focussedDate, { years: 1 })\n          : add(this.focussedDate, { months: 1 });\n        break;\n      default:\n        return;\n    }\n\n    event.preventDefault();\n    this.focusDate(newDate);\n  }\n}\n","<div class=\"header\">\n  <div class=\"month-navigator\">\n    <button\n      kirby-button\n      type=\"button\"\n      class=\"no-margin\"\n      [attr.aria-label]=\"translations.get('previousMonth')\"\n      [attr.aria-disabled]=\"_canNavigateBack ? null : true\"\n      [noDecoration]=\"true\"\n      (click)=\"_changeMonth(-1)\"\n    >\n      <kirby-icon name=\"arrow-back\" aria-hidden=\"true\"></kirby-icon>\n    </button>\n\n    <div class=\"month-and-year\" [id]=\"_tableMonthId\" aria-live=\"polite\" aria-atomic=\"true\">\n      <span class=\"month\">{{ activeMonthName }}</span>\n      <span *ngIf=\"!_hasYearNavigator\" class=\"year\">{{ activeYear }}</span>\n    </div>\n\n    <button\n      kirby-button\n      type=\"button\"\n      class=\"no-margin\"\n      [attr.aria-label]=\"translations.get('nextMonth')\"\n      [attr.aria-disabled]=\"_canNavigateForward ? null : true\"\n      [noDecoration]=\"true\"\n      (click)=\"_changeMonth(1)\"\n    >\n      <kirby-icon name=\"arrow-more\" aria-hidden=\"true\"></kirby-icon>\n    </button>\n  </div>\n  <kirby-dropdown\n    *ngIf=\"_hasYearNavigator\"\n    [usePopover]=\"usePopover\"\n    [selectedIndex]=\"navigatedYear\"\n    [items]=\"navigableYears\"\n    [attr.aria-label]=\"translations.get('selectYear')\"\n    popout=\"left\"\n    (change)=\"_changeYear($event)\"\n  ></kirby-dropdown>\n</div>\n\n<table [attr.aria-labelledby]=\"_tableMonthId\" role=\"grid\">\n  <thead>\n    <tr>\n      <th *ngFor=\"let weekDay of _weekDays\" scope=\"col\">\n        <span aria-hidden=\"true\">{{ weekDay.firstLetterCapitalized }}</span>\n        <span class=\"visually-hidden\">{{ weekDay.fullName }}</span>\n      </th>\n    </tr>\n  </thead>\n\n  <tbody>\n    <tr *ngFor=\"let week of _month\">\n      <td *ngFor=\"let day of week\" [attr.aria-selected]=\"day.isSelected ? true : false\">\n        <button\n          kirby-button\n          type=\"button\"\n          (click)=\"_onDateSelected(day)\"\n          (keydown)=\"_onDateKeydown($event)\"\n          class=\"day\"\n          [class.current-month]=\"day.isCurrentMonth\"\n          [class.weekend]=\"day.isWeekend\"\n          [class.today]=\"day.isToday\"\n          [class.selectable]=\"day.isSelectable\"\n          [class.selected]=\"day.isSelected\"\n          [class.focussed]=\"day.isFocussed\"\n          [class.past]=\"day.isPast\"\n          [attr.aria-label]=\"day.ariaLabel\"\n          [attr.aria-disabled]=\"day.isSelectable ? null : true\"\n          [noDecoration]=\"true\"\n          [disabled]=\"day.isFocusable ? null : true\"\n          [tabIndex]=\"day.isFocussed ? 0 : -1\"\n        >\n          {{ day.date }}\n        </button>\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}