@elderbyte/ngx-starter 14.10.0 → 14.12.0-beta

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 (303) hide show
  1. package/_index.scss +2 -0
  2. package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +4 -4
  3. package/esm2020/lib/common/forms/elder-form-field-control-base.directive.mjs +4 -4
  4. package/esm2020/lib/common/forms/elder-from-field-base.mjs +4 -4
  5. package/esm2020/lib/common/forms/elder-from-field-entity-base.mjs +4 -4
  6. package/esm2020/lib/common/forms/elder-from-field-multi-entity-base.mjs +4 -4
  7. package/esm2020/lib/common/forms/form-field-base.component.mjs +4 -4
  8. package/esm2020/lib/common/forms/multi-model-base.component.mjs +4 -4
  9. package/esm2020/lib/common/forms/template-composite-control.mjs +4 -4
  10. package/esm2020/lib/common/forms/value-accessor-base.mjs +4 -4
  11. package/esm2020/lib/common/http/http-client-builder.service.mjs +4 -4
  12. package/esm2020/lib/common/http/http-client-pristine.mjs +4 -4
  13. package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +4 -4
  14. package/esm2020/lib/common/url/elder-router.service.mjs +4 -4
  15. package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +4 -4
  16. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +5 -6
  17. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +8 -12
  18. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +11 -15
  19. package/esm2020/lib/components/auditing/elder-audit.module.mjs +5 -9
  20. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +5 -6
  21. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +8 -12
  22. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +6 -7
  23. package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +4 -4
  24. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +7 -8
  25. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +8 -9
  26. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +5 -7
  27. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +20 -22
  28. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +8 -9
  29. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +8 -9
  30. package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +4 -4
  31. package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +4 -4
  32. package/esm2020/lib/components/containers/elder-containers.module.mjs +6 -10
  33. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +5 -6
  34. package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +4 -4
  35. package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +4 -4
  36. package/esm2020/lib/components/csv/elder-csv.module.mjs +5 -5
  37. package/esm2020/lib/components/currency/elder-currency.module.mjs +5 -5
  38. package/esm2020/lib/components/currency/elder-currency.pipe.mjs +4 -4
  39. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +8 -9
  40. package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +4 -4
  41. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +5 -6
  42. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +6 -7
  43. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +8 -9
  44. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +7 -8
  45. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +4 -4
  46. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +6 -7
  47. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +8 -9
  48. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +8 -9
  49. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +6 -7
  50. package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -4
  51. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +5 -6
  52. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +47 -34
  53. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +5 -9
  54. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +4 -4
  55. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +8 -9
  56. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  57. package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +4 -4
  58. package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +4 -4
  59. package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +4 -4
  60. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +11 -12
  61. package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +4 -4
  62. package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  63. package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +4 -4
  64. package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +4 -4
  65. package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +4 -4
  66. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +8 -9
  67. package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +4 -4
  68. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +6 -7
  69. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +11 -12
  70. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +4 -4
  71. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +6 -7
  72. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +6 -7
  73. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +4 -4
  74. package/esm2020/lib/components/errors/elder-error.module.mjs +8 -12
  75. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +5 -6
  76. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +6 -7
  77. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +6 -7
  78. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +5 -6
  79. package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +4 -4
  80. package/esm2020/lib/components/files/elder-file-select.directive.mjs +4 -4
  81. package/esm2020/lib/components/files/elder-file.module.mjs +8 -9
  82. package/esm2020/lib/components/files/file-select/file-select.component.mjs +4 -4
  83. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +13 -14
  84. package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +4 -4
  85. package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +4 -4
  86. package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +4 -4
  87. package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +4 -4
  88. package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +4 -4
  89. package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +4 -4
  90. package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +4 -4
  91. package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +4 -4
  92. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +14 -14
  93. package/esm2020/lib/components/forms/directives/elder-input-pattern.directive.mjs +4 -4
  94. package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +4 -4
  95. package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +4 -4
  96. package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +4 -4
  97. package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +4 -4
  98. package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
  99. package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
  100. package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  101. package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +4 -4
  102. package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +4 -4
  103. package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +4 -4
  104. package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +4 -4
  105. package/esm2020/lib/components/forms/elder-forms.module.mjs +5 -5
  106. package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +4 -4
  107. package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
  108. package/esm2020/lib/components/forms/search/elder-search.module.mjs +8 -9
  109. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +7 -8
  110. package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +4 -4
  111. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +6 -7
  112. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +6 -7
  113. package/esm2020/lib/components/global-search/elder-global-search.service.mjs +4 -4
  114. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +5 -13
  115. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +6 -10
  116. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +6 -7
  117. package/esm2020/lib/components/headers/elder-header.module.mjs +8 -9
  118. package/esm2020/lib/components/http-support/elder-http-client.service.mjs +4 -4
  119. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -9
  120. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +12 -13
  121. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +10 -11
  122. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +4 -4
  123. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +16 -17
  124. package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +4 -4
  125. package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  126. package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +4 -4
  127. package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +4 -4
  128. package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +4 -4
  129. package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +4 -4
  130. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +5 -9
  131. package/esm2020/lib/components/i18n/language/elder-language.service.mjs +4 -4
  132. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +7 -8
  133. package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
  134. package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +6 -7
  135. package/esm2020/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +4 -4
  136. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +5 -9
  137. package/esm2020/lib/components/iframes/iframe-close.directive.mjs +4 -4
  138. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +6 -7
  139. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +8 -9
  140. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +6 -7
  141. package/esm2020/lib/components/iframes/iframe.service.mjs +4 -4
  142. package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +4 -4
  143. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  144. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +8 -8
  145. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +6 -7
  146. package/esm2020/lib/components/input/autocomplete/elder-autocomplete-many.directive.mjs +4 -4
  147. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  148. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +5 -9
  149. package/esm2020/lib/components/labels/elder-labels.module.mjs +5 -5
  150. package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +4 -4
  151. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +7 -18
  152. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +4 -4
  153. package/esm2020/lib/components/measures/elder-measures.module.mjs +9 -13
  154. package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +4 -4
  155. package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +4 -4
  156. package/esm2020/lib/components/measures/elder-unit.service.mjs +4 -4
  157. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +14 -15
  158. package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +4 -4
  159. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +14 -15
  160. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +8 -9
  161. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +8 -9
  162. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +5 -6
  163. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +6 -7
  164. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +5 -7
  165. package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +4 -4
  166. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +8 -9
  167. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +4 -4
  168. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +8 -9
  169. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +4 -4
  170. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +4 -4
  171. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +5 -5
  172. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +5 -5
  173. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +5 -5
  174. package/esm2020/lib/components/overlays/elder-overlay.module.mjs +5 -5
  175. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +5 -6
  176. package/esm2020/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +5 -6
  177. package/esm2020/lib/components/panels/elder-panel.module.mjs +6 -10
  178. package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +4 -4
  179. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +4 -4
  180. package/esm2020/lib/components/select/elder-select-base.mjs +4 -4
  181. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +10 -10
  182. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  183. package/esm2020/lib/components/select/elder-select-value.directive.mjs +4 -4
  184. package/esm2020/lib/components/select/elder-select.module.mjs +8 -9
  185. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +4 -4
  186. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +14 -15
  187. package/esm2020/lib/components/select/multi/elder-multi-select-form-field.mjs +4 -4
  188. package/esm2020/lib/components/select/popup/selection-model-popup-trigger-adapter.directive.mjs +4 -4
  189. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +4 -4
  190. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +7 -8
  191. package/esm2020/lib/components/select/single/elder-clear-select.directive.mjs +4 -4
  192. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +11 -12
  193. package/esm2020/lib/components/select/single/elder-select-form-field.mjs +4 -4
  194. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +7 -9
  195. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +8 -9
  196. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +8 -9
  197. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +5 -6
  198. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +5 -6
  199. package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +4 -4
  200. package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +4 -4
  201. package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +4 -4
  202. package/esm2020/lib/components/shell/elder-shell.module.mjs +8 -9
  203. package/esm2020/lib/components/shell/elder-shell.service.mjs +4 -4
  204. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +6 -7
  205. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +15 -16
  206. package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +4 -4
  207. package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +4 -4
  208. package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  209. package/esm2020/lib/components/tabs/elder-tab.module.mjs +7 -11
  210. package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +4 -4
  211. package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +4 -4
  212. package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +4 -4
  213. package/esm2020/lib/components/theme/elder-theme.directive.mjs +4 -4
  214. package/esm2020/lib/components/theme/elder-theme.module.mjs +5 -5
  215. package/esm2020/lib/components/theme/elder-theme.service.mjs +4 -4
  216. package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +4 -4
  217. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +9 -10
  218. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +11 -12
  219. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +9 -10
  220. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +9 -10
  221. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +14 -15
  222. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +11 -12
  223. package/esm2020/lib/components/time/elder-time.module.mjs +9 -19
  224. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +9 -10
  225. package/esm2020/lib/components/toasts/elder-toast.module.mjs +6 -7
  226. package/esm2020/lib/components/toasts/elder-toast.service.mjs +10 -10
  227. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +7 -8
  228. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -9
  229. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +6 -7
  230. package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +4 -4
  231. package/esm2020/lib/components/viewers/elder-viewers.module.mjs +5 -5
  232. package/esm2020/lib/features/event-source/elder-event-source.service.mjs +4 -4
  233. package/esm2020/lib/features/kafent/access-token-provider.mjs +4 -4
  234. package/esm2020/lib/features/kafent/kafent-config.mjs +4 -4
  235. package/esm2020/lib/features/kafent/kafent-event-stream.mjs +4 -4
  236. package/esm2020/lib/features/kafent/kafent-event.service.mjs +4 -4
  237. package/esm2020/lib/features/kafent/kafent.module.mjs +5 -5
  238. package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +4 -4
  239. package/esm2020/lib/pipes/bytes.pipe.mjs +4 -4
  240. package/esm2020/lib/pipes/elder-pipes.module.mjs +11 -11
  241. package/esm2020/lib/pipes/elder-repeat.pipe.mjs +4 -4
  242. package/esm2020/lib/pipes/elder-round.pipe.mjs +4 -4
  243. package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +4 -4
  244. package/esm2020/lib/pipes/elder-truncate.pipe.mjs +4 -4
  245. package/esm2020/lib/pipes/iso-duration.pipe.mjs +4 -4
  246. package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +4 -4
  247. package/esm2020/lib/pipes/iso-interval.pipe.mjs +4 -4
  248. package/esm2020/lib/pipes/time-ago.pipe.mjs +4 -4
  249. package/esm2020/lib/pipes/time-duration.pipe.mjs +4 -4
  250. package/esm2020/lib/pipes/weight.pipe.mjs +4 -4
  251. package/fesm2015/elderbyte-ngx-starter.mjs +1126 -1190
  252. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  253. package/fesm2020/elderbyte-ngx-starter.mjs +1126 -1190
  254. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  255. package/lib/components/access-denied/elder-access-denied.module.d.ts +1 -2
  256. package/lib/components/auditing/audited-entity/elder-audited-entity.component.d.ts +1 -2
  257. package/lib/components/auditing/elder-audit.module.d.ts +5 -6
  258. package/lib/components/button-group/elder-button-group.module.d.ts +1 -2
  259. package/lib/components/card-organizer/elder-card-organizer.module.d.ts +3 -4
  260. package/lib/components/cards/elder-card/elder-card.module.d.ts +2 -3
  261. package/lib/components/connectivity/elder-connectivity.module.d.ts +6 -7
  262. package/lib/components/containers/elder-containers.module.d.ts +1 -2
  263. package/lib/components/data-transfer/elder-data-transfer.module.d.ts +4 -5
  264. package/lib/components/data-view/common/elder-data-common.module.d.ts +1 -2
  265. package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -3
  266. package/lib/components/data-view/grid/elder-grid.module.d.ts +6 -7
  267. package/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.d.ts +4 -5
  268. package/lib/components/data-view/table/elder-table.module.d.ts +4 -5
  269. package/lib/components/dialogs/elder-dialog.module.d.ts +2 -3
  270. package/lib/components/errors/elder-error.module.d.ts +1 -2
  271. package/lib/components/expand-toggle-button/elder-expand-toggle-button.module.d.ts +1 -2
  272. package/lib/components/files/elder-file.module.d.ts +6 -7
  273. package/lib/components/forms/search/elder-search.module.d.ts +2 -3
  274. package/lib/components/global-search/elder-global-search.module.d.ts +2 -3
  275. package/lib/components/graph/elder-progress-bar/elder-progress-bar.component.d.ts +1 -8
  276. package/lib/components/graph/elder-progress-bar/elder-progress-bar.module.d.ts +1 -2
  277. package/lib/components/headers/elder-header.module.d.ts +2 -3
  278. package/lib/components/i18n/entities/elder-i18n-entities.module.d.ts +15 -16
  279. package/lib/components/i18n/language/elder-language.module.d.ts +2 -3
  280. package/lib/components/iframes/elder-iframe.module.d.ts +5 -6
  281. package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +2 -3
  282. package/lib/components/measures/dimensions-input/elder-dimensions-input.component.d.ts +1 -3
  283. package/lib/components/measures/elder-measures.module.d.ts +5 -6
  284. package/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.d.ts +8 -9
  285. package/lib/components/navigation/nav/elder-nav.module.d.ts +1 -2
  286. package/lib/components/navigation/nav/nav-list/elder-nav-list.component.d.ts +1 -3
  287. package/lib/components/navigation/toolbar/elder-toolbar.module.d.ts +8 -9
  288. package/lib/components/panels/elder-panel.module.d.ts +1 -2
  289. package/lib/components/select/elder-select.module.d.ts +10 -11
  290. package/lib/components/select-chip-list/elder-chip-list-select.module.d.ts +3 -4
  291. package/lib/components/select-list/elder-select-list.module.d.ts +1 -2
  292. package/lib/components/shell/elder-shell.module.d.ts +4 -5
  293. package/lib/components/tabs/elder-tab.module.d.ts +1 -2
  294. package/lib/components/time/elder-time.module.d.ts +9 -10
  295. package/lib/components/toasts/elder-toast.module.d.ts +3 -4
  296. package/lib/components/url-fragment/elder-url-fragment.module.d.ts +2 -3
  297. package/package.json +1 -2
  298. package/src/lib/components/graph/elder-progress-bar/elder-progress-bar.component.scss +5 -0
  299. package/src/lib/components/navigation/nav/nav-list/elder-nav-list.component.scss +5 -6
  300. package/src/lib/components/select/single/elder-select/elder-select.component.scss +1 -4
  301. package/theming/_elder-common.scss +32 -0
  302. package/theming/_elder-flex-layout.scss +562 -0
  303. package/theming/_elder-style-fixes.scss +3 -0
