@elderbyte/ngx-starter 13.8.1 → 13.9.0

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 (253) hide show
  1. package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +4 -4
  2. package/esm2020/lib/common/forms/form-field-base.component.mjs +4 -4
  3. package/esm2020/lib/common/forms/multi-model-base.component.mjs +4 -4
  4. package/esm2020/lib/common/forms/template-composite-control.mjs +4 -4
  5. package/esm2020/lib/common/forms/value-accessor-base.mjs +4 -4
  6. package/esm2020/lib/common/http/http-client-builder.service.mjs +4 -4
  7. package/esm2020/lib/common/http/http-client-pristine.mjs +4 -4
  8. package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +4 -4
  9. package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +4 -4
  10. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +4 -4
  11. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +5 -5
  12. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +4 -4
  13. package/esm2020/lib/components/auditing/elder-audit.module.mjs +5 -5
  14. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +4 -4
  15. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +5 -5
  16. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -4
  17. package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +4 -4
  18. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +4 -4
  19. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +5 -5
  20. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +4 -4
  21. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +19 -19
  22. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +5 -5
  23. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +5 -5
  24. package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +4 -4
  25. package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +4 -4
  26. package/esm2020/lib/components/containers/elder-containers.module.mjs +5 -5
  27. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +4 -4
  28. package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +4 -4
  29. package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +4 -4
  30. package/esm2020/lib/components/csv/elder-csv.module.mjs +5 -5
  31. package/esm2020/lib/components/currency/elder-currency.module.mjs +5 -5
  32. package/esm2020/lib/components/currency/elder-currency.pipe.mjs +4 -4
  33. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +5 -5
  34. package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +4 -4
  35. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +4 -4
  36. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -4
  37. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +4 -4
  38. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +4 -4
  39. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +4 -4
  40. package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +5 -5
  41. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -4
  42. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +5 -5
  43. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +7 -7
  44. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -4
  45. package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -4
  46. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +4 -4
  47. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +11 -11
  48. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +5 -5
  49. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +4 -4
  50. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +5 -5
  51. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  52. package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +4 -4
  53. package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +4 -4
  54. package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +4 -4
  55. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +5 -5
  56. package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +4 -4
  57. package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  58. package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +4 -4
  59. package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +4 -4
  60. package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +4 -4
  61. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +5 -5
  62. package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +4 -4
  63. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -4
  64. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +8 -8
  65. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +4 -4
  66. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -4
  67. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -4
  68. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +4 -4
  69. package/esm2020/lib/components/errors/elder-error.module.mjs +5 -5
  70. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +4 -4
  71. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -4
  72. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +5 -5
  73. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
  74. package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +4 -4
  75. package/esm2020/lib/components/files/elder-file-select.directive.mjs +4 -4
  76. package/esm2020/lib/components/files/elder-file.module.mjs +5 -5
  77. package/esm2020/lib/components/files/file-select/file-select.component.mjs +4 -4
  78. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +4 -4
  79. package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +4 -4
  80. package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +34 -0
  81. package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +4 -4
  82. package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +4 -4
  83. package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +10 -25
  84. package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +4 -4
  85. package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +34 -0
  86. package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +11 -32
  87. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +24 -18
  88. package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +4 -4
  89. package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +4 -4
  90. package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +4 -4
  91. package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +4 -4
  92. package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
  93. package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
  94. package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  95. package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +4 -4
  96. package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +4 -4
  97. package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +4 -4
  98. package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +4 -4
  99. package/esm2020/lib/components/forms/elder-forms.module.mjs +5 -5
  100. package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +4 -4
  101. package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
  102. package/esm2020/lib/components/forms/search/elder-search.module.mjs +5 -5
  103. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
  104. package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +4 -4
  105. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -4
  106. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +5 -5
  107. package/esm2020/lib/components/global-search/elder-global-search.service.mjs +4 -4
  108. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +4 -4
  109. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +5 -5
  110. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -4
  111. package/esm2020/lib/components/headers/elder-header.module.mjs +5 -5
  112. package/esm2020/lib/components/http-support/elder-http-client.service.mjs +4 -4
  113. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -5
  114. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
  115. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +4 -4
  116. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +4 -4
  117. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
  118. package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +4 -4
  119. package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  120. package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +4 -4
  121. package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +4 -4
  122. package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +4 -4
  123. package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +4 -4
  124. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +5 -5
  125. package/esm2020/lib/components/i18n/language/elder-language.service.mjs +4 -4
  126. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +4 -4
  127. package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
  128. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +5 -5
  129. package/esm2020/lib/components/iframes/iframe-close.directive.mjs +4 -4
  130. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -4
  131. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +4 -4
  132. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -4
  133. package/esm2020/lib/components/iframes/iframe.service.mjs +4 -4
  134. package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +4 -4
  135. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  136. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +8 -8
  137. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -4
  138. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  139. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +5 -5
  140. package/esm2020/lib/components/labels/elder-labels.module.mjs +5 -5
  141. package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +4 -4
  142. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +4 -4
  143. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +4 -4
  144. package/esm2020/lib/components/measures/elder-measures.module.mjs +9 -9
  145. package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +4 -4
  146. package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +4 -4
  147. package/esm2020/lib/components/measures/elder-unit.service.mjs +4 -4
  148. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +4 -4
  149. package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +4 -4
  150. package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +5 -5
  151. package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +4 -4
  152. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
  153. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +5 -5
  154. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +5 -5
  155. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
  156. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -4
  157. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +4 -4
  158. package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +4 -4
  159. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +5 -5
  160. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +4 -4
  161. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +4 -4
  162. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +4 -4
  163. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +4 -4
  164. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +4 -4
  165. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +4 -4
  166. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +4 -4
  167. package/esm2020/lib/components/overlays/elder-overlay.module.mjs +5 -5
  168. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +4 -4
  169. package/esm2020/lib/components/panels/elder-panel.module.mjs +5 -5
  170. package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +4 -4
  171. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +4 -4
  172. package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +17 -15
  173. package/esm2020/lib/components/select/elder-select-base.mjs +20 -6
  174. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +4 -4
  175. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  176. package/esm2020/lib/components/select/elder-select-value.directive.mjs +4 -4
  177. package/esm2020/lib/components/select/elder-select.module.mjs +9 -8
  178. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +30 -5
  179. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +18 -24
  180. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +7 -5
  181. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +4 -4
  182. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -4
  183. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +5 -5
  184. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +5 -5
  185. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +4 -4
  186. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +4 -4
  187. package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +4 -4
  188. package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +4 -4
  189. package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +4 -4
  190. package/esm2020/lib/components/shell/elder-shell.module.mjs +5 -5
  191. package/esm2020/lib/components/shell/elder-shell.service.mjs +4 -4
  192. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
  193. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +13 -13
  194. package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +4 -4
  195. package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +4 -4
  196. package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  197. package/esm2020/lib/components/tabs/elder-tab.module.mjs +5 -5
  198. package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +4 -4
  199. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +4 -4
  200. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +4 -4
  201. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +4 -4
  202. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +4 -4
  203. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +4 -4
  204. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +4 -4
  205. package/esm2020/lib/components/time/elder-time.module.mjs +9 -9
  206. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +4 -4
  207. package/esm2020/lib/components/toasts/elder-toast.module.mjs +5 -5
  208. package/esm2020/lib/components/toasts/elder-toast.service.mjs +10 -10
  209. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +4 -4
  210. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -5
  211. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -4
  212. package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +4 -4
  213. package/esm2020/lib/components/viewers/elder-viewers.module.mjs +5 -5
  214. package/esm2020/lib/features/event-source/elder-event-source.service.mjs +4 -4
  215. package/esm2020/lib/features/kafent/access-token-provider.mjs +4 -4
  216. package/esm2020/lib/features/kafent/kafent-config.mjs +4 -4
  217. package/esm2020/lib/features/kafent/kafent-event-stream.mjs +4 -4
  218. package/esm2020/lib/features/kafent/kafent-event.service.mjs +4 -4
  219. package/esm2020/lib/features/kafent/kafent-live-event-request.mjs +1 -1
  220. package/esm2020/lib/features/kafent/kafent.module.mjs +5 -5
  221. package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +4 -4
  222. package/esm2020/lib/pipes/bytes.pipe.mjs +4 -4
  223. package/esm2020/lib/pipes/elder-pipes.module.mjs +12 -10
  224. package/esm2020/lib/pipes/elder-repeat.pipe.mjs +4 -4
  225. package/esm2020/lib/pipes/elder-round.pipe.mjs +4 -4
  226. package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +4 -4
  227. package/esm2020/lib/pipes/elder-trim.pipe.mjs +40 -0
  228. package/esm2020/lib/pipes/iso-duration.pipe.mjs +4 -4
  229. package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +4 -4
  230. package/esm2020/lib/pipes/iso-interval.pipe.mjs +4 -4
  231. package/esm2020/lib/pipes/time-ago.pipe.mjs +4 -4
  232. package/esm2020/lib/pipes/time-duration.pipe.mjs +4 -4
  233. package/esm2020/lib/pipes/weight.pipe.mjs +4 -4
  234. package/fesm2015/elderbyte-ngx-starter.mjs +979 -881
  235. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  236. package/fesm2020/elderbyte-ngx-starter.mjs +979 -881
  237. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  238. package/lib/components/forms/directives/base/elder-class-hostbinding-base.d.ts +32 -0
  239. package/lib/components/forms/directives/elder-form-field-dense.directive.d.ts +3 -17
  240. package/lib/components/forms/directives/elder-form-field-no-hint.directive.d.ts +19 -0
  241. package/lib/components/forms/directives/elder-form-field-no-spinner.directive.d.ts +3 -17
  242. package/lib/components/forms/directives/elder-forms-directives.module.d.ts +5 -3
  243. package/lib/components/select/elder-select-base.d.ts +10 -2
  244. package/lib/components/select/elder-select.module.d.ts +2 -1
  245. package/lib/components/select/multi/elder-multi-select-base.d.ts +9 -0
  246. package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +0 -3
  247. package/lib/components/select/popup/selection-model-popup.directive.d.ts +2 -1
  248. package/lib/pipes/elder-pipes.module.d.ts +4 -2
  249. package/lib/pipes/elder-trim.pipe.d.ts +17 -0
  250. package/package.json +1 -1
  251. package/src/lib/components/select/elder-select/elder-select.component.scss +4 -0
  252. package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +4 -0
  253. package/theming/_elder-common.scss +13 -8
