@elderbyte/ngx-starter 17.10.0 → 17.11.0-beta2

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 (352) hide show
  1. package/esm2022/lib/common/data/datasource/data-source-base.mjs +1 -1
  2. package/esm2022/lib/common/data/datasource/rest/rest-client.mjs +1 -1
  3. package/esm2022/lib/common/data/filters/filter-commons.mjs +23 -0
  4. package/esm2022/lib/common/data/filters/filter-value.mjs +2 -0
  5. package/esm2022/lib/common/enums/elder-enum-translation.service.mjs +4 -4
  6. package/esm2022/lib/common/format/curency-format-util.mjs +43 -0
  7. package/esm2022/lib/common/format/duration-format-util.mjs +44 -0
  8. package/esm2022/lib/common/format/iso-interval-format-util.mjs +109 -0
  9. package/esm2022/lib/common/format/public_api.mjs +4 -1
  10. package/esm2022/lib/common/forms/elder-form-field-control-base.directive.mjs +4 -4
  11. package/esm2022/lib/common/forms/elder-from-field-base.mjs +4 -4
  12. package/esm2022/lib/common/forms/elder-from-field-customizable-base.mjs +4 -4
  13. package/esm2022/lib/common/forms/elder-from-field-entity-base.mjs +4 -4
  14. package/esm2022/lib/common/forms/elder-from-field-multi-entity-base.mjs +4 -4
  15. package/esm2022/lib/common/forms/form-field-base.component.mjs +4 -4
  16. package/esm2022/lib/common/forms/multi-model-base.component.mjs +4 -4
  17. package/esm2022/lib/common/forms/template-composite-control.mjs +4 -4
  18. package/esm2022/lib/common/forms/value-accessor-base.mjs +4 -4
  19. package/esm2022/lib/common/http/http-client-builder.service.mjs +4 -4
  20. package/esm2022/lib/common/http/http-client-pristine.mjs +4 -4
  21. package/esm2022/lib/common/http/transfer/data-transfer-factory.mjs +4 -4
  22. package/esm2022/lib/common/url/elder-router.service.mjs +4 -4
  23. package/esm2022/lib/common/url/elder-url-fragment-params.service.mjs +4 -4
  24. package/esm2022/lib/components/access-denied/elder-access-denied.component.mjs +4 -4
  25. package/esm2022/lib/components/access-denied/elder-access-denied.module.mjs +5 -5
  26. package/esm2022/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +4 -4
  27. package/esm2022/lib/components/auditing/elder-audit.module.mjs +5 -5
  28. package/esm2022/lib/components/badge/elder-badge/elder-badge.component.mjs +10 -10
  29. package/esm2022/lib/components/badge/elder-badge.directive.mjs +44 -22
  30. package/esm2022/lib/components/badge/elder-badge.module.mjs +5 -5
  31. package/esm2022/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +4 -4
  32. package/esm2022/lib/components/button-group/elder-button-group.module.mjs +5 -5
  33. package/esm2022/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -4
  34. package/esm2022/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +4 -4
  35. package/esm2022/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +4 -4
  36. package/esm2022/lib/components/card-organizer/elder-card-organizer.module.mjs +5 -5
  37. package/esm2022/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +4 -4
  38. package/esm2022/lib/components/cards/elder-card/elder-card.component.mjs +19 -19
  39. package/esm2022/lib/components/cards/elder-card/elder-card.module.mjs +5 -5
  40. package/esm2022/lib/components/chips/elder-chip-label.directive.mjs +4 -4
  41. package/esm2022/lib/components/chips/elder-chips.module.mjs +5 -5
  42. package/esm2022/lib/components/connectivity/elder-connectivity.module.mjs +5 -5
  43. package/esm2022/lib/components/connectivity/elder-connectivity.service.mjs +4 -4
  44. package/esm2022/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +4 -4
  45. package/esm2022/lib/components/containers/elder-containers.module.mjs +5 -5
  46. package/esm2022/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +4 -4
  47. package/esm2022/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +4 -4
  48. package/esm2022/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +4 -4
  49. package/esm2022/lib/components/csv/elder-csv.module.mjs +5 -5
  50. package/esm2022/lib/components/currency/elder-currency.module.mjs +5 -5
  51. package/esm2022/lib/components/currency/elder-currency.pipe.mjs +16 -13
  52. package/esm2022/lib/components/data-transfer/elder-data-transfer.module.mjs +5 -5
  53. package/esm2022/lib/components/data-transfer/elder-data-transfer.service.mjs +4 -4
  54. package/esm2022/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +4 -4
  55. package/esm2022/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -4
  56. package/esm2022/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +4 -4
  57. package/esm2022/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +4 -4
  58. package/esm2022/lib/components/data-view/base/elder-data-view-base.mjs +4 -4
  59. package/esm2022/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -4
  60. package/esm2022/lib/components/data-view/common/elder-data-common.module.mjs +5 -5
  61. package/esm2022/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +7 -7
  62. package/esm2022/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -4
  63. package/esm2022/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -4
  64. package/esm2022/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +4 -4
  65. package/esm2022/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +10 -10
  66. package/esm2022/lib/components/data-view/grid/elder-grid.module.mjs +5 -5
  67. package/esm2022/lib/components/data-view/master-detail/elder-detail-dialog/elder-detail-dialog.component.mjs +4 -4
  68. package/esm2022/lib/components/data-view/master-detail/elder-detail.directive.mjs +4 -4
  69. package/esm2022/lib/components/data-view/master-detail/elder-master-activation.directive.mjs +4 -4
  70. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.component.mjs +4 -4
  71. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.module.mjs +5 -5
  72. package/esm2022/lib/components/data-view/master-detail/elder-master-detail.service.mjs +4 -4
  73. package/esm2022/lib/components/data-view/master-detail/elder-master.directive.mjs +4 -4
  74. package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +4 -4
  75. package/esm2022/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +5 -5
  76. package/esm2022/lib/components/data-view/table/activation/elder-delete-active.directive.mjs +4 -4
  77. package/esm2022/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  78. package/esm2022/lib/components/data-view/table/elder-number-cell.directive.mjs +4 -4
  79. package/esm2022/lib/components/data-view/table/elder-paginator-intl.mjs +4 -4
  80. package/esm2022/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +4 -4
  81. package/esm2022/lib/components/data-view/table/elder-table/elder-table.component.mjs +4 -4
  82. package/esm2022/lib/components/data-view/table/elder-table-column.directive.mjs +4 -4
  83. package/esm2022/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  84. package/esm2022/lib/components/data-view/table/elder-table-root.directive.mjs +4 -4
  85. package/esm2022/lib/components/data-view/table/elder-table-row.directive.mjs +4 -4
  86. package/esm2022/lib/components/data-view/table/elder-table-sort.directive.mjs +4 -4
  87. package/esm2022/lib/components/data-view/table/elder-table.module.mjs +5 -5
  88. package/esm2022/lib/components/data-view/table/model/elder-table-model.mjs +4 -4
  89. package/esm2022/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -4
  90. package/esm2022/lib/components/dialogs/elder-dialog.module.mjs +5 -5
  91. package/esm2022/lib/components/dialogs/elder-dialog.service.mjs +4 -4
  92. package/esm2022/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -4
  93. package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -4
  94. package/esm2022/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +4 -4
  95. package/esm2022/lib/components/errors/elder-error.module.mjs +5 -5
  96. package/esm2022/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +4 -4
  97. package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -4
  98. package/esm2022/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +5 -5
  99. package/esm2022/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
  100. package/esm2022/lib/components/files/drag-n-drop/elder-drop-zone/elder-drop-zone.component.mjs +4 -4
  101. package/esm2022/lib/components/files/drag-n-drop/global-drag-drop.service.mjs +4 -4
  102. package/esm2022/lib/components/files/elder-file-drop-zone.directive.mjs +4 -4
  103. package/esm2022/lib/components/files/elder-file-select.directive.mjs +4 -4
  104. package/esm2022/lib/components/files/elder-file.module.mjs +5 -5
  105. package/esm2022/lib/components/files/file-select/file-select.component.mjs +4 -4
  106. package/esm2022/lib/components/files/file-upload/file-upload.component.mjs +4 -4
  107. package/esm2022/lib/components/forms/clipboard/elder-clipboard.service.mjs +4 -4
  108. package/esm2022/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +4 -4
  109. package/esm2022/lib/components/forms/directives/elder-clipboard-put.directive.mjs +4 -4
  110. package/esm2022/lib/components/forms/directives/elder-delayed-focus.directive.mjs +4 -4
  111. package/esm2022/lib/components/forms/directives/elder-form-field-dense.directive.mjs +4 -4
  112. package/esm2022/lib/components/forms/directives/elder-form-field-label.directive.mjs +4 -4
  113. package/esm2022/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +4 -4
  114. package/esm2022/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +4 -4
  115. package/esm2022/lib/components/forms/directives/elder-forms-directives.module.mjs +5 -5
  116. package/esm2022/lib/components/forms/directives/elder-initial-value.directive.mjs +11 -8
  117. package/esm2022/lib/components/forms/directives/elder-input-pattern.directive.mjs +4 -4
  118. package/esm2022/lib/components/forms/directives/elder-key-event.directive.mjs +4 -4
  119. package/esm2022/lib/components/forms/directives/elder-next-focusable.directive.mjs +4 -4
  120. package/esm2022/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
  121. package/esm2022/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
  122. package/esm2022/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  123. package/esm2022/lib/components/forms/directives/elder-touched.directive.mjs +4 -4
  124. package/esm2022/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +4 -4
  125. package/esm2022/lib/components/forms/directives/validation/elder-validation-error.directive.mjs +4 -4
  126. package/esm2022/lib/components/forms/directives/validation/strategies/common-validation-message-strategy.mjs +4 -4
  127. package/esm2022/lib/components/forms/directives/validation/strategies/dynamic-validation-message-strategy.mjs +4 -4
  128. package/esm2022/lib/components/forms/directives/validation/validation-message-renderer.service.mjs +4 -4
  129. package/esm2022/lib/components/forms/directives/validation/validators/elder-max.validator.mjs +4 -4
  130. package/esm2022/lib/components/forms/directives/validation/validators/elder-min.validator.mjs +4 -4
  131. package/esm2022/lib/components/forms/directives/validation/validators/elder-multiple-of.validator.mjs +4 -4
  132. package/esm2022/lib/components/forms/directives/validation/validators/elder-required-ignore-zero.validator.mjs +4 -4
  133. package/esm2022/lib/components/forms/elder-forms.module.mjs +5 -5
  134. package/esm2022/lib/components/forms/search/domain/context/search-context.service.mjs +4 -4
  135. package/esm2022/lib/components/forms/search/domain/input/input-value.mjs +2 -0
  136. package/esm2022/lib/components/forms/search/domain/input/search-input-state.mjs +15 -6
  137. package/esm2022/lib/components/forms/search/domain/input/search-input.mjs +1 -1
  138. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.directive.mjs +4 -4
  139. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.service.mjs +4 -4
  140. package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +39 -28
  141. package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +50 -17
  142. package/esm2022/lib/components/forms/search/elder-search.module.mjs +5 -5
  143. package/esm2022/lib/components/forms/search/filter/default-input-filter-converter.mjs +46 -0
  144. package/esm2022/lib/components/forms/search/filter/include-exclude-input-converter.mjs +165 -0
  145. package/esm2022/lib/components/forms/search/filter/input-filter-converter.mjs +2 -0
  146. package/esm2022/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
  147. package/esm2022/lib/components/forms/search/search-box/elder-search-panel.component.mjs +4 -4
  148. package/esm2022/lib/components/global-search/elder-global-search.component.mjs +4 -4
  149. package/esm2022/lib/components/global-search/elder-global-search.module.mjs +5 -5
  150. package/esm2022/lib/components/global-search/elder-global-search.service.mjs +4 -4
  151. package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +4 -4
  152. package/esm2022/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +5 -5
  153. package/esm2022/lib/components/headers/elder-header/elder-header.component.mjs +4 -4
  154. package/esm2022/lib/components/headers/elder-header.module.mjs +5 -5
  155. package/esm2022/lib/components/http-support/elder-http-client.service.mjs +4 -4
  156. package/esm2022/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -5
  157. package/esm2022/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
  158. package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +4 -4
  159. package/esm2022/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +4 -4
  160. package/esm2022/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
  161. package/esm2022/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +4 -4
  162. package/esm2022/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  163. package/esm2022/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +4 -4
  164. package/esm2022/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +4 -4
  165. package/esm2022/lib/components/i18n/entities/picker/localisation-picker.service.mjs +4 -4
  166. package/esm2022/lib/components/i18n/language/elder-language-interceptor.mjs +4 -4
  167. package/esm2022/lib/components/i18n/language/elder-language.module.mjs +5 -5
  168. package/esm2022/lib/components/i18n/language/elder-language.service.mjs +4 -4
  169. package/esm2022/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +4 -4
  170. package/esm2022/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
  171. package/esm2022/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +4 -4
  172. package/esm2022/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +4 -4
  173. package/esm2022/lib/components/iframes/elder-iframe.module.mjs +5 -5
  174. package/esm2022/lib/components/iframes/iframe-close.directive.mjs +4 -4
  175. package/esm2022/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -4
  176. package/esm2022/lib/components/iframes/iframe-host/iframe-host.component.mjs +4 -4
  177. package/esm2022/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -4
  178. package/esm2022/lib/components/iframes/iframe.service.mjs +4 -4
  179. package/esm2022/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +4 -4
  180. package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  181. package/esm2022/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +5 -5
  182. package/esm2022/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete-option-selected.mjs +1 -1
  183. package/esm2022/lib/components/input/autocomplete/elder-autocomplete/elder-suggestion-panel.component.mjs +231 -0
  184. package/esm2022/lib/components/input/autocomplete/elder-autocomplete-many.directive.mjs +4 -4
  185. package/esm2022/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +7 -4
  186. package/esm2022/lib/components/input/autocomplete/elder-autocomplete.module.mjs +12 -12
  187. package/esm2022/lib/components/labels/elder-labels.module.mjs +5 -5
  188. package/esm2022/lib/components/labels/labels-input/labels-input.component.mjs +4 -4
  189. package/esm2022/lib/components/measures/dimensions/dimensions-input/elder-dimensions-input.component.mjs +4 -4
  190. package/esm2022/lib/components/measures/dimensions/validation/elder-required-dimensions.validator.mjs +4 -4
  191. package/esm2022/lib/components/measures/directives/elder-unit-select.directive.mjs +4 -4
  192. package/esm2022/lib/components/measures/elder-measures.module.mjs +9 -9
  193. package/esm2022/lib/components/measures/elder-quantity-transform.pipe.mjs +5 -16
  194. package/esm2022/lib/components/measures/elder-quantity.pipe.mjs +15 -46
  195. package/esm2022/lib/components/measures/elder-unit.service.mjs +4 -4
  196. package/esm2022/lib/components/measures/quantity-input/quantity-form-field/elder-quantity-form-field.component.mjs +4 -4
  197. package/esm2022/lib/components/measures/quantity-input/quantity-input-control/elder-quantity-input-control.component.mjs +8 -10
  198. package/esm2022/lib/components/measures/quantity-input/validation/elder-quantity-range.validator.mjs +4 -4
  199. package/esm2022/lib/components/measures/quantity-input/validation/elder-required-quantity.validator.mjs +4 -4
  200. package/esm2022/lib/components/measures/util/elder-quantity.service.mjs +70 -4
  201. package/esm2022/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
  202. package/esm2022/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +5 -5
  203. package/esm2022/lib/components/navigation/nav/elder-nav.module.mjs +5 -5
  204. package/esm2022/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
  205. package/esm2022/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -4
  206. package/esm2022/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +4 -4
  207. package/esm2022/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +4 -4
  208. package/esm2022/lib/components/navigation/toolbar/elder-toolbar.module.mjs +5 -5
  209. package/esm2022/lib/components/navigation/toolbar/elder-toolbar.service.mjs +4 -4
  210. package/esm2022/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +4 -4
  211. package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +4 -4
  212. package/esm2022/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +4 -4
  213. package/esm2022/lib/components/overlays/elder-overlay-origin.directive.mjs +4 -4
  214. package/esm2022/lib/components/overlays/elder-overlay-ref.mjs +4 -4
  215. package/esm2022/lib/components/overlays/elder-overlay-trigger.directive.mjs +4 -4
  216. package/esm2022/lib/components/overlays/elder-overlay.component.mjs +4 -4
  217. package/esm2022/lib/components/overlays/elder-overlay.module.mjs +5 -5
  218. package/esm2022/lib/components/panels/card-panel/elder-card-panel.component.mjs +4 -4
  219. package/esm2022/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +4 -4
  220. package/esm2022/lib/components/panels/elder-panel.module.mjs +5 -5
  221. package/esm2022/lib/components/panels/flat/elder-panel.component.mjs +4 -4
  222. package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel-trigger.directive.mjs +4 -4
  223. package/esm2022/lib/components/panels/toggle-panel/elder-toggle-panel.component.mjs +10 -10
  224. package/esm2022/lib/components/scrollbar/elder-scrollbar.directive.mjs +4 -4
  225. package/esm2022/lib/components/scrollbar/elder-scrollbar.module.mjs +5 -5
  226. package/esm2022/lib/components/select/auto/elder-auto-select-first.directive.mjs +27 -7
  227. package/esm2022/lib/components/select/auto/elder-auto-select-first.service.mjs +38 -0
  228. package/esm2022/lib/components/select/auto/elder-auto-select-suggest-first.directive.mjs +66 -0
  229. package/esm2022/lib/components/select/auto/elder-select-first-util.mjs +4 -14
  230. package/esm2022/lib/components/select/elder-select-base.mjs +9 -9
  231. package/esm2022/lib/components/select/elder-select-chip.directive.mjs +10 -10
  232. package/esm2022/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  233. package/esm2022/lib/components/select/elder-select-value.directive.mjs +4 -4
  234. package/esm2022/lib/components/select/elder-select.module.mjs +35 -10
  235. package/esm2022/lib/components/select/filter/elder-chip-filter-style-resolver.mjs +70 -0
  236. package/esm2022/lib/components/select/filter/elder-chips-filter.directive.mjs +174 -0
  237. package/esm2022/lib/components/select/filter/elder-filter-chip-template/elder-filter-chip-template.component.mjs +58 -0
  238. package/esm2022/lib/components/select/multi/elder-chip-select-option/elder-select-option.component.mjs +4 -4
  239. package/esm2022/lib/components/select/multi/elder-multi-select-base.mjs +4 -4
  240. package/esm2022/lib/components/select/multi/elder-multi-select-chip-options/elder-multi-select-chip-options.component.mjs +14 -7
  241. package/esm2022/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +10 -6
  242. package/esm2022/lib/components/select/multi/elder-multi-select-form-field.mjs +4 -4
  243. package/esm2022/lib/components/select/multi/elder-mutli-select-all-directive.mjs +4 -4
  244. package/esm2022/lib/components/select/multi/elder-search-include-exclude.directive.mjs +83 -0
  245. package/esm2022/lib/components/select/popup/selection-model-popup-trigger-adapter.directive.mjs +4 -4
  246. package/esm2022/lib/components/select/popup/selection-model-popup.directive.mjs +4 -4
  247. package/esm2022/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +4 -4
  248. package/esm2022/lib/components/select/single/elder-clear-select.directive.mjs +4 -4
  249. package/esm2022/lib/components/select/single/elder-select/elder-select.component.mjs +9 -14
  250. package/esm2022/lib/components/select/single/elder-select-form-field.mjs +4 -4
  251. package/esm2022/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -4
  252. package/esm2022/lib/components/select-chip-list/elder-chip-list-select.module.mjs +5 -5
  253. package/esm2022/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +4 -4
  254. package/esm2022/lib/components/shell/drawers/elder-router-outlet.service.mjs +4 -4
  255. package/esm2022/lib/components/shell/elder-shell-slot.directive.mjs +4 -4
  256. package/esm2022/lib/components/shell/elder-shell.module.mjs +5 -5
  257. package/esm2022/lib/components/shell/elder-shell.service.mjs +4 -4
  258. package/esm2022/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
  259. package/esm2022/lib/components/shell/shell/elder-shell.component.mjs +13 -13
  260. package/esm2022/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +4 -4
  261. package/esm2022/lib/components/tabs/elder-tab/elder-tab.directive.mjs +4 -4
  262. package/esm2022/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  263. package/esm2022/lib/components/tabs/elder-tab.module.mjs +5 -5
  264. package/esm2022/lib/components/theme/elder-theme-applier.directive.mjs +4 -4
  265. package/esm2022/lib/components/theme/elder-theme-preference.service.mjs +4 -4
  266. package/esm2022/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +4 -4
  267. package/esm2022/lib/components/theme/elder-theme.directive.mjs +4 -4
  268. package/esm2022/lib/components/theme/elder-theme.module.mjs +5 -5
  269. package/esm2022/lib/components/theme/elder-theme.service.mjs +4 -4
  270. package/esm2022/lib/components/time/date-adapters/custom-date-adapter.mjs +4 -4
  271. package/esm2022/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +4 -4
  272. package/esm2022/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +4 -4
  273. package/esm2022/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +4 -4
  274. package/esm2022/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +4 -4
  275. package/esm2022/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +4 -4
  276. package/esm2022/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +4 -4
  277. package/esm2022/lib/components/time/elder-time.module.mjs +5 -5
  278. package/esm2022/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +4 -4
  279. package/esm2022/lib/components/time/pipes/to-iso-date-string.pipe.mjs +4 -4
  280. package/esm2022/lib/components/toasts/elder-toast.module.mjs +5 -5
  281. package/esm2022/lib/components/toasts/elder-toast.service.mjs +4 -4
  282. package/esm2022/lib/components/toasts/standard-toast/standard-toast.component.mjs +4 -4
  283. package/esm2022/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -5
  284. package/esm2022/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -4
  285. package/esm2022/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +4 -4
  286. package/esm2022/lib/components/viewers/elder-viewers.module.mjs +5 -5
  287. package/esm2022/lib/features/event-source/fetch/reactive-fetch-event-source.service.mjs +4 -4
  288. package/esm2022/lib/features/event-source/standard/elder-event-source.service.mjs +4 -4
  289. package/esm2022/lib/features/kafent/access-token-provider.mjs +4 -4
  290. package/esm2022/lib/features/kafent/kafent-config.mjs +4 -4
  291. package/esm2022/lib/features/kafent/kafent-event-stream.mjs +4 -4
  292. package/esm2022/lib/features/kafent/kafent-event.service.mjs +4 -4
  293. package/esm2022/lib/features/kafent/kafent.module.mjs +5 -5
  294. package/esm2022/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +4 -4
  295. package/esm2022/lib/pipes/bytes.pipe.mjs +4 -4
  296. package/esm2022/lib/pipes/elder-pipes.module.mjs +11 -11
  297. package/esm2022/lib/pipes/elder-repeat.pipe.mjs +4 -4
  298. package/esm2022/lib/pipes/elder-round.pipe.mjs +4 -4
  299. package/esm2022/lib/pipes/elder-safe-url.pipe.mjs +4 -4
  300. package/esm2022/lib/pipes/elder-truncate.pipe.mjs +4 -4
  301. package/esm2022/lib/pipes/iso-duration.pipe.mjs +8 -26
  302. package/esm2022/lib/pipes/iso-interval-parse.pipe.mjs +4 -4
  303. package/esm2022/lib/pipes/iso-interval.pipe.mjs +24 -73
  304. package/esm2022/lib/pipes/time-ago.pipe.mjs +4 -4
  305. package/esm2022/lib/pipes/time-duration.pipe.mjs +4 -4
  306. package/esm2022/lib/pipes/weight.pipe.mjs +4 -4
  307. package/fesm2022/elderbyte-ngx-starter.mjs +8822 -7833
  308. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  309. package/lib/common/data/filters/filter-commons.d.ts +12 -0
  310. package/lib/common/data/filters/filter-value.d.ts +1 -0
  311. package/lib/common/format/curency-format-util.d.ts +24 -0
  312. package/lib/common/format/duration-format-util.d.ts +23 -0
  313. package/lib/common/format/iso-interval-format-util.d.ts +22 -0
  314. package/lib/common/format/public_api.d.ts +3 -0
  315. package/lib/components/badge/elder-badge.directive.d.ts +10 -1
  316. package/lib/components/currency/elder-currency.pipe.d.ts +7 -4
  317. package/lib/components/forms/directives/elder-initial-value.directive.d.ts +4 -2
  318. package/lib/components/forms/search/domain/input/input-value.d.ts +1 -0
  319. package/lib/components/forms/search/domain/input/search-input-state.d.ts +14 -4
  320. package/lib/components/forms/search/domain/input/search-input.d.ts +6 -1
  321. package/lib/components/forms/search/elder-search-context.directive.d.ts +7 -2
  322. package/lib/components/forms/search/elder-search-input.directive.d.ts +18 -7
  323. package/lib/components/forms/search/filter/default-input-filter-converter.d.ts +31 -0
  324. package/lib/components/forms/search/filter/include-exclude-input-converter.d.ts +78 -0
  325. package/lib/components/forms/search/filter/input-filter-converter.d.ts +16 -0
  326. package/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete-option-selected.d.ts +3 -3
  327. package/lib/components/input/autocomplete/elder-autocomplete/{elder-autocomplete.component.d.ts → elder-suggestion-panel.component.d.ts} +17 -6
  328. package/lib/components/input/autocomplete/elder-autocomplete-many.directive.d.ts +3 -3
  329. package/lib/components/input/autocomplete/elder-autocomplete.directive.d.ts +3 -3
  330. package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +3 -3
  331. package/lib/components/measures/elder-quantity.pipe.d.ts +4 -15
  332. package/lib/components/measures/quantity-input/quantity-input-control/elder-quantity-input-control.component.d.ts +2 -4
  333. package/lib/components/measures/util/elder-quantity.service.d.ts +12 -0
  334. package/lib/components/select/auto/elder-auto-select-first.directive.d.ts +9 -1
  335. package/lib/components/select/auto/elder-auto-select-first.service.d.ts +23 -0
  336. package/lib/components/select/auto/elder-auto-select-suggest-first.directive.d.ts +32 -0
  337. package/lib/components/select/auto/elder-select-first-util.d.ts +2 -2
  338. package/lib/components/select/elder-select-base.d.ts +1 -1
  339. package/lib/components/select/elder-select.module.d.ts +9 -1
  340. package/lib/components/select/filter/elder-chip-filter-style-resolver.d.ts +19 -0
  341. package/lib/components/select/filter/elder-chips-filter.directive.d.ts +68 -0
  342. package/lib/components/select/filter/elder-filter-chip-template/elder-filter-chip-template.component.d.ts +32 -0
  343. package/lib/components/select/multi/elder-multi-select-chip-options/elder-multi-select-chip-options.component.d.ts +5 -1
  344. package/lib/components/select/multi/elder-search-include-exclude.directive.d.ts +39 -0
  345. package/lib/components/select/single/elder-select/elder-select.component.d.ts +0 -1
  346. package/lib/pipes/iso-duration.pipe.d.ts +0 -3
  347. package/lib/pipes/iso-interval.pipe.d.ts +5 -12
  348. package/package.json +1 -1
  349. package/src/lib/components/select/filter/elder-filter-chip-template/elder-filter-chip-template.component.scss +95 -0
  350. package/src/lib/components/select/multi/elder-select-include-exclude-chip/elder-select-include-exclude-chip.component.scss +0 -0
  351. package/esm2022/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +0 -186
  352. /package/src/lib/components/input/autocomplete/elder-autocomplete/{elder-autocomplete.component.scss → elder-suggestion-panel.component.scss} +0 -0
