@elderbyte/ngx-starter 14.3.0 → 14.3.3

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 (293) hide show
  1. package/esm2020/lib/common/data/data-context/data-context-base.mjs +1 -1
  2. package/esm2020/lib/common/data/data-context/data-context-continuable-paged.mjs +1 -1
  3. package/esm2020/lib/common/data/data-context/data-context-simple.mjs +1 -1
  4. package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +3 -3
  5. package/esm2020/lib/common/forms/elder-form-field-control.mjs +139 -0
  6. package/esm2020/lib/common/forms/form-field-base.component.mjs +3 -3
  7. package/esm2020/lib/common/forms/multi-model-base.component.mjs +3 -3
  8. package/esm2020/lib/common/forms/public_api.mjs +2 -1
  9. package/esm2020/lib/common/forms/template-composite-control.mjs +3 -3
  10. package/esm2020/lib/common/forms/value-accessor-base.mjs +3 -3
  11. package/esm2020/lib/common/http/http-client-builder.service.mjs +3 -3
  12. package/esm2020/lib/common/http/http-client-pristine.mjs +3 -3
  13. package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +3 -3
  14. package/esm2020/lib/common/http/transfer/http-data-transfer.mjs +1 -1
  15. package/esm2020/lib/common/public_api.mjs +1 -2
  16. package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +3 -3
  17. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -3
  18. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -4
  19. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +3 -3
  20. package/esm2020/lib/components/auditing/elder-audit.module.mjs +4 -4
  21. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -3
  22. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -4
  23. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +3 -3
  24. package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +3 -3
  25. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +4 -4
  26. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -4
  27. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -3
  28. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +18 -18
  29. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -4
  30. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -4
  31. package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +3 -3
  32. package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +3 -3
  33. package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -4
  34. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -3
  35. package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +3 -3
  36. package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +3 -3
  37. package/esm2020/lib/components/csv/elder-csv.module.mjs +4 -4
  38. package/esm2020/lib/components/currency/elder-currency.module.mjs +4 -4
  39. package/esm2020/lib/components/currency/elder-currency.pipe.mjs +3 -3
  40. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -4
  41. package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +3 -3
  42. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -3
  43. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +3 -3
  44. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +3 -3
  45. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +3 -3
  46. package/esm2020/lib/components/data-view/base/data-view-options-provider-binding.mjs +63 -0
  47. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +56 -13
  48. package/esm2020/lib/components/data-view/base/elder-data-view-options-provider.mjs +44 -0
  49. package/esm2020/lib/components/data-view/base/elder-data-view-options.mjs +42 -0
  50. package/esm2020/lib/components/data-view/base/public_api.mjs +6 -0
  51. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +3 -3
  52. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -4
  53. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +6 -6
  54. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +3 -3
  55. package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +3 -3
  56. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -3
  57. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +16 -30
  58. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +4 -4
  59. package/esm2020/lib/components/data-view/public_api.mjs +2 -2
  60. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +3 -3
  61. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -4
  62. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  63. package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +3 -3
  64. package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +3 -3
  65. package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +3 -3
  66. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +12 -46
  67. package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +3 -3
  68. package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  69. package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +3 -3
  70. package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +3 -3
  71. package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +3 -3
  72. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -4
  73. package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +3 -3
  74. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +3 -3
  75. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +7 -7
  76. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +3 -3
  77. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +3 -3
  78. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +3 -3
  79. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +3 -3
  80. package/esm2020/lib/components/errors/elder-error.module.mjs +4 -4
  81. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -3
  82. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +3 -3
  83. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -4
  84. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
  85. package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +3 -3
  86. package/esm2020/lib/components/files/elder-file-select.directive.mjs +3 -3
  87. package/esm2020/lib/components/files/elder-file.module.mjs +4 -4
  88. package/esm2020/lib/components/files/file-select/file-select.component.mjs +3 -3
  89. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +3 -3
  90. package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +3 -3
  91. package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +3 -3
  92. package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +3 -3
  93. package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +3 -3
  94. package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +3 -3
  95. package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +3 -3
  96. package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +3 -3
  97. package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +3 -3
  98. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +13 -13
  99. package/esm2020/lib/components/forms/directives/elder-input-pattern.directive.mjs +3 -3
  100. package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +3 -3
  101. package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +3 -3
  102. package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +3 -3
  103. package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +3 -3
  104. package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +3 -3
  105. package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +3 -3
  106. package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  107. package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +3 -3
  108. package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +3 -3
  109. package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +3 -3
  110. package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +3 -3
  111. package/esm2020/lib/components/forms/elder-forms.module.mjs +4 -4
  112. package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +6 -6
  113. package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
  114. package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -4
  115. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
  116. package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +3 -3
  117. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +3 -3
  118. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -4
  119. package/esm2020/lib/components/global-search/elder-global-search.service.mjs +3 -3
  120. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -3
  121. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -4
  122. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +3 -3
  123. package/esm2020/lib/components/headers/elder-header.module.mjs +4 -4
  124. package/esm2020/lib/components/http-support/elder-http-client.service.mjs +3 -3
  125. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +4 -4
  126. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
  127. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +3 -3
  128. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +3 -3
  129. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
  130. package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +3 -3
  131. package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  132. package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +3 -3
  133. package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +3 -3
  134. package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +3 -3
  135. package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +3 -3
  136. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +4 -4
  137. package/esm2020/lib/components/i18n/language/elder-language.service.mjs +3 -3
  138. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +3 -3
  139. package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +4 -4
  140. package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +119 -0
  141. package/esm2020/lib/components/iframes/data-view/data-view-iframe-adapter.directive.mjs +137 -0
  142. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +22 -10
  143. package/esm2020/lib/components/iframes/iframe-close.directive.mjs +3 -3
  144. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +3 -3
  145. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +58 -32
  146. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +3 -3
  147. package/esm2020/lib/components/iframes/iframe.service.mjs +6 -8
  148. package/esm2020/lib/components/iframes/typed-event-message.mjs +42 -0
  149. package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +7 -5
  150. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  151. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +7 -7
  152. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +3 -3
  153. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  154. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +4 -4
  155. package/esm2020/lib/components/labels/elder-labels.module.mjs +4 -4
  156. package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +3 -3
  157. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +3 -3
  158. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +5 -5
  159. package/esm2020/lib/components/measures/elder-measures.module.mjs +8 -8
  160. package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +3 -3
  161. package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +3 -3
  162. package/esm2020/lib/components/measures/elder-unit.service.mjs +3 -3
  163. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +3 -3
  164. package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +3 -3
  165. package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +4 -4
  166. package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +3 -3
  167. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
  168. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -4
  169. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -4
  170. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
  171. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +3 -3
  172. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -3
  173. package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +3 -3
  174. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -4
  175. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +3 -3
  176. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +4 -4
  177. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +3 -3
  178. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +3 -3
  179. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +3 -3
  180. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +3 -3
  181. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +4 -4
  182. package/esm2020/lib/components/overlays/elder-overlay.module.mjs +4 -4
  183. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -3
  184. package/esm2020/lib/components/panels/elder-panel.module.mjs +4 -4
  185. package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +3 -3
  186. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +5 -5
  187. package/esm2020/lib/components/select/auto/elder-select-first-util.mjs +1 -1
  188. package/esm2020/lib/components/select/elder-select-base.mjs +3 -3
  189. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +6 -6
  190. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  191. package/esm2020/lib/components/select/elder-select-value.directive.mjs +3 -3
  192. package/esm2020/lib/components/select/elder-select.module.mjs +8 -8
  193. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +3 -3
  194. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +3 -3
  195. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +23 -28
  196. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +3 -3
  197. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +419 -0
  198. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +3 -3
  199. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -4
  200. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -4
  201. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -3
  202. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -3
  203. package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +3 -3
  204. package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +3 -3
  205. package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +3 -3
  206. package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -4
  207. package/esm2020/lib/components/shell/elder-shell.service.mjs +3 -3
  208. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
  209. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +13 -13
  210. package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +3 -3
  211. package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +3 -3
  212. package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  213. package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -4
  214. package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +4 -4
  215. package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +3 -3
  216. package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +3 -3
  217. package/esm2020/lib/components/theme/elder-theme.directive.mjs +4 -4
  218. package/esm2020/lib/components/theme/elder-theme.module.mjs +4 -4
  219. package/esm2020/lib/components/theme/elder-theme.service.mjs +3 -3
  220. package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +3 -3
  221. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +3 -3
  222. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +3 -3
  223. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +3 -3
  224. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +3 -3
  225. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +3 -3
  226. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +3 -3
  227. package/esm2020/lib/components/time/elder-time.module.mjs +8 -8
  228. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +3 -3
  229. package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -4
  230. package/esm2020/lib/components/toasts/elder-toast.service.mjs +9 -9
  231. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +3 -3
  232. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +4 -4
  233. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +3 -3
  234. package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +3 -3
  235. package/esm2020/lib/components/viewers/elder-viewers.module.mjs +4 -4
  236. package/esm2020/lib/features/event-source/elder-event-source.service.mjs +3 -3
  237. package/esm2020/lib/features/kafent/access-token-provider.mjs +3 -3
  238. package/esm2020/lib/features/kafent/kafent-config.mjs +3 -3
  239. package/esm2020/lib/features/kafent/kafent-event-stream.mjs +3 -3
  240. package/esm2020/lib/features/kafent/kafent-event.service.mjs +3 -3
  241. package/esm2020/lib/features/kafent/kafent.module.mjs +4 -4
  242. package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +3 -3
  243. package/esm2020/lib/pipes/bytes.pipe.mjs +3 -3
  244. package/esm2020/lib/pipes/elder-pipes.module.mjs +10 -10
  245. package/esm2020/lib/pipes/elder-repeat.pipe.mjs +3 -3
  246. package/esm2020/lib/pipes/elder-round.pipe.mjs +3 -3
  247. package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +3 -3
  248. package/esm2020/lib/pipes/elder-truncate.pipe.mjs +3 -3
  249. package/esm2020/lib/pipes/iso-duration.pipe.mjs +3 -3
  250. package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +3 -3
  251. package/esm2020/lib/pipes/iso-interval.pipe.mjs +3 -3
  252. package/esm2020/lib/pipes/time-ago.pipe.mjs +3 -3
  253. package/esm2020/lib/pipes/time-duration.pipe.mjs +3 -3
  254. package/esm2020/lib/pipes/weight.pipe.mjs +3 -3
  255. package/fesm2015/elderbyte-ngx-starter.mjs +2717 -2204
  256. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  257. package/fesm2020/elderbyte-ngx-starter.mjs +2472 -1962
  258. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  259. package/lib/common/data/data-context/data-context-base.d.ts +1 -1
  260. package/lib/common/forms/elder-form-field-control.d.ts +86 -0
  261. package/lib/common/forms/public_api.d.ts +1 -0
  262. package/lib/common/public_api.d.ts +0 -1
  263. package/lib/components/data-view/base/data-view-options-provider-binding.d.ts +39 -0
  264. package/lib/components/data-view/base/elder-data-view-base.d.ts +29 -6
  265. package/lib/{common/rxjs/lazy-behavior-subject.d.ts → components/data-view/base/elder-data-view-options-provider.d.ts} +20 -20
  266. package/lib/components/data-view/base/elder-data-view-options.d.ts +33 -0
  267. package/lib/components/data-view/base/public_api.d.ts +5 -0
  268. package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -6
  269. package/lib/components/data-view/public_api.d.ts +1 -1
  270. package/lib/components/data-view/table/elder-table/elder-table.component.d.ts +5 -19
  271. package/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.d.ts +66 -0
  272. package/lib/components/iframes/data-view/data-view-iframe-adapter.directive.d.ts +62 -0
  273. package/lib/components/iframes/elder-iframe.module.d.ts +14 -10
  274. package/lib/components/iframes/iframe-host/iframe-host.component.d.ts +28 -10
  275. package/lib/components/iframes/iframe.service.d.ts +3 -3
  276. package/lib/components/iframes/typed-event-message.d.ts +26 -0
  277. package/lib/components/measures/directives/elder-unit-select.directive.d.ts +1 -1
  278. package/lib/components/select/auto/elder-auto-select-first.directive.d.ts +1 -1
  279. package/lib/components/select/auto/elder-select-first-util.d.ts +1 -1
  280. package/lib/components/select/elder-select.module.d.ts +3 -3
  281. package/lib/components/select/popup/selection-model-popup.directive.d.ts +5 -13
  282. package/lib/components/select/{elder-select → single/elder-select}/elder-select.component.d.ts +3 -3
  283. package/package.json +3 -2
  284. package/src/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.scss +0 -0
  285. package/src/lib/components/select/{elder-select → single/elder-select}/elder-select.component.scss +0 -0
  286. package/esm2020/lib/common/rxjs/lazy-behavior-subject.mjs +0 -59
  287. package/esm2020/lib/common/rxjs/public_api.mjs +0 -2
  288. package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +0 -18
  289. package/esm2020/lib/components/iframes/iframe-message.mjs +0 -2
  290. package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +0 -411
  291. package/lib/common/rxjs/public_api.d.ts +0 -1
  292. package/lib/components/data-view/base/elder-data-view-base.module.d.ts +0 -9
  293. package/lib/components/iframes/iframe-message.d.ts +0 -5