@@ -117,12 +117,12 @@ export class ElderRouterOutletService {
117
117
  }
118
118
  }
119
119
  }
120
- ElderRouterOutletService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderRouterOutletService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable });
121
- ElderRouterOutletService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderRouterOutletService, providedIn: 'root' });
122
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderRouterOutletService, decorators: [{
120
+ ElderRouterOutletService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderRouterOutletService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable });
121
+ ElderRouterOutletService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderRouterOutletService, providedIn: 'root' });
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderRouterOutletService, decorators: [{
123
123
  type: Injectable,
124
124
  args: [{
125
125
  providedIn: 'root'
126
126
  }]
127
127
  }], ctorParameters: function () { return [{ type: i1.Router }]; } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-router-outlet.service.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/drawers/elder-router-outlet.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAC,YAAY,EAAE,MAAM,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAyB,aAAa,EAAgD,MAAM,iBAAiB,CAAC;AACrH,OAAO,EAAC,eAAe,EAAa,MAAM,MAAM,CAAC;AACjD,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;;;AAKnD,MAAM,OAAO,wBAAwB;IAYnC;;;;gFAI4E;IAE5E,YACU,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAjBxB;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;QAEtE,mBAAc,GAAiC,IAAI,CAAC;IAW5D,CAAC;IACD;;;;gFAI4E;IAE5E;;OAEG;IACH,IAAW,aAAa;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,IAAW,qBAAqB;QAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;IACnC,CAAC;IAED;;;;gFAI4E;IAE5E;;OAEG;IACI,QAAQ,CAAC,MAAc;QAC5B,OAAO,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAChD,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,MAAc;QAE9B,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;YACzB,MAAM,OAAO,GAAQ,EAAE,CAAC;YACxB,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;YACxB,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;YAElC,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBAC1B,OAAO;aACR,EAAC,EAAC,mBAAmB,EAAE,OAAO,EAAC,CAAE,CAAC;SACpC;aAAM;YACL,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAED;;;;;OAKG;IACI,QAAQ,CAAC,MAAc,EAAE,KAAe,EAAE,MAAyB;QACxE,MAAM,OAAO,GAAQ,EAAE,CAAC;QACxB,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;QACxB,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC;QACnC,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,CAAC;IACjD,CAAC;IAED;;;;gFAI4E;IAEpE,cAAc;QACpB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,IAAI,CAAC,cAAc,GAAG,IAAI,eAAe,CAAc,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;YAEpF,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CACrB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,EAC/C,YAAY,CAAC,EAAE,CAAC,EAChB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAsB,CAAC,CACrC,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBAClB,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC7B,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,mBAAmB;QACzB,MAAM,KAAK,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE;YAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACjC;IACH,CAAC;IAEO,oBAAoB;QAC1B,MAAM,EAAE,GAAyB,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC;QAClE,MAAM,IAAI,GAA2B,EAAE,CAAC,IAAI,CAAC;QAC7C,OAAO,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;IAEO,uBAAuB,CAAC,IAA4B;QAC1D,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;QAClC,IAAI,CAAC,6BAA6B,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAClD,OAAO,OAAO,CAAC;IACjB,CAAC;IAEO,6BAA6B,CAAC,IAA4B,EAAE,OAAoB;QACtF,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzB,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC7B,IAAI,CAAC,6BAA6B,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;SAChD;IACH,CAAC;;qHArIU,wBAAwB;yHAAxB,wBAAwB,cAFvB,MAAM;2FAEP,wBAAwB;kBAHpC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport {debounceTime, filter, map} from 'rxjs/operators';\nimport {ActivatedRouteSnapshot, NavigationEnd, NavigationExtras, Router, RouterStateSnapshot} from '@angular/router';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {Sets} from '../../../common/sets';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderRouterOutletService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderRouterOutletService');\n\n  private _activeOutlets: BehaviorSubject<Set<string>> = null;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private router: Router,\n  ) {\n  }\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Emits the current active outlets over time\n   */\n  public get activeOutlets(): Observable<Set<string>> {\n    this.ensureListener();\n    return this._activeOutlets.asObservable();\n  }\n\n  /**\n   * Gets a snapshot of the current active outlets\n   */\n  public get activeOutletsSnapshot(): Set<string> {\n    this.ensureListener();\n    return this._activeOutlets.value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the given outlet is currently active\n   */\n  public isActive(outlet: string): boolean {\n    return this.activeOutletsSnapshot.has(outlet);\n  }\n\n  /**\n   * Deactivates the given outlet\n   */\n  public deactivate(outlet: string): Promise<boolean> {\n\n    if (this.isActive(outlet)) {\n      const command: any = {};\n      command['outlets'] = {};\n      command['outlets'][outlet] = null;\n\n      return this.router.navigate([\n        command\n      ],{queryParamsHandling: 'merge'} );\n    } else {\n      return Promise.resolve(false);\n    }\n  }\n\n  /**\n   * Activates the given outlet route with the given path\n   * @param outlet\n   * @param parts\n   * @param extras\n   */\n  public activate(outlet: string, parts: string[], extras?: NavigationExtras): Promise<boolean> {\n    const command: any = {};\n    command['outlets'] = {};\n    command['outlets'][outlet] = parts;\n    return this.router.navigate([command], extras);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private ensureListener(): void {\n    if (!this._activeOutlets) {\n      this._activeOutlets = new BehaviorSubject<Set<string>>(this.collectActiveOutlets());\n\n      this.router.events.pipe(\n        filter(event => event instanceof NavigationEnd),\n        debounceTime(60),\n        map(event => event as NavigationEnd)\n      ).subscribe(event => {\n        this.updateActiveOutlets();\n      });\n    }\n  }\n\n  private updateActiveOutlets(): void {\n    const found = this.collectActiveOutlets();\n    const current = this.activeOutletsSnapshot;\n    if (!Sets.equals(found, current)) {\n      this._activeOutlets.next(found);\n    }\n  }\n\n  private collectActiveOutlets(): Set<string> {\n    const rs: RouterStateSnapshot =  this.router.routerState.snapshot;\n    const snap: ActivatedRouteSnapshot = rs.root;\n    return this.collectActiveOutletsFor(snap);\n  }\n\n  private collectActiveOutletsFor(root: ActivatedRouteSnapshot): Set<string> {\n    const outlets = new Set<string>();\n    this.collectActiveOutletsRecursive(root, outlets);\n    return outlets;\n  }\n\n  private collectActiveOutletsRecursive(snap: ActivatedRouteSnapshot, outlets: Set<string>): void {\n    outlets.add(snap.outlet);\n    for (const c of snap.children) {\n      this.collectActiveOutletsRecursive(c, outlets);\n    }\n  }\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-router-outlet.service.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/drawers/elder-router-outlet.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {debounceTime, filter, map} from 'rxjs/operators';\nimport {ActivatedRouteSnapshot, NavigationEnd, NavigationExtras, Router, RouterStateSnapshot} from '@angular/router';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {Sets} from '../../../common/sets';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderRouterOutletService {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderRouterOutletService');\n\n  private _activeOutlets: BehaviorSubject<Set<string>> = null;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private router: Router,\n  ) {\n  }\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Emits the current active outlets over time\n   */\n  public get activeOutlets(): Observable<Set<string>> {\n    this.ensureListener();\n    return this._activeOutlets.asObservable();\n  }\n\n  /**\n   * Gets a snapshot of the current active outlets\n   */\n  public get activeOutletsSnapshot(): Set<string> {\n    this.ensureListener();\n    return this._activeOutlets.value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the given outlet is currently active\n   */\n  public isActive(outlet: string): boolean {\n    return this.activeOutletsSnapshot.has(outlet);\n  }\n\n  /**\n   * Deactivates the given outlet\n   */\n  public deactivate(outlet: string): Promise<boolean> {\n\n    if (this.isActive(outlet)) {\n      const command: any = {};\n      command['outlets'] = {};\n      command['outlets'][outlet] = null;\n\n      return this.router.navigate([\n        command\n      ],{queryParamsHandling: 'merge'} );\n    } else {\n      return Promise.resolve(false);\n    }\n  }\n\n  /**\n   * Activates the given outlet route with the given path\n   * @param outlet\n   * @param parts\n   * @param extras\n   */\n  public activate(outlet: string, parts: string[], extras?: NavigationExtras): Promise<boolean> {\n    const command: any = {};\n    command['outlets'] = {};\n    command['outlets'][outlet] = parts;\n    return this.router.navigate([command], extras);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private ensureListener(): void {\n    if (!this._activeOutlets) {\n      this._activeOutlets = new BehaviorSubject<Set<string>>(this.collectActiveOutlets());\n\n      this.router.events.pipe(\n        filter(event => event instanceof NavigationEnd),\n        debounceTime(60),\n        map(event => event as NavigationEnd)\n      ).subscribe(event => {\n        this.updateActiveOutlets();\n      });\n    }\n  }\n\n  private updateActiveOutlets(): void {\n    const found = this.collectActiveOutlets();\n    const current = this.activeOutletsSnapshot;\n    if (!Sets.equals(found, current)) {\n      this._activeOutlets.next(found);\n    }\n  }\n\n  private collectActiveOutlets(): Set<string> {\n    const rs: RouterStateSnapshot =  this.router.routerState.snapshot;\n    const snap: ActivatedRouteSnapshot = rs.root;\n    return this.collectActiveOutletsFor(snap);\n  }\n\n  private collectActiveOutletsFor(root: ActivatedRouteSnapshot): Set<string> {\n    const outlets = new Set<string>();\n    this.collectActiveOutletsRecursive(root, outlets);\n    return outlets;\n  }\n\n  private collectActiveOutletsRecursive(snap: ActivatedRouteSnapshot, outlets: Set<string>): void {\n    outlets.add(snap.outlet);\n    for (const c of snap.children) {\n      this.collectActiveOutletsRecursive(c, outlets);\n    }\n  }\n}\n"]}
@@ -31,9 +31,9 @@ export class ElderShellSlotDirective {
31
31
  this.elderShellService.deregisterColumn(this.templateRef, this.elderShellSlot);
32
32
  }
33
33
  }