@@ -2,9 +2,13 @@ import { Quantity } from '../model/quantity';
2
2
  import { Injectable } from '@angular/core';
3
3
  import { Dimensions } from '../model/dimensions';
4
4
  import { LoggerFactory } from '@elderbyte/ts-logger';
5
+ import { formatNumber } from '@angular/common';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "../elder-unit.service";
7
8
  export class ElderQuantityService {
9
+ static { this.EMPTY_STRING = ''; }
10
+ static { this.SPACE_STRING = ' '; }
11
+ static { this.DEFAULT_DIGITS = '1.0-1'; }
8
12
  /***************************************************************************
9
13
  * *
10
14
  * Builder support *
@@ -215,6 +219,31 @@ export class ElderQuantityService {
215
219
  return targetQuantity;
216
220
  }
217
221
  }
222
+ transformQuantity(quantity, normalize = true, targetUnit) {
223
+ if (!quantity) {
224
+ return null;
225
+ }
226
+ if (normalize) {
227
+ return this.normalize(quantity);
228
+ }
229
+ else if (targetUnit) {
230
+ return this.convertToUnit(quantity, targetUnit);
231
+ }
232
+ else {
233
+ return quantity;
234
+ }
235
+ }
236
+ formatQuantity(quantity, locale, normalize, targetUnit, digitsInfo) {
237
+ digitsInfo ||= ElderQuantityService.DEFAULT_DIGITS;
238
+ if (!quantity) {
239
+ return ElderQuantityService.EMPTY_STRING;
240
+ }
241
+ const userOptions = ElderQuantityService.determineUserOptions(normalize, targetUnit, digitsInfo);
242
+ const quantityToDisplay = this.transformQuantity(quantity, userOptions.normalize, userOptions.targetUnit);
243
+ const number = this.strToNumber(quantityToDisplay.value);
244
+ const suffix = this.determineSuffix(userOptions, quantityToDisplay);
245
+ return formatNumber(number, locale, userOptions.digitsInfo) + suffix;
246
+ }
218
247
  /***************************************************************************
219
248
  * *
220
249
  * Private Methods *
@@ -258,13 +287,50 @@ export class ElderQuantityService {
258
287
  getQuantityIdentifier(quantity) {
259
288
  return quantity.value + '-' + quantity.unit;
260
289
  }
261
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderQuantityService, deps: [{ token: i1.ElderUnitService }], target: i0.ɵɵFactoryTarget.Injectable }); }
262
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderQuantityService, providedIn: 'root' }); }
290
+ /**
291
+ * Adapted from @angular/common number_pipe.ts
292
+ */
293
+ strToNumber(value) {
294
+ // Convert strings to numbers
295
+ if (typeof value === 'string' && !isNaN(Number(value) - parseFloat(value))) {
296
+ return Number(value);
297
+ }
298
+ if (typeof value !== 'number') {
299
+ throw new Error(`${value} is not a number`);
300
+ }
301
+ return value;
302
+ }
303
+ static determineUserOptions(normalize, targetUnit, digitsInfo) {
304
+ const userOptions = (normalize === undefined || typeof normalize === 'boolean')
305
+ ? {
306
+ normalize: normalize,
307
+ targetUnit: targetUnit,
308
+ digitsInfo: digitsInfo
309
+ }
310
+ : normalize;
311
+ if (userOptions.normalize === undefined && !userOptions.targetUnit) {
312
+ userOptions.normalize = true;
313
+ }
314
+ if (userOptions.digitsInfo === undefined) {
315
+ userOptions.digitsInfo = ElderQuantityService.DEFAULT_DIGITS;
316
+ }
317
+ return userOptions;
318
+ }
319
+ determineSuffix(userOptions, quantityToDisplay) {
320
+ if (!userOptions.hideUnit) {
321
+ return ElderQuantityService.SPACE_STRING + this.unitService.getUnitSymbol(quantityToDisplay.unit);
322
+ }
323
+ else {
324
+ return '';
325
+ }
326
+ }
327
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderQuantityService, deps: [{ token: i1.ElderUnitService }], target: i0.ɵɵFactoryTarget.Injectable }); }
328
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderQuantityService, providedIn: 'root' }); }
263
329
  }