@@ -5,8 +5,7 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../../theme/elder-theme.service";
6
6
  import * as i2 from "@angular/common";
7
7
  import * as i3 from "@angular/material/icon";
8
- import * as i4 from "@angular/flex-layout/flex";
9
- import * as i5 from "../../../panels/flat/elder-panel.component";
8
+ import * as i4 from "../../../panels/flat/elder-panel.component";
10
9
  export class ElderAppHeaderComponent {
11
10
  /***************************************************************************
12
11
  * *
@@ -51,11 +50,11 @@ export class ElderAppHeaderComponent {
51
50
  this.iconColor$.next(c);
52
51
  }
53
52
  }
54
- ElderAppHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderAppHeaderComponent, deps: [{ token: i1.ElderThemeService }], target: i0.ɵɵFactoryTarget.Component });
55
- ElderAppHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: ElderAppHeaderComponent, selector: "elder-app-header", inputs: { icon: "icon", title: "title", subTitle: "subTitle", subTitleLink: "subTitleLink", version: "version", color: "color", iconColor: "iconColor" }, ngImport: i0, template: "<mat-panel fxLayout=\"column\" [color]=\"color$ | async\" class=\"light\" fxFill>\n <div fxLayout=\"row\" style=\"padding: 20px\" fxFlex=\"none\">\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n </div>\n <div fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" style=\"width: 100%\">\n <div fxLayout=\"row\" fxLayoutAlign=\"start end\" fxLayoutGap=\"5px\">\n <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n </div>\n </div>\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <span class=\"mat-caption noselect\">\n <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Project child content here -->\n <ng-content></ng-content>\n\n</mat-panel>\n", styles: [".title-icon{font-size:42px;width:42px;height:42px;padding:20px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i4.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i4.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i4.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i5.ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: ["color"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderAppHeaderComponent, decorators: [{
53
+ ElderAppHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderAppHeaderComponent, deps: [{ token: i1.ElderThemeService }], target: i0.ɵɵFactoryTarget.Component });
54
+ ElderAppHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderAppHeaderComponent, selector: "elder-app-header", inputs: { icon: "icon", title: "title", subTitle: "subTitle", subTitleLink: "subTitleLink", version: "version", color: "color", iconColor: "iconColor" }, ngImport: i0, template: "<mat-panel [color]=\"color$ | async\" class=\"layout-col full light\">\n <div class=\"layout-row flex-none p-lg\">\n <div class=\"layout-row place-center-center\">\n <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n </div>\n <div class=\"layout-col place-center-start\">\n <div class=\"layout-col place-center-center\" style=\"width: 100%\">\n <div class=\"layout-row place-start-end gap-xs\">\n <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n </div>\n </div>\n <div class=\"layout-row place-start-center\">\n <span class=\"mat-caption noselect\">\n <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Project child content here -->\n <ng-content></ng-content>\n\n</mat-panel>\n", styles: [".title-icon{font-size:42px;width:42px;height:42px;padding:20px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: ["color"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderAppHeaderComponent, decorators: [{
57
56
  type: Component,
58
- args: [{ selector: 'elder-app-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-panel fxLayout=\"column\" [color]=\"color$ | async\" class=\"light\" fxFill>\n <div fxLayout=\"row\" style=\"padding: 20px\" fxFlex=\"none\">\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n </div>\n <div fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div fxLayout=\"column\" fxLayoutAlign=\"center center\" style=\"width: 100%\">\n <div fxLayout=\"row\" fxLayoutAlign=\"start end\" fxLayoutGap=\"5px\">\n <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n </div>\n </div>\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <span class=\"mat-caption noselect\">\n <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Project child content here -->\n <ng-content></ng-content>\n\n</mat-panel>\n", styles: [".title-icon{font-size:42px;width:42px;height:42px;padding:20px}\n"] }]
57
+ args: [{ selector: 'elder-app-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-panel [color]=\"color$ | async\" class=\"layout-col full light\">\n <div class=\"layout-row flex-none p-lg\">\n <div class=\"layout-row place-center-center\">\n <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n </div>\n <div class=\"layout-col place-center-start\">\n <div class=\"layout-col place-center-center\" style=\"width: 100%\">\n <div class=\"layout-row place-start-end gap-xs\">\n <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n </div>\n </div>\n <div class=\"layout-row place-start-center\">\n <span class=\"mat-caption noselect\">\n <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n </span>\n </div>\n </div>\n </div>\n\n <!-- Project child content here -->\n <ng-content></ng-content>\n\n</mat-panel>\n", styles: [".title-icon{font-size:42px;width:42px;height:42px;padding:20px}\n"] }]
59
58
  }], ctorParameters: function () { return [{ type: i1.ElderThemeService }]; }, propDecorators: { icon: [{
60
59
  type: Input
61
60
  }], title: [{
@@ -71,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
71
70
  }], iconColor: [{
72
71
  type: Input
73
72
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-app-header.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/header/elder-app-header/elder-app-header.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/header/elder-app-header/elder-app-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAU,uBAAuB,EAAE,KAAK,EAAY,MAAM,eAAe,CAAC;AAG3F,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;;;;;;;AAQ9C,MAAM,OAAO,uBAAuB;IA4BlC;;;;gFAI4E;IAE5E,YACmB,YAA+B;QAA/B,iBAAY,GAAZ,YAAY,CAAmB;QApB3C,aAAQ,GAAG,cAAc,CAAC;QAG1B,iBAAY,GAAG,uBAAuB,CAAC;QAK9B,WAAM,GAAG,IAAI,eAAe,CAAe,SAAS,CAAC,CAAC;QACtD,eAAU,GAAG,IAAI,eAAe,CAAe,QAAQ,CAAC,CAAC;QAExD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAU5C,CAAC;IAEL;;;;gFAI4E;IAErE,QAAQ;QACb,IAAI,CAAC,YAAY;aACd,YAAY;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,YAAY,CAAC,GAAG,CAAC,CAAC,uBAAuB;SAC1C,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,cAAc,CAAC;YAClC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,aAAa,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,CAAe;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED,IACW,SAAS,CAAC,CAAe;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;;oHA3EU,uBAAuB;wGAAvB,uBAAuB,kNCZpC,qrCAyBA;2FDba,uBAAuB;kBANnC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM;wGAWxC,IAAI;sBADV,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAgDK,KAAK;sBADf,KAAK;gBAMK,SAAS;sBADnB,KAAK","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Input, OnDestroy} from '@angular/core';\nimport {ThemePalette} from '@angular/material/core';\nimport {ElderThemeService} from '../../../theme/elder-theme.service';\nimport {debounceTime, takeUntil} from 'rxjs/operators';\nimport {BehaviorSubject, Subject} from 'rxjs';\n\n@Component({\n  selector: 'elder-app-header',\n  templateUrl: './elder-app-header.component.html',\n  styleUrls: ['./elder-app-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderAppHeaderComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public icon: string;\n\n  @Input()\n  public title: string;\n\n  @Input()\n  public subTitle = 'by ElderByte';\n\n  @Input()\n  public subTitleLink = 'https://elderbyte.com';\n\n  @Input()\n  public version: string;\n\n  public readonly color$ = new BehaviorSubject<ThemePalette>('primary');\n  public readonly iconColor$ = new BehaviorSubject<ThemePalette>('accent');\n\n  private readonly destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly themeService: ElderThemeService\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.themeService\n      .activeTheme$\n      .pipe(\n        takeUntil(this.destroy$),\n        debounceTime(200) // Fix for NG0100 error\n      ).subscribe(theme => {\n      this.color = theme.heroBackground;\n      this.iconColor = theme.heroIconColor;\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  @Input()\n  public set color(c: ThemePalette){\n    this.color$.next(c);\n  }\n\n  @Input()\n  public set iconColor(c: ThemePalette){\n    this.iconColor$.next(c);\n  }\n}\n","<mat-panel fxLayout=\"column\" [color]=\"color$ | async\" class=\"light\" fxFill>\n  <div fxLayout=\"row\" style=\"padding: 20px\" fxFlex=\"none\">\n    <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n      <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n    </div>\n    <div fxLayout=\"column\" fxLayoutAlign=\"center start\">\n      <div fxLayout=\"column\" fxLayoutAlign=\"center center\" style=\"width: 100%\">\n        <div fxLayout=\"row\" fxLayoutAlign=\"start end\" fxLayoutGap=\"5px\">\n          <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n          <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n        </div>\n      </div>\n      <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n        <span class=\"mat-caption noselect\">\n          <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n          <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Project child content here -->\n  <ng-content></ng-content>\n\n</mat-panel>\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-app-header.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/header/elder-app-header/elder-app-header.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/header/elder-app-header/elder-app-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAU,uBAAuB,EAAE,KAAK,EAAY,MAAM,eAAe,CAAC;AAG3F,OAAO,EAAC,YAAY,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;;;;;;AAQ9C,MAAM,OAAO,uBAAuB;IA4BlC;;;;gFAI4E;IAE5E,YACmB,YAA+B;QAA/B,iBAAY,GAAZ,YAAY,CAAmB;QApB3C,aAAQ,GAAG,cAAc,CAAC;QAG1B,iBAAY,GAAG,uBAAuB,CAAC;QAK9B,WAAM,GAAG,IAAI,eAAe,CAAe,SAAS,CAAC,CAAC;QACtD,eAAU,GAAG,IAAI,eAAe,CAAe,QAAQ,CAAC,CAAC;QAExD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAU5C,CAAC;IAEL;;;;gFAI4E;IAErE,QAAQ;QACb,IAAI,CAAC,YAAY;aACd,YAAY;aACZ,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,YAAY,CAAC,GAAG,CAAC,CAAC,uBAAuB;SAC1C,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,cAAc,CAAC;YAClC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,aAAa,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,KAAK,CAAC,CAAe;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC;IAED,IACW,SAAS,CAAC,CAAe;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;;qHA3EU,uBAAuB;yGAAvB,uBAAuB,kNCZpC,0lCAyBA;4FDba,uBAAuB;kBANnC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM;wGAWxC,IAAI;sBADV,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAgDK,KAAK;sBADf,KAAK;gBAMK,SAAS;sBADnB,KAAK","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, Input, OnDestroy} from '@angular/core';\nimport {ThemePalette} from '@angular/material/core';\nimport {ElderThemeService} from '../../../theme/elder-theme.service';\nimport {debounceTime, takeUntil} from 'rxjs/operators';\nimport {BehaviorSubject, Subject} from 'rxjs';\n\n@Component({\n  selector: 'elder-app-header',\n  templateUrl: './elder-app-header.component.html',\n  styleUrls: ['./elder-app-header.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderAppHeaderComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public icon: string;\n\n  @Input()\n  public title: string;\n\n  @Input()\n  public subTitle = 'by ElderByte';\n\n  @Input()\n  public subTitleLink = 'https://elderbyte.com';\n\n  @Input()\n  public version: string;\n\n  public readonly color$ = new BehaviorSubject<ThemePalette>('primary');\n  public readonly iconColor$ = new BehaviorSubject<ThemePalette>('accent');\n\n  private readonly destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly themeService: ElderThemeService\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.themeService\n      .activeTheme$\n      .pipe(\n        takeUntil(this.destroy$),\n        debounceTime(200) // Fix for NG0100 error\n      ).subscribe(theme => {\n      this.color = theme.heroBackground;\n      this.iconColor = theme.heroIconColor;\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  @Input()\n  public set color(c: ThemePalette){\n    this.color$.next(c);\n  }\n\n  @Input()\n  public set iconColor(c: ThemePalette){\n    this.iconColor$.next(c);\n  }\n}\n","<mat-panel [color]=\"color$ | async\" class=\"layout-col full light\">\n  <div class=\"layout-row flex-none p-lg\">\n    <div class=\"layout-row place-center-center\">\n      <mat-icon class=\"noselect title-icon\" [color]=\"iconColor$ | async\">{{icon}}</mat-icon>\n    </div>\n    <div class=\"layout-col place-center-start\">\n      <div class=\"layout-col place-center-center\" style=\"width: 100%\">\n        <div class=\"layout-row place-start-end gap-xs\">\n          <span id=\"title\" class=\"noselect\" style=\"font-size: 28px\">{{title}}</span>\n          <span class=\"mat-caption noselect\"><small>{{version}}</small></span>\n        </div>\n      </div>\n      <div class=\"layout-row place-start-center\">\n        <span class=\"mat-caption noselect\">\n          <span *ngIf=\"!subTitleLink\">{{subTitle}}</span>\n          <a *ngIf=\"subTitleLink\" [href]=\"subTitleLink\" target=\"_blank\" style=\"text-decoration:none; color: inherit\">{{subTitle}}</a>\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Project child content here -->\n  <ng-content></ng-content>\n\n</mat-panel>\n"]}
@@ -13,17 +13,16 @@ import * as i7 from "@angular/material/toolbar";
13
13
  import * as i8 from "@angular/material/icon";
14
14
  import * as i9 from "@angular/material/button";
15
15
  import * as i10 from "../../navigation/toolbar/toolbar/elder-toolbar.component";
16
- import * as i11 from "@angular/flex-layout/flex";
17
- import * as i12 from "../../theme/elder-theme-applier.directive";
16
+ import * as i11 from "../../theme/elder-theme-applier.directive";
18
17
  export class ElderShellSideLeftDirective {
19
18
  constructor(templateRef, viewContainer) {
20
19
  this.templateRef = templateRef;
21
20
  this.viewContainer = viewContainer;
22
21
  }
23
22
  }
24
- ElderShellSideLeftDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellSideLeftDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
25
- ElderShellSideLeftDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: ElderShellSideLeftDirective, selector: "[elderShellSideLeft], [ebsShellSideLeft]", ngImport: i0 });
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellSideLeftDirective, decorators: [{
23
+ ElderShellSideLeftDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellSideLeftDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
24
+ ElderShellSideLeftDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: ElderShellSideLeftDirective, selector: "[elderShellSideLeft], [ebsShellSideLeft]", ngImport: i0 });
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellSideLeftDirective, decorators: [{
27
26
  type: Directive,
28
27
  args: [{ selector: '[elderShellSideLeft], [ebsShellSideLeft]' }]
29
28
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -33,9 +32,9 @@ export class ElderShellSideRightDirective {
33
32
  this.viewContainer = viewContainer;
34
33
  }
35
34
  }
36
- ElderShellSideRightDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellSideRightDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
37
- ElderShellSideRightDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: ElderShellSideRightDirective, selector: "[elderShellSideRight], [ebsShellSideRight]", ngImport: i0 });
38
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellSideRightDirective, decorators: [{
35
+ ElderShellSideRightDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellSideRightDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
36
+ ElderShellSideRightDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: ElderShellSideRightDirective, selector: "[elderShellSideRight], [ebsShellSideRight]", ngImport: i0 });
37
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellSideRightDirective, decorators: [{
39
38
  type: Directive,
40
39
  args: [{ selector: '[elderShellSideRight], [ebsShellSideRight]' }]
41
40
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -45,9 +44,9 @@ export class ElderShellCenterDirective {
45
44
  this.viewContainer = viewContainer;
46
45
  }
47
46
  }
48
- ElderShellCenterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellCenterDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
49
- ElderShellCenterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: ElderShellCenterDirective, selector: "[elderShellCenter], [ebsShellCenter]", ngImport: i0 });
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellCenterDirective, decorators: [{
47
+ ElderShellCenterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellCenterDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
48
+ ElderShellCenterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: ElderShellCenterDirective, selector: "[elderShellCenter], [ebsShellCenter]", ngImport: i0 });
49
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellCenterDirective, decorators: [{
51
50
  type: Directive,
52
51
  args: [{ selector: '[elderShellCenter], [ebsShellCenter]' }]
53
52
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -174,11 +173,11 @@ export class ElderShellComponent {
174
173
  }, 5);
175
174
  }
176
175
  }
177
- ElderShellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellComponent, deps: [{ token: i1.ElderShellService }, { token: i2.ElderRouteOutletDrawerService }, { token: i0.ChangeDetectorRef }, { token: i3.ElderThemeService }], target: i0.ɵɵFactoryTarget.Component });
178
- ElderShellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: ElderShellComponent, selector: "elder-shell, ebs-shell", inputs: { sideNavToggleEnabled: "sideNavToggleEnabled", leftSideAutoFocus: "leftSideAutoFocus", rightSideAutoFocus: "rightSideAutoFocus", color: "color", menuColor: "menuColor", menuIconColor: "menuIconColor" }, queries: [{ propertyName: "sideContentLeft", first: true, predicate: ElderShellSideLeftDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "sideContentRight", first: true, predicate: ElderShellSideRightDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "centerContent", first: true, predicate: ElderShellCenterDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "rightSideDrawer", first: true, predicate: ["rightSideDetail"], descendants: true, static: true }], ngImport: i0, template: "\n<mat-sidenav-container\n elderThemeApplier\n style=\"height:100%; width: 100%\"\n (backdropClick)=\"onBackdropClick($event)\"\n>\n\n <!-- Left Side Nav -->\n <mat-sidenav position=\"start\"\n mode=\"over\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"leftSideAutoFocus\"\n [opened]=\"leftSideContentOpen$ | async\"\n (closed)=\"closeLeftSideContent()\">\n <div fxFill fxLayout=\"column\">\n <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n </div>\n </mat-sidenav>\n\n <!-- Main Content -->\n <mat-sidenav-content>\n <div fxLayout=\"column\" fxFill>\n <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n </div>\n </mat-sidenav-content>\n\n <!-- Right Side Detail -->\n <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n position=\"end\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"rightSideAutoFocus\"\n [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n <div fxFill fxLayout=\"column\">\n <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n </div>\n </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n <div fxLayout=\"column\" fxFlex>\n <p class=\"noselect\">No Left Side Content Defined!</p>\n </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n <div fxLayout=\"column\" fxFill>\n\n <!-- Header -->\n <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n <!-- Center -->\n <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n <!-- Footer -->\n <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n <elder-toolbar [color]=\"color\">\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\"\n [color]=\"menuColor$ | async\">\n <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n <!-- Default Footer is empty -->\n</ng-template>\n", styles: ["mat-sidenav{margin:0;height:100%;overflow:hidden}mat-sidenav-container{margin:0;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: i6.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i6.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i6.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i7.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i9.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i10.ElderToolbarComponent, selector: "elder-toolbar, ebs-toolbar", inputs: ["color"] }, { kind: "directive", type: i11.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i11.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i11.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i11.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i12.ElderThemeApplierDirective, selector: "[elderThemeApplier]" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
179
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellComponent, decorators: [{
176
+ ElderShellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellComponent, deps: [{ token: i1.ElderShellService }, { token: i2.ElderRouteOutletDrawerService }, { token: i0.ChangeDetectorRef }, { token: i3.ElderThemeService }], target: i0.ɵɵFactoryTarget.Component });
177
+ ElderShellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderShellComponent, selector: "elder-shell, ebs-shell", inputs: { sideNavToggleEnabled: "sideNavToggleEnabled", leftSideAutoFocus: "leftSideAutoFocus", rightSideAutoFocus: "rightSideAutoFocus", color: "color", menuColor: "menuColor", menuIconColor: "menuIconColor" }, queries: [{ propertyName: "sideContentLeft", first: true, predicate: ElderShellSideLeftDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "sideContentRight", first: true, predicate: ElderShellSideRightDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "centerContent", first: true, predicate: ElderShellCenterDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "rightSideDrawer", first: true, predicate: ["rightSideDetail"], descendants: true, static: true }], ngImport: i0, template: "<mat-sidenav-container\n elderThemeApplier\n class=\"full-width\"\n (backdropClick)=\"onBackdropClick($event)\"\n>\n\n <!-- Left Side Nav -->\n <mat-sidenav position=\"start\"\n mode=\"over\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"leftSideAutoFocus\"\n [opened]=\"leftSideContentOpen$ | async\"\n (closed)=\"closeLeftSideContent()\">\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n </div>\n </mat-sidenav>\n\n <!-- Main Content -->\n <mat-sidenav-content>\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n </div>\n </mat-sidenav-content>\n\n <!-- Right Side Detail -->\n <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n position=\"end\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"rightSideAutoFocus\"\n [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n </div>\n </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n <div class=\"layout-col flex\">\n <p class=\"noselect\">No Left Side Content Defined!</p>\n </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n <div class=\"layout-col full\">\n\n <!-- Header -->\n <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n <!-- Center -->\n <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n <!-- Footer -->\n <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n <elder-toolbar [color]=\"color\" class=\"flex-none\" style=\"max-width: 100%; min-width: 100%\" >\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\"\n [color]=\"menuColor$ | async\"\n class=\"flex-none\" style=\"width: auto\"\n >\n <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n <!-- Default Footer is empty -->\n</ng-template>\n", styles: ["mat-sidenav{margin:0;height:100%;overflow:hidden}mat-sidenav-container{margin:0;width:100%;height:100%;overflow:hidden}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "component", type: i6.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i6.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i6.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i7.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i9.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i10.ElderToolbarComponent, selector: "elder-toolbar, ebs-toolbar", inputs: ["color"] }, { kind: "directive", type: i11.ElderThemeApplierDirective, selector: "[elderThemeApplier]" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
178
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellComponent, decorators: [{
180
179
  type: Component,
181
- args: [{ selector: 'elder-shell, ebs-shell', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n<mat-sidenav-container\n elderThemeApplier\n style=\"height:100%; width: 100%\"\n (backdropClick)=\"onBackdropClick($event)\"\n>\n\n <!-- Left Side Nav -->\n <mat-sidenav position=\"start\"\n mode=\"over\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"leftSideAutoFocus\"\n [opened]=\"leftSideContentOpen$ | async\"\n (closed)=\"closeLeftSideContent()\">\n <div fxFill fxLayout=\"column\">\n <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n </div>\n </mat-sidenav>\n\n <!-- Main Content -->\n <mat-sidenav-content>\n <div fxLayout=\"column\" fxFill>\n <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n </div>\n </mat-sidenav-content>\n\n <!-- Right Side Detail -->\n <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n position=\"end\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"rightSideAutoFocus\"\n [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n <div fxFill fxLayout=\"column\">\n <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n </div>\n </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n <div fxLayout=\"column\" fxFlex>\n <p class=\"noselect\">No Left Side Content Defined!</p>\n </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n <div fxLayout=\"column\" fxFill>\n\n <!-- Header -->\n <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n <!-- Center -->\n <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n <!-- Footer -->\n <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n <elder-toolbar [color]=\"color\">\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\"\n [color]=\"menuColor$ | async\">\n <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n <!-- Default Footer is empty -->\n</ng-template>\n", styles: ["mat-sidenav{margin:0;height:100%;overflow:hidden}mat-sidenav-container{margin:0;width:100%;height:100%;overflow:hidden}\n"] }]
180
+ args: [{ selector: 'elder-shell, ebs-shell', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-sidenav-container\n elderThemeApplier\n class=\"full-width\"\n (backdropClick)=\"onBackdropClick($event)\"\n>\n\n <!-- Left Side Nav -->\n <mat-sidenav position=\"start\"\n mode=\"over\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"leftSideAutoFocus\"\n [opened]=\"leftSideContentOpen$ | async\"\n (closed)=\"closeLeftSideContent()\">\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n </div>\n </mat-sidenav>\n\n <!-- Main Content -->\n <mat-sidenav-content>\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n </div>\n </mat-sidenav-content>\n\n <!-- Right Side Detail -->\n <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n position=\"end\"\n [fixedInViewport]=\"true\"\n [autoFocus]=\"rightSideAutoFocus\"\n [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n <div class=\"layout-col full\">\n <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n </div>\n </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n <div class=\"layout-col flex\">\n <p class=\"noselect\">No Left Side Content Defined!</p>\n </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n <div class=\"layout-col full\">\n\n <!-- Header -->\n <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n <!-- Center -->\n <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n <!-- Footer -->\n <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n <elder-toolbar [color]=\"color\" class=\"flex-none\" style=\"max-width: 100%; min-width: 100%\" >\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\"\n [color]=\"menuColor$ | async\"\n class=\"flex-none\" style=\"width: auto\"\n >\n <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n <!-- Default Footer is empty -->\n</ng-template>\n", styles: ["mat-sidenav{margin:0;height:100%;overflow:hidden}mat-sidenav-container{margin:0;width:100%;height:100%;overflow:hidden}\n"] }]
182
181
  }], ctorParameters: function () { return [{ type: i1.ElderShellService }, { type: i2.ElderRouteOutletDrawerService }, { type: i0.ChangeDetectorRef }, { type: i3.ElderThemeService }]; }, propDecorators: { sideNavToggleEnabled: [{
183
182
  type: Input
184
183
  }], leftSideAutoFocus: [{
@@ -204,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
204
203
  }], menuIconColor: [{
205
204
  type: Input
206
205
  }] } });
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell/elder-shell.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell/elder-shell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  Directive,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {ElderShellService} from '../elder-shell.service';\nimport {MatSidenav} from '@angular/material/sidenav';\nimport {ElderRouteOutletDrawerService} from '../drawers/elder-route-outlet-drawer.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {takeUntil, tap} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core';\nimport {ElderThemeService} from '../../theme/elder-theme.service';\nimport {ThemeSpec} from '../../theme/theme-spec';\n\n\n@Directive({selector: '[elderShellSideLeft], [ebsShellSideLeft]'})\nexport class ElderShellSideLeftDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Directive({selector: '[elderShellSideRight], [ebsShellSideRight]'})\nexport class ElderShellSideRightDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Directive({selector: '[elderShellCenter], [ebsShellCenter]'})\nexport class ElderShellCenterDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Component({\n  selector: 'elder-shell, ebs-shell', // ebs-* prefix is deprecated!\n  templateUrl: './elder-shell.component.html',\n  styleUrls: ['./elder-shell.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderShellComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderShellComponent');\n\n  /** Controls if the SideNav toggle should be displayed. Default: true */\n  @Input()\n  public sideNavToggleEnabled = true;\n\n  @Input()\n  public leftSideAutoFocus = false;\n\n  @Input()\n  public rightSideAutoFocus = false;\n\n  @ContentChild(ElderShellSideLeftDirective, { read: TemplateRef, static: true })\n  public sideContentLeft: TemplateRef<any>;\n\n  @ContentChild(ElderShellSideRightDirective, { read: TemplateRef, static: true })\n  public sideContentRight: TemplateRef<any>;\n\n  @ContentChild(ElderShellCenterDirective, { read: TemplateRef, static: true })\n  public centerContent: TemplateRef<any>;\n\n  @ViewChild('rightSideDetail', { static: true })\n  public rightSideDrawer: MatSidenav;\n\n  public rightSideOutletName = 'side';\n\n  public leftSideContentOpen$: Observable<boolean>;\n\n\n  public readonly headerTemplate$: Observable<TemplateRef<any>>;\n  public readonly centerTemplate$: Observable<TemplateRef<any>>;\n  public readonly footerTemplate$: Observable<TemplateRef<any>>;\n\n  private readonly destroy$ = new Subject<void>();\n\n  @Input()\n  public color: ThemePalette = 'primary';\n\n  public readonly menuColor$ = new BehaviorSubject<ThemePalette>('accent');\n  public readonly menuIconColor$ = new BehaviorSubject<ThemePalette>(undefined);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private shellService: ElderShellService,\n    private outletDrawerService: ElderRouteOutletDrawerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    private themeService: ElderThemeService\n  ) {\n    this.headerTemplate$ = shellService.activeSlotTemplate('header').pipe(\n      tap(() => this.checkSoon())\n    );\n    this.centerTemplate$ = shellService.activeSlotTemplate('center').pipe(\n      tap(() => this.checkSoon())\n    );\n    this.footerTemplate$ = shellService.activeSlotTemplate('footer').pipe(\n      tap(() => this.checkSoon())\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.outletDrawerService.registerOutletDrawer(\n      this.rightSideOutletName,\n      this.rightSideDrawer\n    );\n\n    this.outletDrawerService\n      .drawerVisibilityChange\n      .pipe(\n        takeUntil(this.destroy$)\n      )\n      .subscribe(drawer =>  this.changeDetectorRef.markForCheck());\n\n    this.leftSideContentOpen$ =  this.shellService.navigationOpenChange;\n\n    this.themeService.activeTheme$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(theme => this.adjustColorsForTheme(theme));\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set menuColor(c: ThemePalette) {\n    this.menuColor$.next(c);\n  }\n\n  public get menuColor(): ThemePalette {\n    return this.menuColor$.getValue();\n  }\n\n  @Input()\n  public set menuIconColor(c: ThemePalette) {\n    this.menuIconColor$.next(c);\n  }\n\n  public get menuIconColor(): ThemePalette {\n    return this.menuIconColor$.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public closeLeftSideContent() {\n    this.shellService.closeSideNav();\n  }\n\n  public toggleSideNav(): void {\n    this.shellService.toggleSidenav();\n  }\n\n  public onBackdropClick(event: any): void {\n    if (this.shellService.isSideContentActive()) {\n      this.shellService.closeSideContent();\n    }\n  }\n\n  public onEscapeRightSide(event: Event): void {\n    const target = event.target as HTMLElement;\n    if (target && this.isContained(target, 'elder-right-side-detail')) {\n      // Ensure we only react to Esc Events targeted at our side nav!\n      if (this.shellService.isSideContentActive()) {\n        this.shellService.closeSideContent();\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private adjustColorsForTheme(theme: ThemeSpec): void {\n    this.menuColor = theme?.dark ? undefined : 'accent';\n    this.menuIconColor = theme?.dark ? 'primary' : undefined;\n  }\n\n  private isContained(child: HTMLElement, id: string): boolean {\n\n    if (child.id === id) {\n      return true;\n    }\n    const maxDepth = 1;\n    let depth = 0;\n    let node = child.parentNode as HTMLElement;\n    while (node) {\n      if (node.id === id) {\n        return true;\n      }\n      node = node.parentNode as HTMLElement;\n      if (maxDepth >= ++depth) { break; }\n    }\n    return false;\n  }\n\n  private checkSoon(): void {\n    setTimeout(() => {\n      this.changeDetectorRef.markForCheck();\n    }, 5);\n  }\n}\n","\n<mat-sidenav-container\n  elderThemeApplier\n  style=\"height:100%; width: 100%\"\n  (backdropClick)=\"onBackdropClick($event)\"\n>\n\n  <!-- Left Side Nav -->\n  <mat-sidenav position=\"start\"\n               mode=\"over\"\n               [fixedInViewport]=\"true\"\n               [autoFocus]=\"leftSideAutoFocus\"\n               [opened]=\"leftSideContentOpen$ | async\"\n               (closed)=\"closeLeftSideContent()\">\n    <div fxFill fxLayout=\"column\">\n      <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n    </div>\n  </mat-sidenav>\n\n  <!-- Main Content -->\n  <mat-sidenav-content>\n    <div fxLayout=\"column\" fxFill>\n      <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n    </div>\n  </mat-sidenav-content>\n\n  <!-- Right Side Detail -->\n  <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n               position=\"end\"\n               [fixedInViewport]=\"true\"\n               [autoFocus]=\"rightSideAutoFocus\"\n               [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n    <div fxFill fxLayout=\"column\">\n      <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n    </div>\n  </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n  <div fxLayout=\"column\" fxFlex>\n    <p class=\"noselect\">No Left Side Content Defined!</p>\n  </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n  <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n  <div fxLayout=\"column\" fxFill>\n\n    <!-- Header -->\n    <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n    <!-- Center -->\n    <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n    <!-- Footer -->\n    <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n  </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n  <elder-toolbar [color]=\"color\">\n    <!-- Toolbar Prefix: Sidenav Toggle -->\n    <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n                 fxLayout=\"row\" fxLayoutAlign=\"center center\"\n                 [color]=\"menuColor$ | async\">\n      <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n        <mat-icon>menu</mat-icon>\n      </button>\n    </mat-toolbar>\n  </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n  <!-- Primary Router Outlet -->\n  <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n  <!-- Default Footer is empty -->\n</ng-template>\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell/elder-shell.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell/elder-shell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  Directive,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport {ElderShellService} from '../elder-shell.service';\nimport {MatSidenav} from '@angular/material/sidenav';\nimport {ElderRouteOutletDrawerService} from '../drawers/elder-route-outlet-drawer.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {takeUntil, tap} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core';\nimport {ElderThemeService} from '../../theme/elder-theme.service';\nimport {ThemeSpec} from '../../theme/theme-spec';\n\n\n@Directive({selector: '[elderShellSideLeft], [ebsShellSideLeft]'})\nexport class ElderShellSideLeftDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Directive({selector: '[elderShellSideRight], [ebsShellSideRight]'})\nexport class ElderShellSideRightDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Directive({selector: '[elderShellCenter], [ebsShellCenter]'})\nexport class ElderShellCenterDirective {\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef) { }\n}\n\n@Component({\n  selector: 'elder-shell, ebs-shell', // ebs-* prefix is deprecated!\n  templateUrl: './elder-shell.component.html',\n  styleUrls: ['./elder-shell.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderShellComponent implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderShellComponent');\n\n  /** Controls if the SideNav toggle should be displayed. Default: true */\n  @Input()\n  public sideNavToggleEnabled = true;\n\n  @Input()\n  public leftSideAutoFocus = false;\n\n  @Input()\n  public rightSideAutoFocus = false;\n\n  @ContentChild(ElderShellSideLeftDirective, { read: TemplateRef, static: true })\n  public sideContentLeft: TemplateRef<any>;\n\n  @ContentChild(ElderShellSideRightDirective, { read: TemplateRef, static: true })\n  public sideContentRight: TemplateRef<any>;\n\n  @ContentChild(ElderShellCenterDirective, { read: TemplateRef, static: true })\n  public centerContent: TemplateRef<any>;\n\n  @ViewChild('rightSideDetail', { static: true })\n  public rightSideDrawer: MatSidenav;\n\n  public rightSideOutletName = 'side';\n\n  public leftSideContentOpen$: Observable<boolean>;\n\n\n  public readonly headerTemplate$: Observable<TemplateRef<any>>;\n  public readonly centerTemplate$: Observable<TemplateRef<any>>;\n  public readonly footerTemplate$: Observable<TemplateRef<any>>;\n\n  private readonly destroy$ = new Subject<void>();\n\n  @Input()\n  public color: ThemePalette = 'primary';\n\n  public readonly menuColor$ = new BehaviorSubject<ThemePalette>('accent');\n  public readonly menuIconColor$ = new BehaviorSubject<ThemePalette>(undefined);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private shellService: ElderShellService,\n    private outletDrawerService: ElderRouteOutletDrawerService,\n    private changeDetectorRef: ChangeDetectorRef,\n    private themeService: ElderThemeService\n  ) {\n    this.headerTemplate$ = shellService.activeSlotTemplate('header').pipe(\n      tap(() => this.checkSoon())\n    );\n    this.centerTemplate$ = shellService.activeSlotTemplate('center').pipe(\n      tap(() => this.checkSoon())\n    );\n    this.footerTemplate$ = shellService.activeSlotTemplate('footer').pipe(\n      tap(() => this.checkSoon())\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n    this.outletDrawerService.registerOutletDrawer(\n      this.rightSideOutletName,\n      this.rightSideDrawer\n    );\n\n    this.outletDrawerService\n      .drawerVisibilityChange\n      .pipe(\n        takeUntil(this.destroy$)\n      )\n      .subscribe(drawer =>  this.changeDetectorRef.markForCheck());\n\n    this.leftSideContentOpen$ =  this.shellService.navigationOpenChange;\n\n    this.themeService.activeTheme$.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(theme => this.adjustColorsForTheme(theme));\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set menuColor(c: ThemePalette) {\n    this.menuColor$.next(c);\n  }\n\n  public get menuColor(): ThemePalette {\n    return this.menuColor$.getValue();\n  }\n\n  @Input()\n  public set menuIconColor(c: ThemePalette) {\n    this.menuIconColor$.next(c);\n  }\n\n  public get menuIconColor(): ThemePalette {\n    return this.menuIconColor$.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public closeLeftSideContent() {\n    this.shellService.closeSideNav();\n  }\n\n  public toggleSideNav(): void {\n    this.shellService.toggleSidenav();\n  }\n\n  public onBackdropClick(event: any): void {\n    if (this.shellService.isSideContentActive()) {\n      this.shellService.closeSideContent();\n    }\n  }\n\n  public onEscapeRightSide(event: Event): void {\n    const target = event.target as HTMLElement;\n    if (target && this.isContained(target, 'elder-right-side-detail')) {\n      // Ensure we only react to Esc Events targeted at our side nav!\n      if (this.shellService.isSideContentActive()) {\n        this.shellService.closeSideContent();\n      }\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private adjustColorsForTheme(theme: ThemeSpec): void {\n    this.menuColor = theme?.dark ? undefined : 'accent';\n    this.menuIconColor = theme?.dark ? 'primary' : undefined;\n  }\n\n  private isContained(child: HTMLElement, id: string): boolean {\n\n    if (child.id === id) {\n      return true;\n    }\n    const maxDepth = 1;\n    let depth = 0;\n    let node = child.parentNode as HTMLElement;\n    while (node) {\n      if (node.id === id) {\n        return true;\n      }\n      node = node.parentNode as HTMLElement;\n      if (maxDepth >= ++depth) { break; }\n    }\n    return false;\n  }\n\n  private checkSoon(): void {\n    setTimeout(() => {\n      this.changeDetectorRef.markForCheck();\n    }, 5);\n  }\n}\n","<mat-sidenav-container\n  elderThemeApplier\n  class=\"full-width\"\n  (backdropClick)=\"onBackdropClick($event)\"\n>\n\n  <!-- Left Side Nav -->\n  <mat-sidenav position=\"start\"\n               mode=\"over\"\n               [fixedInViewport]=\"true\"\n               [autoFocus]=\"leftSideAutoFocus\"\n               [opened]=\"leftSideContentOpen$ | async\"\n               (closed)=\"closeLeftSideContent()\">\n    <div class=\"layout-col full\">\n      <ng-container *ngTemplateOutlet=\"sideContentLeft || fallbackSideContentLeft;\"></ng-container>\n    </div>\n  </mat-sidenav>\n\n  <!-- Main Content -->\n  <mat-sidenav-content>\n    <div class=\"layout-col full\">\n      <ng-container *ngTemplateOutlet=\"centerContent || fallbackCenterContent;\"></ng-container>\n    </div>\n  </mat-sidenav-content>\n\n  <!-- Right Side Detail -->\n  <mat-sidenav mode=\"over\" #rightSideDetail id=\"elder-right-side-detail\"\n               position=\"end\"\n               [fixedInViewport]=\"true\"\n               [autoFocus]=\"rightSideAutoFocus\"\n               [disableClose]=\"true\" (keydown.escape)=\"onEscapeRightSide($event)\">\n    <div class=\"layout-col full\">\n      <ng-container *ngTemplateOutlet=\"sideContentRight || fallbackSideContentRight;\"></ng-container>\n    </div>\n  </mat-sidenav>\n\n</mat-sidenav-container>\n\n<ng-template #fallbackSideContentLeft>\n  <div class=\"layout-col flex\">\n    <p class=\"noselect\">No Left Side Content Defined!</p>\n  </div>\n</ng-template>\n\n<ng-template #fallbackSideContentRight>\n  <router-outlet name=\"side\" class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #fallbackCenterContent>\n  <div class=\"layout-col full\">\n\n    <!-- Header -->\n    <ng-container *ngTemplateOutlet=\"(headerTemplate$ | async) || defaultHeaderTemplate\"></ng-container>\n\n    <!-- Center -->\n    <ng-container *ngTemplateOutlet=\"(centerTemplate$ | async) || defaultCenterTemplate\"></ng-container>\n\n    <!-- Footer -->\n    <ng-container *ngTemplateOutlet=\"(footerTemplate$ | async) || defaultFooterTemplate\"></ng-container>\n\n  </div>\n</ng-template>\n\n\n<ng-template #defaultHeaderTemplate>\n  <elder-toolbar [color]=\"color\" class=\"flex-none\" style=\"max-width: 100%; min-width: 100%\" >\n    <!-- Toolbar Prefix: Sidenav Toggle -->\n    <mat-toolbar *ngIf=\"sideNavToggleEnabled\"\n                 [color]=\"menuColor$ | async\"\n                 class=\"flex-none\" style=\"width: auto\"\n    >\n      <button mat-icon-button [color]=\"menuIconColor$ | async\" type=\"button\" (click)=\"toggleSideNav()\">\n        <mat-icon>menu</mat-icon>\n      </button>\n    </mat-toolbar>\n  </elder-toolbar>\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n  <!-- Primary Router Outlet -->\n  <router-outlet class=\"router-flex\"></router-outlet>\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n  <!-- Default Footer is empty -->\n</ng-template>\n"]}
@@ -124,9 +124,9 @@ export class ElderShellNavigationToggleComponent {
124
124
  return parts.join('/');
125
125
  }
126
126
  }
127
- ElderShellNavigationToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellNavigationToggleComponent, deps: [{ token: i1.Router }, { token: i2.ElderShellService }], target: i0.ɵɵFactoryTarget.Component });
128
- ElderShellNavigationToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.4", type: ElderShellNavigationToggleComponent, selector: "elder-shell-nav-toggle", inputs: { roots: "roots", hide: "hide" }, ngImport: i0, template: "\n<button mat-icon-button type=\"button\" (click)=\"onClick()\" *ngIf=\"showComponent()\">\n <mat-icon>{{icon | async}}</mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
129
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderShellNavigationToggleComponent, decorators: [{
127
+ ElderShellNavigationToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellNavigationToggleComponent, deps: [{ token: i1.Router }, { token: i2.ElderShellService }], target: i0.ɵɵFactoryTarget.Component });
128
+ ElderShellNavigationToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderShellNavigationToggleComponent, selector: "elder-shell-nav-toggle", inputs: { roots: "roots", hide: "hide" }, ngImport: i0, template: "\n<button mat-icon-button type=\"button\" (click)=\"onClick()\" *ngIf=\"showComponent()\">\n <mat-icon>{{icon | async}}</mat-icon>\n</button>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderShellNavigationToggleComponent, decorators: [{
130
130
  type: Component,
131
131
  args: [{ selector: 'elder-shell-nav-toggle', template: "\n<button mat-icon-button type=\"button\" (click)=\"onClick()\" *ngIf=\"showComponent()\">\n <mat-icon>{{icon | async}}</mat-icon>\n</button>\n" }]
132
132
  }], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ElderShellService }]; }, propDecorators: { roots: [{
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
134
134
  }], hide: [{
135
135
  type: Input
136
136
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell-navigation-toggle.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit} from '@angular/core';\nimport {NavigationEnd, Router} from '@angular/router';\nimport {ElderShellService} from '../elder-shell.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subscription} from 'rxjs';\n\n@Component({\n    selector: 'elder-shell-nav-toggle',\n    templateUrl: './elder-shell-navigation-toggle.component.html',\n    styleUrls: ['./elder-shell-navigation-toggle.component.scss']\n})\nexport class ElderShellNavigationToggleComponent implements OnInit, OnDestroy {\n\n    /***************************************************************************\n     *                                                                         *\n     * Fields                                                                  *\n     *                                                                         *\n     **************************************************************************/\n\n    private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n    private _icon = new BehaviorSubject<string>('menu');\n    private sub: Subscription;\n    private _currentUrl: string;\n\n    @Input()\n    public roots: string[] = [];\n\n    @Input()\n    public hide: string[] = [];\n\n    /***************************************************************************\n     *                                                                         *\n     * Constructor                                                             *\n     *                                                                         *\n     **************************************************************************/\n\n    constructor(\n        private router: Router,\n        private sideContentService: ElderShellService,\n    ) { }\n\n    /***************************************************************************\n     *                                                                         *\n     * Life Cycle                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public ngOnInit(): void {\n\n        this.sub = this.router.events.subscribe((event) => {\n            if (event instanceof NavigationEnd) {\n                const navEnd = event as NavigationEnd;\n                this._currentUrl = navEnd.url;\n                this.updateIcon();\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.sub.unsubscribe();\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Public API                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public onClick(): void {\n        if (this.showNavigateBack) {\n            this.goBack(this._currentUrl);\n        } else {\n            this.toggleSideContent();\n        }\n    }\n\n    public get icon(): Observable<string> {\n        return this._icon;\n    }\n\n    public showComponent(): boolean {\n        if (this._currentUrl && this.hide && this.hide.length > 0) {\n            return !this.isPartOfHiddenRoute(this._currentUrl);\n        }\n        return true;\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Private methods                                                         *\n     *                                                                         *\n     **************************************************************************/\n\n    private updateIcon() {\n        const icon = this.showNavigateBack ? 'arrow_back' : 'menu';\n        this.logger.trace('updating icon to ' + icon);\n        this._icon.next(icon);\n    }\n\n\n    private get showNavigateBack(): boolean {\n        if (this._currentUrl && this.roots && this.roots.length > 0) {\n            return !this.isRootRoute(this._currentUrl);\n        }\n        return false;\n    }\n\n\n    private toggleSideContent() {\n        this.sideContentService.toggleSidenav();\n    }\n\n    private goBack(url: string) {\n        const rootUrl = this.findRoot(url);\n        this.router.navigate([rootUrl]);\n    }\n\n    private isRootRoute(url: string): boolean {\n        return !!this.roots.find(r => r === url);\n    }\n\n    private isPartOfHiddenRoute(url: string): boolean {\n        return !!this.hide.find(r => url.indexOf(r) >= 0);\n    }\n\n    /**\n     * Find the parent root url of a given url:\n     *\n     * /app/my/sub/route\n     *\n     * roots: ['/app/my', '/app/foo']\n     *\n     * -> /app/my\n     *\n     */\n    private findRoot(url: string): string {\n        if (url && url.length > 0) {\n            if (this.isRootRoute(url)) { return url; }\n            const parent = this.parent(url);\n            return this.findRoot(parent);\n        } else {\n            return '/';\n        }\n    }\n\n    private parent(url: string): string {\n        const parts = url.split('/');\n        // Remove last part\n        parts.splice(parts.length - 1, 1);\n        return parts.join('/');\n    }\n}\n","\n<button mat-icon-button type=\"button\" (click)=\"onClick()\" *ngIf=\"showComponent()\">\n  <mat-icon>{{icon | async}}</mat-icon>\n</button>\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell-navigation-toggle.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit} from '@angular/core';\nimport {NavigationEnd, Router} from '@angular/router';\nimport {ElderShellService} from '../elder-shell.service';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subscription} from 'rxjs';\n\n@Component({\n    selector: 'elder-shell-nav-toggle',\n    templateUrl: './elder-shell-navigation-toggle.component.html',\n    styleUrls: ['./elder-shell-navigation-toggle.component.scss']\n})\nexport class ElderShellNavigationToggleComponent implements OnInit, OnDestroy {\n\n    /***************************************************************************\n     *                                                                         *\n     * Fields                                                                  *\n     *                                                                         *\n     **************************************************************************/\n\n    private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n    private _icon = new BehaviorSubject<string>('menu');\n    private sub: Subscription;\n    private _currentUrl: string;\n\n    @Input()\n    public roots: string[] = [];\n\n    @Input()\n    public hide: string[] = [];\n\n    /***************************************************************************\n     *                                                                         *\n     * Constructor                                                             *\n     *                                                                         *\n     **************************************************************************/\n\n    constructor(\n        private router: Router,\n        private sideContentService: ElderShellService,\n    ) { }\n\n    /***************************************************************************\n     *                                                                         *\n     * Life Cycle                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public ngOnInit(): void {\n\n        this.sub = this.router.events.subscribe((event) => {\n            if (event instanceof NavigationEnd) {\n                const navEnd = event as NavigationEnd;\n                this._currentUrl = navEnd.url;\n                this.updateIcon();\n            }\n        });\n    }\n\n    public ngOnDestroy(): void {\n        this.sub.unsubscribe();\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Public API                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public onClick(): void {\n        if (this.showNavigateBack) {\n            this.goBack(this._currentUrl);\n        } else {\n            this.toggleSideContent();\n        }\n    }\n\n    public get icon(): Observable<string> {\n        return this._icon;\n    }\n\n    public showComponent(): boolean {\n        if (this._currentUrl && this.hide && this.hide.length > 0) {\n            return !this.isPartOfHiddenRoute(this._currentUrl);\n        }\n        return true;\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Private methods                                                         *\n     *                                                                         *\n     **************************************************************************/\n\n    private updateIcon() {\n        const icon = this.showNavigateBack ? 'arrow_back' : 'menu';\n        this.logger.trace('updating icon to ' + icon);\n        this._icon.next(icon);\n    }\n\n\n    private get showNavigateBack(): boolean {\n        if (this._currentUrl && this.roots && this.roots.length > 0) {\n            return !this.isRootRoute(this._currentUrl);\n        }\n        return false;\n    }\n\n\n    private toggleSideContent() {\n        this.sideContentService.toggleSidenav();\n    }\n\n    private goBack(url: string) {\n        const rootUrl = this.findRoot(url);\n        this.router.navigate([rootUrl]);\n    }\n\n    private isRootRoute(url: string): boolean {\n        return !!this.roots.find(r => r === url);\n    }\n\n    private isPartOfHiddenRoute(url: string): boolean {\n        return !!this.hide.find(r => url.indexOf(r) >= 0);\n    }\n\n    /**\n     * Find the parent root url of a given url:\n     *\n     * /app/my/sub/route\n     *\n     * roots: ['/app/my', '/app/foo']\n     *\n     * -> /app/my\n     *\n     */\n    private findRoot(url: string): string {\n        if (url && url.length > 0) {\n            if (this.isRootRoute(url)) { return url; }\n            const parent = this.parent(url);\n            return this.findRoot(parent);\n        } else {\n            return '/';\n        }\n    }\n\n    private parent(url: string): string {\n        const parts = url.split('/');\n        // Remove last part\n        parts.splice(parts.length - 1, 1);\n        return parts.join('/');\n    }\n}\n","\n<button mat-icon-button type=\"button\" (click)=\"onClick()\" *ngIf=\"showComponent()\">\n  <mat-icon>{{icon | async}}</mat-icon>\n</button>\n"]}
@@ -11,9 +11,9 @@ export class ElderTabDirective {
11
11
  this.tab = tab;
12
12
  }
13
13
  }
14
- ElderTabDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderTabDirective, deps: [{ token: i1.MatTab }], target: i0.ɵɵFactoryTarget.Directive });
15
- ElderTabDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: ElderTabDirective, selector: "[elderTab]", inputs: { id: ["elderTab", "id"] }, ngImport: i0 });
16
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderTabDirective, decorators: [{
14
+ ElderTabDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderTabDirective, deps: [{ token: i1.MatTab }], target: i0.ɵɵFactoryTarget.Directive });
15
+ ElderTabDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: ElderTabDirective, selector: "[elderTab]", inputs: { id: ["elderTab", "id"] }, ngImport: i0 });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderTabDirective, decorators: [{
17
17
  type: Directive,
18
18
  args: [{
19
19
  selector: '[elderTab]'
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
22
22
  type: Input,
23
23
  args: ['elderTab']
24
24
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItdGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvdGFicy9lbGRlci10YWIvZWxkZXItdGFiLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7O0FBTS9DLE1BQU0sT0FBTyxpQkFBaUI7SUFXNUI7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ1MsR0FBVztRQUFYLFFBQUcsR0FBSCxHQUFHLENBQVE7SUFDaEIsQ0FBQzs7OEdBbkJNLGlCQUFpQjtrR0FBakIsaUJBQWlCOzJGQUFqQixpQkFBaUI7a0JBSDdCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7aUJBQ3ZCOzZGQVVRLEVBQUU7c0JBRFIsS0FBSzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWF0VGFifSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJzJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2VsZGVyVGFiXSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJUYWJEaXJlY3RpdmUge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIEBJbnB1dCgnZWxkZXJUYWInKVxuICBwdWJsaWMgaWQ6IHN0cmluZztcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgdGFiOiBNYXRUYWJcbiAgKSB7IH1cblxuXG5cblxufVxuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItdGFiLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbXBvbmVudHMvdGFicy9lbGRlci10YWIvZWxkZXItdGFiLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7O0FBTS9DLE1BQU0sT0FBTyxpQkFBaUI7SUFXNUI7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ1MsR0FBVztRQUFYLFFBQUcsR0FBSCxHQUFHLENBQVE7SUFDaEIsQ0FBQzs7K0dBbkJNLGlCQUFpQjttR0FBakIsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBSDdCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7aUJBQ3ZCOzZGQVVRLEVBQUU7c0JBRFIsS0FBSzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWF0VGFifSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJzJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2VsZGVyVGFiXSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJUYWJEaXJlY3RpdmUge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIEBJbnB1dCgnZWxkZXJUYWInKVxuICBwdWJsaWMgaWQ6IHN0cmluZztcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgdGFiOiBNYXRUYWJcbiAgKSB7IH1cblxuXG5cblxufVxuIl19
@@ -235,9 +235,9 @@ export class ElderTabGroupRoutingDirective {
235
235
  * Prefix used to indicate and index-based tab marker.
236
236
  */
237
237
  ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX = 'idx:';
238
- ElderTabGroupRoutingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderTabGroupRoutingDirective, deps: [{ token: i1.ElderUrlFragmentParamsService }, { token: i2.MatTabGroup }], target: i0.ɵɵFactoryTarget.Directive });
239
- ElderTabGroupRoutingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.4", type: ElderTabGroupRoutingDirective, selector: "[elderTabGroupRouting]", inputs: { tabGroupQueryParamKey: ["elderTabGroupRouting", "tabGroupQueryParamKey"] }, queries: [{ propertyName: "tabs", predicate: MatTab }, { propertyName: "elderTabs", predicate: ElderTabDirective }], exportAs: ["elderTabGroupRouting"], ngImport: i0 });
240
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: ElderTabGroupRoutingDirective, decorators: [{
238
+ ElderTabGroupRoutingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderTabGroupRoutingDirective, deps: [{ token: i1.ElderUrlFragmentParamsService }, { token: i2.MatTabGroup }], target: i0.ɵɵFactoryTarget.Directive });
239
+ ElderTabGroupRoutingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.10", type: ElderTabGroupRoutingDirective, selector: "[elderTabGroupRouting]", inputs: { tabGroupQueryParamKey: ["elderTabGroupRouting", "tabGroupQueryParamKey"] }, queries: [{ propertyName: "tabs", predicate: MatTab }, { propertyName: "elderTabs", predicate: ElderTabDirective }], exportAs: ["elderTabGroupRouting"], ngImport: i0 });
240
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderTabGroupRoutingDirective, decorators: [{
241
241
  type: Directive,
242
242
  args: [{
243
243
  selector: '[elderTabGroupRouting]',
@@ -253,4 +253,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImpor
253
253
  type: ContentChildren,
254
254
  args: [ElderTabDirective]
255
255
  }] } });
256
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-tab-group-routing.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ContentChildren, Directive, Input, OnDestroy, QueryList} from '@angular/core';\nimport {first, takeUntil} from 'rxjs/operators';\nimport {Subject} from 'rxjs';\nimport {MatTab, MatTabChangeEvent, MatTabGroup} from '@angular/material/tabs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTabDirective} from '../elder-tab/elder-tab.directive';\nimport {ElderUrlFragmentParamsService} from '../../../common/url/elder-url-fragment-params.service';\nimport {UrlQueryParams} from '../../../common/url/url-query-params';\nimport {QueryListBinding} from '../../../common/utils/query-list-binding';\n\n/**\n * Adds out-of-the-box url-fragment based tab navigation\n * within the mat-tab-group it is placed upon.\n *\n * Add elderTab directive to each tab of the group to\n * support id-based tab navigation.\n */\n@Directive({\n  selector: '[elderTabGroupRouting]',\n  exportAs: 'elderTabGroupRouting'\n})\nexport class ElderTabGroupRoutingDirective implements AfterViewInit, OnDestroy {\n\n  /**\n   * Prefix used to indicate and index-based tab marker.\n   */\n  private static readonly TAB_INDEX_PREFIX = 'idx:';\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _log = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _destroy$ = new Subject<void>();\n\n  /**\n   * Stores the last tab marker (either ID or index)\n   * which could not be activated. This is used to retry\n   * activation once changes on tab structure occur.\n   */\n  private lastFailedTabMarker: string;\n\n  /**\n   * String to use as query param key.\n   */\n  @Input('elderTabGroupRouting')\n  public tabGroupQueryParamKey: string;\n\n  /**\n   * The child tabs within this navigation context.\n   */\n  @ContentChildren(MatTab)\n  public tabs: QueryList<MatTab>;\n\n  /**\n   * The child tabs within this navigation context\n   * marked with the elderTabs directive.\n   */\n  @ContentChildren(ElderTabDirective)\n  public elderTabs: QueryList<ElderTabDirective>;\n\n  /**\n   * The tab marked with elderTab directive which\n   * is currently active. May be null if\n   * elderTab markers are not used.\n   */\n  public activeElderTab: ElderTabDirective;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private fragmentParamsService: ElderUrlFragmentParamsService,\n    private tabGroup: MatTabGroup\n  ) {\n    this.tabGroup.selectedTabChange\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(event => this.handleTabChangeEvent(event));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n    this.fragmentParamsService.params$\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(params => this.handleFragmentParamsChange(params));\n\n    QueryListBinding\n      .of(this.tabs)\n      .updated(() => this.retryLastFailedActivation())\n      .bindUntil(this._destroy$);\n\n    QueryListBinding\n      .of(this.elderTabs)\n      .updated(() => this.retryLastFailedActivation())\n      .bindUntil(this._destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.removeFragmentParam();\n\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get activeTabId(): string {\n    return this.activeElderTab?.id;\n  }\n\n  public get activeTabIndex(): number {\n    return this.tabGroup.selectedIndex;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleFragmentParamsChange(params: UrlQueryParams): void {\n    const tabMarker = this.getTabMarker(params);\n\n    if (tabMarker) {\n      this.activateTabByMarker(tabMarker);\n    }\n  }\n\n  private activateTabByMarker(tabMarker: string): void {\n\n    let success: boolean;\n    if (this.isIndexMarker(tabMarker)) {\n      const index = this.parseIndexMarker(tabMarker);\n      success = this.activateTabByIndex(index);\n    } else {\n      // if no index is given we assume the marker is the id of the tab.\n      success = this.activateTabById(tabMarker);\n    }\n\n    // remember tab marker in case of failure to retry later.\n    this.lastFailedTabMarker = success ? null : tabMarker;\n  }\n\n  private activateTabByIndex(indexToActivate: number): boolean {\n\n    if (indexToActivate !== this.activeTabIndex) {\n      this._log.trace('Activating tab by index ', indexToActivate);\n\n      // First try to identify corresponding elder tab, so that we may work with its ID instead of index.\n      const elderTab = this.findElderTabByIndex(indexToActivate);\n\n      if (elderTab) {\n        return this.activateElderTab(elderTab);\n      } else {\n        // If no elder tab found, clear active elder tab to ensure consistent state.\n        this.activeElderTab = null;\n        return this.setSelectedIndex(indexToActivate);\n      }\n    } else {\n      return true;\n    }\n\n  }\n\n  private activateTabById(tabId: string): boolean {\n    const elderTab = this.findElderTabById(tabId);\n\n    if (elderTab) {\n      return this.activateElderTab(elderTab);\n    } else {\n      // If no elder tab found, clear active elder tab to ensure consistent state.\n      this.activeElderTab = null;\n      this._log.warn('Could not find tab with ID \"' + tabId + '\". Ensure elderTab directive is added to corresponding tab.');\n      return false;\n    }\n  }\n\n  private activateElderTab(elderTab: ElderTabDirective): boolean {\n\n    if (this.activeElderTab !== elderTab) {\n      this.activeElderTab = elderTab;\n      const indexToActivate = this.getIndexOfTab(elderTab.tab);\n      return this.setSelectedIndex(indexToActivate);\n    } else {\n      return true;\n    }\n\n  }\n\n  private handleTabChangeEvent(tabChangeEvent: MatTabChangeEvent): void {\n    this._log.trace('Handling tabChangeEvent: ', tabChangeEvent);\n    this.lastFailedTabMarker = null;\n    this.activeElderTab = this.findElderTabByTab(tabChangeEvent.tab);\n    this.updateFragmentParam();\n  }\n\n  private retryLastFailedActivation(): void {\n    if (this.lastFailedTabMarker) {\n      this._log.trace('Retrying to activate tab by marker:', this.lastFailedTabMarker);\n      this.activateTabByMarker(this.lastFailedTabMarker);\n    }\n  }\n\n  private setSelectedIndex(index: number): boolean {\n    if (index !== this.activeTabIndex) {\n\n      if (this.isValidIndex(index)) {\n        this._log.trace('Activating tab by index ', index);\n        this.tabGroup.selectedIndex = index;\n        return true;\n      } else {\n        this._log.warn('Could not find tab with index \"' + index + '\".');\n        return false;\n      }\n    } else {\n      return true;\n    }\n  }\n\n  private isValidIndex(index: number): boolean {\n    return this.tabs.length > index;\n  }\n\n  private findElderTabById(tabId: string): ElderTabDirective | null {\n    return this.elderTabs.find(t => t.id === tabId);\n  }\n\n  private findElderTabByIndex(tabIndex: number): ElderTabDirective | null {\n    const tab = this.findTabByIndex(tabIndex);\n    if (tab) {\n      return this.findElderTabByTab(tab);\n    } else {\n      return null;\n    }\n  }\n\n  private findElderTabByTab(tab: MatTab): ElderTabDirective | null {\n    return this.elderTabs.find(elderTab => elderTab.tab === tab);\n  }\n\n  private findTabByIndex(tabIndex: number): MatTab | null {\n    if (this.tabs.length > tabIndex) {\n      return this.tabs.get(tabIndex);\n    } else {\n      return null;\n    }\n  }\n\n  private getIndexOfTab(tab: MatTab): number | null {\n    return this.tabs.toArray().indexOf(tab);\n  }\n\n  private updateFragmentParam(): void {\n\n    const currentTabMarker = this.getTabMarker(this.fragmentParamsService.params);\n\n    // If possible, use tab ID as marker. If not, use tab index as fallback.\n    const newTabMarker = this.activeTabId\n      ? this.activeTabId\n      : this.serializeIndexMarker(this.activeTabIndex);\n\n    if (newTabMarker !== currentTabMarker) {\n      this.setFragmentParam(newTabMarker);\n    }\n  }\n\n  private setFragmentParam(value: string): void {\n\n    const params = this.fragmentParamsService.params;\n    params.set(this.tabGroupQueryParamKey, value);\n\n    this.fragmentParamsService.setParams(params);\n  }\n\n  private removeFragmentParam(): void {\n\n    const params = this.fragmentParamsService.params;\n    params.remove(this.tabGroupQueryParamKey);\n\n    this.fragmentParamsService.setParams(params);\n  }\n\n  private getTabMarker(queryParams: UrlQueryParams): string {\n    return queryParams.has(this.tabGroupQueryParamKey)\n      ? queryParams.get(this.tabGroupQueryParamKey)\n      : null;\n  }\n\n  private isIndexMarker(marker: string) {\n    return marker && marker.startsWith(ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX);\n  }\n\n  private parseIndexMarker(marker: string): number {\n\n    if (this.isIndexMarker(marker)) {\n      const indexStr = marker.replace(ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX, '');\n      return Number(indexStr);\n    } else {\n      throw new Error('Cannot parse index from marker  \"' + marker + '\". Check with isIndexMarker first!');\n    }\n  }\n\n  private serializeIndexMarker(index: number): string {\n    return ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX + String(index);\n  }\n}\n"]}
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-tab-group-routing.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, ContentChildren, Directive, Input, OnDestroy, QueryList} from '@angular/core';\nimport {first, takeUntil} from 'rxjs/operators';\nimport {Subject} from 'rxjs';\nimport {MatTab, MatTabChangeEvent, MatTabGroup} from '@angular/material/tabs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTabDirective} from '../elder-tab/elder-tab.directive';\nimport {ElderUrlFragmentParamsService} from '../../../common/url/elder-url-fragment-params.service';\nimport {UrlQueryParams} from '../../../common/url/url-query-params';\nimport {QueryListBinding} from '../../../common/utils/query-list-binding';\n\n/**\n * Adds out-of-the-box url-fragment based tab navigation\n * within the mat-tab-group it is placed upon.\n *\n * Add elderTab directive to each tab of the group to\n * support id-based tab navigation.\n */\n@Directive({\n  selector: '[elderTabGroupRouting]',\n  exportAs: 'elderTabGroupRouting'\n})\nexport class ElderTabGroupRoutingDirective implements AfterViewInit, OnDestroy {\n\n  /**\n   * Prefix used to indicate and index-based tab marker.\n   */\n  private static readonly TAB_INDEX_PREFIX = 'idx:';\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _log = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _destroy$ = new Subject<void>();\n\n  /**\n   * Stores the last tab marker (either ID or index)\n   * which could not be activated. This is used to retry\n   * activation once changes on tab structure occur.\n   */\n  private lastFailedTabMarker: string;\n\n  /**\n   * String to use as query param key.\n   */\n  @Input('elderTabGroupRouting')\n  public tabGroupQueryParamKey: string;\n\n  /**\n   * The child tabs within this navigation context.\n   */\n  @ContentChildren(MatTab)\n  public tabs: QueryList<MatTab>;\n\n  /**\n   * The child tabs within this navigation context\n   * marked with the elderTabs directive.\n   */\n  @ContentChildren(ElderTabDirective)\n  public elderTabs: QueryList<ElderTabDirective>;\n\n  /**\n   * The tab marked with elderTab directive which\n   * is currently active. May be null if\n   * elderTab markers are not used.\n   */\n  public activeElderTab: ElderTabDirective;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private fragmentParamsService: ElderUrlFragmentParamsService,\n    private tabGroup: MatTabGroup\n  ) {\n    this.tabGroup.selectedTabChange\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(event => this.handleTabChangeEvent(event));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n    this.fragmentParamsService.params$\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(params => this.handleFragmentParamsChange(params));\n\n    QueryListBinding\n      .of(this.tabs)\n      .updated(() => this.retryLastFailedActivation())\n      .bindUntil(this._destroy$);\n\n    QueryListBinding\n      .of(this.elderTabs)\n      .updated(() => this.retryLastFailedActivation())\n      .bindUntil(this._destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.removeFragmentParam();\n\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get activeTabId(): string {\n    return this.activeElderTab?.id;\n  }\n\n  public get activeTabIndex(): number {\n    return this.tabGroup.selectedIndex;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private handleFragmentParamsChange(params: UrlQueryParams): void {\n    const tabMarker = this.getTabMarker(params);\n\n    if (tabMarker) {\n      this.activateTabByMarker(tabMarker);\n    }\n  }\n\n  private activateTabByMarker(tabMarker: string): void {\n\n    let success: boolean;\n    if (this.isIndexMarker(tabMarker)) {\n      const index = this.parseIndexMarker(tabMarker);\n      success = this.activateTabByIndex(index);\n    } else {\n      // if no index is given we assume the marker is the id of the tab.\n      success = this.activateTabById(tabMarker);\n    }\n\n    // remember tab marker in case of failure to retry later.\n    this.lastFailedTabMarker = success ? null : tabMarker;\n  }\n\n  private activateTabByIndex(indexToActivate: number): boolean {\n\n    if (indexToActivate !== this.activeTabIndex) {\n      this._log.trace('Activating tab by index ', indexToActivate);\n\n      // First try to identify corresponding elder tab, so that we may work with its ID instead of index.\n      const elderTab = this.findElderTabByIndex(indexToActivate);\n\n      if (elderTab) {\n        return this.activateElderTab(elderTab);\n      } else {\n        // If no elder tab found, clear active elder tab to ensure consistent state.\n        this.activeElderTab = null;\n        return this.setSelectedIndex(indexToActivate);\n      }\n    } else {\n      return true;\n    }\n\n  }\n\n  private activateTabById(tabId: string): boolean {\n    const elderTab = this.findElderTabById(tabId);\n\n    if (elderTab) {\n      return this.activateElderTab(elderTab);\n    } else {\n      // If no elder tab found, clear active elder tab to ensure consistent state.\n      this.activeElderTab = null;\n      this._log.warn('Could not find tab with ID \"' + tabId + '\". Ensure elderTab directive is added to corresponding tab.');\n      return false;\n    }\n  }\n\n  private activateElderTab(elderTab: ElderTabDirective): boolean {\n\n    if (this.activeElderTab !== elderTab) {\n      this.activeElderTab = elderTab;\n      const indexToActivate = this.getIndexOfTab(elderTab.tab);\n      return this.setSelectedIndex(indexToActivate);\n    } else {\n      return true;\n    }\n\n  }\n\n  private handleTabChangeEvent(tabChangeEvent: MatTabChangeEvent): void {\n    this._log.trace('Handling tabChangeEvent: ', tabChangeEvent);\n    this.lastFailedTabMarker = null;\n    this.activeElderTab = this.findElderTabByTab(tabChangeEvent.tab);\n    this.updateFragmentParam();\n  }\n\n  private retryLastFailedActivation(): void {\n    if (this.lastFailedTabMarker) {\n      this._log.trace('Retrying to activate tab by marker:', this.lastFailedTabMarker);\n      this.activateTabByMarker(this.lastFailedTabMarker);\n    }\n  }\n\n  private setSelectedIndex(index: number): boolean {\n    if (index !== this.activeTabIndex) {\n\n      if (this.isValidIndex(index)) {\n        this._log.trace('Activating tab by index ', index);\n        this.tabGroup.selectedIndex = index;\n        return true;\n      } else {\n        this._log.warn('Could not find tab with index \"' + index + '\".');\n        return false;\n      }\n    } else {\n      return true;\n    }\n  }\n\n  private isValidIndex(index: number): boolean {\n    return this.tabs.length > index;\n  }\n\n  private findElderTabById(tabId: string): ElderTabDirective | null {\n    return this.elderTabs.find(t => t.id === tabId);\n  }\n\n  private findElderTabByIndex(tabIndex: number): ElderTabDirective | null {\n    const tab = this.findTabByIndex(tabIndex);\n    if (tab) {\n      return this.findElderTabByTab(tab);\n    } else {\n      return null;\n    }\n  }\n\n  private findElderTabByTab(tab: MatTab): ElderTabDirective | null {\n    return this.elderTabs.find(elderTab => elderTab.tab === tab);\n  }\n\n  private findTabByIndex(tabIndex: number): MatTab | null {\n    if (this.tabs.length > tabIndex) {\n      return this.tabs.get(tabIndex);\n    } else {\n      return null;\n    }\n  }\n\n  private getIndexOfTab(tab: MatTab): number | null {\n    return this.tabs.toArray().indexOf(tab);\n  }\n\n  private updateFragmentParam(): void {\n\n    const currentTabMarker = this.getTabMarker(this.fragmentParamsService.params);\n\n    // If possible, use tab ID as marker. If not, use tab index as fallback.\n    const newTabMarker = this.activeTabId\n      ? this.activeTabId\n      : this.serializeIndexMarker(this.activeTabIndex);\n\n    if (newTabMarker !== currentTabMarker) {\n      this.setFragmentParam(newTabMarker);\n    }\n  }\n\n  private setFragmentParam(value: string): void {\n\n    const params = this.fragmentParamsService.params;\n    params.set(this.tabGroupQueryParamKey, value);\n\n    this.fragmentParamsService.setParams(params);\n  }\n\n  private removeFragmentParam(): void {\n\n    const params = this.fragmentParamsService.params;\n    params.remove(this.tabGroupQueryParamKey);\n\n    this.fragmentParamsService.setParams(params);\n  }\n\n  private getTabMarker(queryParams: UrlQueryParams): string {\n    return queryParams.has(this.tabGroupQueryParamKey)\n      ? queryParams.get(this.tabGroupQueryParamKey)\n      : null;\n  }\n\n  private isIndexMarker(marker: string) {\n    return marker && marker.startsWith(ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX);\n  }\n\n  private parseIndexMarker(marker: string): number {\n\n    if (this.isIndexMarker(marker)) {\n      const indexStr = marker.replace(ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX, '');\n      return Number(indexStr);\n    } else {\n      throw new Error('Cannot parse index from marker  \"' + marker + '\". Check with isIndexMarker first!');\n    }\n  }\n\n  private serializeIndexMarker(index: number): string {\n    return ElderTabGroupRoutingDirective.TAB_INDEX_PREFIX + String(index);\n  }\n}\n"]}