34
- ElderShellSlotDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSlotDirective, deps: [{ token: i0.ViewContainerRef }, { token: i1.ElderShellService }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
35
- ElderShellSlotDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderShellSlotDirective, selector: "[elderShellSlot]", inputs: { elderShellSlot: "elderShellSlot", elderShellSlotDefault: "elderShellSlotDefault" }, ngImport: i0 });
36
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSlotDirective, decorators: [{
34
+ ElderShellSlotDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSlotDirective, deps: [{ token: i0.ViewContainerRef }, { token: i1.ElderShellService }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
35
+ ElderShellSlotDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderShellSlotDirective, selector: "[elderShellSlot]", inputs: { elderShellSlot: "elderShellSlot", elderShellSlotDefault: "elderShellSlotDefault" }, ngImport: i0 });
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSlotDirective, decorators: [{
37
37
  type: Directive,
38
38
  args: [{
39
39
  selector: '[elderShellSlot]'
@@ -43,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
43
43
  }], elderShellSlotDefault: [{
44
44
  type: Input
45
45
  }] } });
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2hlbGwtc2xvdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NoZWxsL2VsZGVyLXNoZWxsLXNsb3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFtRCxNQUFNLGVBQWUsQ0FBQztBQUNqRyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7OztBQU9uRCxNQUFNLE9BQU8sdUJBQXVCO0lBbUJsQzs7OztnRkFJNEU7SUFFNUUsWUFDVSxhQUErQixFQUMvQixpQkFBb0MsRUFDckMsV0FBNkI7UUFGNUIsa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBQy9CLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFDckMsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBekJ0Qzs7OztvRkFJNEU7UUFFM0QsV0FBTSxHQUFHLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQW9CckUsQ0FBQztJQUVMOzs7O2dGQUk0RTtJQUVyRSxRQUFRO1FBQ2IsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGNBQWMsQ0FDbkMsSUFBSSxDQUFDLGNBQWMsRUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFDaEIsSUFBSSxDQUFDLHFCQUFxQixDQUMzQixDQUFDO0lBQ0osQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixDQUNyQyxJQUFJLENBQUMsV0FBVyxFQUNoQixJQUFJLENBQUMsY0FBYyxDQUNwQixDQUFDO0lBQ0osQ0FBQzs7b0hBbERVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCOzJGQUF2Qix1QkFBdUI7a0JBSG5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7aUtBY1EsY0FBYztzQkFEcEIsS0FBSztnQkFLQyxxQkFBcUI7c0JBRDNCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0LCBUZW1wbGF0ZVJlZiwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7U2hlbGxDb250ZW50U2xvdH0gZnJvbSAnLi9zaGVsbC1jb250ZW50LXNsb3QnO1xuaW1wb3J0IHtFbGRlclNoZWxsU2VydmljZX0gZnJvbSAnLi9lbGRlci1zaGVsbC5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2VsZGVyU2hlbGxTbG90XSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJTaGVsbFNsb3REaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG5cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGxvZ2dlciA9IExvZ2dlckZhY3RvcnkuZ2V0TG9nZ2VyKHRoaXMuY29uc3RydWN0b3IubmFtZSk7XG5cbiAgLyoqIFNsb3QgYXQgd2hpY2ggdGVtcGxhdGUgc2hvdWxkIGJlIHBsYWNlZC4gKi9cbiAgQElucHV0KClcbiAgcHVibGljIGVsZGVyU2hlbGxTbG90OiBTaGVsbENvbnRlbnRTbG90O1xuXG4gIC8qKiBJZiB0aGUgY29sdW1uIHNob3VsZCBiZSBjb25zaWRlcmVkIGFzIGRlZmF1bHQgKGZhbGxiYWNrKS4gKi9cbiAgQElucHV0KClcbiAgcHVibGljIGVsZGVyU2hlbGxTbG90RGVmYXVsdDogYm9vbGVhbjtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHZpZXdDb250YWluZXI6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHJpdmF0ZSBlbGRlclNoZWxsU2VydmljZTogRWxkZXJTaGVsbFNlcnZpY2UsXG4gICAgcHVibGljIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+LFxuICApIHsgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBMaWZlIEN5Y2xlICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmVsZGVyU2hlbGxTZXJ2aWNlLnJlZ2lzdGVyQ29sdW1uKFxuICAgICAgdGhpcy5lbGRlclNoZWxsU2xvdCxcbiAgICAgIHRoaXMudGVtcGxhdGVSZWYsXG4gICAgICB0aGlzLmVsZGVyU2hlbGxTbG90RGVmYXVsdFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5lbGRlclNoZWxsU2VydmljZS5kZXJlZ2lzdGVyQ29sdW1uKFxuICAgICAgdGhpcy50ZW1wbGF0ZVJlZixcbiAgICAgIHRoaXMuZWxkZXJTaGVsbFNsb3RcbiAgICApO1xuICB9XG5cbn1cbiJdfQ==
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2hlbGwtc2xvdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NoZWxsL2VsZGVyLXNoZWxsLXNsb3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFtRCxNQUFNLGVBQWUsQ0FBQztBQUNqRyxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7OztBQU9uRCxNQUFNLE9BQU8sdUJBQXVCO0lBbUJsQzs7OztnRkFJNEU7SUFFNUUsWUFDVSxhQUErQixFQUMvQixpQkFBb0MsRUFDckMsV0FBNkI7UUFGNUIsa0JBQWEsR0FBYixhQUFhLENBQWtCO1FBQy9CLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFDckMsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBekJ0Qzs7OztvRkFJNEU7UUFFM0QsV0FBTSxHQUFHLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQW9CckUsQ0FBQztJQUVMOzs7O2dGQUk0RTtJQUVyRSxRQUFRO1FBQ2IsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGNBQWMsQ0FDbkMsSUFBSSxDQUFDLGNBQWMsRUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFDaEIsSUFBSSxDQUFDLHFCQUFxQixDQUMzQixDQUFDO0lBQ0osQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixDQUNyQyxJQUFJLENBQUMsV0FBVyxFQUNoQixJQUFJLENBQUMsY0FBYyxDQUNwQixDQUFDO0lBQ0osQ0FBQzs7cUhBbERVLHVCQUF1Qjt5R0FBdkIsdUJBQXVCOzRGQUF2Qix1QkFBdUI7a0JBSG5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7aUtBY1EsY0FBYztzQkFEcEIsS0FBSztnQkFLQyxxQkFBcUI7c0JBRDNCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgSW5wdXQsIE9uRGVzdHJveSwgT25Jbml0LCBUZW1wbGF0ZVJlZiwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7U2hlbGxDb250ZW50U2xvdH0gZnJvbSAnLi9zaGVsbC1jb250ZW50LXNsb3QnO1xuaW1wb3J0IHtFbGRlclNoZWxsU2VydmljZX0gZnJvbSAnLi9lbGRlci1zaGVsbC5zZXJ2aWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2VsZGVyU2hlbGxTbG90XSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJTaGVsbFNsb3REaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG5cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGxvZ2dlciA9IExvZ2dlckZhY3RvcnkuZ2V0TG9nZ2VyKHRoaXMuY29uc3RydWN0b3IubmFtZSk7XG5cbiAgLyoqIFNsb3QgYXQgd2hpY2ggdGVtcGxhdGUgc2hvdWxkIGJlIHBsYWNlZC4gKi9cbiAgQElucHV0KClcbiAgcHVibGljIGVsZGVyU2hlbGxTbG90OiBTaGVsbENvbnRlbnRTbG90O1xuXG4gIC8qKiBJZiB0aGUgY29sdW1uIHNob3VsZCBiZSBjb25zaWRlcmVkIGFzIGRlZmF1bHQgKGZhbGxiYWNrKS4gKi9cbiAgQElucHV0KClcbiAgcHVibGljIGVsZGVyU2hlbGxTbG90RGVmYXVsdDogYm9vbGVhbjtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHZpZXdDb250YWluZXI6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHJpdmF0ZSBlbGRlclNoZWxsU2VydmljZTogRWxkZXJTaGVsbFNlcnZpY2UsXG4gICAgcHVibGljIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+LFxuICApIHsgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBMaWZlIEN5Y2xlICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmVsZGVyU2hlbGxTZXJ2aWNlLnJlZ2lzdGVyQ29sdW1uKFxuICAgICAgdGhpcy5lbGRlclNoZWxsU2xvdCxcbiAgICAgIHRoaXMudGVtcGxhdGVSZWYsXG4gICAgICB0aGlzLmVsZGVyU2hlbGxTbG90RGVmYXVsdFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy5lbGRlclNoZWxsU2VydmljZS5kZXJlZ2lzdGVyQ29sdW1uKFxuICAgICAgdGhpcy50ZW1wbGF0ZVJlZixcbiAgICAgIHRoaXMuZWxkZXJTaGVsbFNsb3RcbiAgICApO1xuICB9XG5cbn1cbiJdfQ==
@@ -25,8 +25,8 @@ export { ElderShellSlotDirective } from './elder-shell-slot.directive';
25
25
  export { ElderAppHeaderComponent } from './header/elder-app-header/elder-app-header.component';
26
26
  export class ElderShellModule {
27
27
  }
28
- ElderShellModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
29
- ElderShellModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellModule, declarations: [ElderShellComponent,
28
+ ElderShellModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
29
+ ElderShellModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellModule, declarations: [ElderShellComponent,
30
30
  ElderShellSideLeftDirective,
31
31
  ElderShellSideRightDirective,
32
32
  ElderShellCenterDirective,
@@ -46,7 +46,7 @@ ElderShellModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
46
46
  ElderShellNavigationToggleComponent,
47
47
  ElderShellSlotDirective,
48
48
  ElderAppHeaderComponent] });