264
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderQuantityService, decorators: [{
330
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderQuantityService, decorators: [{
265
331
  type: Injectable,
266
332
  args: [{
267
333
  providedIn: 'root'
268
334
  }]
269
335
  }], ctorParameters: () => [{ type: i1.ElderUnitService }] });
270
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-quantity.service.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/util/elder-quantity.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Unit} from '../model/unit';\nimport {Quantity} from '../model/quantity';\nimport {UnitInfo} from '../model/unit-registry';\nimport {Injectable} from '@angular/core';\nimport {ElderUnitService} from '../elder-unit.service';\nimport {Dimensions} from '../model/dimensions';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\n\ninterface QuantityWithBaseValue {\n  original: Quantity;\n  baseValue: number;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderQuantityService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly QUANTITY_CACHE_SIZE = 500;\n  private readonly QUANTITY_CACHE = new Map<string, Quantity>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Builder support                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  public createArea(length: Quantity, width: Quantity): Dimensions {\n    return this.createDimensions(\n      length,\n      width,\n      Quantity.zero(length.unit)\n    );\n  }\n\n  public createDimensions(\n    length: Quantity,\n    width: Quantity,\n    height: Quantity\n  ): Dimensions {\n    return Dimensions.from(\n      length.unit,\n      length.value,\n      this.convertToUnit(width, length.unit).value,\n      this.convertToUnit(height, length.unit).value\n    );\n  }\n\n  /**\n   * Returns a copy of the maximum (longest) edge of the dimensions.\n   *\n   * @param dimensions\n   */\n  public getMaxEdge(dimensions: Dimensions): Quantity {\n    if (!dimensions) {\n      return null;\n    } else {\n      return Quantity.from(\n        dimensions.unit,\n        Math.max(dimensions.width, dimensions.length, dimensions.height)\n      );\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly unitService: ElderUnitService\n  ) {\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public withUnit(quantity: Quantity, unit: Unit) {\n    return Quantity.from(unit, quantity.value);\n  }\n\n  public withValue(quantity: Quantity, value: number) {\n    return Quantity.from(quantity.unit, value);\n  }\n\n  public cacheLookup(lookup: Quantity): Quantity {\n    return this.QUANTITY_CACHE.get(this.getQuantityIdentifier(lookup));\n  }\n\n  public cacheUpdate(key: Quantity, value: Quantity) {\n    if (this.QUANTITY_CACHE.size >= this.QUANTITY_CACHE_SIZE) {\n      this.QUANTITY_CACHE.clear();\n    }\n    this.QUANTITY_CACHE.set(this.getQuantityIdentifier(key), value);\n  }\n\n  /**\n   * Multiplies a quantity with a multiplier and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') * 3 = Quantity(30000,'g')\n   *\n   * @param quantity\n   * @param multiplier\n   */\n\n  public multiply(quantity: Quantity, multiplier: number): Quantity {\n\n    if (!quantity || !multiplier) {\n      return null;\n    }\n    return Quantity.from(\n      quantity.unit,\n      quantity.value * multiplier\n    );\n  }\n\n  /**\n   * Divides a quantity by another quantity and returns a scalar.\n   *\n   * Examples:\n   * Quantity(10,'kg') / Quantity(5,'kg') = 2\n   * Quantity(10,'kg') / Quantity(5,'g') = 2000\n   *\n   * @param dividend\n   * @param divisor\n   */\n  public divideByQuantity(dividend: Quantity, divisor: Quantity): number {\n\n    if (!dividend || !divisor) {\n      return null;\n    }\n    const dividendNormal =  this.toBaseUnitValue(dividend);\n    const divisorNormal =  this.toBaseUnitValue(divisor);\n    return dividendNormal / divisorNormal;\n  }\n\n\n  /**\n   * Sums up Quantities and returns a Quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') + Quantity(5,'kg') + Quantity(5,'g') = Quantity(15005, 'g')\n   *\n   * @param quantities\n   */\n  public sum(quantities: Quantity[]): Quantity {\n    if (!quantities || quantities.length === 0) {\n      return null;\n    }\n\n    const targetUnit = quantities[0].unit;\n\n    return Quantity.from(\n      targetUnit,\n      quantities.reduce(\n        (total, add) => {\n          return total + this.convertToUnit(add, targetUnit).value;\n        }, 0\n      )\n    );\n  }\n\n  /**\n   * Subtracts a quantity from another quantity and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') - Quantity(5,'g') = Quantity(9995, 'g')\n   *\n   * @param minuend\n   * @param subtrahend\n   */\n  public subtract(minuend: Quantity, subtrahend: Quantity): Quantity {\n    if (!minuend || !subtrahend) {\n      return null;\n    }\n    return Quantity.from(\n      minuend.unit,\n      minuend.value - this.convertToUnit(subtrahend, minuend.unit).value\n    );\n  }\n\n  /**\n   * Subtracts a quantity from another quantity and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') + Quantity(500,'g') = Quantity(10.5, 'kg')\n   *\n   * @param left\n   * @param right\n   */\n  public add(left: Quantity, right: Quantity): Quantity {\n    if (!left || !right) {\n      return null;\n    }\n    return Quantity.from(\n      left.unit,\n      left.value - this.convertToUnit(right, left.unit).value\n    );\n  }\n\n\n  /**\n   * Returns the max quantity of an array of quantities.\n   *\n   * Example:\n   * Quantity(10, 'm'), Quantity(2500, 'cm'), Quantity(0.003, 'km') = Quantity(2500, 'cm')\n   *\n   * @param quantities\n   */\n\n  public max(quantities: Quantity[]): Quantity {\n\n    if (!quantities || quantities.length == 0) {\n      return null;\n    }\n\n    const helpers = quantities\n      .map(quantity => <QuantityWithBaseValue>{\n        original: quantity,\n        baseValue: this.toBaseUnitValue(quantity)\n      });\n\n    helpers.sort((a, b) => b.baseValue - a.baseValue);\n\n    return helpers[0].original;\n  }\n\n\n  /**\n   * Transforms a quantity to another quantity of the same dimension by target-SI\n   *\n   * @param quantity\n   * @param targetUnit\n   */\n  public convertToUnit(quantity: Quantity, targetUnit: Unit): Quantity {\n    if (!quantity || !targetUnit) {\n      return null;\n    }\n\n    if (quantity.unit === targetUnit) {\n      return Quantity.from(quantity.unit, quantity.value);\n    }\n\n    const targetBaseFactor = this.unitService.getToBaseFactor(targetUnit);\n\n    if (targetBaseFactor > 0) {\n      return Quantity.from(\n        targetUnit,\n        this.toBaseUnitValue(quantity) / targetBaseFactor\n      );\n    } else {\n      this.logger.warn('Failed to convert quantity to target unit:' + targetUnit + '. Quantity: ', quantity);\n      return quantity;\n    }\n  }\n\n  public toBaseUnitValue(quantity: Quantity): number {\n    const targetBaseFactor = this.unitService.getToBaseFactor(quantity.unit);\n    return quantity.value * targetBaseFactor;\n  }\n\n  /**\n   * Returns a quantity in a normalized form.\n   * A cache is used to reduce calculations.\n   *\n   * 8500 kg -> 8.5 t\n   * 9000000 mm -> 9 km\n   * 1215 m -> 1.2 km\n   *\n   * @param quantity\n   */\n  public normalize(quantity: Quantity): Quantity {\n\n    // Check cache\n    const cachedItem = this.cacheLookup(quantity);\n\n    // Value is in cache\n    if (cachedItem) {\n      return cachedItem;\n    } else {\n\n      const targetQuantity = this.normalizeInternal(quantity);\n\n      // Update cache\n      this.cacheUpdate(quantity, targetQuantity);\n\n      return targetQuantity;\n\n    }\n  }\n\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private normalizeInternal(quantity: Quantity): Quantity {\n\n    // Given quantity value in base unit\n\n    const dimension = this.unitService.getUnitDimension(quantity.unit);\n\n    if (!dimension) { return quantity; }\n\n    const baseValue = this.toBaseUnitValue(quantity);\n\n    let suitableUnit: UnitInfo;\n\n    const dimensionUnits = this.unitService.getUnitInfosByDimension(dimension);\n\n    if (dimensionUnits) {\n\n      const factorSortedUnits = dimensionUnits.sort((a, b) => b.toBaseFactor - a.toBaseFactor);\n\n      for (const unitInfo of factorSortedUnits) {\n        const signedBaseValue = ((baseValue < 0) ? baseValue * -1 : baseValue);\n        if (unitInfo.toBaseFactor <= signedBaseValue) {\n          suitableUnit = unitInfo;\n          break;\n        }\n      }\n    } else {\n      this.logger.debug('Could not find Dimension info for ' + dimension + '. (' + quantity.unit + ' --> ' + dimension + ')');\n    }\n\n    if (!suitableUnit) {\n      return quantity;\n    }\n\n    const currentToBase = this.unitService.getToBaseFactor(quantity.unit);\n\n    // Ensure we prefer the initial unit if the actual value is not affected.\n    // This helps to be consistent and display the actual unit in rare cases when multiple unit alternatives exist (same factor)\n    if (suitableUnit.toBaseFactor === currentToBase) {\n      return quantity;\n    } else {\n      return this.convertToUnit(quantity, suitableUnit.unit);\n    }\n  }\n\n  private getQuantityIdentifier(quantity: Quantity): string {\n    return quantity.value + '-' + quantity.unit;\n  }\n\n}\n"]}
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-quantity.service.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/measures/util/elder-quantity.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Unit} from '../model/unit';\nimport {Quantity} from '../model/quantity';\nimport {UnitInfo} from '../model/unit-registry';\nimport {Injectable} from '@angular/core';\nimport {ElderUnitService} from '../elder-unit.service';\nimport {Dimensions} from '../model/dimensions';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {formatNumber} from '@angular/common';\nimport {QuantityPipeOptions} from '../elder-quantity.pipe';\n\ninterface QuantityWithBaseValue {\n  original: Quantity;\n  baseValue: number;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderQuantityService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private static readonly EMPTY_STRING: string = '';\n  private static readonly SPACE_STRING: string = ' ';\n\n  private static readonly DEFAULT_DIGITS: string = '1.0-1';\n\n  private readonly QUANTITY_CACHE_SIZE = 500;\n  private readonly QUANTITY_CACHE = new Map<string, Quantity>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Builder support                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  public createArea(length: Quantity, width: Quantity): Dimensions {\n    return this.createDimensions(\n      length,\n      width,\n      Quantity.zero(length.unit)\n    );\n  }\n\n  public createDimensions(\n    length: Quantity,\n    width: Quantity,\n    height: Quantity\n  ): Dimensions {\n    return Dimensions.from(\n      length.unit,\n      length.value,\n      this.convertToUnit(width, length.unit).value,\n      this.convertToUnit(height, length.unit).value\n    );\n  }\n\n  /**\n   * Returns a copy of the maximum (longest) edge of the dimensions.\n   *\n   * @param dimensions\n   */\n  public getMaxEdge(dimensions: Dimensions): Quantity {\n    if (!dimensions) {\n      return null;\n    } else {\n      return Quantity.from(\n        dimensions.unit,\n        Math.max(dimensions.width, dimensions.length, dimensions.height)\n      );\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly unitService: ElderUnitService\n  ) {\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public withUnit(quantity: Quantity, unit: Unit) {\n    return Quantity.from(unit, quantity.value);\n  }\n\n  public withValue(quantity: Quantity, value: number) {\n    return Quantity.from(quantity.unit, value);\n  }\n\n  public cacheLookup(lookup: Quantity): Quantity {\n    return this.QUANTITY_CACHE.get(this.getQuantityIdentifier(lookup));\n  }\n\n  public cacheUpdate(key: Quantity, value: Quantity) {\n    if (this.QUANTITY_CACHE.size >= this.QUANTITY_CACHE_SIZE) {\n      this.QUANTITY_CACHE.clear();\n    }\n    this.QUANTITY_CACHE.set(this.getQuantityIdentifier(key), value);\n  }\n\n  /**\n   * Multiplies a quantity with a multiplier and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') * 3 = Quantity(30000,'g')\n   *\n   * @param quantity\n   * @param multiplier\n   */\n\n  public multiply(quantity: Quantity, multiplier: number): Quantity {\n\n    if (!quantity || !multiplier) {\n      return null;\n    }\n    return Quantity.from(\n      quantity.unit,\n      quantity.value * multiplier\n    );\n  }\n\n  /**\n   * Divides a quantity by another quantity and returns a scalar.\n   *\n   * Examples:\n   * Quantity(10,'kg') / Quantity(5,'kg') = 2\n   * Quantity(10,'kg') / Quantity(5,'g') = 2000\n   *\n   * @param dividend\n   * @param divisor\n   */\n  public divideByQuantity(dividend: Quantity, divisor: Quantity): number {\n\n    if (!dividend || !divisor) {\n      return null;\n    }\n    const dividendNormal =  this.toBaseUnitValue(dividend);\n    const divisorNormal =  this.toBaseUnitValue(divisor);\n    return dividendNormal / divisorNormal;\n  }\n\n\n  /**\n   * Sums up Quantities and returns a Quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') + Quantity(5,'kg') + Quantity(5,'g') = Quantity(15005, 'g')\n   *\n   * @param quantities\n   */\n  public sum(quantities: Quantity[]): Quantity {\n    if (!quantities || quantities.length === 0) {\n      return null;\n    }\n\n    const targetUnit = quantities[0].unit;\n\n    return Quantity.from(\n      targetUnit,\n      quantities.reduce(\n        (total, add) => {\n          return total + this.convertToUnit(add, targetUnit).value;\n        }, 0\n      )\n    );\n  }\n\n  /**\n   * Subtracts a quantity from another quantity and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') - Quantity(5,'g') = Quantity(9995, 'g')\n   *\n   * @param minuend\n   * @param subtrahend\n   */\n  public subtract(minuend: Quantity, subtrahend: Quantity): Quantity {\n    if (!minuend || !subtrahend) {\n      return null;\n    }\n    return Quantity.from(\n      minuend.unit,\n      minuend.value - this.convertToUnit(subtrahend, minuend.unit).value\n    );\n  }\n\n  /**\n   * Subtracts a quantity from another quantity and returns a quantity.\n   *\n   * Example:\n   * Quantity(10,'kg') + Quantity(500,'g') = Quantity(10.5, 'kg')\n   *\n   * @param left\n   * @param right\n   */\n  public add(left: Quantity, right: Quantity): Quantity {\n    if (!left || !right) {\n      return null;\n    }\n    return Quantity.from(\n      left.unit,\n      left.value - this.convertToUnit(right, left.unit).value\n    );\n  }\n\n\n  /**\n   * Returns the max quantity of an array of quantities.\n   *\n   * Example:\n   * Quantity(10, 'm'), Quantity(2500, 'cm'), Quantity(0.003, 'km') = Quantity(2500, 'cm')\n   *\n   * @param quantities\n   */\n\n  public max(quantities: Quantity[]): Quantity {\n\n    if (!quantities || quantities.length == 0) {\n      return null;\n    }\n\n    const helpers = quantities\n      .map(quantity => <QuantityWithBaseValue>{\n        original: quantity,\n        baseValue: this.toBaseUnitValue(quantity)\n      });\n\n    helpers.sort((a, b) => b.baseValue - a.baseValue);\n\n    return helpers[0].original;\n  }\n\n\n  /**\n   * Transforms a quantity to another quantity of the same dimension by target-SI\n   *\n   * @param quantity\n   * @param targetUnit\n   */\n  public convertToUnit(quantity: Quantity, targetUnit: Unit): Quantity {\n    if (!quantity || !targetUnit) {\n      return null;\n    }\n\n    if (quantity.unit === targetUnit) {\n      return Quantity.from(quantity.unit, quantity.value);\n    }\n\n    const targetBaseFactor = this.unitService.getToBaseFactor(targetUnit);\n\n    if (targetBaseFactor > 0) {\n      return Quantity.from(\n        targetUnit,\n        this.toBaseUnitValue(quantity) / targetBaseFactor\n      );\n    } else {\n      this.logger.warn('Failed to convert quantity to target unit:' + targetUnit + '. Quantity: ', quantity);\n      return quantity;\n    }\n  }\n\n  public toBaseUnitValue(quantity: Quantity): number {\n    const targetBaseFactor = this.unitService.getToBaseFactor(quantity.unit);\n    return quantity.value * targetBaseFactor;\n  }\n\n  /**\n   * Returns a quantity in a normalized form.\n   * A cache is used to reduce calculations.\n   *\n   * 8500 kg -> 8.5 t\n   * 9000000 mm -> 9 km\n   * 1215 m -> 1.2 km\n   *\n   * @param quantity\n   */\n  public normalize(quantity: Quantity): Quantity {\n\n    // Check cache\n    const cachedItem = this.cacheLookup(quantity);\n\n    // Value is in cache\n    if (cachedItem) {\n      return cachedItem;\n    } else {\n\n      const targetQuantity = this.normalizeInternal(quantity);\n\n      // Update cache\n      this.cacheUpdate(quantity, targetQuantity);\n\n      return targetQuantity;\n\n    }\n  }\n\n  public transformQuantity(\n    quantity: Quantity,\n    normalize: boolean = true,\n    targetUnit?: Unit | string\n  ): Quantity {\n\n    if (!quantity) {\n      return null;\n    }\n\n    if (normalize) {\n      return this.normalize(quantity);\n    } else if (targetUnit) {\n      return this.convertToUnit(quantity, <Unit>targetUnit);\n    } else {\n      return quantity;\n    }\n  }\n\n  public formatQuantity(\n    quantity: Quantity,\n    locale: string,\n    normalize?: boolean | QuantityPipeOptions,\n    targetUnit?: Unit | string,\n    digitsInfo?: string\n  ): string {\n    digitsInfo ||= ElderQuantityService.DEFAULT_DIGITS;\n\n    if (!quantity) {\n      return ElderQuantityService.EMPTY_STRING;\n    }\n    const userOptions = ElderQuantityService.determineUserOptions(normalize, targetUnit, digitsInfo);\n\n    const quantityToDisplay: Quantity = this.transformQuantity(\n      quantity,\n      userOptions.normalize,\n      userOptions.targetUnit\n    );\n    const number = this.strToNumber(quantityToDisplay.value);\n    const suffix = this.determineSuffix(userOptions, quantityToDisplay);\n    return formatNumber(number, locale, userOptions.digitsInfo) + suffix;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private normalizeInternal(quantity: Quantity): Quantity {\n\n    // Given quantity value in base unit\n\n    const dimension = this.unitService.getUnitDimension(quantity.unit);\n\n    if (!dimension) { return quantity; }\n\n    const baseValue = this.toBaseUnitValue(quantity);\n\n    let suitableUnit: UnitInfo;\n\n    const dimensionUnits = this.unitService.getUnitInfosByDimension(dimension);\n\n    if (dimensionUnits) {\n\n      const factorSortedUnits = dimensionUnits.sort((a, b) => b.toBaseFactor - a.toBaseFactor);\n\n      for (const unitInfo of factorSortedUnits) {\n        const signedBaseValue = ((baseValue < 0) ? baseValue * -1 : baseValue);\n        if (unitInfo.toBaseFactor <= signedBaseValue) {\n          suitableUnit = unitInfo;\n          break;\n        }\n      }\n    } else {\n      this.logger.debug('Could not find Dimension info for ' + dimension + '. (' + quantity.unit + ' --> ' + dimension + ')');\n    }\n\n    if (!suitableUnit) {\n      return quantity;\n    }\n\n    const currentToBase = this.unitService.getToBaseFactor(quantity.unit);\n\n    // Ensure we prefer the initial unit if the actual value is not affected.\n    // This helps to be consistent and display the actual unit in rare cases when multiple unit alternatives exist (same factor)\n    if (suitableUnit.toBaseFactor === currentToBase) {\n      return quantity;\n    } else {\n      return this.convertToUnit(quantity, suitableUnit.unit);\n    }\n  }\n\n  private getQuantityIdentifier(quantity: Quantity): string {\n    return quantity.value + '-' + quantity.unit;\n  }\n\n\n  /**\n   * Adapted from @angular/common number_pipe.ts\n   */\n  private strToNumber(value: number | string): number {\n    // Convert strings to numbers\n    if (typeof value === 'string' && !isNaN(Number(value) - parseFloat(value))) {\n      return Number(value);\n    }\n    if (typeof value !== 'number') {\n      throw new Error(`${value} is not a number`);\n    }\n    return value;\n  }\n\n  private static determineUserOptions(\n    normalize: boolean | QuantityPipeOptions,\n    targetUnit: Unit | string,\n    digitsInfo: string\n  ): QuantityPipeOptions {\n    const userOptions = (normalize === undefined || typeof normalize === 'boolean')\n      ? <QuantityPipeOptions>{\n        normalize: normalize,\n        targetUnit: targetUnit,\n        digitsInfo: digitsInfo\n      }\n      : normalize;\n\n    if (userOptions.normalize === undefined && !userOptions.targetUnit) {\n      userOptions.normalize = true;\n    }\n\n    if (userOptions.digitsInfo === undefined) {\n      userOptions.digitsInfo = ElderQuantityService.DEFAULT_DIGITS;\n    }\n    return userOptions;\n  }\n\n  private determineSuffix(userOptions: QuantityPipeOptions, quantityToDisplay: Quantity) {\n    if (!userOptions.hideUnit) {\n      return ElderQuantityService.SPACE_STRING + this.unitService.getUnitSymbol(quantityToDisplay.unit);\n    } else {\n      return '';\n    }\n  }\n\n}\n"]}
@@ -137,10 +137,10 @@ export class ElderBreadCrumbsComponent {
137
137
  }
138
138
  return nodes;
139
139
  }
140
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
141
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: ElderBreadCrumbsComponent, isStandalone: true, selector: "elder-bread-crumbs", inputs: { root: "root", rootTranslation: "rootTranslation", rootIcon: "rootIcon", backgroundColor: "backgroundColor", editModeEnabled: "editModeEnabled", path: "path" }, outputs: { pathChange: "pathChange" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true }], ngImport: i0, template: "<!-- main container-->\n<div class=\"layout-row place-start-center full breadcrumb-bar\"\n [style.background-color]=\"backgroundColor\"\n *ngIf=\"{enabled: editMode$ | async} as editMode\"\n>\n\n <!-- path container -->\n <form #breadCrumbForm=\"ngForm\"\n class=\"layout-row place-start-center flex breadcrumb-path\"\n (click)=\"enableEditMode()\"\n >\n <!-- path edit control (if editMode:enabled) -->\n <mat-form-field class=\"flex\" *ngIf=\"editMode.enabled\" elderDense >\n {{ pathInput.focus() }}\n <input matInput type=\"text\" name=\"pathInput\" #pathInput\n [ngModel]=\"path\" (ngModelChange)=\"onPathInputChange($event)\"\n (blur)=\"onPathEditBlur($event)\"\n elderKeyEvent [elderKeyEventFilter]=\"'Enter'\" (onElderKeyEvent)=\"onEnter()\">\n </mat-form-field>\n\n <!-- navigation control (if editMode:disabled) -->\n <ng-container *ngIf=\"!editMode.enabled\">\n <div class=\"layout-row place-center-center flex-none\"\n *ngFor=\"let node of nodes$ | async;let isFirst = first;let isLast = last\">\n\n <!-- arrow right icon as path element delimiter -->\n <mat-icon *ngIf=\"!isFirst\" class=\"noselect breadcrumb-arrow\">keyboard_arrow_right</mat-icon>\n\n <!-- root element (case root icon) -->\n <a *ngIf=\"isFirst && rootIcon\"\n mat-icon-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <mat-icon>{{rootIcon}}</mat-icon>\n </a>\n\n <!-- intermediate elements (not last and (not first or root icon)) -->\n <a *ngIf=\"!isLast && (!isFirst || !rootIcon)\"\n mat-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <span>{{node.name}}</span>\n </a>\n\n <!-- last element (is last and (not first or root icon)) -->\n <a mat-button class=\"breadcrumb\" *ngIf=\"isLast && (!isFirst || !rootIcon)\"\n (click)=\"null\" elderStopEventPropagation\n >\n {{node.name}}\n <mat-icon>arrow_drop_down</mat-icon>\n </a>\n\n </div>\n </ng-container>\n\n </form>\n\n <!-- bread crumb action menu button -->\n <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n <mat-icon style=\"font-size: 22px\">arrow_drop_down</mat-icon>\n\n <mat-menu #menu=\"matMenu\">\n\n <button mat-menu-item type=\"button\" [elderClipboardPut]=\"path\">\n <mat-icon>content_copy</mat-icon>\n <span>{{'Pfad kopieren'}}</span>\n </button>\n\n <button mat-menu-item type=\"button\" (click)=\"onMenuEditPathClick($event)\" elderStopEventPropagation>\n <mat-icon *ngIf=\"!editMode.enabled\">edit</mat-icon>\n <mat-icon *ngIf=\"editMode.enabled\">done</mat-icon>\n <span *ngIf=\"!editMode.enabled\">{{'Pfad editieren'}}</span>\n <span *ngIf=\"editMode.enabled\">{{'Pfad best\u00E4tigen'}}</span>\n </button>\n\n </mat-menu>\n\n </button>\n</div>\n\n\n", styles: [".breadcrumb-path{padding:0 8px}.breadcrumb{padding-left:4px;padding-right:4px;font-size:18px;font-weight:400}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense", "subscriptSizing", "floatLabel"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: ElderKeyEventDirective, selector: "[elderKeyEvent]", inputs: ["elderKeyEventFilter", "elderKeyEventDown", "elderKeyEventChildren", "elderKeyEventCallback"], outputs: ["onElderKeyEvent"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatIconAnchor, selector: "a[mat-icon-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "directive", type: ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-flat-button], a[mat-stroked-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: ElderClipboardPutDirective, selector: "[elderClipboardPut]", inputs: ["elderClipboardPut"], outputs: ["clipboardCopied"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
140
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
141
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ElderBreadCrumbsComponent, isStandalone: true, selector: "elder-bread-crumbs", inputs: { root: "root", rootTranslation: "rootTranslation", rootIcon: "rootIcon", backgroundColor: "backgroundColor", editModeEnabled: "editModeEnabled", path: "path" }, outputs: { pathChange: "pathChange" }, viewQueries: [{ propertyName: "trigger", first: true, predicate: MatMenuTrigger, descendants: true }], ngImport: i0, template: "<!-- main container-->\n<div class=\"layout-row place-start-center full breadcrumb-bar\"\n [style.background-color]=\"backgroundColor\"\n *ngIf=\"{enabled: editMode$ | async} as editMode\"\n>\n\n <!-- path container -->\n <form #breadCrumbForm=\"ngForm\"\n class=\"layout-row place-start-center flex breadcrumb-path\"\n (click)=\"enableEditMode()\"\n >\n <!-- path edit control (if editMode:enabled) -->\n <mat-form-field class=\"flex\" *ngIf=\"editMode.enabled\" elderDense >\n {{ pathInput.focus() }}\n <input matInput type=\"text\" name=\"pathInput\" #pathInput\n [ngModel]=\"path\" (ngModelChange)=\"onPathInputChange($event)\"\n (blur)=\"onPathEditBlur($event)\"\n elderKeyEvent [elderKeyEventFilter]=\"'Enter'\" (onElderKeyEvent)=\"onEnter()\">\n </mat-form-field>\n\n <!-- navigation control (if editMode:disabled) -->\n <ng-container *ngIf=\"!editMode.enabled\">\n <div class=\"layout-row place-center-center flex-none\"\n *ngFor=\"let node of nodes$ | async;let isFirst = first;let isLast = last\">\n\n <!-- arrow right icon as path element delimiter -->\n <mat-icon *ngIf=\"!isFirst\" class=\"noselect breadcrumb-arrow\">keyboard_arrow_right</mat-icon>\n\n <!-- root element (case root icon) -->\n <a *ngIf=\"isFirst && rootIcon\"\n mat-icon-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <mat-icon>{{rootIcon}}</mat-icon>\n </a>\n\n <!-- intermediate elements (not last and (not first or root icon)) -->\n <a *ngIf=\"!isLast && (!isFirst || !rootIcon)\"\n mat-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <span>{{node.name}}</span>\n </a>\n\n <!-- last element (is last and (not first or root icon)) -->\n <a mat-button class=\"breadcrumb\" *ngIf=\"isLast && (!isFirst || !rootIcon)\"\n (click)=\"null\" elderStopEventPropagation\n >\n {{node.name}}\n <mat-icon>arrow_drop_down</mat-icon>\n </a>\n\n </div>\n </ng-container>\n\n </form>\n\n <!-- bread crumb action menu button -->\n <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n <mat-icon style=\"font-size: 22px\">arrow_drop_down</mat-icon>\n\n <mat-menu #menu=\"matMenu\">\n\n <button mat-menu-item type=\"button\" [elderClipboardPut]=\"path\">\n <mat-icon>content_copy</mat-icon>\n <span>{{'Pfad kopieren'}}</span>\n </button>\n\n <button mat-menu-item type=\"button\" (click)=\"onMenuEditPathClick($event)\" elderStopEventPropagation>\n <mat-icon *ngIf=\"!editMode.enabled\">edit</mat-icon>\n <mat-icon *ngIf=\"editMode.enabled\">done</mat-icon>\n <span *ngIf=\"!editMode.enabled\">{{'Pfad editieren'}}</span>\n <span *ngIf=\"editMode.enabled\">{{'Pfad best\u00E4tigen'}}</span>\n </button>\n\n </mat-menu>\n\n </button>\n</div>\n\n\n", styles: [".breadcrumb-path{padding:0 8px}.breadcrumb{padding-left:4px;padding-right:4px;font-size:18px;font-weight:400}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense", "subscriptSizing", "floatLabel"] }, { kind: "directive", type: MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: ElderKeyEventDirective, selector: "[elderKeyEvent]", inputs: ["elderKeyEventFilter", "elderKeyEventDown", "elderKeyEventChildren", "elderKeyEventCallback"], outputs: ["onElderKeyEvent"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatIconAnchor, selector: "a[mat-icon-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "directive", type: ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: MatAnchor, selector: "a[mat-button], a[mat-raised-button], a[mat-flat-button], a[mat-stroked-button]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: ElderClipboardPutDirective, selector: "[elderClipboardPut]", inputs: ["elderClipboardPut"], outputs: ["clipboardCopied"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
142
142
  }
143
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsComponent, decorators: [{
143
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsComponent, decorators: [{
144
144
  type: Component,
145
145
  args: [{ selector: 'elder-bread-crumbs', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, FormsModule, MatFormField, ElderFormFieldDenseDirective, MatInput, ElderKeyEventDirective, NgFor, MatIcon, MatIconAnchor, ElderStopEventPropagationDirective, MatAnchor, MatIconButton, MatMenuTrigger, MatMenu, MatMenuItem, ElderClipboardPutDirective, AsyncPipe], template: "<!-- main container-->\n<div class=\"layout-row place-start-center full breadcrumb-bar\"\n [style.background-color]=\"backgroundColor\"\n *ngIf=\"{enabled: editMode$ | async} as editMode\"\n>\n\n <!-- path container -->\n <form #breadCrumbForm=\"ngForm\"\n class=\"layout-row place-start-center flex breadcrumb-path\"\n (click)=\"enableEditMode()\"\n >\n <!-- path edit control (if editMode:enabled) -->\n <mat-form-field class=\"flex\" *ngIf=\"editMode.enabled\" elderDense >\n {{ pathInput.focus() }}\n <input matInput type=\"text\" name=\"pathInput\" #pathInput\n [ngModel]=\"path\" (ngModelChange)=\"onPathInputChange($event)\"\n (blur)=\"onPathEditBlur($event)\"\n elderKeyEvent [elderKeyEventFilter]=\"'Enter'\" (onElderKeyEvent)=\"onEnter()\">\n </mat-form-field>\n\n <!-- navigation control (if editMode:disabled) -->\n <ng-container *ngIf=\"!editMode.enabled\">\n <div class=\"layout-row place-center-center flex-none\"\n *ngFor=\"let node of nodes$ | async;let isFirst = first;let isLast = last\">\n\n <!-- arrow right icon as path element delimiter -->\n <mat-icon *ngIf=\"!isFirst\" class=\"noselect breadcrumb-arrow\">keyboard_arrow_right</mat-icon>\n\n <!-- root element (case root icon) -->\n <a *ngIf=\"isFirst && rootIcon\"\n mat-icon-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <mat-icon>{{rootIcon}}</mat-icon>\n </a>\n\n <!-- intermediate elements (not last and (not first or root icon)) -->\n <a *ngIf=\"!isLast && (!isFirst || !rootIcon)\"\n mat-button class=\"breadcrumb\"\n (click)=\"goToPath(node)\" elderStopEventPropagation\n >\n <span>{{node.name}}</span>\n </a>\n\n <!-- last element (is last and (not first or root icon)) -->\n <a mat-button class=\"breadcrumb\" *ngIf=\"isLast && (!isFirst || !rootIcon)\"\n (click)=\"null\" elderStopEventPropagation\n >\n {{node.name}}\n <mat-icon>arrow_drop_down</mat-icon>\n </a>\n\n </div>\n </ng-container>\n\n </form>\n\n <!-- bread crumb action menu button -->\n <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n <mat-icon style=\"font-size: 22px\">arrow_drop_down</mat-icon>\n\n <mat-menu #menu=\"matMenu\">\n\n <button mat-menu-item type=\"button\" [elderClipboardPut]=\"path\">\n <mat-icon>content_copy</mat-icon>\n <span>{{'Pfad kopieren'}}</span>\n </button>\n\n <button mat-menu-item type=\"button\" (click)=\"onMenuEditPathClick($event)\" elderStopEventPropagation>\n <mat-icon *ngIf=\"!editMode.enabled\">edit</mat-icon>\n <mat-icon *ngIf=\"editMode.enabled\">done</mat-icon>\n <span *ngIf=\"!editMode.enabled\">{{'Pfad editieren'}}</span>\n <span *ngIf=\"editMode.enabled\">{{'Pfad best\u00E4tigen'}}</span>\n </button>\n\n </mat-menu>\n\n </button>\n</div>\n\n\n", styles: [".breadcrumb-path{padding:0 8px}.breadcrumb{padding-left:4px;padding-right:4px;font-size:18px;font-weight:400}\n"] }]
146
146
  }], ctorParameters: () => [], propDecorators: { pathChange: [{
@@ -161,4 +161,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
161
161
  }], path: [{
162
162
  type: Input
163
163
  }] } });
164
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-bread-crumbs.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {PathNode} from '../path/path';\nimport {debounceTime, distinctUntilChanged, takeUntil} from 'rxjs/operators';\nimport {MatMenuTrigger, MatMenu, MatMenuItem} from '@angular/material/menu';\nimport {ElderClipboardPutDirective} from '../../../forms/directives/elder-clipboard-put.directive';\nimport {ElderStopEventPropagationDirective} from '../../../forms/directives/elder-stop-event-propagation.directive';\nimport {MatIconAnchor, MatAnchor, MatIconButton} from '@angular/material/button';\nimport {MatIcon} from '@angular/material/icon';\nimport {ElderKeyEventDirective} from '../../../forms/directives/elder-key-event.directive';\nimport {MatInput} from '@angular/material/input';\nimport {ElderFormFieldDenseDirective} from '../../../forms/directives/elder-form-field-dense.directive';\nimport {MatFormField} from '@angular/material/form-field';\nimport {FormsModule} from '@angular/forms';\nimport {NgIf, NgFor, AsyncPipe} from '@angular/common';\n\n@Component({\n    selector: 'elder-bread-crumbs',\n    templateUrl: './elder-bread-crumbs.component.html',\n    styleUrls: ['./elder-bread-crumbs.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, FormsModule, MatFormField, ElderFormFieldDenseDirective, MatInput, ElderKeyEventDirective, NgFor, MatIcon, MatIconAnchor, ElderStopEventPropagationDirective, MatAnchor, MatIconButton, MatMenuTrigger, MatMenu, MatMenuItem, ElderClipboardPutDirective, AsyncPipe]\n})\nexport class ElderBreadCrumbsComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _unsubscribe = new Subject<void>();\n\n  private _path: string;\n\n  public readonly editMode$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _pathInputChanged$: Subject<string> = new Subject<string>();\n\n  @Output()\n  public readonly pathChange = new EventEmitter<string>();\n\n  @Input()\n  public root = '/';\n\n  @Input()\n  public rootTranslation: string = null;\n\n  @Input()\n  public rootIcon: string;\n\n  @Input()\n  public backgroundColor: string;\n\n  @ViewChild(MatMenuTrigger)\n  public trigger: MatMenuTrigger;\n\n  public readonly nodes$ = new BehaviorSubject<PathNode[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {}\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n    this._pathInputChanged$.pipe(\n      takeUntil(this._unsubscribe),\n      distinctUntilChanged(), // only emit if value is different from previous value\n      debounceTime(250),\n    ).subscribe(\n      value => {\n        this.log.info(value);\n        this.pathChange.emit(value);\n      }\n    );\n  }\n\n  public ngOnDestroy() {\n    this._unsubscribe.next();\n    this._unsubscribe.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set editModeEnabled(value: boolean) {\n    this.editMode$.next(value);\n  }\n\n  public get editModeEnabled() {\n    return this.editMode$.getValue();\n  }\n\n  @Input()\n  public set path(path: string) {\n    if (this._path !== path) {\n      this._path = path;\n      this.nodes$.next(this.buildNodes(this._path));\n    }\n  }\n\n  public get rootRawDisplay(): string {\n    const parts = this.root.split('/');\n    const val = parts[parts.length - 1];\n    return val ? val : 'Home';\n  }\n\n  public get path(): string {\n    return this._path;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onEnter(): void {\n    this.disableEditMode();\n  }\n\n  public onPathEditBlur(event: Event): void {\n    // this.log.debug('blurred', event);\n    this.disableEditMode();\n  }\n\n\n  public onPathInputChange(value: string) {\n    this._pathInputChanged$.next(value);\n  }\n\n  public onMenuEditPathClick(event: any) {\n    this.trigger.closeMenu();\n    this.toggleEditMode();\n  }\n\n  public goToRoot() {\n    this.goToPath(new PathNode(this.root, ''));\n  }\n\n  public goToPath(node: PathNode) {\n    this.path = node.id;\n    this.pathChange.next(this._path);\n  }\n\n  public toggleEditMode(): void {\n    this.editModeEnabled = !this.editModeEnabled;\n  }\n\n  public enableEditMode(): void {\n    this.editModeEnabled = true;\n  }\n\n  public disableEditMode(): void {\n    this.editModeEnabled = false;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private buildNodes(path: string): PathNode[] {\n\n    const nodes: PathNode[] = [];\n\n    nodes.push(\n      new PathNode(\n        this.root,\n        this.rootTranslation ? this.rootTranslation : this.rootRawDisplay\n      )\n    );\n\n    if (path) {\n\n      path = path.startsWith(this.root) ? path.substr(this.root.length) : path;\n\n      this.log.debug('path: ' + path);\n\n      const parts = path.split('/');\n\n      let parent = this.root;\n\n      for (const part of parts) {\n\n        if (part.length === 0) { continue; }\n\n\n        const current = parent ? parent + '/' + part : part;\n\n        nodes.push(new PathNode(\n          current,\n          part\n        ));\n\n        parent = current;\n      }\n    }\n\n    return nodes;\n  }\n\n\n}\n","<!-- main container-->\n<div class=\"layout-row place-start-center full breadcrumb-bar\"\n     [style.background-color]=\"backgroundColor\"\n     *ngIf=\"{enabled: editMode$ | async} as editMode\"\n>\n\n  <!-- path container -->\n  <form #breadCrumbForm=\"ngForm\"\n       class=\"layout-row place-start-center flex breadcrumb-path\"\n       (click)=\"enableEditMode()\"\n  >\n      <!-- path edit control (if editMode:enabled) -->\n      <mat-form-field class=\"flex\" *ngIf=\"editMode.enabled\" elderDense >\n        {{ pathInput.focus() }}\n        <input matInput type=\"text\" name=\"pathInput\" #pathInput\n               [ngModel]=\"path\" (ngModelChange)=\"onPathInputChange($event)\"\n               (blur)=\"onPathEditBlur($event)\"\n               elderKeyEvent [elderKeyEventFilter]=\"'Enter'\" (onElderKeyEvent)=\"onEnter()\">\n      </mat-form-field>\n\n      <!-- navigation control (if editMode:disabled) -->\n      <ng-container *ngIf=\"!editMode.enabled\">\n        <div class=\"layout-row place-center-center flex-none\"\n             *ngFor=\"let node of nodes$ | async;let isFirst = first;let isLast = last\">\n\n          <!-- arrow right icon as path element delimiter -->\n          <mat-icon *ngIf=\"!isFirst\" class=\"noselect breadcrumb-arrow\">keyboard_arrow_right</mat-icon>\n\n          <!-- root element (case root icon) -->\n          <a *ngIf=\"isFirst && rootIcon\"\n             mat-icon-button class=\"breadcrumb\"\n             (click)=\"goToPath(node)\" elderStopEventPropagation\n          >\n            <mat-icon>{{rootIcon}}</mat-icon>\n          </a>\n\n          <!-- intermediate elements (not last and (not first or root icon)) -->\n          <a *ngIf=\"!isLast && (!isFirst || !rootIcon)\"\n             mat-button class=\"breadcrumb\"\n             (click)=\"goToPath(node)\" elderStopEventPropagation\n          >\n            <span>{{node.name}}</span>\n          </a>\n\n          <!-- last element (is last and (not first or root icon)) -->\n          <a mat-button class=\"breadcrumb\" *ngIf=\"isLast && (!isFirst || !rootIcon)\"\n             (click)=\"null\" elderStopEventPropagation\n          >\n            {{node.name}}\n            <mat-icon>arrow_drop_down</mat-icon>\n          </a>\n\n        </div>\n      </ng-container>\n\n  </form>\n\n  <!-- bread crumb action menu button -->\n  <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n    <mat-icon style=\"font-size: 22px\">arrow_drop_down</mat-icon>\n\n    <mat-menu #menu=\"matMenu\">\n\n      <button mat-menu-item type=\"button\" [elderClipboardPut]=\"path\">\n        <mat-icon>content_copy</mat-icon>\n        <span>{{'Pfad kopieren'}}</span>\n      </button>\n\n      <button mat-menu-item type=\"button\" (click)=\"onMenuEditPathClick($event)\" elderStopEventPropagation>\n        <mat-icon *ngIf=\"!editMode.enabled\">edit</mat-icon>\n        <mat-icon *ngIf=\"editMode.enabled\">done</mat-icon>\n        <span *ngIf=\"!editMode.enabled\">{{'Pfad editieren'}}</span>\n        <span *ngIf=\"editMode.enabled\">{{'Pfad bestätigen'}}</span>\n      </button>\n\n    </mat-menu>\n\n  </button>\n</div>\n\n\n"]}
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-bread-crumbs.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,QAAQ,EAAC,MAAM,cAAc,CAAC;AACtC,OAAO,EAAC,YAAY,EAAE,oBAAoB,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAC,cAAc,EAAE,OAAO,EAAE,WAAW,EAAC,MAAM,wBAAwB,CAAC;AAC5E,OAAO,EAAC,0BAA0B,EAAC,MAAM,yDAAyD,CAAC;AACnG,OAAO,EAAC,kCAAkC,EAAC,MAAM,kEAAkE,CAAC;AACpH,OAAO,EAAC,aAAa,EAAE,SAAS,EAAE,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACjF,OAAO,EAAC,OAAO,EAAC,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAC,sBAAsB,EAAC,MAAM,qDAAqD,CAAC;AAC3F,OAAO,EAAC,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAC,4BAA4B,EAAC,MAAM,4DAA4D,CAAC;AACxG,OAAO,EAAC,YAAY,EAAC,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,IAAI,EAAE,KAAK,EAAE,SAAS,EAAC,MAAM,iBAAiB,CAAC;;;AAUvD,MAAM,OAAO,yBAAyB;IAsCpC;;;;gFAI4E;IAE5E;QA1CA;;;;oFAI4E;QAE3D,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAErD,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAIpC,cAAS,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAE/C,uBAAkB,GAAoB,IAAI,OAAO,EAAU,CAAC;QAG7D,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAGjD,SAAI,GAAG,GAAG,CAAC;QAGX,oBAAe,GAAW,IAAI,CAAC;QAWtB,WAAM,GAAG,IAAI,eAAe,CAAa,EAAE,CAAC,CAAC;IAQ9C,CAAC;IAEhB;;;;gFAI4E;IAErE,QAAQ;QAEb,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAC1B,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAC5B,oBAAoB,EAAE,EAAE,sDAAsD;QAC9E,YAAY,CAAC,GAAG,CAAC,CAClB,CAAC,SAAS,CACT,KAAK,CAAC,EAAE;YACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC,CACF,CAAC;IACJ,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,eAAe,CAAC,KAAc;QACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAED,IACW,IAAI,CAAC,IAAY;QAC1B,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,EAAE;YACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SAC/C;IACH,CAAC;IAED,IAAW,cAAc;QACvB,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACpC,OAAO,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;IAC5B,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;gFAI4E;IAErE,OAAO;QACZ,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEM,cAAc,CAAC,KAAY;QAChC,oCAAoC;QACpC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAGM,iBAAiB,CAAC,KAAa;QACpC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,mBAAmB,CAAC,KAAU;QACnC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;IAEM,QAAQ,CAAC,IAAc;QAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;QACpB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;IAC/C,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAGpE,UAAU,CAAC,IAAY;QAE7B,MAAM,KAAK,GAAe,EAAE,CAAC;QAE7B,KAAK,CAAC,IAAI,CACR,IAAI,QAAQ,CACV,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAClE,CACF,CAAC;QAEF,IAAI,IAAI,EAAE;YAER,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAEzE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;YAEhC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAE9B,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC;YAEvB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;gBAExB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;oBAAE,SAAS;iBAAE;gBAGpC,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;gBAEpD,KAAK,CAAC,IAAI,CAAC,IAAI,QAAQ,CACrB,OAAO,EACP,IAAI,CACL,CAAC,CAAC;gBAEH,MAAM,GAAG,OAAO,CAAC;aAClB;SACF;QAED,OAAO,KAAK,CAAC;IACf,CAAC;+GAnMU,yBAAyB;mGAAzB,yBAAyB,wUAiCzB,cAAc,gDCnE3B,mlGAkFA,yKDlDc,IAAI,4FAAE,WAAW,wiCAAE,YAAY,4LAAE,4BAA4B,gIAAE,QAAQ,iUAAE,sBAAsB,kMAAE,KAAK,mHAAE,OAAO,2IAAE,aAAa,qGAAE,kCAAkC,wEAAE,SAAS,iKAAE,aAAa,6FAAE,cAAc,qSAAE,OAAO,2QAAE,WAAW,sIAAE,0BAA0B,wHAAE,SAAS;;4FAE1Q,yBAAyB;kBARrC,SAAS;+BACI,oBAAoB,mBAGb,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,IAAI,EAAE,WAAW,EAAE,YAAY,EAAE,4BAA4B,EAAE,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,kCAAkC,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,OAAO,EAAE,WAAW,EAAE,0BAA0B,EAAE,SAAS,CAAC;wDAqBtQ,UAAU;sBADzB,MAAM;gBAIA,IAAI;sBADV,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAIC,OAAO;sBADb,SAAS;uBAAC,cAAc;gBA6Cd,eAAe;sBADzB,KAAK;gBAUK,IAAI;sBADd,KAAK","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport {BehaviorSubject, Subject} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {PathNode} from '../path/path';\nimport {debounceTime, distinctUntilChanged, takeUntil} from 'rxjs/operators';\nimport {MatMenuTrigger, MatMenu, MatMenuItem} from '@angular/material/menu';\nimport {ElderClipboardPutDirective} from '../../../forms/directives/elder-clipboard-put.directive';\nimport {ElderStopEventPropagationDirective} from '../../../forms/directives/elder-stop-event-propagation.directive';\nimport {MatIconAnchor, MatAnchor, MatIconButton} from '@angular/material/button';\nimport {MatIcon} from '@angular/material/icon';\nimport {ElderKeyEventDirective} from '../../../forms/directives/elder-key-event.directive';\nimport {MatInput} from '@angular/material/input';\nimport {ElderFormFieldDenseDirective} from '../../../forms/directives/elder-form-field-dense.directive';\nimport {MatFormField} from '@angular/material/form-field';\nimport {FormsModule} from '@angular/forms';\nimport {NgIf, NgFor, AsyncPipe} from '@angular/common';\n\n@Component({\n    selector: 'elder-bread-crumbs',\n    templateUrl: './elder-bread-crumbs.component.html',\n    styleUrls: ['./elder-bread-crumbs.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, FormsModule, MatFormField, ElderFormFieldDenseDirective, MatInput, ElderKeyEventDirective, NgFor, MatIcon, MatIconAnchor, ElderStopEventPropagationDirective, MatAnchor, MatIconButton, MatMenuTrigger, MatMenu, MatMenuItem, ElderClipboardPutDirective, AsyncPipe]\n})\nexport class ElderBreadCrumbsComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _unsubscribe = new Subject<void>();\n\n  private _path: string;\n\n  public readonly editMode$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _pathInputChanged$: Subject<string> = new Subject<string>();\n\n  @Output()\n  public readonly pathChange = new EventEmitter<string>();\n\n  @Input()\n  public root = '/';\n\n  @Input()\n  public rootTranslation: string = null;\n\n  @Input()\n  public rootIcon: string;\n\n  @Input()\n  public backgroundColor: string;\n\n  @ViewChild(MatMenuTrigger)\n  public trigger: MatMenuTrigger;\n\n  public readonly nodes$ = new BehaviorSubject<PathNode[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {}\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n    this._pathInputChanged$.pipe(\n      takeUntil(this._unsubscribe),\n      distinctUntilChanged(), // only emit if value is different from previous value\n      debounceTime(250),\n    ).subscribe(\n      value => {\n        this.log.info(value);\n        this.pathChange.emit(value);\n      }\n    );\n  }\n\n  public ngOnDestroy() {\n    this._unsubscribe.next();\n    this._unsubscribe.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set editModeEnabled(value: boolean) {\n    this.editMode$.next(value);\n  }\n\n  public get editModeEnabled() {\n    return this.editMode$.getValue();\n  }\n\n  @Input()\n  public set path(path: string) {\n    if (this._path !== path) {\n      this._path = path;\n      this.nodes$.next(this.buildNodes(this._path));\n    }\n  }\n\n  public get rootRawDisplay(): string {\n    const parts = this.root.split('/');\n    const val = parts[parts.length - 1];\n    return val ? val : 'Home';\n  }\n\n  public get path(): string {\n    return this._path;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onEnter(): void {\n    this.disableEditMode();\n  }\n\n  public onPathEditBlur(event: Event): void {\n    // this.log.debug('blurred', event);\n    this.disableEditMode();\n  }\n\n\n  public onPathInputChange(value: string) {\n    this._pathInputChanged$.next(value);\n  }\n\n  public onMenuEditPathClick(event: any) {\n    this.trigger.closeMenu();\n    this.toggleEditMode();\n  }\n\n  public goToRoot() {\n    this.goToPath(new PathNode(this.root, ''));\n  }\n\n  public goToPath(node: PathNode) {\n    this.path = node.id;\n    this.pathChange.next(this._path);\n  }\n\n  public toggleEditMode(): void {\n    this.editModeEnabled = !this.editModeEnabled;\n  }\n\n  public enableEditMode(): void {\n    this.editModeEnabled = true;\n  }\n\n  public disableEditMode(): void {\n    this.editModeEnabled = false;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private buildNodes(path: string): PathNode[] {\n\n    const nodes: PathNode[] = [];\n\n    nodes.push(\n      new PathNode(\n        this.root,\n        this.rootTranslation ? this.rootTranslation : this.rootRawDisplay\n      )\n    );\n\n    if (path) {\n\n      path = path.startsWith(this.root) ? path.substr(this.root.length) : path;\n\n      this.log.debug('path: ' + path);\n\n      const parts = path.split('/');\n\n      let parent = this.root;\n\n      for (const part of parts) {\n\n        if (part.length === 0) { continue; }\n\n\n        const current = parent ? parent + '/' + part : part;\n\n        nodes.push(new PathNode(\n          current,\n          part\n        ));\n\n        parent = current;\n      }\n    }\n\n    return nodes;\n  }\n\n\n}\n","<!-- main container-->\n<div class=\"layout-row place-start-center full breadcrumb-bar\"\n     [style.background-color]=\"backgroundColor\"\n     *ngIf=\"{enabled: editMode$ | async} as editMode\"\n>\n\n  <!-- path container -->\n  <form #breadCrumbForm=\"ngForm\"\n       class=\"layout-row place-start-center flex breadcrumb-path\"\n       (click)=\"enableEditMode()\"\n  >\n      <!-- path edit control (if editMode:enabled) -->\n      <mat-form-field class=\"flex\" *ngIf=\"editMode.enabled\" elderDense >\n        {{ pathInput.focus() }}\n        <input matInput type=\"text\" name=\"pathInput\" #pathInput\n               [ngModel]=\"path\" (ngModelChange)=\"onPathInputChange($event)\"\n               (blur)=\"onPathEditBlur($event)\"\n               elderKeyEvent [elderKeyEventFilter]=\"'Enter'\" (onElderKeyEvent)=\"onEnter()\">\n      </mat-form-field>\n\n      <!-- navigation control (if editMode:disabled) -->\n      <ng-container *ngIf=\"!editMode.enabled\">\n        <div class=\"layout-row place-center-center flex-none\"\n             *ngFor=\"let node of nodes$ | async;let isFirst = first;let isLast = last\">\n\n          <!-- arrow right icon as path element delimiter -->\n          <mat-icon *ngIf=\"!isFirst\" class=\"noselect breadcrumb-arrow\">keyboard_arrow_right</mat-icon>\n\n          <!-- root element (case root icon) -->\n          <a *ngIf=\"isFirst && rootIcon\"\n             mat-icon-button class=\"breadcrumb\"\n             (click)=\"goToPath(node)\" elderStopEventPropagation\n          >\n            <mat-icon>{{rootIcon}}</mat-icon>\n          </a>\n\n          <!-- intermediate elements (not last and (not first or root icon)) -->\n          <a *ngIf=\"!isLast && (!isFirst || !rootIcon)\"\n             mat-button class=\"breadcrumb\"\n             (click)=\"goToPath(node)\" elderStopEventPropagation\n          >\n            <span>{{node.name}}</span>\n          </a>\n\n          <!-- last element (is last and (not first or root icon)) -->\n          <a mat-button class=\"breadcrumb\" *ngIf=\"isLast && (!isFirst || !rootIcon)\"\n             (click)=\"null\" elderStopEventPropagation\n          >\n            {{node.name}}\n            <mat-icon>arrow_drop_down</mat-icon>\n          </a>\n\n        </div>\n      </ng-container>\n\n  </form>\n\n  <!-- bread crumb action menu button -->\n  <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n    <mat-icon style=\"font-size: 22px\">arrow_drop_down</mat-icon>\n\n    <mat-menu #menu=\"matMenu\">\n\n      <button mat-menu-item type=\"button\" [elderClipboardPut]=\"path\">\n        <mat-icon>content_copy</mat-icon>\n        <span>{{'Pfad kopieren'}}</span>\n      </button>\n\n      <button mat-menu-item type=\"button\" (click)=\"onMenuEditPathClick($event)\" elderStopEventPropagation>\n        <mat-icon *ngIf=\"!editMode.enabled\">edit</mat-icon>\n        <mat-icon *ngIf=\"editMode.enabled\">done</mat-icon>\n        <span *ngIf=\"!editMode.enabled\">{{'Pfad editieren'}}</span>\n        <span *ngIf=\"editMode.enabled\">{{'Pfad bestätigen'}}</span>\n      </button>\n\n    </mat-menu>\n\n  </button>\n</div>\n\n\n"]}
@@ -13,8 +13,8 @@ import * as i0 from "@angular/core";
13
13
  export * from './bread-crumbs/elder-bread-crumbs.component';
14
14
  export * from './path/path';
15
15
  export class ElderBreadCrumbsModule {
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
17
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
16
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
17
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
18
18
  TranslateModule,
19
19
  MatFormFieldModule,
20
20
  MatIconModule,
@@ -23,7 +23,7 @@ export class ElderBreadCrumbsModule {
23
23
  MatMenuModule,
24
24
  ElderFormsDirectivesModule,
25
25
  ElderBreadCrumbsComponent], exports: [ElderBreadCrumbsComponent] }); }
26
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
26
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
27
27
  TranslateModule,
28
28
  MatFormFieldModule,
29
29
  MatIconModule,
@@ -33,7 +33,7 @@ export class ElderBreadCrumbsModule {
33
33
  ElderFormsDirectivesModule,
34
34
  ElderBreadCrumbsComponent] }); }
35
35
  }
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderBreadCrumbsModule, decorators: [{
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderBreadCrumbsModule, decorators: [{
37
37
  type: NgModule,
38
38
  args: [{
39
39
  imports: [
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
52
52
  ]
53
53
  }]
54
54
  }] });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYnJlYWQtY3J1bWJzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9icmVhZC1jcnVtYnMvZWxkZXItYnJlYWQtY3J1bWJzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLFdBQVcsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ2hFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFckQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGFBQWEsQ0FBQztBQWtCNUIsTUFBTSxPQUFPLHNCQUFzQjs4R0FBdEIsc0JBQXNCOytHQUF0QixzQkFBc0IsWUFkM0IsWUFBWSxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7WUFDOUMsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixhQUFhO1lBQ2IsZUFBZTtZQUNmLGNBQWM7WUFDZCxhQUFhO1lBQ2IsMEJBQTBCO1lBQzFCLHlCQUF5QixhQUd6Qix5QkFBeUI7K0dBR3BCLHNCQUFzQixZQWQzQixZQUFZLEVBQUUsV0FBVyxFQUFFLG1CQUFtQjtZQUM5QyxlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixlQUFlO1lBQ2YsY0FBYztZQUNkLGFBQWE7WUFDYiwwQkFBMEI7WUFDMUIseUJBQXlCOzsyRkFNcEIsc0JBQXNCO2tCQWhCbEMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWSxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7d0JBQzlDLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxhQUFhO3dCQUNiLDBCQUEwQjt3QkFDMUIseUJBQXlCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wseUJBQXlCO3FCQUM1QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyQnJlYWRDcnVtYnNDb21wb25lbnR9IGZyb20gJy4vYnJlYWQtY3J1bWJzL2VsZGVyLWJyZWFkLWNydW1icy5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEZvcm1GaWVsZE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtNYXRJbnB1dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHtGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZX0gZnJvbSAnLi4vLi4vZm9ybXMvZGlyZWN0aXZlcy9lbGRlci1mb3Jtcy1kaXJlY3RpdmVzLm1vZHVsZSc7XG5pbXBvcnQge01hdE1lbnVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL21lbnUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2JyZWFkLWNydW1icy9lbGRlci1icmVhZC1jcnVtYnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGF0aC9wYXRoJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAgICBNYXRJY29uTW9kdWxlLFxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgICAgIE1hdElucHV0TW9kdWxlLFxuICAgICAgICBNYXRNZW51TW9kdWxlLFxuICAgICAgICBFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZSxcbiAgICAgICAgRWxkZXJCcmVhZENydW1ic0NvbXBvbmVudFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBFbGRlckJyZWFkQ3J1bWJzQ29tcG9uZW50XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckJyZWFkQ3J1bWJzTW9kdWxlIHsgfVxuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYnJlYWQtY3J1bWJzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9icmVhZC1jcnVtYnMvZWxkZXItYnJlYWQtY3J1bWJzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUN0RixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLFdBQVcsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ2hFLE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBQ2hHLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFckQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGFBQWEsQ0FBQztBQWtCNUIsTUFBTSxPQUFPLHNCQUFzQjsrR0FBdEIsc0JBQXNCO2dIQUF0QixzQkFBc0IsWUFkM0IsWUFBWSxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7WUFDOUMsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixhQUFhO1lBQ2IsZUFBZTtZQUNmLGNBQWM7WUFDZCxhQUFhO1lBQ2IsMEJBQTBCO1lBQzFCLHlCQUF5QixhQUd6Qix5QkFBeUI7Z0hBR3BCLHNCQUFzQixZQWQzQixZQUFZLEVBQUUsV0FBVyxFQUFFLG1CQUFtQjtZQUM5QyxlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixlQUFlO1lBQ2YsY0FBYztZQUNkLGFBQWE7WUFDYiwwQkFBMEI7WUFDMUIseUJBQXlCOzs0RkFNcEIsc0JBQXNCO2tCQWhCbEMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWSxFQUFFLFdBQVcsRUFBRSxtQkFBbUI7d0JBQzlDLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxhQUFhO3dCQUNiLDBCQUEwQjt3QkFDMUIseUJBQXlCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wseUJBQXlCO3FCQUM1QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0VsZGVyQnJlYWRDcnVtYnNDb21wb25lbnR9IGZyb20gJy4vYnJlYWQtY3J1bWJzL2VsZGVyLWJyZWFkLWNydW1icy5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEZvcm1GaWVsZE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHtNYXRJbnB1dE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHtGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZX0gZnJvbSAnLi4vLi4vZm9ybXMvZGlyZWN0aXZlcy9lbGRlci1mb3Jtcy1kaXJlY3RpdmVzLm1vZHVsZSc7XG5pbXBvcnQge01hdE1lbnVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL21lbnUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2JyZWFkLWNydW1icy9lbGRlci1icmVhZC1jcnVtYnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGF0aC9wYXRoJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAgICBNYXRJY29uTW9kdWxlLFxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgICAgIE1hdElucHV0TW9kdWxlLFxuICAgICAgICBNYXRNZW51TW9kdWxlLFxuICAgICAgICBFbGRlckZvcm1zRGlyZWN0aXZlc01vZHVsZSxcbiAgICAgICAgRWxkZXJCcmVhZENydW1ic0NvbXBvbmVudFxuICAgIF0sXG4gICAgZXhwb3J0czogW1xuICAgICAgICBFbGRlckJyZWFkQ3J1bWJzQ29tcG9uZW50XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckJyZWFkQ3J1bWJzTW9kdWxlIHsgfVxuIl19
@@ -15,8 +15,8 @@ export { ElderNavListComponent } from './nav-list/elder-nav-list.component';
15
15
  export { ElderNavLinkComponent } from './nav-link/elder-nav-link.component';
16
16
  export { ElderNavGroupComponent } from './nav-group/elder-nav-group.component';
17
17
  export class ElderNavModule {
18
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
19
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.4", ngImport: i0, type: ElderNavModule, imports: [CommonModule, RouterModule,
18
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderNavModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
19
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: ElderNavModule, imports: [CommonModule, RouterModule,
20
20
  MatIconModule, MatButtonModule,
21
21
  A11yModule,
22
22
  TranslateModule, MatListModule, MatRippleModule,
@@ -25,14 +25,14 @@ export class ElderNavModule {
25
25
  ElderNavGroupComponent], exports: [ElderNavListComponent,
26
26
  ElderNavLinkComponent,
27
27
  ElderNavGroupComponent] }); }
28
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderNavModule, imports: [CommonModule, RouterModule,
28
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderNavModule, imports: [CommonModule, RouterModule,
29
29
  MatIconModule, MatButtonModule,
30
30
  A11yModule,
31
31
  TranslateModule, MatListModule, MatRippleModule,
32
32
  ElderNavLinkComponent,
33
33
  ElderNavGroupComponent] }); }
34
34
  }
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderNavModule, decorators: [{
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderNavModule, decorators: [{
36
36
  type: NgModule,
37
37
  args: [{
38
38
  exports: [
@@ -51,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
51
51
  ]
52
52
  }]
53
53
  }] });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbmF2Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9uYXYvZWxkZXItbmF2Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7O0FBRXZELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBa0I3RSxNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsWUFUbkIsWUFBWSxFQUFFLFlBQVk7WUFDMUIsYUFBYSxFQUFFLGVBQWU7WUFDOUIsVUFBVTtZQUNWLGVBQWUsRUFBRSxhQUFhLEVBQUUsZUFBZTtZQUMvQyxxQkFBcUI7WUFDckIscUJBQXFCO1lBQ3JCLHNCQUFzQixhQVh0QixxQkFBcUI7WUFDckIscUJBQXFCO1lBQ3JCLHNCQUFzQjsrR0FZakIsY0FBYyxZQVRuQixZQUFZLEVBQUUsWUFBWTtZQUMxQixhQUFhLEVBQUUsZUFBZTtZQUM5QixVQUFVO1lBQ1YsZUFBZSxFQUFFLGFBQWEsRUFBRSxlQUFlO1lBRS9DLHFCQUFxQjtZQUNyQixzQkFBc0I7OzJGQUdqQixjQUFjO2tCQWhCMUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wscUJBQXFCO3dCQUNyQixxQkFBcUI7d0JBQ3JCLHNCQUFzQjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVksRUFBRSxZQUFZO3dCQUMxQixhQUFhLEVBQUUsZUFBZTt3QkFDOUIsVUFBVTt3QkFDVixlQUFlLEVBQUUsYUFBYSxFQUFFLGVBQWU7d0JBQy9DLHFCQUFxQjt3QkFDckIscUJBQXFCO3dCQUNyQixzQkFBc0I7cUJBQ3pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RWxkZXJOYXZMaXN0Q29tcG9uZW50fSBmcm9tICcuL25hdi1saXN0L2VsZGVyLW5hdi1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyTmF2TGlua0NvbXBvbmVudH0gZnJvbSAnLi9uYXYtbGluay9lbGRlci1uYXYtbGluay5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge0ExMXlNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7RWxkZXJOYXZHcm91cENvbXBvbmVudH0gZnJvbSAnLi9uYXYtZ3JvdXAvZWxkZXItbmF2LWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQge01hdExpc3RNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xuaW1wb3J0IHtNYXRSaXBwbGVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuXG5leHBvcnQge0VsZGVyTmF2TGlzdENvbXBvbmVudH0gZnJvbSAnLi9uYXYtbGlzdC9lbGRlci1uYXYtbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0IHtFbGRlck5hdkxpbmtDb21wb25lbnR9IGZyb20gJy4vbmF2LWxpbmsvZWxkZXItbmF2LWxpbmsuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJOYXZHcm91cENvbXBvbmVudH0gZnJvbSAnLi9uYXYtZ3JvdXAvZWxkZXItbmF2LWdyb3VwLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZXhwb3J0czogW1xuICAgICAgICBFbGRlck5hdkxpc3RDb21wb25lbnQsXG4gICAgICAgIEVsZGVyTmF2TGlua0NvbXBvbmVudCxcbiAgICAgICAgRWxkZXJOYXZHcm91cENvbXBvbmVudFxuICAgIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsIFJvdXRlck1vZHVsZSxcbiAgICAgICAgTWF0SWNvbk1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlLFxuICAgICAgICBBMTF5TW9kdWxlLFxuICAgICAgICBUcmFuc2xhdGVNb2R1bGUsIE1hdExpc3RNb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSxcbiAgICAgICAgRWxkZXJOYXZMaXN0Q29tcG9uZW50LFxuICAgICAgICBFbGRlck5hdkxpbmtDb21wb25lbnQsXG4gICAgICAgIEVsZGVyTmF2R3JvdXBDb21wb25lbnRcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyTmF2TW9kdWxlIHsgfVxuIl19
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbmF2Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9uYXYvZWxkZXItbmF2Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUMxRSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7O0FBRXZELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBa0I3RSxNQUFNLE9BQU8sY0FBYzsrR0FBZCxjQUFjO2dIQUFkLGNBQWMsWUFUbkIsWUFBWSxFQUFFLFlBQVk7WUFDMUIsYUFBYSxFQUFFLGVBQWU7WUFDOUIsVUFBVTtZQUNWLGVBQWUsRUFBRSxhQUFhLEVBQUUsZUFBZTtZQUMvQyxxQkFBcUI7WUFDckIscUJBQXFCO1lBQ3JCLHNCQUFzQixhQVh0QixxQkFBcUI7WUFDckIscUJBQXFCO1lBQ3JCLHNCQUFzQjtnSEFZakIsY0FBYyxZQVRuQixZQUFZLEVBQUUsWUFBWTtZQUMxQixhQUFhLEVBQUUsZUFBZTtZQUM5QixVQUFVO1lBQ1YsZUFBZSxFQUFFLGFBQWEsRUFBRSxlQUFlO1lBRS9DLHFCQUFxQjtZQUNyQixzQkFBc0I7OzRGQUdqQixjQUFjO2tCQWhCMUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wscUJBQXFCO3dCQUNyQixxQkFBcUI7d0JBQ3JCLHNCQUFzQjtxQkFDekI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVksRUFBRSxZQUFZO3dCQUMxQixhQUFhLEVBQUUsZUFBZTt3QkFDOUIsVUFBVTt3QkFDVixlQUFlLEVBQUUsYUFBYSxFQUFFLGVBQWU7d0JBQy9DLHFCQUFxQjt3QkFDckIscUJBQXFCO3dCQUNyQixzQkFBc0I7cUJBQ3pCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7RWxkZXJOYXZMaXN0Q29tcG9uZW50fSBmcm9tICcuL25hdi1saXN0L2VsZGVyLW5hdi1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQge0VsZGVyTmF2TGlua0NvbXBvbmVudH0gZnJvbSAnLi9uYXYtbGluay9lbGRlci1uYXYtbGluay5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge0ExMXlNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7RWxkZXJOYXZHcm91cENvbXBvbmVudH0gZnJvbSAnLi9uYXYtZ3JvdXAvZWxkZXItbmF2LWdyb3VwLmNvbXBvbmVudCc7XG5pbXBvcnQge01hdExpc3RNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xpc3QnO1xuaW1wb3J0IHtNYXRSaXBwbGVNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuXG5leHBvcnQge0VsZGVyTmF2TGlzdENvbXBvbmVudH0gZnJvbSAnLi9uYXYtbGlzdC9lbGRlci1uYXYtbGlzdC5jb21wb25lbnQnO1xuZXhwb3J0IHtFbGRlck5hdkxpbmtDb21wb25lbnR9IGZyb20gJy4vbmF2LWxpbmsvZWxkZXItbmF2LWxpbmsuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJOYXZHcm91cENvbXBvbmVudH0gZnJvbSAnLi9uYXYtZ3JvdXAvZWxkZXItbmF2LWdyb3VwLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZXhwb3J0czogW1xuICAgICAgICBFbGRlck5hdkxpc3RDb21wb25lbnQsXG4gICAgICAgIEVsZGVyTmF2TGlua0NvbXBvbmVudCxcbiAgICAgICAgRWxkZXJOYXZHcm91cENvbXBvbmVudFxuICAgIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsIFJvdXRlck1vZHVsZSxcbiAgICAgICAgTWF0SWNvbk1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlLFxuICAgICAgICBBMTF5TW9kdWxlLFxuICAgICAgICBUcmFuc2xhdGVNb2R1bGUsIE1hdExpc3RNb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSxcbiAgICAgICAgRWxkZXJOYXZMaXN0Q29tcG9uZW50LFxuICAgICAgICBFbGRlck5hdkxpbmtDb21wb25lbnQsXG4gICAgICAgIEVsZGVyTmF2R3JvdXBDb21wb25lbnRcbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyTmF2TW9kdWxlIHsgfVxuIl19
@@ -74,8 +74,8 @@ export class ElderNavGroupComponent {
74
74
  get isCurrentValueActive() {
75
75
  return this.navList.isActive(this.value);
76
76
  }
77
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderNavGroupComponent, deps: [{ token: i1.ElderNavListComponent }], target: i0.ɵɵFactoryTarget.Component }); }
78
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.4", type: ElderNavGroupComponent, isStandalone: true, selector: "elder-nav-group", inputs: { value: "value" }, outputs: { clicked: "clicked" }, queries: [{ propertyName: "children", predicate: ElderNavLinkComponent }], ngImport: i0, template: "\n<ng-container *ngIf=\"(state$ | async) as state\">\n <div class=\"layout-col nav-group\">\n <a matRipple\n class=\"layout-row place-start-center nav-group-button mat-button-fill\n mdc-list-item\n mdc-list-item--with-one-line\"\n [class.nav-group-button-open]=\"state.isOpen\"\n [class.nav-group-button-closed]=\"!state.isOpen\"\n [class.nav-group-button-active]=\"active$ | async\"\n (click)=\"itemClick($event)\"\n >\n\n <div class=\"layout-row place-start-center gap-lg full noselect mdc-list-item__primary-text\">\n <ng-content></ng-content>\n <span class=\"flex\"></span>\n <mat-icon>{{state.isOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down'}}</mat-icon>\n </div>\n </a>\n\n <!-- Nested Items projection -->\n <div class=\"layout-col nav-group-items-container p-sm gap-sm\"\n [@openClose]=\"state.isOpen ? 'open' : 'closed'\">\n <ng-content select=\"elder-nav-link\"></ng-content>\n </div>\n\n </div>\n</ng-container>\n", styles: [".nav-group-button-closed{padding-left:16px}.nav-group{min-height:48px}.nav-group-button{padding-right:16px;min-height:48px;font-size:16px;font-weight:400;border-radius:4px;cursor:pointer}.nav-group-button .mat-icon{height:24px;width:24px;font-size:24px;padding:4px}.nav-group-items-container{overflow:hidden}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], animations: [
77
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderNavGroupComponent, deps: [{ token: i1.ElderNavListComponent }], target: i0.ɵɵFactoryTarget.Component }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ElderNavGroupComponent, isStandalone: true, selector: "elder-nav-group", inputs: { value: "value" }, outputs: { clicked: "clicked" }, queries: [{ propertyName: "children", predicate: ElderNavLinkComponent }], ngImport: i0, template: "\n<ng-container *ngIf=\"(state$ | async) as state\">\n <div class=\"layout-col nav-group\">\n <a matRipple\n class=\"layout-row place-start-center nav-group-button mat-button-fill\n mdc-list-item\n mdc-list-item--with-one-line\"\n [class.nav-group-button-open]=\"state.isOpen\"\n [class.nav-group-button-closed]=\"!state.isOpen\"\n [class.nav-group-button-active]=\"active$ | async\"\n (click)=\"itemClick($event)\"\n >\n\n <div class=\"layout-row place-start-center gap-lg full noselect mdc-list-item__primary-text\">\n <ng-content></ng-content>\n <span class=\"flex\"></span>\n <mat-icon>{{state.isOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down'}}</mat-icon>\n </div>\n </a>\n\n <!-- Nested Items projection -->\n <div class=\"layout-col nav-group-items-container p-sm gap-sm\"\n [@openClose]=\"state.isOpen ? 'open' : 'closed'\">\n <ng-content select=\"elder-nav-link\"></ng-content>\n </div>\n\n </div>\n</ng-container>\n", styles: [".nav-group-button-closed{padding-left:16px}.nav-group{min-height:48px}.nav-group-button{padding-right:16px;min-height:48px;font-size:16px;font-weight:400;border-radius:4px;cursor:pointer}.nav-group-button .mat-icon{height:24px;width:24px;font-size:24px;padding:4px}.nav-group-items-container{overflow:hidden}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], animations: [
79
79
  trigger('openClose', [
80
80
  state('open', style({
81
81
  height: '*',
@@ -95,7 +95,7 @@ export class ElderNavGroupComponent {
95
95
  ])
96
96
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
97
97
  }
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: ElderNavGroupComponent, decorators: [{
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ElderNavGroupComponent, decorators: [{
99
99
  type: Component,
100
100
  args: [{ selector: 'elder-nav-group', animations: [
101
101
  trigger('openClose', [
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
124
124
  }], value: [{
125
125
  type: Input
126
126
  }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-nav-group.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/nav/nav-group/elder-nav-group.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/nav/nav-group/elder-nav-group.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,eAAe,EAAE,KAAK,EAAqB,MAAM,EAAY,MAAM,eAAe,CAAC;AAC/H,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAC,qBAAqB,EAAE,cAAc,EAAC,MAAM,sCAAsC,CAAC;AAC3F,OAAO,EAAC,eAAe,EAAc,OAAO,EAAC,MAAM,MAAM,CAAC;AAE1D,OAAO,EAAC,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAC,OAAO,EAAC,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAC,IAAI,EAAE,SAAS,EAAC,MAAM,iBAAiB,CAAC;;;AAkChD,MAAM,OAAO,sBAAsB;IAoBjC;;;;gFAI4E;IAE5E,YACmB,OAA8B;QAA9B,YAAO,GAAP,OAAO,CAAuB;QAhBjC,WAAM,GAAG,IAAI,eAAe,CAAgB,EAAC,MAAM,EAAE,KAAK,EAAC,CAAC,CAAC;QAG7D,YAAO,GAAG,IAAI,OAAO,EAAkB,CAAC;QAEvC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC/B,aAAQ,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;IAYhE,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ;QACb,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAC3B,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,CACxC,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QAElD,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;SAC/C;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAE5E,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IACW,KAAK,CAAC,CAAM;QACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAClB,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;;;gFAI4E;IAErE,SAAS,CAAC,KAAiB;QAChC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,EAAE,CAAC;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;SACjC;IACH,CAAC;IAEM,MAAM;QACX,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,EAAC,CAAC,CAAC;IAC9C,CAAC;IAED;;;;gFAI4E;IAE5E,IAAY,oBAAoB;QAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;8GAnGU,sBAAsB;kGAAtB,sBAAsB,iKAQhB,qBAAqB,6BClDxC,0hCA4BA,gXDYc,IAAI,6FAAE,SAAS,wPAAE,OAAO,sIAAE,SAAS,gCArBjC;YACR,OAAO,CAAC,WAAW,EAAE;gBACjB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;oBAChB,MAAM,EAAE,GAAG;oBACX,OAAO,EAAE,CAAC;iBACb,CAAC,CAAC;gBACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;oBAClB,MAAM,EAAE,CAAC;oBACT,OAAO,EAAE,GAAG;oBACZ,OAAO,EAAE,CAAC;iBACb,CAAC,CAAC;gBACH,UAAU,CAAC,gBAAgB,EAAE;oBACzB,OAAO,CAAC,OAAO,CAAC;iBACnB,CAAC;gBACF,UAAU,CAAC,gBAAgB,EAAE;oBACzB,OAAO,CAAC,OAAO,CAAC;iBACnB,CAAC;aACL,CAAC;SACL;;2FAKQ,sBAAsB;kBA3BlC,SAAS;+BACI,iBAAiB,cAGf;wBACR,OAAO,CAAC,WAAW,EAAE;4BACjB,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;gCAChB,MAAM,EAAE,GAAG;gCACX,OAAO,EAAE,CAAC;6BACb,CAAC,CAAC;4BACH,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC;gCAClB,MAAM,EAAE,CAAC;gCACT,OAAO,EAAE,GAAG;gCACZ,OAAO,EAAE,CAAC;6BACb,CAAC,CAAC;4BACH,UAAU,CAAC,gBAAgB,EAAE;gCACzB,OAAO,CAAC,OAAO,CAAC;6BACnB,CAAC;4BACF,UAAU,CAAC,gBAAgB,EAAE;gCACzB,OAAO,CAAC,OAAO,CAAC;6BACnB,CAAC;yBACL,CAAC;qBACL,mBACgB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC;0FAWzC,QAAQ;sBADd,eAAe;uBAAC,qBAAqB;gBAMtB,OAAO;sBADtB,MAAM;gBAmDI,KAAK;sBADf,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, Input, OnDestroy, OnInit, Output, QueryList} from '@angular/core';\nimport {animate, state, style, transition, trigger} from '@angular/animations';\nimport {ElderNavLinkComponent, NavItemClicked} from '../nav-link/elder-nav-link.component';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {ElderNavListComponent} from '../nav-list/elder-nav-list.component';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {MatIcon} from '@angular/material/icon';\nimport {MatRipple} from '@angular/material/core';\nimport {NgIf, AsyncPipe} from '@angular/common';\n\n\ninterface NavGroupState {\n  isOpen: boolean;\n}\n\n@Component({\n    selector: 'elder-nav-group',\n    templateUrl: './elder-nav-group.component.html',\n    styleUrls: ['./elder-nav-group.component.scss'],\n    animations: [\n        trigger('openClose', [\n            state('open', style({\n                height: '*',\n                opacity: 1,\n            })),\n            state('closed', style({\n                height: 0,\n                opacity: 0.5,\n                padding: 0\n            })),\n            transition('open => closed', [\n                animate('200ms')\n            ]),\n            transition('closed => open', [\n                animate('200ms')\n            ]),\n        ])\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, MatRipple, MatIcon, AsyncPipe]\n})\nexport class ElderNavGroupComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  @ContentChildren(ElderNavLinkComponent)\n  public children: QueryList<ElderNavLinkComponent>;\n\n  public readonly state$ = new BehaviorSubject<NavGroupState>({isOpen: false});\n\n  @Output()\n  public readonly clicked = new Subject<NavItemClicked>();\n\n  private readonly destroy$ = new Subject<void>();\n  private readonly _active$ = new BehaviorSubject<boolean>(false);\n  private _value: any;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly navList: ElderNavListComponent\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.navList.valueChange.pipe(\n      takeUntil(this.destroy$),\n      map(value => this.isCurrentValueActive),\n    ).subscribe(active => this._active$.next(active));\n\n    if (this.value) {\n      this._active$.next(this.isCurrentValueActive);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get active$(): Observable<boolean> {\n    return this._active$;\n  }\n\n  @Input()\n  public set value(v: any) {\n    this._value = v;\n  }\n\n  public get value(): any {\n    return this._value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public Api                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public itemClick(event: MouseEvent): void {\n    this.clicked.next(new NavItemClicked(event, this.value));\n    this.toggle();\n    if (this.value) {\n      this.navList.value = this.value;\n    }\n  }\n\n  public toggle(): void {\n    const myState = this.state$.getValue();\n    this.state$.next({isOpen: !myState.isOpen});\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private get isCurrentValueActive(): boolean {\n    return this.navList.isActive(this.value);\n  }\n}\n","\n<ng-container *ngIf=\"(state$ | async) as state\">\n  <div class=\"layout-col nav-group\">\n    <a matRipple\n       class=\"layout-row place-start-center nav-group-button mat-button-fill\n              mdc-list-item\n              mdc-list-item--with-one-line\"\n       [class.nav-group-button-open]=\"state.isOpen\"\n       [class.nav-group-button-closed]=\"!state.isOpen\"\n       [class.nav-group-button-active]=\"active$ | async\"\n       (click)=\"itemClick($event)\"\n    >\n\n      <div class=\"layout-row place-start-center gap-lg full noselect mdc-list-item__primary-text\">\n        <ng-content></ng-content>\n        <span class=\"flex\"></span>\n        <mat-icon>{{state.isOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down'}}</mat-icon>\n      </div>\n    </a>\n\n    <!-- Nested Items projection -->\n    <div class=\"layout-col nav-group-items-container p-sm gap-sm\"\n         [@openClose]=\"state.isOpen ? 'open' : 'closed'\">\n      <ng-content select=\"elder-nav-link\"></ng-content>\n    </div>\n\n  </div>\n</ng-container>\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-nav-group.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/nav/nav-group/elder-nav-group.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/navigation/nav/nav-group/elder-nav-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, Input, OnDestroy, OnInit, Output, QueryList} from '@angular/core';\nimport {animate, state, style, transition, trigger} from '@angular/animations';\nimport {ElderNavLinkComponent, NavItemClicked} from '../nav-link/elder-nav-link.component';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {ElderNavListComponent} from '../nav-list/elder-nav-list.component';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {MatIcon} from '@angular/material/icon';\nimport {MatRipple} from '@angular/material/core';\nimport {NgIf, AsyncPipe} from '@angular/common';\n\n\ninterface NavGroupState {\n  isOpen: boolean;\n}\n\n@Component({\n    selector: 'elder-nav-group',\n    templateUrl: './elder-nav-group.component.html',\n    styleUrls: ['./elder-nav-group.component.scss'],\n    animations: [\n        trigger('openClose', [\n            state('open', style({\n                height: '*',\n                opacity: 1,\n            })),\n            state('closed', style({\n                height: 0,\n                opacity: 0.5,\n                padding: 0\n            })),\n            transition('open => closed', [\n                animate('200ms')\n            ]),\n            transition('closed => open', [\n                animate('200ms')\n            ]),\n        ])\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [NgIf, MatRipple, MatIcon, AsyncPipe]\n})\nexport class ElderNavGroupComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  @ContentChildren(ElderNavLinkComponent)\n  public children: QueryList<ElderNavLinkComponent>;\n\n  public readonly state$ = new BehaviorSubject<NavGroupState>({isOpen: false});\n\n  @Output()\n  public readonly clicked = new Subject<NavItemClicked>();\n\n  private readonly destroy$ = new Subject<void>();\n  private readonly _active$ = new BehaviorSubject<boolean>(false);\n  private _value: any;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly navList: ElderNavListComponent\n  ) {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.navList.valueChange.pipe(\n      takeUntil(this.destroy$),\n      map(value => this.isCurrentValueActive),\n    ).subscribe(active => this._active$.next(active));\n\n    if (this.value) {\n      this._active$.next(this.isCurrentValueActive);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get active$(): Observable<boolean> {\n    return this._active$;\n  }\n\n  @Input()\n  public set value(v: any) {\n    this._value = v;\n  }\n\n  public get value(): any {\n    return this._value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public Api                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public itemClick(event: MouseEvent): void {\n    this.clicked.next(new NavItemClicked(event, this.value));\n    this.toggle();\n    if (this.value) {\n      this.navList.value = this.value;\n    }\n  }\n\n  public toggle(): void {\n    const myState = this.state$.getValue();\n    this.state$.next({isOpen: !myState.isOpen});\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private get isCurrentValueActive(): boolean {\n    return this.navList.isActive(this.value);\n  }\n}\n","\n<ng-container *ngIf=\"(state$ | async) as state\">\n  <div class=\"layout-col nav-group\">\n    <a matRipple\n       class=\"layout-row place-start-center nav-group-button mat-button-fill\n              mdc-list-item\n              mdc-list-item--with-one-line\"\n       [class.nav-group-button-open]=\"state.isOpen\"\n       [class.nav-group-button-closed]=\"!state.isOpen\"\n       [class.nav-group-button-active]=\"active$ | async\"\n       (click)=\"itemClick($event)\"\n    >\n\n      <div class=\"layout-row place-start-center gap-lg full noselect mdc-list-item__primary-text\">\n        <ng-content></ng-content>\n        <span class=\"flex\"></span>\n        <mat-icon>{{state.isOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down'}}</mat-icon>\n      </div>\n    </a>\n\n    <!-- Nested Items projection -->\n    <div class=\"layout-col nav-group-items-container p-sm gap-sm\"\n         [@openClose]=\"state.isOpen ? 'open' : 'closed'\">\n      <ng-content select=\"elder-nav-link\"></ng-content>\n    </div>\n\n  </div>\n</ng-container>\n"]}