@@ -239,9 +239,9 @@ export class ElderTableActivationDirective {
239
239
  }
240
240
  }
241
241
  }
242
- ElderTableActivationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableActivationDirective, deps: [{ token: i1.ElderTableComponent }], target: i0.ɵɵFactoryTarget.Directive });
243
- ElderTableActivationDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.3", type: ElderTableActivationDirective, selector: "elder-table[elderTableActivation]", inputs: { activationOptions: ["elderTableActivation", "activationOptions"], activeItem: "activeItem" }, outputs: { activeItemChange: "activeItemChange" }, host: { listeners: { "keydown": "onKeydown($event)" } }, exportAs: ["elderTableActivation"], ngImport: i0 });
244
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableActivationDirective, decorators: [{
242
+ ElderTableActivationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableActivationDirective, deps: [{ token: i1.ElderTableComponent }], target: i0.ɵɵFactoryTarget.Directive });
243
+ ElderTableActivationDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.0", type: ElderTableActivationDirective, selector: "elder-table[elderTableActivation]", inputs: { activationOptions: ["elderTableActivation", "activationOptions"], activeItem: "activeItem" }, outputs: { activeItemChange: "activeItemChange" }, host: { listeners: { "keydown": "onKeydown($event)" } }, exportAs: ["elderTableActivation"], ngImport: i0 });
244
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableActivationDirective, decorators: [{
245
245
  type: Directive,
246
246
  args: [{
247
247
  selector: 'elder-table[elderTableActivation]',
@@ -258,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImpor
258
258
  }], activeItem: [{
259
259
  type: Input
260
260
  }] } });