49
- ElderShellModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellModule, imports: [[
49
+ ElderShellModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellModule, imports: [[
50
50
  CommonModule, RouterModule,
51
51
  MatSidenavModule,
52
52
  MatToolbarModule,
@@ -56,7 +56,7 @@ ElderShellModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versio
56
56
  ElderToolbarModule,
57
57
  FlexLayoutModule, TranslateModule, ElderPanelModule
58
58
  ]] });
59
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellModule, decorators: [{
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellModule, decorators: [{
60
60
  type: NgModule,
61
61
  args: [{
62
62
  imports: [
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
89
89
  ]
90
90
  }]
91
91
  }] });
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2hlbGwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zaGVsbC9lbGRlci1zaGVsbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLHlCQUF5QixFQUN6QixtQkFBbUIsRUFDbkIsMkJBQTJCLEVBQzNCLDRCQUE0QixFQUM3QixNQUFNLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLG1DQUFtQyxFQUFDLE1BQU0sbUVBQW1FLENBQUM7QUFDdEgsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdkUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDL0YsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sOEJBQThCLENBQUM7O0FBRTlELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsT0FBTyxFQUFDLG1DQUFtQyxFQUFDLE1BQU0sbUVBQW1FLENBQUM7QUFDdEgsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDMUYsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDL0UsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFFckUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFxQzdGLE1BQU0sT0FBTyxnQkFBZ0I7OzZHQUFoQixnQkFBZ0I7OEdBQWhCLGdCQUFnQixpQkFsQnpCLG1CQUFtQjtRQUNuQiwyQkFBMkI7UUFDM0IsNEJBQTRCO1FBQzVCLHlCQUF5QjtRQUN6QixtQ0FBbUM7UUFDbkMsdUJBQXVCO1FBQ3ZCLHVCQUF1QixhQXJCbkIsWUFBWSxFQUFFLFlBQVk7UUFFMUIsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUNoQixhQUFhO1FBQ2IsYUFBYTtRQUNiLGVBQWU7UUFHZixrQkFBa0I7UUFFbEIsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixhQWF2RCxtQkFBbUI7UUFDbkIsMkJBQTJCO1FBQzNCLDRCQUE0QjtRQUM1Qix5QkFBeUI7UUFDekIsbUNBQW1DO1FBQ25DLHVCQUF1QjtRQUN2Qix1QkFBdUI7OEdBR2QsZ0JBQWdCLFlBbENoQjtZQUNMLFlBQVksRUFBRSxZQUFZO1lBRTFCLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsYUFBYTtZQUNiLGFBQWE7WUFDYixlQUFlO1lBR2Ysa0JBQWtCO1lBRWxCLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxnQkFBZ0I7U0FFdEQ7MkZBb0JRLGdCQUFnQjtrQkFuQzVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVksRUFBRSxZQUFZO3dCQUUxQixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGVBQWU7d0JBR2Ysa0JBQWtCO3dCQUVsQixnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCO3FCQUV0RDtvQkFDSCxZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQiwyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIseUJBQXlCO3dCQUN6QixtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsdUJBQXVCO3FCQUN4QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQiwyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIseUJBQXlCO3dCQUN6QixtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsdUJBQXVCO3FCQUN4QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgRWxkZXJTaGVsbENlbnRlckRpcmVjdGl2ZSxcbiAgRWxkZXJTaGVsbENvbXBvbmVudCxcbiAgRWxkZXJTaGVsbFNpZGVMZWZ0RGlyZWN0aXZlLFxuICBFbGRlclNoZWxsU2lkZVJpZ2h0RGlyZWN0aXZlXG59IGZyb20gJy4vc2hlbGwvZWxkZXItc2hlbGwuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBNYXRUb29sYmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQge0ZsZXhMYXlvdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcbmltcG9ydCB7VHJhbnNsYXRlTW9kdWxlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7RWxkZXJUb29sYmFyTW9kdWxlfSBmcm9tICcuLi9uYXZpZ2F0aW9uL3Rvb2xiYXIvZWxkZXItdG9vbGJhci5tb2R1bGUnO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge0VsZGVyU2hlbGxOYXZpZ2F0aW9uVG9nZ2xlQ29tcG9uZW50fSBmcm9tICcuL3NoZWxsLW5hdmlnYXRpb24tdG9nZ2xlL2VsZGVyLXNoZWxsLW5hdmlnYXRpb24tdG9nZ2xlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFbGRlclNoZWxsU2xvdERpcmVjdGl2ZSB9IGZyb20gJy4vZWxkZXItc2hlbGwtc2xvdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRWxkZXJBcHBIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2hlYWRlci9lbGRlci1hcHAtaGVhZGVyL2VsZGVyLWFwcC1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7RWxkZXJQYW5lbE1vZHVsZX0gZnJvbSAnLi4vcGFuZWxzL2VsZGVyLXBhbmVsLm1vZHVsZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vc2hlbGwvZWxkZXItc2hlbGwuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJTaGVsbE5hdmlnYXRpb25Ub2dnbGVDb21wb25lbnR9IGZyb20gJy4vc2hlbGwtbmF2aWdhdGlvbi10b2dnbGUvZWxkZXItc2hlbGwtbmF2aWdhdGlvbi10b2dnbGUuY29tcG9uZW50JztcbmV4cG9ydCB7RHJhd2VyT3V0bGV0QmluZGluZ30gZnJvbSAnLi9kcmF3ZXJzL2RyYXdlci1vdXRsZXQtYmluZGluZyc7XG5leHBvcnQge0VsZGVyUm91dGVPdXRsZXREcmF3ZXJTZXJ2aWNlfSBmcm9tICcuL2RyYXdlcnMvZWxkZXItcm91dGUtb3V0bGV0LWRyYXdlci5zZXJ2aWNlJztcbmV4cG9ydCB7RWxkZXJSb3V0ZXJPdXRsZXRTZXJ2aWNlfSBmcm9tICcuL2RyYXdlcnMvZWxkZXItcm91dGVyLW91dGxldC5zZXJ2aWNlJztcbmV4cG9ydCB7RWxkZXJTaGVsbFNlcnZpY2V9IGZyb20gJy4vZWxkZXItc2hlbGwuc2VydmljZSc7XG5leHBvcnQge0VsZGVyU2hlbGxTbG90RGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXNoZWxsLXNsb3QuZGlyZWN0aXZlJztcbmV4cG9ydCB7U2hlbGxDb250ZW50U2xvdH0gZnJvbSAnLi9zaGVsbC1jb250ZW50LXNsb3QnO1xuZXhwb3J0IHtFbGRlckFwcEhlYWRlckNvbXBvbmVudH0gZnJvbSAnLi9oZWFkZXIvZWxkZXItYXBwLWhlYWRlci9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsIFJvdXRlck1vZHVsZSxcblxuICAgICAgICBNYXRTaWRlbmF2TW9kdWxlLFxuICAgICAgICBNYXRUb29sYmFyTW9kdWxlLFxuICAgICAgICBNYXRJY29uTW9kdWxlLFxuICAgICAgICBNYXRMaXN0TW9kdWxlLFxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXG5cblxuICAgICAgICBFbGRlclRvb2xiYXJNb2R1bGUsXG5cbiAgICAgICAgRmxleExheW91dE1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLCBFbGRlclBhbmVsTW9kdWxlXG5cbiAgICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlclNoZWxsQ29tcG9uZW50LFxuICAgIEVsZGVyU2hlbGxTaWRlTGVmdERpcmVjdGl2ZSxcbiAgICBFbGRlclNoZWxsU2lkZVJpZ2h0RGlyZWN0aXZlLFxuICAgIEVsZGVyU2hlbGxDZW50ZXJEaXJlY3RpdmUsXG4gICAgRWxkZXJTaGVsbE5hdmlnYXRpb25Ub2dnbGVDb21wb25lbnQsXG4gICAgRWxkZXJTaGVsbFNsb3REaXJlY3RpdmUsXG4gICAgRWxkZXJBcHBIZWFkZXJDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyU2hlbGxDb21wb25lbnQsXG4gICAgRWxkZXJTaGVsbFNpZGVMZWZ0RGlyZWN0aXZlLFxuICAgIEVsZGVyU2hlbGxTaWRlUmlnaHREaXJlY3RpdmUsXG4gICAgRWxkZXJTaGVsbENlbnRlckRpcmVjdGl2ZSxcbiAgICBFbGRlclNoZWxsTmF2aWdhdGlvblRvZ2dsZUNvbXBvbmVudCxcbiAgICBFbGRlclNoZWxsU2xvdERpcmVjdGl2ZSxcbiAgICBFbGRlckFwcEhlYWRlckNvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyU2hlbGxNb2R1bGUgeyB9XG4iXX0=
92
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2hlbGwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zaGVsbC9lbGRlci1zaGVsbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLHlCQUF5QixFQUN6QixtQkFBbUIsRUFDbkIsMkJBQTJCLEVBQzNCLDRCQUE0QixFQUM3QixNQUFNLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUM5RSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLG1DQUFtQyxFQUFDLE1BQU0sbUVBQW1FLENBQUM7QUFDdEgsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDdkUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDL0YsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sOEJBQThCLENBQUM7O0FBRTlELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsT0FBTyxFQUFDLG1DQUFtQyxFQUFDLE1BQU0sbUVBQW1FLENBQUM7QUFDdEgsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sNkNBQTZDLENBQUM7QUFDMUYsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFDL0UsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDeEQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFFckUsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFxQzdGLE1BQU0sT0FBTyxnQkFBZ0I7OzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFsQnpCLG1CQUFtQjtRQUNuQiwyQkFBMkI7UUFDM0IsNEJBQTRCO1FBQzVCLHlCQUF5QjtRQUN6QixtQ0FBbUM7UUFDbkMsdUJBQXVCO1FBQ3ZCLHVCQUF1QixhQXJCbkIsWUFBWSxFQUFFLFlBQVk7UUFFMUIsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUNoQixhQUFhO1FBQ2IsYUFBYTtRQUNiLGVBQWU7UUFHZixrQkFBa0I7UUFFbEIsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixhQWF2RCxtQkFBbUI7UUFDbkIsMkJBQTJCO1FBQzNCLDRCQUE0QjtRQUM1Qix5QkFBeUI7UUFDekIsbUNBQW1DO1FBQ25DLHVCQUF1QjtRQUN2Qix1QkFBdUI7K0dBR2QsZ0JBQWdCLFlBbENoQjtZQUNMLFlBQVksRUFBRSxZQUFZO1lBRTFCLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsYUFBYTtZQUNiLGFBQWE7WUFDYixlQUFlO1lBR2Ysa0JBQWtCO1lBRWxCLGdCQUFnQixFQUFFLGVBQWUsRUFBRSxnQkFBZ0I7U0FFdEQ7NEZBb0JRLGdCQUFnQjtrQkFuQzVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVksRUFBRSxZQUFZO3dCQUUxQixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsYUFBYTt3QkFDYixhQUFhO3dCQUNiLGVBQWU7d0JBR2Ysa0JBQWtCO3dCQUVsQixnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCO3FCQUV0RDtvQkFDSCxZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQiwyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIseUJBQXlCO3dCQUN6QixtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsdUJBQXVCO3FCQUN4QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQiwyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIseUJBQXlCO3dCQUN6QixtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsdUJBQXVCO3FCQUN4QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgRWxkZXJTaGVsbENlbnRlckRpcmVjdGl2ZSxcbiAgRWxkZXJTaGVsbENvbXBvbmVudCxcbiAgRWxkZXJTaGVsbFNpZGVMZWZ0RGlyZWN0aXZlLFxuICBFbGRlclNoZWxsU2lkZVJpZ2h0RGlyZWN0aXZlXG59IGZyb20gJy4vc2hlbGwvZWxkZXItc2hlbGwuY29tcG9uZW50JztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBNYXRMaXN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGlzdCc7XG5pbXBvcnQgeyBNYXRTaWRlbmF2TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQgeyBNYXRUb29sYmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQge0ZsZXhMYXlvdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcbmltcG9ydCB7VHJhbnNsYXRlTW9kdWxlfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7RWxkZXJUb29sYmFyTW9kdWxlfSBmcm9tICcuLi9uYXZpZ2F0aW9uL3Rvb2xiYXIvZWxkZXItdG9vbGJhci5tb2R1bGUnO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge0VsZGVyU2hlbGxOYXZpZ2F0aW9uVG9nZ2xlQ29tcG9uZW50fSBmcm9tICcuL3NoZWxsLW5hdmlnYXRpb24tdG9nZ2xlL2VsZGVyLXNoZWxsLW5hdmlnYXRpb24tdG9nZ2xlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBFbGRlclNoZWxsU2xvdERpcmVjdGl2ZSB9IGZyb20gJy4vZWxkZXItc2hlbGwtc2xvdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgRWxkZXJBcHBIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2hlYWRlci9lbGRlci1hcHAtaGVhZGVyL2VsZGVyLWFwcC1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7RWxkZXJQYW5lbE1vZHVsZX0gZnJvbSAnLi4vcGFuZWxzL2VsZGVyLXBhbmVsLm1vZHVsZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vc2hlbGwvZWxkZXItc2hlbGwuY29tcG9uZW50JztcbmV4cG9ydCB7RWxkZXJTaGVsbE5hdmlnYXRpb25Ub2dnbGVDb21wb25lbnR9IGZyb20gJy4vc2hlbGwtbmF2aWdhdGlvbi10b2dnbGUvZWxkZXItc2hlbGwtbmF2aWdhdGlvbi10b2dnbGUuY29tcG9uZW50JztcbmV4cG9ydCB7RHJhd2VyT3V0bGV0QmluZGluZ30gZnJvbSAnLi9kcmF3ZXJzL2RyYXdlci1vdXRsZXQtYmluZGluZyc7XG5leHBvcnQge0VsZGVyUm91dGVPdXRsZXREcmF3ZXJTZXJ2aWNlfSBmcm9tICcuL2RyYXdlcnMvZWxkZXItcm91dGUtb3V0bGV0LWRyYXdlci5zZXJ2aWNlJztcbmV4cG9ydCB7RWxkZXJSb3V0ZXJPdXRsZXRTZXJ2aWNlfSBmcm9tICcuL2RyYXdlcnMvZWxkZXItcm91dGVyLW91dGxldC5zZXJ2aWNlJztcbmV4cG9ydCB7RWxkZXJTaGVsbFNlcnZpY2V9IGZyb20gJy4vZWxkZXItc2hlbGwuc2VydmljZSc7XG5leHBvcnQge0VsZGVyU2hlbGxTbG90RGlyZWN0aXZlfSBmcm9tICcuL2VsZGVyLXNoZWxsLXNsb3QuZGlyZWN0aXZlJztcbmV4cG9ydCB7U2hlbGxDb250ZW50U2xvdH0gZnJvbSAnLi9zaGVsbC1jb250ZW50LXNsb3QnO1xuZXhwb3J0IHtFbGRlckFwcEhlYWRlckNvbXBvbmVudH0gZnJvbSAnLi9oZWFkZXIvZWxkZXItYXBwLWhlYWRlci9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsIFJvdXRlck1vZHVsZSxcblxuICAgICAgICBNYXRTaWRlbmF2TW9kdWxlLFxuICAgICAgICBNYXRUb29sYmFyTW9kdWxlLFxuICAgICAgICBNYXRJY29uTW9kdWxlLFxuICAgICAgICBNYXRMaXN0TW9kdWxlLFxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXG5cblxuICAgICAgICBFbGRlclRvb2xiYXJNb2R1bGUsXG5cbiAgICAgICAgRmxleExheW91dE1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLCBFbGRlclBhbmVsTW9kdWxlXG5cbiAgICBdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBFbGRlclNoZWxsQ29tcG9uZW50LFxuICAgIEVsZGVyU2hlbGxTaWRlTGVmdERpcmVjdGl2ZSxcbiAgICBFbGRlclNoZWxsU2lkZVJpZ2h0RGlyZWN0aXZlLFxuICAgIEVsZGVyU2hlbGxDZW50ZXJEaXJlY3RpdmUsXG4gICAgRWxkZXJTaGVsbE5hdmlnYXRpb25Ub2dnbGVDb21wb25lbnQsXG4gICAgRWxkZXJTaGVsbFNsb3REaXJlY3RpdmUsXG4gICAgRWxkZXJBcHBIZWFkZXJDb21wb25lbnRcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEVsZGVyU2hlbGxDb21wb25lbnQsXG4gICAgRWxkZXJTaGVsbFNpZGVMZWZ0RGlyZWN0aXZlLFxuICAgIEVsZGVyU2hlbGxTaWRlUmlnaHREaXJlY3RpdmUsXG4gICAgRWxkZXJTaGVsbENlbnRlckRpcmVjdGl2ZSxcbiAgICBFbGRlclNoZWxsTmF2aWdhdGlvblRvZ2dsZUNvbXBvbmVudCxcbiAgICBFbGRlclNoZWxsU2xvdERpcmVjdGl2ZSxcbiAgICBFbGRlckFwcEhlYWRlckNvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEVsZGVyU2hlbGxNb2R1bGUgeyB9XG4iXX0=
@@ -134,12 +134,12 @@ export class ElderShellService {
134
134
  return this.routerOutletService.activate(this.detailContentOutlet, args, extras);
135
135
  }