261
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table-activation.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/activation/elder-table-activation.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  HostListener,\n  Input,\n  OnDestroy, Output,\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {switchMap, takeUntil, tap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {ElderTableComponent} from '../elder-table/elder-table.component';\nimport {ElderTableActivationOptions} from './elder-table-activation-options';\nimport {ElderItemActivator} from './elder-item-activator';\n\n@Directive({\n  selector: 'elder-table[elderTableActivation]',\n  exportAs: 'elderTableActivation'\n})\nexport class ElderTableActivationDirective<T> implements ElderItemActivator<T>, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly unsubscribe$ = new Subject();\n\n  public readonly activeItem$ = new BehaviorSubject<T>(null);\n\n  @Input('elderTableActivation')\n  public activationOptions: ElderTableActivationOptions = {};\n\n  private _data: T[] = [];\n\n  private readonly rows$ = new BehaviorSubject<ElderTableRowDirective<T>[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly elderTable: ElderTableComponent\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n\n    const rows$ = this.elderTable.rows$;\n    const data$ = this.elderTable.dataContext$.pipe(\n      switchMap(dc => dc.data),\n      tap(data => this._data = data)\n    );\n\n    combineLatest([rows$, data$]).pipe(\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      ([rows, data]) => {\n        this.rows$.next(\n          this.rowDataUpdated(rows, data)\n        );\n      }\n    );\n\n    combineLatest([this.rows$, this.activeItem$]).pipe(\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      ([rows, activeItem]) => this.updateRowsActivation(rows, activeItem)\n    );\n  }\n\n  private updateRowsActivation(rows: ElderTableRowDirective<T>[], activeItem: T): void {\n    const activeId = this.getId(activeItem);\n    rows.forEach(row => {\n      this.updateRowActivation(row, activeId);\n    });\n  }\n\n  private updateRowActivation(row: ElderTableRowDirective<T>, activeId: any): void {\n    if (row.model) {\n      if (this.itemEqualsId(row.model, activeId)) {\n        if (!row.activated) {\n          row.activated = true;\n          this.logger.debug('Activated row: ', row);\n          if (!row.hasFocus) {\n            row.bringToView();\n          }\n        }\n      } else {\n        row.activated = false;\n      }\n    } else {\n      row.activated = false;\n    }\n  }\n\n  private rowDataUpdated(\n    rows: ElderTableRowDirective<T>[],\n    data: T[]\n  ): ElderTableRowDirective<T>[] {\n    // this.logger.debug('Found rows:', rows);\n    rows.forEach(row => {\n      row.bindTableActivation(this);\n    });\n    this.handleAutoActivations();\n    return rows;\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    // this.elderTable.rows$.getValue().forEach(r => r.bindTableActivation(null));\n  }\n\n  /***************************************************************************\n   *                                                                         *.\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown', ['$event'])\n  public onKeydown(event: KeyboardEvent) {\n    let newActiveItem: T;\n    if (event.key === 'ArrowDown') {\n      newActiveItem = this.nextRowItem();\n    } else if (event.key === 'ArrowUp') {\n      newActiveItem = this.previousRowItem();\n    }\n\n    if (newActiveItem) {\n      this.focusAndActivate(newActiveItem);\n    }\n\n    const active = this.activeItem;\n    if (active) {\n      if (event.key === 'Enter') {\n        this.elderTable.onItemClick(active);\n        event.stopPropagation();\n      } else if (event.key === 'Spacebar' || event.key === ' ') {\n        this.elderTable.selectionModel.toggle(active);\n        event.stopPropagation();\n      }\n    }\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Output()\n  public get activeItemChange(): Observable<T> {\n    return this.activeItem$;\n  }\n\n  public get activeItem(): T {\n    return this.activeItem$.getValue();\n  }\n\n  @Input()\n  public set activeItem(item: T) {\n    if (item !== this.activeItem) {\n      this.activeItem$.next(item);\n      this.logger.debug('Set active item to ', item);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public activate(item: T): void {\n    this.activeItem = item;\n  }\n\n  public focusAndActivate(item: T): void {\n    const row = this.getRowForItem(item);\n    if (row) {\n      row.foucs(); // Focus will auto activate the row\n    }\n  }\n\n  public isItemActive(item: T): boolean {\n    if (this.activeItem) {\n      return this.itemEquals(this.activeItem, item);\n    } else {\n      return false;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private getRowForItem(item: T): ElderTableRowDirective<T> | null {\n    const rows = this.rows$.getValue();\n    return rows.find(r => r.model === item);\n  }\n\n  private handleAutoActivations(): void {\n    if (!this.hasActiveItem || this.activationOptions.mode === 'always') {\n      switch (this.activationOptions.row) {\n        case 'none': break;\n        case 'first': this.activateFirst(); break;\n        case 'last': this.activateLast(); break;\n      }\n    }\n  }\n\n  private get hasActiveItem(): boolean {\n    return !!this.activeItem;\n  }\n\n  private activateFirst(): void {\n    const item = this.getItemAtIndex(0);\n    if (item) {\n      this.activate(item);\n    }\n  }\n\n  private activateLast(): void {\n    if (this._data) {\n      const item = this.getItemAtIndex(this._data.length - 1);\n      if (item) {\n        this.activate(item);\n      }\n    }\n  }\n\n  private previousRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n    if (currentIndex > 0) {\n      --currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = rows.length - 1;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private nextRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n\n    if (currentIndex < (rows.length - 1)) {\n      ++currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = 0;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private getCurrentIndex(): number {\n    const activeItem = this.activeItem;\n    if (activeItem) {\n      return this.findItemIndex(activeItem);\n    } else {\n      return -1;\n    }\n  }\n\n  private getItemAtIndex(index: number): T | undefined {\n    return  this._data[index];\n  }\n\n  private findItemIndex(item: T): number {\n    const needleId = this.getId(item);\n    return this._data.findIndex(itm => this.itemEqualsId(itm, needleId));\n  }\n\n  private itemEquals(a: T, b: T): boolean {\n    return this.getId(a) === this.getId(b);\n  }\n\n  private itemEqualsId(a: T, needleId: any): boolean {\n    return this.getId(a) === needleId;\n  }\n\n  private getId(item: T): any {\n    if (item) {\n      const dc = this.elderTable.dataContext$.getValue();\n      return dc?.dataSource?.getId(item);\n    } else {\n      return item;\n    }\n  }\n\n}\n"]}
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table-activation.directive.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/activation/elder-table-activation.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,KAAK,EACM,MAAM,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAAC,SAAS,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAC,eAAe,EAAE,aAAa,EAAc,OAAO,EAAC,MAAM,MAAM,CAAC;;;AASzE,MAAM,OAAO,6BAA6B;IAqBxC;;;;gFAI4E;IAE5E,YACmB,UAA+B;QAA/B,eAAU,GAAV,UAAU,CAAqB;QA1BlD;;;;oFAI4E;QAE3D,WAAM,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAExD,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEpC,gBAAW,GAAG,IAAI,eAAe,CAAI,IAAI,CAAC,CAAC;QAGpD,sBAAiB,GAAgC,EAAE,CAAC;QAEnD,UAAK,GAAQ,EAAE,CAAC;QAEP,UAAK,GAAG,IAAI,eAAe,CAA8B,EAAE,CAAC,CAAC;IAU1E,CAAC;IAEL;;;;gFAI4E;IAErE,eAAe;QAEpB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QACpC,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAC7C,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EACxB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAC/B,CAAC;QAEF,aAAa,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,CAChC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC7B,CAAC,SAAS,CACT,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE;YACf,IAAI,CAAC,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAChC,CAAC;QACJ,CAAC,CACF,CAAC;QAEF,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAChD,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC7B,CAAC,SAAS,CACT,CAAC,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,UAAU,CAAC,CACpE,CAAC;IACJ,CAAC;IAEO,oBAAoB,CAAC,IAAiC,EAAE,UAAa;QAC3E,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACjB,IAAI,CAAC,mBAAmB,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB,CAAC,GAA8B,EAAE,QAAa;QACvE,IAAI,GAAG,CAAC,KAAK,EAAE;YACb,IAAI,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,EAAE;gBAC1C,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE;oBAClB,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC;oBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,EAAE,GAAG,CAAC,CAAC;oBAC1C,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;wBACjB,GAAG,CAAC,WAAW,EAAE,CAAC;qBACnB;iBACF;aACF;iBAAM;gBACL,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;aACvB;SACF;aAAM;YACL,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;SACvB;IACH,CAAC;IAEO,cAAc,CACpB,IAAiC,EACjC,IAAS;QAET,0CAA0C;QAC1C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACjB,GAAG,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;QAC7B,8EAA8E;IAChF,CAAC;IAED;;;;gFAI4E;IAGrE,SAAS,CAAC,KAAoB;QACnC,IAAI,aAAgB,CAAC;QACrB,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YAC7B,aAAa,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;SACpC;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE;YAClC,aAAa,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;SACxC;QAED,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SACtC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC;QAC/B,IAAI,MAAM,EAAE;YACV,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;gBACzB,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;gBACpC,KAAK,CAAC,eAAe,EAAE,CAAC;aACzB;iBAAM,IAAI,KAAK,CAAC,GAAG,KAAK,UAAU,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;gBACxD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAC9C,KAAK,CAAC,eAAe,EAAE,CAAC;aACzB;SACF;IACH,CAAC;IAGD;;;;gFAI4E;IAE5E,IACW,gBAAgB;QACzB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAED,IACW,UAAU,CAAC,IAAO;QAC3B,IAAI,IAAI,KAAK,IAAI,CAAC,UAAU,EAAE;YAC5B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAC;SAChD;IACH,CAAC;IAED;;;;gFAI4E;IAErE,QAAQ,CAAC,IAAO;QACrB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAEM,gBAAgB,CAAC,IAAO;QAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,GAAG,EAAE;YACP,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,mCAAmC;SACjD;IACH,CAAC;IAEM,YAAY,CAAC,IAAO;QACzB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;SAC/C;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED;;;;gFAI4E;IAEpE,aAAa,CAAC,IAAO;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC;IAC1C,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,KAAK,QAAQ,EAAE;YACnE,QAAQ,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAClC,KAAK,MAAM,CAAC,CAAC,MAAM;gBACnB,KAAK,OAAO;oBAAE,IAAI,CAAC,aAAa,EAAE,CAAC;oBAAC,MAAM;gBAC1C,KAAK,MAAM;oBAAE,IAAI,CAAC,YAAY,EAAE,CAAC;oBAAC,MAAM;aACzC;SACF;IACH,CAAC;IAED,IAAY,aAAa;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAEO,aAAa;QACnB,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;QACpC,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SACrB;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACxD,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;aACrB;SACF;IACH,CAAC;IAEO,eAAe;QACrB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC1C,IAAI,YAAY,GAAG,CAAC,EAAE;YACpB,EAAE,YAAY,CAAC;SAChB;aAAM;YACL,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE;gBAC/B,YAAY,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aAChC;SACF;QACD,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;IAC3C,CAAC;IAEO,WAAW;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAE1C,IAAI,YAAY,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE;YACpC,EAAE,YAAY,CAAC;SAChB;aAAM;YACL,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE;gBAC/B,YAAY,GAAG,CAAC,CAAC;aAClB;SACF;QACD,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;IAC3C,CAAC;IAEO,eAAe;QACrB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QACnC,IAAI,UAAU,EAAE;YACd,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SACvC;aAAM;YACL,OAAO,CAAC,CAAC,CAAC;SACX;IACH,CAAC;IAEO,cAAc,CAAC,KAAa;QAClC,OAAQ,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAEO,aAAa,CAAC,IAAO;QAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC,CAAC;IACvE,CAAC;IAEO,UAAU,CAAC,CAAI,EAAE,CAAI;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACzC,CAAC;IAEO,YAAY,CAAC,CAAI,EAAE,QAAa;QACtC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;IACpC,CAAC;IAEO,KAAK,CAAC,IAAO;QACnB,IAAI,IAAI,EAAE;YACR,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YACnD,OAAO,EAAE,EAAE,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;SACpC;aAAM;YACL,OAAO,IAAI,CAAC;SACb;IACH,CAAC;;0HA9RU,6BAA6B;8GAA7B,6BAA6B;2FAA7B,6BAA6B;kBAJzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,mCAAmC;oBAC7C,QAAQ,EAAE,sBAAsB;iBACjC;0GAgBQ,iBAAiB;sBADvB,KAAK;uBAAC,sBAAsB;gBAkGtB,SAAS;sBADf,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC;gBAiCxB,gBAAgB;sBAD1B,MAAM;gBAUI,UAAU;sBADpB,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  HostListener,\n  Input,\n  OnDestroy, Output,\n} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {switchMap, takeUntil, tap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {ElderTableComponent} from '../elder-table/elder-table.component';\nimport {ElderTableActivationOptions} from './elder-table-activation-options';\nimport {ElderItemActivator} from './elder-item-activator';\n\n@Directive({\n  selector: 'elder-table[elderTableActivation]',\n  exportAs: 'elderTableActivation'\n})\nexport class ElderTableActivationDirective<T> implements ElderItemActivator<T>, AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  public readonly activeItem$ = new BehaviorSubject<T>(null);\n\n  @Input('elderTableActivation')\n  public activationOptions: ElderTableActivationOptions = {};\n\n  private _data: T[] = [];\n\n  private readonly rows$ = new BehaviorSubject<ElderTableRowDirective<T>[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly elderTable: ElderTableComponent\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit(): void {\n\n    const rows$ = this.elderTable.rows$;\n    const data$ = this.elderTable.dataContext$.pipe(\n      switchMap(dc => dc.data),\n      tap(data => this._data = data)\n    );\n\n    combineLatest([rows$, data$]).pipe(\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      ([rows, data]) => {\n        this.rows$.next(\n          this.rowDataUpdated(rows, data)\n        );\n      }\n    );\n\n    combineLatest([this.rows$, this.activeItem$]).pipe(\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      ([rows, activeItem]) => this.updateRowsActivation(rows, activeItem)\n    );\n  }\n\n  private updateRowsActivation(rows: ElderTableRowDirective<T>[], activeItem: T): void {\n    const activeId = this.getId(activeItem);\n    rows.forEach(row => {\n      this.updateRowActivation(row, activeId);\n    });\n  }\n\n  private updateRowActivation(row: ElderTableRowDirective<T>, activeId: any): void {\n    if (row.model) {\n      if (this.itemEqualsId(row.model, activeId)) {\n        if (!row.activated) {\n          row.activated = true;\n          this.logger.debug('Activated row: ', row);\n          if (!row.hasFocus) {\n            row.bringToView();\n          }\n        }\n      } else {\n        row.activated = false;\n      }\n    } else {\n      row.activated = false;\n    }\n  }\n\n  private rowDataUpdated(\n    rows: ElderTableRowDirective<T>[],\n    data: T[]\n  ): ElderTableRowDirective<T>[] {\n    // this.logger.debug('Found rows:', rows);\n    rows.forEach(row => {\n      row.bindTableActivation(this);\n    });\n    this.handleAutoActivations();\n    return rows;\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    // this.elderTable.rows$.getValue().forEach(r => r.bindTableActivation(null));\n  }\n\n  /***************************************************************************\n   *                                                                         *.\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown', ['$event'])\n  public onKeydown(event: KeyboardEvent) {\n    let newActiveItem: T;\n    if (event.key === 'ArrowDown') {\n      newActiveItem = this.nextRowItem();\n    } else if (event.key === 'ArrowUp') {\n      newActiveItem = this.previousRowItem();\n    }\n\n    if (newActiveItem) {\n      this.focusAndActivate(newActiveItem);\n    }\n\n    const active = this.activeItem;\n    if (active) {\n      if (event.key === 'Enter') {\n        this.elderTable.onItemClick(active);\n        event.stopPropagation();\n      } else if (event.key === 'Spacebar' || event.key === ' ') {\n        this.elderTable.selectionModel.toggle(active);\n        event.stopPropagation();\n      }\n    }\n  }\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Output()\n  public get activeItemChange(): Observable<T> {\n    return this.activeItem$;\n  }\n\n  public get activeItem(): T {\n    return this.activeItem$.getValue();\n  }\n\n  @Input()\n  public set activeItem(item: T) {\n    if (item !== this.activeItem) {\n      this.activeItem$.next(item);\n      this.logger.debug('Set active item to ', item);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public activate(item: T): void {\n    this.activeItem = item;\n  }\n\n  public focusAndActivate(item: T): void {\n    const row = this.getRowForItem(item);\n    if (row) {\n      row.foucs(); // Focus will auto activate the row\n    }\n  }\n\n  public isItemActive(item: T): boolean {\n    if (this.activeItem) {\n      return this.itemEquals(this.activeItem, item);\n    } else {\n      return false;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private getRowForItem(item: T): ElderTableRowDirective<T> | null {\n    const rows = this.rows$.getValue();\n    return rows.find(r => r.model === item);\n  }\n\n  private handleAutoActivations(): void {\n    if (!this.hasActiveItem || this.activationOptions.mode === 'always') {\n      switch (this.activationOptions.row) {\n        case 'none': break;\n        case 'first': this.activateFirst(); break;\n        case 'last': this.activateLast(); break;\n      }\n    }\n  }\n\n  private get hasActiveItem(): boolean {\n    return !!this.activeItem;\n  }\n\n  private activateFirst(): void {\n    const item = this.getItemAtIndex(0);\n    if (item) {\n      this.activate(item);\n    }\n  }\n\n  private activateLast(): void {\n    if (this._data) {\n      const item = this.getItemAtIndex(this._data.length - 1);\n      if (item) {\n        this.activate(item);\n      }\n    }\n  }\n\n  private previousRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n    if (currentIndex > 0) {\n      --currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = rows.length - 1;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private nextRowItem(): T {\n    const rows = this._data;\n    let currentIndex = this.getCurrentIndex();\n\n    if (currentIndex < (rows.length - 1)) {\n      ++currentIndex;\n    } else {\n      if (this.activationOptions.loop) {\n        currentIndex = 0;\n      }\n    }\n    return this.getItemAtIndex(currentIndex);\n  }\n\n  private getCurrentIndex(): number {\n    const activeItem = this.activeItem;\n    if (activeItem) {\n      return this.findItemIndex(activeItem);\n    } else {\n      return -1;\n    }\n  }\n\n  private getItemAtIndex(index: number): T | undefined {\n    return  this._data[index];\n  }\n\n  private findItemIndex(item: T): number {\n    const needleId = this.getId(item);\n    return this._data.findIndex(itm => this.itemEqualsId(itm, needleId));\n  }\n\n  private itemEquals(a: T, b: T): boolean {\n    return this.getId(a) === this.getId(b);\n  }\n\n  private itemEqualsId(a: T, needleId: any): boolean {\n    return this.getId(a) === needleId;\n  }\n\n  private getId(item: T): any {\n    if (item) {\n      const dc = this.elderTable.dataContext$.getValue();\n      return dc?.dataSource?.getId(item);\n    } else {\n      return item;\n    }\n  }\n\n}\n"]}
@@ -13,9 +13,9 @@ export class ElderNumberCellDirective {
13
13
  }
14
14
  }
15
15
  }
16
- ElderNumberCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderNumberCellDirective, deps: [{ token: i1.MatSortHeader, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
17
- ElderNumberCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.3", type: ElderNumberCellDirective, selector: "[elderNumberCell]", host: { properties: { "class.elder-number-cell": "true" } }, ngImport: i0 });
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderNumberCellDirective, decorators: [{
16
+ ElderNumberCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderNumberCellDirective, deps: [{ token: i1.MatSortHeader, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
17
+ ElderNumberCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.0", type: ElderNumberCellDirective, selector: "[elderNumberCell]", host: { properties: { "class.elder-number-cell": "true" } }, ngImport: i0 });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderNumberCellDirective, decorators: [{
19
19
  type: Directive,
20
20
  args: [{
21
21
  selector: '[elderNumberCell]',
@@ -64,9 +64,9 @@ export class ElderPaginatorIntl extends MatPaginatorIntl {
64
64
  this.changes.next();
65
65
  }
66
66
  }
67
- ElderPaginatorIntl.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderPaginatorIntl, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable });
68
- ElderPaginatorIntl.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderPaginatorIntl });
69
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderPaginatorIntl, decorators: [{
67
+ ElderPaginatorIntl.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderPaginatorIntl, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable });
68
+ ElderPaginatorIntl.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderPaginatorIntl });
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderPaginatorIntl, decorators: [{
70
70
  type: Injectable
71
71
  }], ctorParameters: function () { return [{ type: i1.TranslateService }]; } });
72
72
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-paginator-intl.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-paginator-intl.ts"],"names":[],"mappings":"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","sourcesContent":["import { MatPaginatorIntl } from '@angular/material/paginator';\nimport {Injectable} from '@angular/core';\nimport {TranslateService} from '@ngx-translate/core';\n\n@Injectable()\nexport class ElderPaginatorIntl extends MatPaginatorIntl {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _itemCountSeparatorKey = 'paginator.itemCountSeparator';\n  private readonly _itemsPerPageKey = 'paginator.itemsPerPage';\n  private readonly _firstPageLabelKey = 'paginator.firstPage';\n  private readonly _lastPageKey = 'paginator.lastPage';\n  private readonly _nextPageKey = 'paginator.nextPage';\n  private readonly _previousPageKey = 'paginator.previousPage';\n\n  private itemCountSeparatorLabel: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  public constructor(\n    private translate: TranslateService\n  ) {\n    super();\n\n    this.translate.onLangChange.subscribe((e: Event) => {\n      this.translateLabels();\n    });\n\n    this.translateLabels();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public getRangeLabel = (\n    page: number,\n    pageSize: number,\n    length: number\n  ): string => {\n\n    if (length === 0 || pageSize === 0) {\n      return `0 ${this.itemCountSeparatorLabel} ${length}`;\n    }\n\n    length = Math.max(length, 0);\n\n    const startIndex: number = page * pageSize;\n    const endIndex: number = startIndex < length\n      ? Math.min(startIndex + pageSize, length)\n      : startIndex + pageSize;\n\n    return `${startIndex + 1} - ${endIndex} ${this.itemCountSeparatorLabel} ${length}`;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private translateLabels(): void {\n\n    const itemCountSeparatorLabel = this.translate.instant(this._itemCountSeparatorKey);\n    const itemsPerPageLabel = this.translate.instant(this._itemsPerPageKey);\n    const firstPageLabel = this.translate.instant(this._firstPageLabelKey);\n    const lastPageLabel = this.translate.instant(this._lastPageKey);\n    const nextPageLabel = this.translate.instant(this._nextPageKey);\n    const previousPageLabel = this.translate.instant(this._previousPageKey);\n\n    this.itemCountSeparatorLabel = itemCountSeparatorLabel !== this._itemCountSeparatorKey ? itemCountSeparatorLabel : 'of';\n    this.itemsPerPageLabel = itemsPerPageLabel !== this._itemsPerPageKey ? itemsPerPageLabel : 'Items per page';\n    this.firstPageLabel = firstPageLabel !== this._firstPageLabelKey ? firstPageLabel : 'First page';\n    this.lastPageLabel = lastPageLabel !== this._lastPageKey ? lastPageLabel : 'Last page';\n    this.nextPageLabel = nextPageLabel !== this._nextPageKey ? nextPageLabel : 'Next page';\n    this.previousPageLabel = previousPageLabel !== this._previousPageKey ? previousPageLabel : 'Previous page';\n\n    this.changes.next();\n  }\n\n}\n"]}
@@ -9,9 +9,9 @@ export class ElderTableToolbarDirective {
9
9
  this.viewContainer = viewContainer;
10
10
  }
11
11
  }
12
- ElderTableToolbarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableToolbarDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
13
- ElderTableToolbarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.3", type: ElderTableToolbarDirective, selector: "[elderTableToolbar]", ngImport: i0 });
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableToolbarDirective, decorators: [{
12
+ ElderTableToolbarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableToolbarDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
13
+ ElderTableToolbarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.1.0", type: ElderTableToolbarDirective, selector: "[elderTableToolbar]", ngImport: i0 });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableToolbarDirective, decorators: [{
15
15
  type: Directive,
16
16
  args: [{ selector: '[elderTableToolbar]' }]
17
17
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -3,7 +3,7 @@ import { MatTableDataContextBindingBuilder } from '../../../../common/data/data-
3
3
  import { MatPaginator } from '@angular/material/paginator';
4
4
  import { MatColumnDef, MatRowDef, MatTable } from '@angular/material/table';
5
5
  import { isDataContext } from '../../../../common/data/data-context/data-context';
6
- import { BehaviorSubject, combineLatest, of, Subject } from 'rxjs';
6
+ import { BehaviorSubject, combineLatest, of } from 'rxjs';
7
7
  import { map, takeUntil } from 'rxjs/operators';
8
8
  import { LoggerFactory } from '@elderbyte/ts-logger';
9
9
  import { DataContextBuilder } from '../../../../common/data/data-context/data-context-builder';
@@ -21,7 +21,7 @@ import { ElderTableToolbarDirective } from './elder-table-toolbar.directive';
21
21
  import * as i0 from "@angular/core";
22
22
  import * as i1 from "../model/elder-table-model";
23
23
  import * as i2 from "../../../../common/selection/selection-model";
24
- import * as i3 from "../../../select/popup/selection-model-popup.directive";
24
+ import * as i3 from "../../base/elder-data-view-options-provider";
25
25
  import * as i4 from "@angular/material/sort";
26
26
  import * as i5 from "../elder-table-extension.directive";
27
27
  import * as i6 from "@angular/common";
@@ -43,8 +43,8 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
43
43
  * Constructor *
44
44
  * *
45
45
  **************************************************************************/
46
- constructor(tableModel, selectionModel, dataViewSelection, matSort, parentExtension, cdr, zone) {
47
- super(selectionModel, dataViewSelection);
46
+ constructor(tableModel, selectionModel, dataViewOptionsProvider, matSort, parentExtension, cdr, zone) {
47
+ super(selectionModel, dataViewOptionsProvider);
48
48
  this.tableModel = tableModel;
49
49
  this.parentExtension = parentExtension;
50
50
  this.cdr = cdr;
@@ -55,7 +55,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
55
55
  * *
56
56
  **************************************************************************/
57
57
  this.logger = LoggerFactory.getLogger(this.constructor.name);
58
- this.destroy$ = new Subject();
59
58
  /**
60
59
  * Load next chunk after current is done
61
60
  */
@@ -76,14 +75,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
76
75
  */
77
76
  this.hiddenField = null;
78
77
  this.pageSizeOptions = [30, 50, 100, 150, 200];
79
- /**
80
- * Define if elder-table should clean up the
81
- * data-context resources for you.
82
- *
83
- * In more advanced scenarios where you plan to reuse the same data-context
84
- * set this to false and release the resources yourself. (dataContext.close)
85
- */
86
- this.cleanUp = true;
87
78
  this.keepSelection = true;
88
79
  this.showFooter = false;
89
80
  this.toolbarRowTemplates$ = new BehaviorSubject([]);
@@ -103,16 +94,7 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
103
94
  * *
104
95
  **************************************************************************/
105
96
  ngOnInit() {
106
- if (this.dataViewSelection) {
107
- this.selectionVisible = true;
108
- this.selectionMultiEnabled = this.dataViewSelection.multi;
109
- this.interactionMode = 'selection';
110
- this.float = false;
111
- if (this.dataContext) {
112
- this.dataContext.filter.updateFilters(this.dataViewSelection.filters);
113
- this.dataContext.sort.updateSorts(this.dataViewSelection.sorts);
114
- }
115
- }
97
+ super.ngOnInit();
116
98
  ElderTableModelCdkTableBinding
117
99
  .of(this.tableModel)
118
100
  .table(this.matTable)
@@ -142,11 +124,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
142
124
  .updated(rows => this.rows$.next(rows))
143
125
  .bindUntil(this.destroy$);
144
126
  }
145
- ngOnDestroy() {
146
- this.destroy$.next();
147
- this.destroy$.complete();
148
- this.autoCleanUp();
149
- }
150
127
  /***************************************************************************
151
128
  * *
152
129
  * Properties *
@@ -270,25 +247,16 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
270
247
  }
271
248
  });
272
249
  }
273
- /**
274
- * Performs clean up of the current data context if auto clean up is enabled.
275
- */
276
- autoCleanUp() {
277
- if (this.cleanUp && this.dataContext) {
278
- this.logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]="true"');
279
- this.dataContext.close();
280
- }
281
- }
282
250
  }
283
- ElderTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableComponent, deps: [{ token: i1.ElderTableModel }, { token: i2.SelectionModel, optional: true }, { token: i3.ElderDataViewSelectionMode, optional: true, skipSelf: true }, { token: i4.MatSort, optional: true }, { token: i5.ElderTableExtensionDirective, optional: true, skipSelf: true }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
284
- ElderTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: ElderTableComponent, selector: "elder-table, ebs-table", inputs: { idField: "idField", removingField: "removingField", hiddenField: "hiddenField", pageSizeOptions: "pageSizeOptions", cleanUp: "cleanUp", keepSelection: "keepSelection", showFooter: "showFooter", toolbarTemplate: "toolbarTemplate", data: "data", displayedColumns: "displayedColumns", selectionVisible: "selectionVisible" }, providers: [
251
+ ElderTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableComponent, deps: [{ token: i1.ElderTableModel }, { token: i2.SelectionModel, optional: true }, { token: i3.ElderDataViewOptionsProvider, optional: true, skipSelf: true }, { token: i4.MatSort, optional: true }, { token: i5.ElderTableExtensionDirective, optional: true, skipSelf: true }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
252
+ ElderTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: ElderTableComponent, selector: "elder-table, ebs-table", inputs: { idField: "idField", removingField: "removingField", hiddenField: "hiddenField", pageSizeOptions: "pageSizeOptions", keepSelection: "keepSelection", showFooter: "showFooter", toolbarTemplate: "toolbarTemplate", data: "data", displayedColumns: "displayedColumns", selectionVisible: "selectionVisible" }, providers: [
285
253
  ElderTableProviders.ExistingOrNewTableModel,
286
254
  {
287
255
  provide: ELDER_DATA_VIEW,
288
256
  useExisting: forwardRef(() => ElderTableComponent)
289
257
  }
290
- ], queries: [{ propertyName: "columnDefs", predicate: MatColumnDef }, { propertyName: "elderColumns", predicate: ElderTableColumnDirective }, { propertyName: "rowDefs", predicate: MatRowDef }, { propertyName: "toolbarRowTemplateQuery", predicate: ElderTableToolbarDirective, read: TemplateRef }], viewQueries: [{ propertyName: "matTable", first: true, predicate: MatTable, descendants: true, static: true }, { propertyName: "matPaginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "rowsQuery", predicate: ElderTableRowDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"$any(dataContext$ | async)\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n </elder-data-context-state-indicator>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".elder-table-scroll{height:100%}.elder-mat-inner-table{width:100%}.elder-table-row.dense{height:42px!important}.elder-mat-table-container{border-radius:4px;overflow:hidden}.mat-column-select{overflow:visible;overflow:initial;max-width:42px;width:42px}.elder-row-removing{text-decoration:line-through}.elder-row-hidden{display:none}.elder-table-row{cursor:pointer}:host{min-width:0;min-height:0}.elder-table-hint{color:gray}.elder-table-footer{height:44px}.elder-table-checkbox{opacity:.25;transition:opacity .5s ease-in-out}.elder-table-row:hover .elder-table-checkbox{opacity:.9}.elder-table-checkbox-visible{opacity:1}.mat-table .mat-header-cell{padding-left:8px;padding-right:12px;overflow-wrap:normal;word-wrap:normal;word-break:normal;white-space:inherit;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto}.mat-table .mat-header-cell:first-of-type{padding-left:20px}.mat-table .mat-header-cell:last-of-type{padding-right:8px}.mat-table .mat-header-cell:last-of-type[mat-sort-header]:not([arrowposition=before]){padding-right:8px}.mat-table .mat-header-cell[mat-sort-header][arrowposition=before]{padding-left:0}.mat-table .mat-header-cell[mat-sort-header]:not([arrowposition=before]){padding-right:12px}.mat-table .mat-header-cell>.mat-sort-header-container{display:inline-flex}.mat-table .mat-cell{padding-left:8px;padding-right:12px;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;white-space:inherit;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto}.mat-table .mat-cell:first-of-type{padding-left:20px}.mat-table .mat-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell{padding-left:8px;padding-right:12px;font-weight:700}.mat-table .mat-footer-cell:first-of-type{padding-left:20px}.mat-table .mat-footer-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell .mat-paginator{margin-left:-8px;margin-right:-8px}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i11.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i11.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i11.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i11.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i11.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i11.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i11.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i11.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i11.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i11.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i11.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i11.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i11.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i11.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "component", type: i12.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "directive", type: i13.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i13.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i13.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i13.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i14.ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox" }, { kind: "directive", type: i15.DataContextSelectionDirective, selector: "[elderDataContextSelection]", inputs: ["elderDataContextSelectionModel", "elderDataContextSelection"], exportAs: ["elderDataContextSelection"] }, { kind: "component", type: i16.DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: ["dataContext"] }, { kind: "directive", type: i17.ElderInfiniteScrollLegacyDirective, selector: "[infiniteScroll]" }, { kind: "directive", type: i18.ElderTableRowDirective, selector: "tr[elderTableRow]", inputs: ["elderTableRow"], exportAs: ["elderTableRow"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
291
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ElderTableComponent, decorators: [{
258
+ ], queries: [{ propertyName: "columnDefs", predicate: MatColumnDef }, { propertyName: "elderColumns", predicate: ElderTableColumnDirective }, { propertyName: "rowDefs", predicate: MatRowDef }, { propertyName: "toolbarRowTemplateQuery", predicate: ElderTableToolbarDirective, read: TemplateRef }], viewQueries: [{ propertyName: "matTable", first: true, predicate: MatTable, descendants: true, static: true }, { propertyName: "matPaginator", first: true, predicate: MatPaginator, descendants: true }, { propertyName: "rowsQuery", predicate: ElderTableRowDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"$any(dataContext$ | async)\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n </elder-data-context-state-indicator>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".elder-table-scroll{height:100%}.elder-mat-inner-table{width:100%}.elder-table-row.dense{height:42px!important}.elder-mat-table-container{border-radius:4px;overflow:hidden}.mat-column-select{overflow:visible;overflow:initial;max-width:42px;width:42px}.elder-row-removing{text-decoration:line-through}.elder-row-hidden{display:none}.elder-table-row{cursor:pointer}:host{min-width:0;min-height:0}.elder-table-hint{color:gray}.elder-table-footer{height:44px}.elder-table-checkbox{opacity:.25;transition:opacity .5s ease-in-out}.elder-table-row:hover .elder-table-checkbox{opacity:.9}.elder-table-checkbox-visible{opacity:1}.mat-table .mat-header-cell{padding-left:8px;padding-right:12px;overflow-wrap:normal;word-wrap:normal;word-break:normal;white-space:inherit;-webkit-hyphens:auto;hyphens:auto}.mat-table .mat-header-cell:first-of-type{padding-left:20px}.mat-table .mat-header-cell:last-of-type{padding-right:8px}.mat-table .mat-header-cell:last-of-type[mat-sort-header]:not([arrowposition=before]){padding-right:8px}.mat-table .mat-header-cell[mat-sort-header][arrowposition=before]{padding-left:0}.mat-table .mat-header-cell[mat-sort-header]:not([arrowposition=before]){padding-right:12px}.mat-table .mat-header-cell>.mat-sort-header-container{display:inline-flex}.mat-table .mat-cell{padding-left:8px;padding-right:12px;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;white-space:inherit;-webkit-hyphens:auto;hyphens:auto}.mat-table .mat-cell:first-of-type{padding-left:20px}.mat-table .mat-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell{padding-left:8px;padding-right:12px;font-weight:700}.mat-table .mat-footer-cell:first-of-type{padding-left:20px}.mat-table .mat-footer-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell .mat-paginator{margin-left:-8px;margin-right:-8px}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i10.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "component", type: i11.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i11.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i11.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i11.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i11.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i11.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i11.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i11.MatFooterRowDef, selector: "[matFooterRowDef]", inputs: ["matFooterRowDef", "matFooterRowDefSticky"] }, { kind: "directive", type: i11.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i11.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i11.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "component", type: i11.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i11.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i11.MatFooterRow, selector: "mat-footer-row, tr[mat-footer-row]", exportAs: ["matFooterRow"] }, { kind: "component", type: i12.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "directive", type: i13.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i13.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i13.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i13.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i14.ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox" }, { kind: "directive", type: i15.DataContextSelectionDirective, selector: "[elderDataContextSelection]", inputs: ["elderDataContextSelectionModel", "elderDataContextSelection"], exportAs: ["elderDataContextSelection"] }, { kind: "component", type: i16.DataContextStateIndicatorComponent, selector: "elder-data-context-state-indicator", inputs: ["dataContext"] }, { kind: "directive", type: i17.ElderInfiniteScrollLegacyDirective, selector: "[infiniteScroll]" }, { kind: "directive", type: i18.ElderTableRowDirective, selector: "tr[elderTableRow]", inputs: ["elderTableRow"], exportAs: ["elderTableRow"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
259
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: ElderTableComponent, decorators: [{
292
260
  type: Component,
293
261
  args: [{ selector: 'elder-table, ebs-table', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
294
262
  ElderTableProviders.ExistingOrNewTableModel,
@@ -296,10 +264,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImpor
296
264
  provide: ELDER_DATA_VIEW,
297
265
  useExisting: forwardRef(() => ElderTableComponent)
298
266
  }
299
- ], template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"$any(dataContext$ | async)\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n </elder-data-context-state-indicator>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".elder-table-scroll{height:100%}.elder-mat-inner-table{width:100%}.elder-table-row.dense{height:42px!important}.elder-mat-table-container{border-radius:4px;overflow:hidden}.mat-column-select{overflow:visible;overflow:initial;max-width:42px;width:42px}.elder-row-removing{text-decoration:line-through}.elder-row-hidden{display:none}.elder-table-row{cursor:pointer}:host{min-width:0;min-height:0}.elder-table-hint{color:gray}.elder-table-footer{height:44px}.elder-table-checkbox{opacity:.25;transition:opacity .5s ease-in-out}.elder-table-row:hover .elder-table-checkbox{opacity:.9}.elder-table-checkbox-visible{opacity:1}.mat-table .mat-header-cell{padding-left:8px;padding-right:12px;overflow-wrap:normal;word-wrap:normal;word-break:normal;white-space:inherit;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto}.mat-table .mat-header-cell:first-of-type{padding-left:20px}.mat-table .mat-header-cell:last-of-type{padding-right:8px}.mat-table .mat-header-cell:last-of-type[mat-sort-header]:not([arrowposition=before]){padding-right:8px}.mat-table .mat-header-cell[mat-sort-header][arrowposition=before]{padding-left:0}.mat-table .mat-header-cell[mat-sort-header]:not([arrowposition=before]){padding-right:12px}.mat-table .mat-header-cell>.mat-sort-header-container{display:inline-flex}.mat-table .mat-cell{padding-left:8px;padding-right:12px;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;white-space:inherit;-webkit-hyphens:auto;-ms-hyphens:auto;hyphens:auto}.mat-table .mat-cell:first-of-type{padding-left:20px}.mat-table .mat-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell{padding-left:8px;padding-right:12px;font-weight:700}.mat-table .mat-footer-cell:first-of-type{padding-left:20px}.mat-table .mat-footer-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell .mat-paginator{margin-left:-8px;margin-right:-8px}\n"] }]
267
+ ], template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"$any(dataContext$ | async)\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n </elder-data-context-state-indicator>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n", styles: [".elder-table-scroll{height:100%}.elder-mat-inner-table{width:100%}.elder-table-row.dense{height:42px!important}.elder-mat-table-container{border-radius:4px;overflow:hidden}.mat-column-select{overflow:visible;overflow:initial;max-width:42px;width:42px}.elder-row-removing{text-decoration:line-through}.elder-row-hidden{display:none}.elder-table-row{cursor:pointer}:host{min-width:0;min-height:0}.elder-table-hint{color:gray}.elder-table-footer{height:44px}.elder-table-checkbox{opacity:.25;transition:opacity .5s ease-in-out}.elder-table-row:hover .elder-table-checkbox{opacity:.9}.elder-table-checkbox-visible{opacity:1}.mat-table .mat-header-cell{padding-left:8px;padding-right:12px;overflow-wrap:normal;word-wrap:normal;word-break:normal;white-space:inherit;-webkit-hyphens:auto;hyphens:auto}.mat-table .mat-header-cell:first-of-type{padding-left:20px}.mat-table .mat-header-cell:last-of-type{padding-right:8px}.mat-table .mat-header-cell:last-of-type[mat-sort-header]:not([arrowposition=before]){padding-right:8px}.mat-table .mat-header-cell[mat-sort-header][arrowposition=before]{padding-left:0}.mat-table .mat-header-cell[mat-sort-header]:not([arrowposition=before]){padding-right:12px}.mat-table .mat-header-cell>.mat-sort-header-container{display:inline-flex}.mat-table .mat-cell{padding-left:8px;padding-right:12px;overflow-wrap:break-word;word-wrap:break-word;word-break:break-word;white-space:inherit;-webkit-hyphens:auto;hyphens:auto}.mat-table .mat-cell:first-of-type{padding-left:20px}.mat-table .mat-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell{padding-left:8px;padding-right:12px;font-weight:700}.mat-table .mat-footer-cell:first-of-type{padding-left:20px}.mat-table .mat-footer-cell:last-of-type{padding-right:8px}.mat-table .mat-footer-cell .mat-paginator{margin-left:-8px;margin-right:-8px}\n"] }]
300
268
  }], ctorParameters: function () { return [{ type: i1.ElderTableModel }, { type: i2.SelectionModel, decorators: [{
301
269
  type: Optional
302
- }] }, { type: i3.ElderDataViewSelectionMode, decorators: [{
270
+ }] }, { type: i3.ElderDataViewOptionsProvider, decorators: [{
303
271
  type: Optional
304
272
  }, {
305
273
  type: SkipSelf
@@ -332,8 +300,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImpor
332
300
  type: Input
333
301
  }], pageSizeOptions: [{
334
302
  type: Input
335
- }], cleanUp: [{
336
- type: Input
337
303
  }], keepSelection: [{
338
304
  type: Input
339
305
  }], showFooter: [{
@@ -353,4 +319,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImpor
353
319
  }], selectionVisible: [{
354
320
  type: Input
355
321
  }] } });
356
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  QueryList,\n  SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport {MatTableDataContextBindingBuilder} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatSort} from '@angular/material/sort';\nimport {MatColumnDef, MatRowDef, MatTable} from '@angular/material/table';\nimport {IDataContext, isDataContext} from '../../../../common/data/data-context/data-context';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject, Subscription} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {CdkColumnDef, CdkRowDef, CdkTable} from '@angular/cdk/table';\nimport {DataContextBuilder} from '../../../../common/data/data-context/data-context-builder';\nimport {ELDER_DATA_VIEW} from '../../base/elder-data-view';\nimport {ElderDataViewSelectionMode} from '../../../select/popup/selection-model-popup.directive';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {IDataSource, isDataSource} from '../../../../common/data/datasource/data-source';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {ElderTableModel} from '../model/elder-table-model';\nimport {ElderTableProviders} from '../model/elder-table-model-provider';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {ElderTableModelCdkTableBinding} from '../model/elder-table-model-cdk-table-binding';\nimport {ElderTableModelQueryGroup} from '../model/elder-table-model-query-group';\nimport {ElderTableExtensionDirective} from '../elder-table-extension.directive';\nimport {ElderTableColumnDirective} from '../elder-table-column.directive';\nimport {ColumnPositionSpec} from '../model/elder-column-layout';\nimport {ElderTableToolbarDirective} from './elder-table-toolbar.directive';\n\n@Component({\n  selector: 'elder-table, ebs-table', // ebs-table is deprecated\n  templateUrl: './elder-table.component.html',\n  styleUrls: ['./elder-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderTableProviders.ExistingOrNewTableModel,\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderTableComponent)\n    }\n  ]\n})\nexport class ElderTableComponent extends ElderDataViewBaseComponent implements OnInit, OnDestroy, AfterContentInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject();\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  /// Table\n  @ViewChild(MatTable, {static: true})\n  public matTable: CdkTable<any>;\n\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  private readonly _matSort: MatSort;\n\n  @ContentChildren(MatColumnDef)\n  public columnDefs: QueryList<CdkColumnDef>;\n\n  @ContentChildren(ElderTableColumnDirective)\n  public elderColumns: QueryList<ElderTableColumnDirective>;\n\n  @ContentChildren(MatRowDef)\n  public rowDefs: QueryList<CdkRowDef<any>>;\n\n  /**\n   * Field to identify the data records (ID field).\n   * Note: This property is only considered in case the\n   * underlying data is an Array.\n   * In case of DataContext, the ID field needs to be defined in the context.\n   * In case of DataSource, the ID field is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField: string;\n\n  /**\n   * When this field is present and true,\n   * the coresponding row is marked to be in the processed of being removed.\n   *\n   * I.e. 'removing'\n   */\n  @Input()\n  public removingField: string = null;\n\n  /**\n   * When this field is present and true,\n   * the corresponding row is hidden.\n   *\n   * I.e. 'deleted'\n   *\n   */\n  @Input()\n  public hiddenField: string = null;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n\n  /**\n   * Define if elder-table should clean up the\n   * data-context resources for you.\n   *\n   * In more advanced scenarios where you plan to reuse the same data-context\n   * set this to false and release the resources yourself. (dataContext.close)\n   */\n  @Input()\n  public cleanUp = true;\n\n  @Input()\n  public keepSelection = true;\n\n  @Input()\n  public showFooter = false;\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  /**\n   * The table toolbar\n   */\n  @ContentChildren(ElderTableToolbarDirective, {read: TemplateRef})\n  public toolbarRowTemplateQuery: QueryList<TemplateRef<any>>;\n  public readonly toolbarRowTemplates$ = new BehaviorSubject<TemplateRef<any>[]>([]);\n\n  /**\n   * Selection model life cycle\n   */\n  private selectionLifeCycle: Subscription;\n\n  @ViewChildren(ElderTableRowDirective)\n  private rowsQuery: QueryList<ElderTableRowDirective<any>>;\n\n  /**\n   * Gets the current rows of this table.\n   */\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<any>[]>([]);\n\n  /**\n   * The index of this table group extension\n   * @private\n   */\n  private readonly _extensionGroupIndex: number;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly tableModel: ElderTableModel,\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewSelection: ElderDataViewSelectionMode,\n    @Optional() matSort: MatSort,\n    @Optional() @SkipSelf() private readonly parentExtension: ElderTableExtensionDirective,\n    private cdr: ChangeDetectorRef,\n    private zone: NgZone\n  ) {\n    super(selectionModel, dataViewSelection);\n    this._matSort = matSort;\n    this._extensionGroupIndex = (parentExtension?.extensionGroupIndex ?? 0) + 1;\n    if (this._matSort) {\n      this._matSort.disableClear = true;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n    if (this.dataViewSelection) {\n      this.selectionVisible = true;\n      this.selectionMultiEnabled = this.dataViewSelection.multi;\n      this.interactionMode = 'selection';\n      this.float = false;\n\n      if (this.dataContext) {\n        this.dataContext.filter.updateFilters(this.dataViewSelection.filters);\n        this.dataContext.sort.updateSorts(this.dataViewSelection.sorts);\n      }\n    }\n\n    ElderTableModelCdkTableBinding\n      .of(this.tableModel)\n      .table(this.matTable)\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterContentInit(): void {\n\n    ElderTableModelQueryGroup\n      .start(this.tableModel, this._extensionGroupIndex)\n      .withColumnsPosition(ColumnPositionSpec.relativeToPrevGroup('start'))\n      .withColumnDefs(this.columnDefs, this.elderColumns)\n      .withRowDefs(this.rowDefs)\n      .withSort(this._matSort)\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.toolbarRowTemplateQuery)\n      .updated(toolbarRows => this.toolbarRowTemplates$.next(toolbarRows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withSorts(this.tableModel.sorts$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.rowsQuery)\n      .updated(rows => this.rows$.next(rows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this.toolbarRowTemplates$.next([template]);\n  }\n\n  @Input()\n  public set data(data: Array<any> | IDataSource<any> | IDataContext<any>) {\n\n    this.autoCleanUp();\n\n    let dc: IDataContext<any>;\n\n    if (data instanceof Array) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .buildLocal(data, this.idField); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataSource(data)) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .reloadOnLocalChanges()\n        .build(data); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataContext(data)) {\n      dc = data;\n    } else if (data === null || data === undefined) {\n      dc = DataContextBuilder.start().buildEmpty();\n    } else {\n      throw new Error('The data must either be an Array, IDataSource or IDataContext, but was: ' + (typeof data));\n    }\n    this.dataContext = dc;\n  }\n\n  protected onDataContextSet(data: IDataContext<any>): void {\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    this.setupSelectionLifeCycle(data);\n\n    // this.selectionModel.clear(); // TODO Support changeable data-context for static array use case\n\n    if (this.isContinuable) {\n      this.canLoadMore$ = combineLatest([data.loading, this.dataContinuable.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  @Input()\n  public set displayedColumns(displayedColumns: string[]) {\n    this.tableModel.displayedColumns = displayedColumns;\n  }\n\n  public get displayedColumns(): string[] {\n    return this.tableModel.displayedColumns;\n  }\n\n  /** Indicates if selection column is shown. */\n  @Input()\n  public set selectionVisible(visible: boolean) {\n    this.tableModel.selectionVisible = visible;\n  }\n\n  public get selectionVisible(): boolean {\n    return this.tableModel.selectionVisible;\n  }\n\n  /*\n  @Output()\n  public get activeItem(): Observable<any> {\n    return this.elderTableActivation.activeItem$;\n  }*/\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public requestMoreDataZoned(event: any): void {\n\n    if (this.dataContinuable.hasMoreDataSnapshot) {\n\n      if (this.dataContinuable.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.zone.run(() => {\n          this.dataContinuable.loadMore()\n            .subscribe(\n              loaded => {\n                if (this.loadNextQueued) {\n                  this.loadNextQueued = false;\n                  this.requestMoreDataZoned(event);\n                }\n              }\n            );\n        });\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => this.getId(entity);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private setupSelectionLifeCycle(data: IDataContext<any>): void {\n\n    if (this.selectionLifeCycle) {\n      this.selectionLifeCycle.unsubscribe(); // Clean up previous sub\n    }\n\n    this.selectionLifeCycle = data.data.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(newData => {\n\n      if (this.keepSelection) {\n        // If keep selection enabled\n        if (this.selectionModel.hasValue) {\n\n          // Check that all selected values are still present or remove them\n          const existingIds = new Set<any>(\n            newData\n              .map(d => this.getId(d))\n          );\n\n          const noLongerAvailableIds = this.selectionModel.selectionSnapshot\n            .map(selected => this.getId(selected))\n            .filter(selectedId => !existingIds.has(selectedId));\n\n          this.selectionModel.deselectIds(noLongerAvailableIds);\n        }\n      } else {\n        this.selectionModel.clear();\n      }\n    });\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  private autoCleanUp(): void {\n    if (this.cleanUp && this.dataContext) {\n      this.logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.dataContext.close();\n    }\n  }\n}\n","\n<div fxLayout=\"column\" fxFlex\n     class=\"elder-table\"\n     [class.elder-mat-table-container]=\"!embedded\"\n     [class.mat-elevation-z5]=\"float\"\n     [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n  <!-- Toolbar Rows -->\n  <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n    <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n    </ng-template>\n  </ng-container>\n\n  <!-- Scrollable Table -->\n  <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n       infiniteScroll\n       [eventThrottle]=\"150\"\n       [offsetFactor]=\"2\"\n       [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n       (closeToEnd)=\"requestMoreDataZoned($event)\"\n  >\n    <table\n      mat-table\n      class=\"elder-mat-inner-table\"\n      [trackBy]=\"trackByFn\"\n      [dataSource]=\"$any(dataContext$ | async)\"\n      [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n      [elderDataContextSelectionModel]=\"selectionModel\"\n    >\n\n      <!-- selection Column -->\n      <ng-container matColumnDef=\"select\">\n        <th mat-header-cell *matHeaderCellDef>\n          <elder-selection-master-checkbox></elder-selection-master-checkbox>\n        </th>\n        <td mat-cell *matCellDef=\"let entity\">\n          <mat-checkbox (click)=\"$event.stopPropagation()\"\n                        (change)=\"$event ? selectionModel.toggle(entity) : null\"\n                        [checked]=\"selectionModel.observeSelection(entity) | async\"\n                        [disabled]=\"!selectionModel.isSelectable(entity)\"\n                        class=\"elder-table-checkbox\"\n                        [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n          >\n          </mat-checkbox>\n        </td>\n        <td mat-footer-cell *matFooterCellDef></td>\n      </ng-container>\n\n      <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n        <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n        <tr mat-row class=\"elder-table-row\"\n            *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n            [elderTableRow]=\"entity\"\n            [class.dense]=\"dense\"\n            [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n            [class.elder-row-removing]=\"removingField && entity[removingField]\"\n            [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n            (click)=\"onItemClick(entity)\"\n            (dblclick)=\"onItemDoubleClick(entity)\"\n        >\n        </tr>\n        <ng-container *ngIf=\"showFooter\">\n          <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n        </ng-container>\n      </ng-container>\n    </table>\n  </div>\n\n  <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n  </elder-data-context-state-indicator>\n\n  <mat-progress-bar fxFlex=\"none\"\n                    [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n                    [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n  </mat-progress-bar>\n\n  <!-- Optional Paginator Toolbar -->\n  <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n                 fxFlex=\"none\"\n                 [length]=\"dataContext?.total | async\"\n                 [pageIndex]=\"page?.index\"\n                 [pageSize]=\"page?.size\"\n                 [pageSizeOptions]=\"pageSizeOptions\">\n  </mat-paginator>\n\n  <!-- Optional Continuation Footer -->\n  <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n       fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n       style=\"padding-right: 10px\" >\n\n    <span class=\"mat-caption noselect\" style=\"color: gray\">\n      {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n    </span>\n\n    <button mat-icon-button type=\"button\" color=\"primary\"\n            [disabled]=\"!(canLoadMore$ | async)\"\n            (click)=\"dataContinuable.loadMore()\">\n      <mat-icon>keyboard_arrow_down</mat-icon>\n    </button>\n  </div>\n\n</div>\n"]}
322
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  QueryList,\n  SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport {MatTableDataContextBindingBuilder} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatSort} from '@angular/material/sort';\nimport {MatColumnDef, MatRowDef, MatTable} from '@angular/material/table';\nimport {IDataContext, isDataContext} from '../../../../common/data/data-context/data-context';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject, Subscription} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {CdkColumnDef, CdkRowDef, CdkTable} from '@angular/cdk/table';\nimport {DataContextBuilder} from '../../../../common/data/data-context/data-context-builder';\nimport {ELDER_DATA_VIEW} from '../../base/elder-data-view';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {IDataSource, isDataSource} from '../../../../common/data/datasource/data-source';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {ElderTableModel} from '../model/elder-table-model';\nimport {ElderTableProviders} from '../model/elder-table-model-provider';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {ElderTableModelCdkTableBinding} from '../model/elder-table-model-cdk-table-binding';\nimport {ElderTableModelQueryGroup} from '../model/elder-table-model-query-group';\nimport {ElderTableExtensionDirective} from '../elder-table-extension.directive';\nimport {ElderTableColumnDirective} from '../elder-table-column.directive';\nimport {ColumnPositionSpec} from '../model/elder-column-layout';\nimport {ElderTableToolbarDirective} from './elder-table-toolbar.directive';\nimport {DataViewOptionsProviderBinding} from '../../base/data-view-options-provider-binding';\nimport {ElderDataViewOptionsProvider} from '../../base/elder-data-view-options-provider';\n\n@Component({\n  selector: 'elder-table, ebs-table', // ebs-table is deprecated\n  templateUrl: './elder-table.component.html',\n  styleUrls: ['./elder-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderTableProviders.ExistingOrNewTableModel,\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderTableComponent)\n    }\n  ]\n})\nexport class ElderTableComponent extends ElderDataViewBaseComponent implements OnInit, AfterContentInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  /// Table\n  @ViewChild(MatTable, {static: true})\n  public matTable: CdkTable<any>;\n\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  private readonly _matSort: MatSort;\n\n  @ContentChildren(MatColumnDef)\n  public columnDefs: QueryList<CdkColumnDef>;\n\n  @ContentChildren(ElderTableColumnDirective)\n  public elderColumns: QueryList<ElderTableColumnDirective>;\n\n  @ContentChildren(MatRowDef)\n  public rowDefs: QueryList<CdkRowDef<any>>;\n\n  /**\n   * Field to identify the data records (ID field).\n   * Note: This property is only considered in case the\n   * underlying data is an Array.\n   * In case of DataContext, the ID field needs to be defined in the context.\n   * In case of DataSource, the ID field is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField: string;\n\n  /**\n   * When this field is present and true,\n   * the coresponding row is marked to be in the processed of being removed.\n   *\n   * I.e. 'removing'\n   */\n  @Input()\n  public removingField: string = null;\n\n  /**\n   * When this field is present and true,\n   * the corresponding row is hidden.\n   *\n   * I.e. 'deleted'\n   *\n   */\n  @Input()\n  public hiddenField: string = null;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n\n  @Input()\n  public keepSelection = true;\n\n  @Input()\n  public showFooter = false;\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  /**\n   * The table toolbar\n   */\n  @ContentChildren(ElderTableToolbarDirective, {read: TemplateRef})\n  public toolbarRowTemplateQuery: QueryList<TemplateRef<any>>;\n  public readonly toolbarRowTemplates$ = new BehaviorSubject<TemplateRef<any>[]>([]);\n\n  /**\n   * Selection model life cycle\n   */\n  private selectionLifeCycle: Subscription;\n\n  @ViewChildren(ElderTableRowDirective)\n  private rowsQuery: QueryList<ElderTableRowDirective<any>>;\n\n  /**\n   * Gets the current rows of this table.\n   */\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<any>[]>([]);\n\n  /**\n   * The index of this table group extension\n   * @private\n   */\n  private readonly _extensionGroupIndex: number;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly tableModel: ElderTableModel,\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewOptionsProvider: ElderDataViewOptionsProvider,\n    @Optional() matSort: MatSort,\n    @Optional() @SkipSelf() private readonly parentExtension: ElderTableExtensionDirective,\n    private cdr: ChangeDetectorRef,\n    private zone: NgZone\n  ) {\n    super(selectionModel, dataViewOptionsProvider);\n    this._matSort = matSort;\n    this._extensionGroupIndex = (parentExtension?.extensionGroupIndex ?? 0) + 1;\n    if (this._matSort) {\n      this._matSort.disableClear = true;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public override ngOnInit(): void {\n    super.ngOnInit();\n\n    ElderTableModelCdkTableBinding\n      .of(this.tableModel)\n      .table(this.matTable)\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterContentInit(): void {\n\n    ElderTableModelQueryGroup\n      .start(this.tableModel, this._extensionGroupIndex)\n      .withColumnsPosition(ColumnPositionSpec.relativeToPrevGroup('start'))\n      .withColumnDefs(this.columnDefs, this.elderColumns)\n      .withRowDefs(this.rowDefs)\n      .withSort(this._matSort)\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.toolbarRowTemplateQuery)\n      .updated(toolbarRows => this.toolbarRowTemplates$.next(toolbarRows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withSorts(this.tableModel.sorts$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.rowsQuery)\n      .updated(rows => this.rows$.next(rows))\n      .bindUntil(this.destroy$);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this.toolbarRowTemplates$.next([template]);\n  }\n\n  @Input()\n  public set data(data: Array<any> | IDataSource<any> | IDataContext<any>) {\n\n    this.autoCleanUp();\n\n    let dc: IDataContext<any>;\n\n    if (data instanceof Array) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .buildLocal(data, this.idField); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataSource(data)) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .reloadOnLocalChanges()\n        .build(data); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataContext(data)) {\n      dc = data;\n    } else if (data === null || data === undefined) {\n      dc = DataContextBuilder.start().buildEmpty();\n    } else {\n      throw new Error('The data must either be an Array, IDataSource or IDataContext, but was: ' + (typeof data));\n    }\n    this.dataContext = dc;\n  }\n\n  protected onDataContextSet(data: IDataContext<any>): void {\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    this.setupSelectionLifeCycle(data);\n\n    // this.selectionModel.clear(); // TODO Support changeable data-context for static array use case\n\n    if (this.isContinuable) {\n      this.canLoadMore$ = combineLatest([data.loading, this.dataContinuable.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  @Input()\n  public set displayedColumns(displayedColumns: string[]) {\n    this.tableModel.displayedColumns = displayedColumns;\n  }\n\n  public get displayedColumns(): string[] {\n    return this.tableModel.displayedColumns;\n  }\n\n  /** Indicates if selection column is shown. */\n  @Input()\n  public set selectionVisible(visible: boolean) {\n    this.tableModel.selectionVisible = visible;\n  }\n\n  public get selectionVisible(): boolean {\n    return this.tableModel.selectionVisible;\n  }\n\n  /*\n  @Output()\n  public get activeItem(): Observable<any> {\n    return this.elderTableActivation.activeItem$;\n  }*/\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public requestMoreDataZoned(event: any): void {\n\n    if (this.dataContinuable.hasMoreDataSnapshot) {\n\n      if (this.dataContinuable.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.zone.run(() => {\n          this.dataContinuable.loadMore()\n            .subscribe(\n              loaded => {\n                if (this.loadNextQueued) {\n                  this.loadNextQueued = false;\n                  this.requestMoreDataZoned(event);\n                }\n              }\n            );\n        });\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => this.getId(entity);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private setupSelectionLifeCycle(data: IDataContext<any>): void {\n\n    if (this.selectionLifeCycle) {\n      this.selectionLifeCycle.unsubscribe(); // Clean up previous sub\n    }\n\n    this.selectionLifeCycle = data.data.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(newData => {\n\n      if (this.keepSelection) {\n        // If keep selection enabled\n        if (this.selectionModel.hasValue) {\n\n          // Check that all selected values are still present or remove them\n          const existingIds = new Set<any>(\n            newData\n              .map(d => this.getId(d))\n          );\n\n          const noLongerAvailableIds = this.selectionModel.selectionSnapshot\n            .map(selected => this.getId(selected))\n            .filter(selectedId => !existingIds.has(selectedId));\n\n          this.selectionModel.deselectIds(noLongerAvailableIds);\n        }\n      } else {\n        this.selectionModel.clear();\n      }\n    });\n  }\n\n\n}\n","\n<div fxLayout=\"column\" fxFlex\n     class=\"elder-table\"\n     [class.elder-mat-table-container]=\"!embedded\"\n     [class.mat-elevation-z5]=\"float\"\n     [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n  <!-- Toolbar Rows -->\n  <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n    <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n    </ng-template>\n  </ng-container>\n\n  <!-- Scrollable Table -->\n  <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n       infiniteScroll\n       [eventThrottle]=\"150\"\n       [offsetFactor]=\"2\"\n       [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n       (closeToEnd)=\"requestMoreDataZoned($event)\"\n  >\n    <table\n      mat-table\n      class=\"elder-mat-inner-table\"\n      [trackBy]=\"trackByFn\"\n      [dataSource]=\"$any(dataContext$ | async)\"\n      [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n      [elderDataContextSelectionModel]=\"selectionModel\"\n    >\n\n      <!-- selection Column -->\n      <ng-container matColumnDef=\"select\">\n        <th mat-header-cell *matHeaderCellDef>\n          <elder-selection-master-checkbox></elder-selection-master-checkbox>\n        </th>\n        <td mat-cell *matCellDef=\"let entity\">\n          <mat-checkbox (click)=\"$event.stopPropagation()\"\n                        (change)=\"$event ? selectionModel.toggle(entity) : null\"\n                        [checked]=\"selectionModel.observeSelection(entity) | async\"\n                        [disabled]=\"!selectionModel.isSelectable(entity)\"\n                        class=\"elder-table-checkbox\"\n                        [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n          >\n          </mat-checkbox>\n        </td>\n        <td mat-footer-cell *matFooterCellDef></td>\n      </ng-container>\n\n      <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n        <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n        <tr mat-row class=\"elder-table-row\"\n            *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n            [elderTableRow]=\"entity\"\n            [class.dense]=\"dense\"\n            [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n            [class.elder-row-removing]=\"removingField && entity[removingField]\"\n            [class.elder-table-row-selected]=\"interactionMode === 'selection' && selectionModel.observeSelection(entity) | async\"\n            (click)=\"onItemClick(entity)\"\n            (dblclick)=\"onItemDoubleClick(entity)\"\n        >\n        </tr>\n        <ng-container *ngIf=\"showFooter\">\n          <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n        </ng-container>\n      </ng-container>\n    </table>\n  </div>\n\n  <elder-data-context-state-indicator fxFlex=\"none\" [dataContext]=\"dataContext\">\n  </elder-data-context-state-indicator>\n\n  <mat-progress-bar fxFlex=\"none\"\n                    [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n                    [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n  </mat-progress-bar>\n\n  <!-- Optional Paginator Toolbar -->\n  <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n                 fxFlex=\"none\"\n                 [length]=\"dataContext?.total | async\"\n                 [pageIndex]=\"page?.index\"\n                 [pageSize]=\"page?.size\"\n                 [pageSizeOptions]=\"pageSizeOptions\">\n  </mat-paginator>\n\n  <!-- Optional Continuation Footer -->\n  <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n       fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n       style=\"padding-right: 10px\" >\n\n    <span class=\"mat-caption noselect\" style=\"color: gray\">\n      {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n    </span>\n\n    <button mat-icon-button type=\"button\" color=\"primary\"\n            [disabled]=\"!(canLoadMore$ | async)\"\n            (click)=\"dataContinuable.loadMore()\">\n      <mat-icon>keyboard_arrow_down</mat-icon>\n    </button>\n  </div>\n\n</div>\n"]}