136
136
  }
137
- ElderShellService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellService, deps: [{ token: i1.Router }, { token: i2.ElderRouterOutletService }], target: i0.ɵɵFactoryTarget.Injectable });
138
- ElderShellService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellService, providedIn: 'root' });
139
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellService, decorators: [{
137
+ ElderShellService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellService, deps: [{ token: i1.Router }, { token: i2.ElderRouterOutletService }], target: i0.ɵɵFactoryTarget.Injectable });
138
+ ElderShellService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellService, providedIn: 'root' });
139
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellService, decorators: [{
140
140
  type: Injectable,
141
141
  args: [{
142
142
  providedIn: 'root'
143
143
  }]
144
144
  }], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ElderRouterOutletService }]; } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell.service.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/elder-shell.service.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {Injectable, TemplateRef} from '@angular/core';\nimport {NavigationEnd, NavigationExtras, Router} from '@angular/router';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {filter, map} from 'rxjs/operators';\nimport {ElderRouterOutletService} from './drawers/elder-router-outlet.service';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {ShellContentSlot} from './shell-content-slot';\nimport {TemplateSlotManager} from '../../common/templates/template-slot-manager';\n\n/**\n * This service manages the side content.\n * This is usually the left side which is a 'side nav' and the right side which shows detail information.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderShellService {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderShellService');\n\n  private _navigationOpen = new BehaviorSubject<boolean>(false);\n  private _clickOutsideToClose = true;\n\n  private detailContentOutlet = 'side';\n\n  private readonly slotManager: TemplateSlotManager<ShellContentSlot>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private router: Router,\n    private routerOutletService: ElderRouterOutletService,\n  ) {\n\n    this.slotManager = new TemplateSlotManager(\n      [\n        'header',\n        'center',\n        'footer'\n      ]\n    );\n\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      map(event => event as NavigationEnd)\n    )\n      .subscribe(event => {\n        this.closeSideNav();\n      });\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the navigation is isOpen\n   */\n  public get navigationOpen(): boolean {\n    return this._navigationOpen.getValue();\n  }\n\n  public set navigationOpen(value: boolean) {\n    this._navigationOpen.next(value);\n  }\n\n  public get navigationOpenChange(): Observable<boolean> {\n    return this._navigationOpen.asObservable();\n  }\n\n  /**\n   * Allow closing the side content by clicking outside of it.\n   */\n  public get clickOutsideToClose(): boolean {\n    return this._clickOutsideToClose;\n  }\n\n\n  public set clickOutsideToClose(value: boolean) {\n    this._clickOutsideToClose = value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Shell Slot Template API                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Returns an observable which emits the current active template for the given position\n   * over time.\n   */\n  public activeSlotTemplate(slot: ShellContentSlot): Observable<TemplateRef<any>> {\n    return this.slotManager.activeSlotTemplate(slot);\n  }\n\n  /**\n   * Registers the given template as toolbar column at the given slot.\n   *\n   * @param slot at which template should be placed\n   * @param template to set at slot\n   * @param isDefault if the given template should be used as app default\n   */\n  public registerColumn(slot: ShellContentSlot, template: TemplateRef<any>, isDefault = false): void {\n    this.slotManager.registerSlotTemplate(slot, template, isDefault);\n  }\n\n  /**\n   * Deregister the given template from the toolbar.\n   *\n   * @param template to deregister\n   * @param slot if set, the template will only be deregistered if it was registered at this slot (optional)\n   */\n  public deregisterColumn(template: TemplateRef<any>, slot?: ShellContentSlot) {\n    this.slotManager.deregisterSlotTemplate(template, slot);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /**\n   * Toggles the side navigation\n   */\n  public toggleSidenav(): boolean {\n    this.navigationOpen = !this.navigationOpen;\n    return this.navigationOpen;\n  }\n\n  /**\n   * Closes the side navigation\n   */\n  public closeSideNav(): void {\n    this.navigationOpen = false;\n  }\n\n  /**\n   * Closes the side detail content\n   */\n  public closeSideContent(): Promise<boolean> {\n    return this.routerOutletService.deactivate(this.detailContentOutlet);\n  }\n\n  public isSideContentActive(): boolean {\n    return this.routerOutletService.isActive(this.detailContentOutlet);\n  }\n\n  /**\n   * Shows the side content\n   * @param args The route arguments / path\n   * @param clickOutsideToClose If enabled, the side content can be closed by clicking outside of it.\n   * @param extras\n   */\n  public navigateSideContent(args: string[], clickOutsideToClose: boolean, extras?: NavigationExtras): Promise<boolean> {\n    this.clickOutsideToClose = clickOutsideToClose;\n    return this.routerOutletService.activate(this.detailContentOutlet, args, extras);\n  }\n\n}\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-shell.service.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/shell/elder-shell.service.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {Injectable, TemplateRef} from '@angular/core';\nimport {NavigationEnd, NavigationExtras, Router} from '@angular/router';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {filter, map} from 'rxjs/operators';\nimport {ElderRouterOutletService} from './drawers/elder-router-outlet.service';\nimport {BehaviorSubject, Observable} from 'rxjs';\nimport {ShellContentSlot} from './shell-content-slot';\nimport {TemplateSlotManager} from '../../common/templates/template-slot-manager';\n\n/**\n * This service manages the side content.\n * This is usually the left side which is a 'side nav' and the right side which shows detail information.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ElderShellService {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger('ElderShellService');\n\n  private _navigationOpen = new BehaviorSubject<boolean>(false);\n  private _clickOutsideToClose = true;\n\n  private detailContentOutlet = 'side';\n\n  private readonly slotManager: TemplateSlotManager<ShellContentSlot>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private router: Router,\n    private routerOutletService: ElderRouterOutletService,\n  ) {\n\n    this.slotManager = new TemplateSlotManager(\n      [\n        'header',\n        'center',\n        'footer'\n      ]\n    );\n\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd),\n      map(event => event as NavigationEnd)\n    )\n      .subscribe(event => {\n        this.closeSideNav();\n      });\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the navigation is isOpen\n   */\n  public get navigationOpen(): boolean {\n    return this._navigationOpen.getValue();\n  }\n\n  public set navigationOpen(value: boolean) {\n    this._navigationOpen.next(value);\n  }\n\n  public get navigationOpenChange(): Observable<boolean> {\n    return this._navigationOpen.asObservable();\n  }\n\n  /**\n   * Allow closing the side content by clicking outside of it.\n   */\n  public get clickOutsideToClose(): boolean {\n    return this._clickOutsideToClose;\n  }\n\n\n  public set clickOutsideToClose(value: boolean) {\n    this._clickOutsideToClose = value;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Shell Slot Template API                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Returns an observable which emits the current active template for the given position\n   * over time.\n   */\n  public activeSlotTemplate(slot: ShellContentSlot): Observable<TemplateRef<any>> {\n    return this.slotManager.activeSlotTemplate(slot);\n  }\n\n  /**\n   * Registers the given template as toolbar column at the given slot.\n   *\n   * @param slot at which template should be placed\n   * @param template to set at slot\n   * @param isDefault if the given template should be used as app default\n   */\n  public registerColumn(slot: ShellContentSlot, template: TemplateRef<any>, isDefault = false): void {\n    this.slotManager.registerSlotTemplate(slot, template, isDefault);\n  }\n\n  /**\n   * Deregister the given template from the toolbar.\n   *\n   * @param template to deregister\n   * @param slot if set, the template will only be deregistered if it was registered at this slot (optional)\n   */\n  public deregisterColumn(template: TemplateRef<any>, slot?: ShellContentSlot) {\n    this.slotManager.deregisterSlotTemplate(template, slot);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /**\n   * Toggles the side navigation\n   */\n  public toggleSidenav(): boolean {\n    this.navigationOpen = !this.navigationOpen;\n    return this.navigationOpen;\n  }\n\n  /**\n   * Closes the side navigation\n   */\n  public closeSideNav(): void {\n    this.navigationOpen = false;\n  }\n\n  /**\n   * Closes the side detail content\n   */\n  public closeSideContent(): Promise<boolean> {\n    return this.routerOutletService.deactivate(this.detailContentOutlet);\n  }\n\n  public isSideContentActive(): boolean {\n    return this.routerOutletService.isActive(this.detailContentOutlet);\n  }\n\n  /**\n   * Shows the side content\n   * @param args The route arguments / path\n   * @param clickOutsideToClose If enabled, the side content can be closed by clicking outside of it.\n   * @param extras\n   */\n  public navigateSideContent(args: string[], clickOutsideToClose: boolean, extras?: NavigationExtras): Promise<boolean> {\n    this.clickOutsideToClose = clickOutsideToClose;\n    return this.routerOutletService.activate(this.detailContentOutlet, args, extras);\n  }\n\n}\n"]}
@@ -14,9 +14,9 @@ export class ElderAppHeaderComponent {
14
14
  ngOnInit() {
15
15
  }
16
16
  }
17
- ElderAppHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderAppHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
- ElderAppHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: ElderAppHeaderComponent, selector: "elder-app-header", inputs: { icon: "icon", iconColor: "iconColor", title: "title", subTitle: "subTitle", subTitleLink: "subTitleLink", version: "version", color: "color" }, ngImport: i0, template: "<mat-panel fxLayout=\"column\" [color]=\"color\" 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\">{{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"], components: [{ type: i1.ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: ["color"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.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"] }, { type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i3.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"] }, { type: i3.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"] }, { type: i3.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"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderAppHeaderComponent, decorators: [{
17
+ ElderAppHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderAppHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
+ ElderAppHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderAppHeaderComponent, selector: "elder-app-header", inputs: { icon: "icon", iconColor: "iconColor", title: "title", subTitle: "subTitle", subTitleLink: "subTitleLink", version: "version", color: "color" }, ngImport: i0, template: "<mat-panel fxLayout=\"column\" [color]=\"color\" 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\">{{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"], components: [{ type: i1.ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: ["color"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.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"] }, { type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i3.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"] }, { type: i3.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"] }, { type: i3.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"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderAppHeaderComponent, decorators: [{
20
20
  type: Component,
21
21
  args: [{ selector: 'elder-app-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-panel fxLayout=\"column\" [color]=\"color\" 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\">{{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"] }]
22
22
  }], ctorParameters: function () { return []; }, propDecorators: { icon: [{
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
34
34
  }], color: [{
35
35
  type: Input
36
36
  }] } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYXBwLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NoZWxsL2hlYWRlci9lbGRlci1hcHAtaGVhZGVyL2VsZGVyLWFwcC1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zaGVsbC9oZWFkZXIvZWxkZXItYXBwLWhlYWRlci9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVUsdUJBQXVCLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFTaEYsTUFBTSxPQUFPLHVCQUF1QjtJQXVCbEM7UUFqQk8sY0FBUyxHQUFpQixRQUFRLENBQUM7UUFNbkMsYUFBUSxHQUFHLGNBQWMsQ0FBQztRQUcxQixpQkFBWSxHQUFHLHVCQUF1QixDQUFDO1FBTXZDLFVBQUssR0FBaUIsU0FBUyxDQUFDO0lBRXZCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7O29IQTFCVSx1QkFBdUI7d0dBQXZCLHVCQUF1QixrTkNUcEMsbXFDQXlCQTsyRkRoQmEsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNOzBFQUt4QyxJQUFJO3NCQURWLEtBQUs7Z0JBSUMsU0FBUztzQkFEZixLQUFLO2dCQUlDLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsWUFBWTtzQkFEbEIsS0FBSztnQkFJQyxPQUFPO3NCQURiLEtBQUs7Z0JBSUMsS0FBSztzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VGhlbWVQYWxldHRlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWxkZXItYXBwLWhlYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItYXBwLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckFwcEhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGljb246IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgaWNvbkNvbG9yOiBUaGVtZVBhbGV0dGUgPSAnYWNjZW50JztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgdGl0bGU6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc3ViVGl0bGUgPSAnYnkgRWxkZXJCeXRlJztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc3ViVGl0bGVMaW5rID0gJ2h0dHBzOi8vZWxkZXJieXRlLmNvbSc7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHZlcnNpb246IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZSA9ICdwcmltYXJ5JztcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbn1cbiIsIjxtYXQtcGFuZWwgZnhMYXlvdXQ9XCJjb2x1bW5cIiBbY29sb3JdPVwiY29sb3JcIiBjbGFzcz1cImxpZ2h0XCIgZnhGaWxsPlxuICA8ZGl2IGZ4TGF5b3V0PVwicm93XCIgc3R5bGU9XCJwYWRkaW5nOiAyMHB4XCIgZnhGbGV4PVwibm9uZVwiPlxuICAgIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiPlxuICAgICAgPG1hdC1pY29uIGNsYXNzPVwibm9zZWxlY3QgdGl0bGUtaWNvblwiIFtjb2xvcl09XCJpY29uQ29sb3JcIj57e2ljb259fTwvbWF0LWljb24+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBmeExheW91dD1cImNvbHVtblwiIGZ4TGF5b3V0QWxpZ249XCJjZW50ZXIgc3RhcnRcIj5cbiAgICAgIDxkaXYgZnhMYXlvdXQ9XCJjb2x1bW5cIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiIHN0eWxlPVwid2lkdGg6IDEwMCVcIj5cbiAgICAgICAgPGRpdiBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0QWxpZ249XCJzdGFydCBlbmRcIiBmeExheW91dEdhcD1cIjVweFwiPlxuICAgICAgICAgIDxzcGFuIGlkPVwidGl0bGVcIiBjbGFzcz1cIm5vc2VsZWN0XCIgc3R5bGU9XCJmb250LXNpemU6IDI4cHhcIj57e3RpdGxlfX08L3NwYW4+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXQtY2FwdGlvbiBub3NlbGVjdFwiPjxzbWFsbD57e3ZlcnNpb259fTwvc21hbGw+PC9zcGFuPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0QWxpZ249XCJzdGFydCBjZW50ZXJcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXQtY2FwdGlvbiBub3NlbGVjdFwiPlxuICAgICAgICAgIDxzcGFuICpuZ0lmPVwiIXN1YlRpdGxlTGlua1wiPnt7c3ViVGl0bGV9fTwvc3Bhbj5cbiAgICAgICAgICA8YSAqbmdJZj1cInN1YlRpdGxlTGlua1wiIFtocmVmXT1cInN1YlRpdGxlTGlua1wiIHRhcmdldD1cIl9ibGFua1wiIHN0eWxlPVwidGV4dC1kZWNvcmF0aW9uOm5vbmU7IGNvbG9yOiBpbmhlcml0XCI+e3tzdWJUaXRsZX19PC9hPlxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbiAgPCEtLSBQcm9qZWN0IGNoaWxkIGNvbnRlbnQgaGVyZSAtLT5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG48L21hdC1wYW5lbD5cbiJdfQ==
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYXBwLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NoZWxsL2hlYWRlci9lbGRlci1hcHAtaGVhZGVyL2VsZGVyLWFwcC1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zaGVsbC9oZWFkZXIvZWxkZXItYXBwLWhlYWRlci9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVUsdUJBQXVCLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFTaEYsTUFBTSxPQUFPLHVCQUF1QjtJQXVCbEM7UUFqQk8sY0FBUyxHQUFpQixRQUFRLENBQUM7UUFNbkMsYUFBUSxHQUFHLGNBQWMsQ0FBQztRQUcxQixpQkFBWSxHQUFHLHVCQUF1QixDQUFDO1FBTXZDLFVBQUssR0FBaUIsU0FBUyxDQUFDO0lBRXZCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7O3FIQTFCVSx1QkFBdUI7eUdBQXZCLHVCQUF1QixrTkNUcEMsbXFDQXlCQTs0RkRoQmEsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNOzBFQUt4QyxJQUFJO3NCQURWLEtBQUs7Z0JBSUMsU0FBUztzQkFEZixLQUFLO2dCQUlDLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsWUFBWTtzQkFEbEIsS0FBSztnQkFJQyxPQUFPO3NCQURiLEtBQUs7Z0JBSUMsS0FBSztzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VGhlbWVQYWxldHRlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZWxkZXItYXBwLWhlYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9lbGRlci1hcHAtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItYXBwLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlckFwcEhlYWRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KClcbiAgcHVibGljIGljb246IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgaWNvbkNvbG9yOiBUaGVtZVBhbGV0dGUgPSAnYWNjZW50JztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgdGl0bGU6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc3ViVGl0bGUgPSAnYnkgRWxkZXJCeXRlJztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc3ViVGl0bGVMaW5rID0gJ2h0dHBzOi8vZWxkZXJieXRlLmNvbSc7XG5cbiAgQElucHV0KClcbiAgcHVibGljIHZlcnNpb246IHN0cmluZztcblxuICBASW5wdXQoKVxuICBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZSA9ICdwcmltYXJ5JztcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbn1cbiIsIjxtYXQtcGFuZWwgZnhMYXlvdXQ9XCJjb2x1bW5cIiBbY29sb3JdPVwiY29sb3JcIiBjbGFzcz1cImxpZ2h0XCIgZnhGaWxsPlxuICA8ZGl2IGZ4TGF5b3V0PVwicm93XCIgc3R5bGU9XCJwYWRkaW5nOiAyMHB4XCIgZnhGbGV4PVwibm9uZVwiPlxuICAgIDxkaXYgZnhMYXlvdXQ9XCJyb3dcIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiPlxuICAgICAgPG1hdC1pY29uIGNsYXNzPVwibm9zZWxlY3QgdGl0bGUtaWNvblwiIFtjb2xvcl09XCJpY29uQ29sb3JcIj57e2ljb259fTwvbWF0LWljb24+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBmeExheW91dD1cImNvbHVtblwiIGZ4TGF5b3V0QWxpZ249XCJjZW50ZXIgc3RhcnRcIj5cbiAgICAgIDxkaXYgZnhMYXlvdXQ9XCJjb2x1bW5cIiBmeExheW91dEFsaWduPVwiY2VudGVyIGNlbnRlclwiIHN0eWxlPVwid2lkdGg6IDEwMCVcIj5cbiAgICAgICAgPGRpdiBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0QWxpZ249XCJzdGFydCBlbmRcIiBmeExheW91dEdhcD1cIjVweFwiPlxuICAgICAgICAgIDxzcGFuIGlkPVwidGl0bGVcIiBjbGFzcz1cIm5vc2VsZWN0XCIgc3R5bGU9XCJmb250LXNpemU6IDI4cHhcIj57e3RpdGxlfX08L3NwYW4+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXQtY2FwdGlvbiBub3NlbGVjdFwiPjxzbWFsbD57e3ZlcnNpb259fTwvc21hbGw+PC9zcGFuPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBmeExheW91dD1cInJvd1wiIGZ4TGF5b3V0QWxpZ249XCJzdGFydCBjZW50ZXJcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXQtY2FwdGlvbiBub3NlbGVjdFwiPlxuICAgICAgICAgIDxzcGFuICpuZ0lmPVwiIXN1YlRpdGxlTGlua1wiPnt7c3ViVGl0bGV9fTwvc3Bhbj5cbiAgICAgICAgICA8YSAqbmdJZj1cInN1YlRpdGxlTGlua1wiIFtocmVmXT1cInN1YlRpdGxlTGlua1wiIHRhcmdldD1cIl9ibGFua1wiIHN0eWxlPVwidGV4dC1kZWNvcmF0aW9uOm5vbmU7IGNvbG9yOiBpbmhlcml0XCI+e3tzdWJUaXRsZX19PC9hPlxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbiAgPCEtLSBQcm9qZWN0IGNoaWxkIGNvbnRlbnQgaGVyZSAtLT5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG48L21hdC1wYW5lbD5cbiJdfQ==
@@ -18,9 +18,9 @@ export class ElderShellSideLeftDirective {
18
18
  this.viewContainer = viewContainer;
19
19
  }
20
20
  }
21
- ElderShellSideLeftDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSideLeftDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
22
- ElderShellSideLeftDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderShellSideLeftDirective, selector: "[elderShellSideLeft], [ebsShellSideLeft]", ngImport: i0 });
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSideLeftDirective, decorators: [{
21
+ ElderShellSideLeftDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSideLeftDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
22
+ ElderShellSideLeftDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderShellSideLeftDirective, selector: "[elderShellSideLeft], [ebsShellSideLeft]", ngImport: i0 });
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSideLeftDirective, decorators: [{
24
24
  type: Directive,
25
25
  args: [{ selector: '[elderShellSideLeft], [ebsShellSideLeft]' }]
26
26
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -30,9 +30,9 @@ export class ElderShellSideRightDirective {
30
30
  this.viewContainer = viewContainer;
31
31
  }
32
32
  }
33
- ElderShellSideRightDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSideRightDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
34
- ElderShellSideRightDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderShellSideRightDirective, selector: "[elderShellSideRight], [ebsShellSideRight]", ngImport: i0 });
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellSideRightDirective, decorators: [{
33
+ ElderShellSideRightDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSideRightDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
34
+ ElderShellSideRightDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderShellSideRightDirective, selector: "[elderShellSideRight], [ebsShellSideRight]", ngImport: i0 });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellSideRightDirective, decorators: [{
36
36
  type: Directive,
37
37
  args: [{ selector: '[elderShellSideRight], [ebsShellSideRight]' }]
38
38
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -42,9 +42,9 @@ export class ElderShellCenterDirective {
42
42
  this.viewContainer = viewContainer;
43
43
  }
44
44
  }
45
- ElderShellCenterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellCenterDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
46
- ElderShellCenterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderShellCenterDirective, selector: "[elderShellCenter], [ebsShellCenter]", ngImport: i0 });
47
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellCenterDirective, decorators: [{
45
+ ElderShellCenterDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellCenterDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
46
+ ElderShellCenterDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderShellCenterDirective, selector: "[elderShellCenter], [ebsShellCenter]", ngImport: i0 });
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellCenterDirective, decorators: [{
48
48
  type: Directive,
49
49
  args: [{ selector: '[elderShellCenter], [ebsShellCenter]' }]
50
50
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -141,9 +141,9 @@ export class ElderShellComponent {
141
141
  }, 5);
142
142
  }
143
143
  }
144
- ElderShellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellComponent, deps: [{ token: i1.ElderShellService }, { token: i2.ElderRouteOutletDrawerService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
145
- ElderShellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: ElderShellComponent, selector: "elder-shell, ebs-shell", inputs: { sideNavToggleEnabled: "sideNavToggleEnabled", color: "color", menuColor: "menuColor", leftSideAutoFocus: "leftSideAutoFocus", rightSideAutoFocus: "rightSideAutoFocus" }, 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 style=\"height:100%; width: 100%\" (backdropClick)=\"onBackdropClick($event)\">\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\n <elder-toolbar [color]=\"color\">\n\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\"\n [color]=\"menuColor\">\n <button mat-icon-button type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n\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"], components: [{ type: i3.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { type: i3.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { type: i3.MatSidenavContent, selector: "mat-sidenav-content" }, { type: i4.ElderToolbarComponent, selector: "elder-toolbar, ebs-toolbar", inputs: ["color"] }, { type: i5.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i6.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"] }, { type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i8.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i8.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"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.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"] }, { type: i10.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.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"] }], pipes: { "async": i9.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
146
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellComponent, decorators: [{
144
+ ElderShellComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellComponent, deps: [{ token: i1.ElderShellService }, { token: i2.ElderRouteOutletDrawerService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
145
+ ElderShellComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderShellComponent, selector: "elder-shell, ebs-shell", inputs: { sideNavToggleEnabled: "sideNavToggleEnabled", color: "color", menuColor: "menuColor", leftSideAutoFocus: "leftSideAutoFocus", rightSideAutoFocus: "rightSideAutoFocus" }, 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 style=\"height:100%; width: 100%\" (backdropClick)=\"onBackdropClick($event)\">\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\n <elder-toolbar [color]=\"color\">\n\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\"\n [color]=\"menuColor\">\n <button mat-icon-button type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n\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"], components: [{ type: i3.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { type: i3.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { type: i3.MatSidenavContent, selector: "mat-sidenav-content" }, { type: i4.ElderToolbarComponent, selector: "elder-toolbar, ebs-toolbar", inputs: ["color"] }, { type: i5.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i6.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"] }, { type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i8.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { type: i8.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"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.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"] }, { type: i10.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.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"] }], pipes: { "async": i9.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
146
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellComponent, decorators: [{
147
147
  type: Component,
148
148
  args: [{ selector: 'elder-shell, ebs-shell', changeDetection: ChangeDetectionStrategy.OnPush, template: "\n<mat-sidenav-container style=\"height:100%; width: 100%\" (backdropClick)=\"onBackdropClick($event)\">\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\n <elder-toolbar [color]=\"color\">\n\n <!-- Toolbar Prefix: Sidenav Toggle -->\n <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\"\n [color]=\"menuColor\">\n <button mat-icon-button type=\"button\" (click)=\"toggleSideNav()\">\n <mat-icon>menu</mat-icon>\n </button>\n </mat-toolbar>\n </elder-toolbar>\n\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n\n <!-- Primary Router Outlet -->\n <router-outlet class=\"router-flex\"></router-outlet>\n\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"] }]
149
149
  }], ctorParameters: function () { return [{ type: i1.ElderShellService }, { type: i2.ElderRouteOutletDrawerService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { sideNavToggleEnabled: [{
@@ -169,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
169
169
  type: ViewChild,
170
170
  args: ['rightSideDetail', { static: true }]
171
171
  }] } });
172
- //# 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, 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 {Observable, Subscription} from 'rxjs';\nimport {ShellContentSlot} from '../shell-content-slot';\nimport {tap} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\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 color: ThemePalette = 'primary';\n\n  @Input()\n  public menuColor: ThemePalette = 'accent';\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 _sub: Subscription;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private shellService: ElderShellService,\n    private outletDrawerService: ElderRouteOutletDrawerService,\n    private changeDetectorRef: ChangeDetectorRef\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._sub = this.outletDrawerService.drawerVisibilityChange.subscribe(\n      drawer =>  this.changeDetectorRef.markForCheck()\n    );\n\n    this.leftSideContentOpen$ =  this.shellService.navigationOpenChange;\n  }\n\n  public ngOnDestroy(): void {\n\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 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 style=\"height:100%; width: 100%\" (backdropClick)=\"onBackdropClick($event)\">\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\n  <elder-toolbar [color]=\"color\">\n\n    <!-- Toolbar Prefix: Sidenav Toggle -->\n    <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n                 fxLayout=\"row\" fxLayoutAlign=\"center center\"\n                 [color]=\"menuColor\">\n      <button mat-icon-button type=\"button\" (click)=\"toggleSideNav()\">\n        <mat-icon>menu</mat-icon>\n      </button>\n    </mat-toolbar>\n  </elder-toolbar>\n\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n\n  <!-- Primary Router Outlet -->\n  <router-outlet class=\"router-flex\"></router-outlet>\n\n</ng-template>\n\n<ng-template #defaultFooterTemplate>\n  <!-- Default Footer is empty -->\n</ng-template>\n"]}
172
+ //# 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, 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 {Observable, Subscription} from 'rxjs';\nimport {ShellContentSlot} from '../shell-content-slot';\nimport {tap} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\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 color: ThemePalette = 'primary';\n\n  @Input()\n  public menuColor: ThemePalette = 'accent';\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 _sub: Subscription;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private shellService: ElderShellService,\n    private outletDrawerService: ElderRouteOutletDrawerService,\n    private changeDetectorRef: ChangeDetectorRef\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._sub = this.outletDrawerService.drawerVisibilityChange.subscribe(\n      drawer =>  this.changeDetectorRef.markForCheck()\n    );\n\n    this.leftSideContentOpen$ =  this.shellService.navigationOpenChange;\n  }\n\n  public ngOnDestroy(): void {\n\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 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 style=\"height:100%; width: 100%\" (backdropClick)=\"onBackdropClick($event)\">\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\n  <elder-toolbar [color]=\"color\">\n\n    <!-- Toolbar Prefix: Sidenav Toggle -->\n    <mat-toolbar *ngIf=\"sideNavToggleEnabled\" fxFlex=\"0\"\n                 fxLayout=\"row\" fxLayoutAlign=\"center center\"\n                 [color]=\"menuColor\">\n      <button mat-icon-button type=\"button\" (click)=\"toggleSideNav()\">\n        <mat-icon>menu</mat-icon>\n      </button>\n    </mat-toolbar>\n  </elder-toolbar>\n\n</ng-template>\n\n<ng-template #defaultCenterTemplate>\n\n  <!-- Primary Router Outlet -->\n  <router-outlet class=\"router-flex\"></router-outlet>\n\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: "13.3.4", ngImport: i0, type: ElderShellNavigationToggleComponent, deps: [{ token: i1.Router }, { token: i2.ElderShellService }], target: i0.ɵɵFactoryTarget.Component });
128
- ElderShellNavigationToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.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: [""], components: [{ type: i3.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"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe } });
129
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderShellNavigationToggleComponent, decorators: [{
127
+ ElderShellNavigationToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderShellNavigationToggleComponent, deps: [{ token: i1.Router }, { token: i2.ElderShellService }], target: i0.ɵɵFactoryTarget.Component });
128
+ ElderShellNavigationToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.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: [""], components: [{ type: i3.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"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe } });
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.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", styles: [""] }]
132
132
  }], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.ElderShellService }]; }, propDecorators: { roots: [{
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.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":"AAAA,OAAO,EAAC,SAAS,EAAE,KAAK,EAAoB,MAAM,eAAe,CAAC;AAClE,OAAO,EAAC,aAAa,EAAS,MAAM,iBAAiB,CAAC;AAEtD,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAA2B,MAAM,MAAM,CAAC;;;;;;;AAO/D,MAAM,OAAO,mCAAmC;IAoB5C;;;;gFAI4E;IAE5E,YACY,MAAc,EACd,kBAAqC;QADrC,WAAM,GAAN,MAAM,CAAQ;QACd,uBAAkB,GAAlB,kBAAkB,CAAmB;QA1BjD;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEjE,UAAK,GAAG,IAAI,eAAe,CAAS,MAAM,CAAC,CAAC;QAK7C,UAAK,GAAa,EAAE,CAAC;QAGrB,SAAI,GAAa,EAAE,CAAC;IAWvB,CAAC;IAEL;;;;gFAI4E;IAErE,QAAQ;QAEX,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC9C,IAAI,KAAK,YAAY,aAAa,EAAE;gBAChC,MAAM,MAAM,GAAG,KAAsB,CAAC;gBACtC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,GAAG,CAAC;gBAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;aACrB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;IAC3B,CAAC;IAED;;;;gFAI4E;IAErE,OAAO;QACV,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACjC;aAAM;YACH,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC5B;IACL,CAAC;IAED,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAEM,aAAa;QAChB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACvD,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACtD;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED;;;;gFAI4E;IAEpE,UAAU;QACd,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC;QAC3D,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,GAAG,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAGD,IAAY,gBAAgB;QACxB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACzD,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC9C;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAGO,iBAAiB;QACrB,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;IAC5C,CAAC;IAEO,MAAM,CAAC,GAAW;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IACpC,CAAC;IAEO,WAAW,CAAC,GAAW;QAC3B,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;IAC7C,CAAC;IAEO,mBAAmB,CAAC,GAAW;QACnC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACtD,CAAC;IAED;;;;;;;;;OASG;IACK,QAAQ,CAAC,GAAW;QACxB,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE;gBAAE,OAAO,GAAG,CAAC;aAAE;YAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAChC,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SAChC;aAAM;YACH,OAAO,GAAG,CAAC;SACd;IACL,CAAC;IAEO,MAAM,CAAC,GAAW;QACtB,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7B,mBAAmB;QACnB,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;;iIA5IQ,mCAAmC;qHAAnC,mCAAmC,wGCXhD,kJAIA;4FDOa,mCAAmC;kBAL/C,SAAS;+BACI,wBAAwB;6HAmB3B,KAAK;sBADX,KAAK;gBAIC,IAAI;sBADV,KAAK","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"]}