@elderbyte/ngx-starter 14.2.2 → 14.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (260) 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/form-field-base.component.mjs +3 -3
  6. package/esm2020/lib/common/forms/multi-model-base.component.mjs +3 -3
  7. package/esm2020/lib/common/forms/template-composite-control.mjs +3 -3
  8. package/esm2020/lib/common/forms/value-accessor-base.mjs +3 -3
  9. package/esm2020/lib/common/http/http-client-builder.service.mjs +3 -3
  10. package/esm2020/lib/common/http/http-client-pristine.mjs +3 -3
  11. package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +3 -3
  12. package/esm2020/lib/common/http/transfer/http-data-transfer.mjs +1 -1
  13. package/esm2020/lib/common/public_api.mjs +1 -2
  14. package/esm2020/lib/common/selection/selection-model.mjs +7 -2
  15. package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +3 -3
  16. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -3
  17. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -4
  18. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +3 -3
  19. package/esm2020/lib/components/auditing/elder-audit.module.mjs +4 -4
  20. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -3
  21. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -4
  22. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +3 -3
  23. package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +3 -3
  24. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +3 -3
  25. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -4
  26. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -3
  27. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +18 -18
  28. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -4
  29. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -4
  30. package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +3 -3
  31. package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +3 -3
  32. package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -4
  33. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -3
  34. package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +3 -3
  35. package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +3 -3
  36. package/esm2020/lib/components/csv/elder-csv.module.mjs +4 -4
  37. package/esm2020/lib/components/currency/elder-currency.module.mjs +4 -4
  38. package/esm2020/lib/components/currency/elder-currency.pipe.mjs +3 -3
  39. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -4
  40. package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +3 -3
  41. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -3
  42. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +3 -3
  43. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +3 -3
  44. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +3 -3
  45. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +6 -5
  46. package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +4 -4
  47. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +3 -3
  48. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -4
  49. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +6 -6
  50. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +5 -5
  51. package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +3 -3
  52. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -3
  53. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +10 -10
  54. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +4 -4
  55. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +3 -3
  56. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -4
  57. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  58. package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +3 -3
  59. package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +3 -3
  60. package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +3 -3
  61. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +6 -6
  62. package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +3 -3
  63. package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  64. package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +3 -3
  65. package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +3 -3
  66. package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +3 -3
  67. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -4
  68. package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +3 -3
  69. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +3 -3
  70. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +7 -7
  71. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +3 -3
  72. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +3 -3
  73. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +3 -3
  74. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +3 -3
  75. package/esm2020/lib/components/errors/elder-error.module.mjs +4 -4
  76. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -3
  77. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +3 -3
  78. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -4
  79. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
  80. package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +3 -3
  81. package/esm2020/lib/components/files/elder-file-select.directive.mjs +3 -3
  82. package/esm2020/lib/components/files/elder-file.module.mjs +4 -4
  83. package/esm2020/lib/components/files/file-select/file-select.component.mjs +3 -3
  84. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +3 -3
  85. package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +3 -3
  86. package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +3 -3
  87. package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +3 -3
  88. package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +3 -3
  89. package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +3 -3
  90. package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +3 -3
  91. package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +3 -3
  92. package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +3 -3
  93. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +13 -13
  94. package/esm2020/lib/components/forms/directives/elder-input-pattern.directive.mjs +3 -3
  95. package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +3 -3
  96. package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +3 -3
  97. package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +3 -3
  98. package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +3 -3
  99. package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +3 -3
  100. package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +3 -3
  101. package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  102. package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +3 -3
  103. package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +3 -3
  104. package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +3 -3
  105. package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +3 -3
  106. package/esm2020/lib/components/forms/elder-forms.module.mjs +4 -4
  107. package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +6 -6
  108. package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
  109. package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -4
  110. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
  111. package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +3 -3
  112. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +3 -3
  113. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -4
  114. package/esm2020/lib/components/global-search/elder-global-search.service.mjs +3 -3
  115. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -3
  116. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -4
  117. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +3 -3
  118. package/esm2020/lib/components/headers/elder-header.module.mjs +4 -4
  119. package/esm2020/lib/components/http-support/elder-http-client.service.mjs +3 -3
  120. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +4 -4
  121. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
  122. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +3 -3
  123. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +3 -3
  124. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
  125. package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +3 -3
  126. package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  127. package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +3 -3
  128. package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +3 -3
  129. package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +3 -3
  130. package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +3 -3
  131. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +4 -4
  132. package/esm2020/lib/components/i18n/language/elder-language.service.mjs +3 -3
  133. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +3 -3
  134. package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +4 -4
  135. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +4 -4
  136. package/esm2020/lib/components/iframes/iframe-close.directive.mjs +3 -3
  137. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +3 -3
  138. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +3 -3
  139. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +3 -3
  140. package/esm2020/lib/components/iframes/iframe.service.mjs +3 -3
  141. package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +7 -5
  142. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  143. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +7 -7
  144. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +3 -3
  145. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  146. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +4 -4
  147. package/esm2020/lib/components/labels/elder-labels.module.mjs +4 -4
  148. package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +3 -3
  149. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +3 -3
  150. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +3 -3
  151. package/esm2020/lib/components/measures/elder-measures.module.mjs +8 -8
  152. package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +3 -3
  153. package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +3 -3
  154. package/esm2020/lib/components/measures/elder-unit.service.mjs +3 -3
  155. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +3 -3
  156. package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +3 -3
  157. package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +4 -4
  158. package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +3 -3
  159. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
  160. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -4
  161. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -4
  162. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
  163. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +3 -3
  164. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -3
  165. package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +3 -3
  166. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -4
  167. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +3 -3
  168. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +4 -4
  169. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +3 -3
  170. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +3 -3
  171. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +3 -3
  172. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +3 -3
  173. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +4 -4
  174. package/esm2020/lib/components/overlays/elder-overlay.module.mjs +4 -4
  175. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -3
  176. package/esm2020/lib/components/panels/elder-panel.module.mjs +4 -4
  177. package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +3 -3
  178. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +3 -3
  179. package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +6 -5
  180. package/esm2020/lib/components/select/elder-select-base.mjs +3 -3
  181. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +6 -6
  182. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  183. package/esm2020/lib/components/select/elder-select-value.directive.mjs +3 -3
  184. package/esm2020/lib/components/select/elder-select.module.mjs +4 -4
  185. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +5 -5
  186. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +3 -3
  187. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +13 -7
  188. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +3 -3
  189. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +3 -3
  190. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -4
  191. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -4
  192. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -3
  193. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -3
  194. package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +3 -3
  195. package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +3 -3
  196. package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +3 -3
  197. package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -4
  198. package/esm2020/lib/components/shell/elder-shell.service.mjs +3 -3
  199. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
  200. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +13 -13
  201. package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +3 -3
  202. package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +3 -3
  203. package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  204. package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -4
  205. package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +4 -4
  206. package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +20 -8
  207. package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +3 -3
  208. package/esm2020/lib/components/theme/elder-theme.directive.mjs +4 -4
  209. package/esm2020/lib/components/theme/elder-theme.module.mjs +4 -4
  210. package/esm2020/lib/components/theme/elder-theme.service.mjs +3 -3
  211. package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +3 -3
  212. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +3 -3
  213. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +3 -3
  214. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +3 -3
  215. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +3 -3
  216. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +3 -3
  217. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +3 -3
  218. package/esm2020/lib/components/time/elder-time.module.mjs +8 -8
  219. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +3 -3
  220. package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -4
  221. package/esm2020/lib/components/toasts/elder-toast.service.mjs +9 -9
  222. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +3 -3
  223. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +4 -4
  224. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +3 -3
  225. package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +3 -3
  226. package/esm2020/lib/components/viewers/elder-viewers.module.mjs +4 -4
  227. package/esm2020/lib/features/event-source/elder-event-source.service.mjs +3 -3
  228. package/esm2020/lib/features/kafent/access-token-provider.mjs +3 -3
  229. package/esm2020/lib/features/kafent/kafent-config.mjs +3 -3
  230. package/esm2020/lib/features/kafent/kafent-event-stream.mjs +3 -3
  231. package/esm2020/lib/features/kafent/kafent-event.service.mjs +3 -3
  232. package/esm2020/lib/features/kafent/kafent.module.mjs +4 -4
  233. package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +3 -3
  234. package/esm2020/lib/pipes/bytes.pipe.mjs +3 -3
  235. package/esm2020/lib/pipes/elder-pipes.module.mjs +10 -10
  236. package/esm2020/lib/pipes/elder-repeat.pipe.mjs +3 -3
  237. package/esm2020/lib/pipes/elder-round.pipe.mjs +3 -3
  238. package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +3 -3
  239. package/esm2020/lib/pipes/elder-truncate.pipe.mjs +3 -3
  240. package/esm2020/lib/pipes/iso-duration.pipe.mjs +3 -3
  241. package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +3 -3
  242. package/esm2020/lib/pipes/iso-interval.pipe.mjs +3 -3
  243. package/esm2020/lib/pipes/time-ago.pipe.mjs +3 -3
  244. package/esm2020/lib/pipes/time-duration.pipe.mjs +3 -3
  245. package/esm2020/lib/pipes/weight.pipe.mjs +3 -3
  246. package/fesm2015/elderbyte-ngx-starter.mjs +882 -915
  247. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  248. package/fesm2020/elderbyte-ngx-starter.mjs +882 -914
  249. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  250. package/lib/common/data/data-context/data-context-base.d.ts +1 -1
  251. package/lib/common/public_api.d.ts +0 -1
  252. package/lib/common/selection/selection-model.d.ts +5 -2
  253. package/lib/components/data-view/base/elder-data-view-base.d.ts +1 -0
  254. package/lib/components/select/popup/selection-model-popup.directive.d.ts +4 -3
  255. package/lib/components/theme/elder-theme-preference.service.d.ts +3 -1
  256. package/package.json +3 -2
  257. package/esm2020/lib/common/rxjs/lazy-behavior-subject.mjs +0 -59
  258. package/esm2020/lib/common/rxjs/public_api.mjs +0 -2
  259. package/lib/common/rxjs/lazy-behavior-subject.d.ts +0 -38
  260. package/lib/common/rxjs/public_api.d.ts +0 -1
@@ -108,9 +108,9 @@ export class ElderSelectOnTabDirective {
108
108
  }
109
109
  }
110
110
  }
111
- ElderSelectOnTabDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectOnTabDirective, deps: [{ token: i1.MatAutocompleteTrigger }, { token: ELDER_SELECT_BASE, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
112
- ElderSelectOnTabDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.2", type: ElderSelectOnTabDirective, selector: "[elderSelectOnTab]", host: { listeners: { "keydown.arrowup": "onOptionSelect()", "keydown.arrowdown": "onOptionSelect()", "keydown.tab": "onBlur()" } }, ngImport: i0 });
113
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectOnTabDirective, decorators: [{
111
+ ElderSelectOnTabDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectOnTabDirective, deps: [{ token: i1.MatAutocompleteTrigger }, { token: ELDER_SELECT_BASE, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
112
+ ElderSelectOnTabDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: ElderSelectOnTabDirective, selector: "[elderSelectOnTab]", host: { listeners: { "keydown.arrowup": "onOptionSelect()", "keydown.arrowdown": "onOptionSelect()", "keydown.tab": "onBlur()" } }, ngImport: i0 });
113
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectOnTabDirective, decorators: [{
114
114
  type: Directive,
115
115
  args: [{
116
116
  selector: '[elderSelectOnTab]'
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
130
130
  type: HostListener,
131
131
  args: ['keydown.tab']
132
132
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-on-tab.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-on-tab.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Directive, Host, HostListener, Inject, OnDestroy, SkipSelf} from '@angular/core';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {Subject} from 'rxjs/internal/Subject';\nimport {delay, map, takeUntil, tap} from 'rxjs/operators';\nimport {merge} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ValueAccessorBase} from '../../common/forms/value-accessor-base';\nimport {ELDER_SELECT_BASE, ElderSelectBase} from './elder-select-base';\nimport {MatOption} from '@angular/material/core';\nimport {isElderEntityValueAccessor} from './elder-entity-value-accessor';\n\n@Directive({\n  selector: '[elderSelectOnTab]'\n})\nexport class ElderSelectOnTabDirective<TEntity = any, TId = any, TValue = TEntity | TId> implements AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject<never>();\n\n  private readonly controlValueAccessor: ValueAccessorBase<any>;\n\n  /**\n   * Whether the autocomplete panel was open before the event\n   */\n  private panelOpen = false;\n\n  /**\n   * Whether the user selected an option.\n   * (We want to ignore selections if there is already a selection present and the user tabs away)\n   */\n  private userInput = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly autoTrigger: MatAutocompleteTrigger,\n    @SkipSelf() @Inject(ELDER_SELECT_BASE) private readonly elderSelectBase: ElderSelectBase<any, any, any>\n  ) {\n    this.controlValueAccessor = elderSelectBase;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event Listener                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown.arrowup')\n  @HostListener('keydown.arrowdown')\n  public onOptionSelect(){\n    this.userInput = true;\n  }\n\n  @HostListener('keydown.tab')\n  public onBlur(): void {\n\n    if (!this.panelOpen) { return; }\n\n    if (!this.userInput) {\n      // The user did not select anything in the auto-complete\n\n      if (this.controlValueAccessor.value) {\n        this.logger.warn('Discarding TAB since the user did probably not intend to change the value! userInput:', this.userInput);\n        return;\n      }\n\n      if(!this.elderSelectBase.required) {\n        // The user did not select any option and no current value is present.\n        // Since the input is NOT marked as required, we assume the user did not want to select a value\n        return;\n      }\n    }\n\n    const activeOption = this.autoTrigger.activeOption as MatOption<TEntity>;\n    if (activeOption) {\n      const entity = activeOption.value;\n      this.writeEntity(entity);\n    }\n\n    this.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit() {\n    const autocomplete = this.autoTrigger.autocomplete;\n    merge(\n      autocomplete.opened.pipe(map(() => true)),\n      autocomplete.closed.pipe(map(() => false))\n    ).pipe(\n      takeUntil(this.destroy$),\n      delay(0)\n    ).subscribe(value => this.panelOpen = value);\n\n    this.autoTrigger.optionSelections.pipe( // TODO https://github.com/angular/components/pull/14813\n      takeUntil(this.destroy$),\n      tap(opt => this.logger.debug('[optionSelections] CHANGED ', opt)),\n      map(opt => opt.isUserInput)\n    ).subscribe(isUserInput => this.userInput = isUserInput);\n  }\n\n  public ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private reset(): void {\n    this.userInput = false;\n  }\n\n  private writeEntity(entity: TEntity): void {\n    const value = this.entityToValue(entity);\n    this.controlValueAccessor.updateValue(value);\n    this.autoTrigger.writeValue(value);\n    this.logger.warn('Wrote entity to control as value: ', value);\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (isElderEntityValueAccessor(this.controlValueAccessor)) {\n      // Since elder-select may use the entity id as value (valueAsId),\n      // we can not directly write to the value safely.\n      return this.controlValueAccessor.entityToValue(entity);\n    } else {\n      // By default, write the selected option to the control value\n      this.logger.warn('[controlValueAccessor] is not a ElderEntityValueAccessor!: ', this.controlValueAccessor);\n      return <any>entity;\n    }\n  }\n}\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-on-tab.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-on-tab.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Directive, Host, HostListener, Inject, OnDestroy, SkipSelf} from '@angular/core';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {Subject} from 'rxjs/internal/Subject';\nimport {delay, map, takeUntil, tap} from 'rxjs/operators';\nimport {merge} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ValueAccessorBase} from '../../common/forms/value-accessor-base';\nimport {ELDER_SELECT_BASE, ElderSelectBase} from './elder-select-base';\nimport {MatOption} from '@angular/material/core';\nimport {isElderEntityValueAccessor} from './elder-entity-value-accessor';\n\n@Directive({\n  selector: '[elderSelectOnTab]'\n})\nexport class ElderSelectOnTabDirective<TEntity = any, TId = any, TValue = TEntity | TId> implements AfterViewInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject<void>();\n\n  private readonly controlValueAccessor: ValueAccessorBase<any>;\n\n  /**\n   * Whether the autocomplete panel was open before the event\n   */\n  private panelOpen = false;\n\n  /**\n   * Whether the user selected an option.\n   * (We want to ignore selections if there is already a selection present and the user tabs away)\n   */\n  private userInput = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly autoTrigger: MatAutocompleteTrigger,\n    @SkipSelf() @Inject(ELDER_SELECT_BASE) private readonly elderSelectBase: ElderSelectBase<any, any, any>\n  ) {\n    this.controlValueAccessor = elderSelectBase;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event Listener                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostListener('keydown.arrowup')\n  @HostListener('keydown.arrowdown')\n  public onOptionSelect(){\n    this.userInput = true;\n  }\n\n  @HostListener('keydown.tab')\n  public onBlur(): void {\n\n    if (!this.panelOpen) { return; }\n\n    if (!this.userInput) {\n      // The user did not select anything in the auto-complete\n\n      if (this.controlValueAccessor.value) {\n        this.logger.warn('Discarding TAB since the user did probably not intend to change the value! userInput:', this.userInput);\n        return;\n      }\n\n      if(!this.elderSelectBase.required) {\n        // The user did not select any option and no current value is present.\n        // Since the input is NOT marked as required, we assume the user did not want to select a value\n        return;\n      }\n    }\n\n    const activeOption = this.autoTrigger.activeOption as MatOption<TEntity>;\n    if (activeOption) {\n      const entity = activeOption.value;\n      this.writeEntity(entity);\n    }\n\n    this.reset();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngAfterViewInit() {\n    const autocomplete = this.autoTrigger.autocomplete;\n    merge(\n      autocomplete.opened.pipe(map(() => true)),\n      autocomplete.closed.pipe(map(() => false))\n    ).pipe(\n      takeUntil(this.destroy$),\n      delay(0)\n    ).subscribe(value => this.panelOpen = value);\n\n    this.autoTrigger.optionSelections.pipe( // TODO https://github.com/angular/components/pull/14813\n      takeUntil(this.destroy$),\n      tap(opt => this.logger.debug('[optionSelections] CHANGED ', opt)),\n      map(opt => opt.isUserInput)\n    ).subscribe(isUserInput => this.userInput = isUserInput);\n  }\n\n  public ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private reset(): void {\n    this.userInput = false;\n  }\n\n  private writeEntity(entity: TEntity): void {\n    const value = this.entityToValue(entity);\n    this.controlValueAccessor.updateValue(value);\n    this.autoTrigger.writeValue(value);\n    this.logger.warn('Wrote entity to control as value: ', value);\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (isElderEntityValueAccessor(this.controlValueAccessor)) {\n      // Since elder-select may use the entity id as value (valueAsId),\n      // we can not directly write to the value safely.\n      return this.controlValueAccessor.entityToValue(entity);\n    } else {\n      // By default, write the selected option to the control value\n      this.logger.warn('[controlValueAccessor] is not a ElderEntityValueAccessor!: ', this.controlValueAccessor);\n      return <any>entity;\n    }\n  }\n}\n"]}
@@ -6,9 +6,9 @@ export class ElderSelectValueDirective {
6
6
  this.viewContainer = viewContainer;
7
7
  }
8
8
  }
9
- ElderSelectValueDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectValueDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
10
- ElderSelectValueDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.2", type: ElderSelectValueDirective, selector: "[elderSelectValue]", ngImport: i0 });
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectValueDirective, decorators: [{
9
+ ElderSelectValueDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectValueDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
10
+ ElderSelectValueDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: ElderSelectValueDirective, selector: "[elderSelectValue]", ngImport: i0 });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectValueDirective, decorators: [{
12
12
  type: Directive,
13
13
  args: [{ selector: '[elderSelectValue]' }]
14
14
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; } });
@@ -39,8 +39,8 @@ export { ElderMultiSelectChipsComponent } from './multi/elder-multi-select-chips
39
39
  export { ElderAutoSelectFirstDirective } from './auto/elder-auto-select-first.directive';
40
40
  export class ElderSelectModule {
41
41
  }
42
- ElderSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
43
- ElderSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectModule, declarations: [ElderSelectComponent,
42
+ ElderSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
43
+ ElderSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectModule, declarations: [ElderSelectComponent,
44
44
  ElderSelectValueDirective,
45
45
  TemplatedSelectionDialogComponent,
46
46
  SelectionModelPopupDirective,
@@ -65,7 +65,7 @@ ElderSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", versi
65
65
  ElderSelectChipDirective,
66
66
  ElderSelectChipAvatarDirective,
67
67
  ElderAutoSelectFirstDirective] });
68
- ElderSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
68
+ ElderSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectModule, imports: [CommonModule, FormsModule, ReactiveFormsModule,
69
69
  MatFormFieldModule,
70
70
  MatIconModule,
71
71
  MatSelectModule,
@@ -75,7 +75,7 @@ ElderSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versi
75
75
  MatProgressSpinnerModule,
76
76
  FlexModule, TranslateModule,
77
77
  ElderFormsDirectivesModule, ElderTableModule, ElderInfiniteScrollModule, ElderAutocompleteModule, MatChipsModule, ElderPipesModule] });
78
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderSelectModule, decorators: [{
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectModule, decorators: [{
79
79
  type: NgModule,
80
80
  args: [{
81
81
  imports: [
@@ -92,7 +92,7 @@ export class ElderMultiSelectBase extends ElderSelectBase {
92
92
  }
93
93
  openSelectionPopup(event) {
94
94
  if (this.selectionPopup) {
95
- this.selectionPopup.choose(this.filters, this.sorts, true).subscribe((selection) => this.appendEntities(selection));
95
+ this.selectionPopup.choose((e) => this.getEntityId(e), this.entities, this.filters, this.sorts, true).subscribe((selection) => this.updateValueByEntities(selection));
96
96
  }
97
97
  else {
98
98
  this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');
@@ -233,9 +233,9 @@ export class ElderMultiSelectBase extends ElderSelectBase {
233
233
  return existingValues;
234
234
  }
235
235
  }
236
- ElderMultiSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderMultiSelectBase, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
237
- ElderMultiSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.2", type: ElderMultiSelectBase, inputs: { entities: "entities", entityIds: "entityIds" }, outputs: { entityIdsChange: "entityIdsChange", entityIdsUpdated: "entityIdsUpdated", entitiesUpdated: "entitiesUpdated" }, usesInheritance: true, ngImport: i0 });
238
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderMultiSelectBase, decorators: [{
236
+ ElderMultiSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectBase, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
237
+ ElderMultiSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: ElderMultiSelectBase, inputs: { entities: "entities", entityIds: "entityIds" }, outputs: { entityIdsChange: "entityIdsChange", entityIdsUpdated: "entityIdsUpdated", entitiesUpdated: "entitiesUpdated" }, usesInheritance: true, ngImport: i0 });
238
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectBase, decorators: [{
239
239
  type: Directive
240
240
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { entityIdsChange: [{
241
241
  type: Output
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
248
248
  }], entityIds: [{
249
249
  type: Input
250
250
  }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, of} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {CollectionUtil} from '../../../common/utils/collection-util';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue> extends ElderSelectBase<TId, TEntity, TValue[]> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  protected readonly entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this.entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    this.entities$.next(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    this.entities$.next(entities);\n    this.writeValueInternal(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public get entities(): TEntity[] {\n    return this.entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>ids as TValue[]);\n    } else {\n      this.selectEntitiesByIds(ids);\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.appendEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.entities$.next(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    if (!CollectionUtil.hasElements(ids)) {\n      if (CollectionUtil.hasElements(currentEntities)) {\n        this.writeValueInternal([]);\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(ids);\n        const missingIds = ids.filter(id => !existing.has(id));\n        const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntityByIds(missingIds) : of(new Map());\n\n        valueLoadRequest$.pipe(\n          map(loaded => {\n            loaded.forEach((v, k) => existing.set(k, v));\n            return existing;\n          }),\n          map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n        ).subscribe(\n          entities => {\n            this.entities = entities;\n          }\n        );\n      } else {\n        this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.suggestionsDc.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load values by ids ' + ids, err);\n        this.updateState(ElderSelectComponentState.error(err));\n        return of(<TEntity[]>[]);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.suggestionsDc.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n\n}\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, of} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {CollectionUtil} from '../../../common/utils/collection-util';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue> extends ElderSelectBase<TId, TEntity, TValue[]> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  protected readonly entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this.entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    this.entities$.next(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    this.entities$.next(entities);\n    this.writeValueInternal(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public get entities(): TEntity[] {\n    return this.entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>ids as TValue[]);\n    } else {\n      this.selectEntitiesByIds(ids);\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        this.entities,\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.updateValueByEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.entities$.next(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    if (!CollectionUtil.hasElements(ids)) {\n      if (CollectionUtil.hasElements(currentEntities)) {\n        this.writeValueInternal([]);\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(ids);\n        const missingIds = ids.filter(id => !existing.has(id));\n        const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntityByIds(missingIds) : of(new Map());\n\n        valueLoadRequest$.pipe(\n          map(loaded => {\n            loaded.forEach((v, k) => existing.set(k, v));\n            return existing;\n          }),\n          map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n        ).subscribe(\n          entities => {\n            this.entities = entities;\n          }\n        );\n      } else {\n        this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.suggestionsDc.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load values by ids ' + ids, err);\n        this.updateState(ElderSelectComponentState.error(err));\n        return of(<TEntity[]>[]);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.suggestionsDc.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n\n}\n"]}
@@ -160,9 +160,9 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
160
160
  }
161
161
  }
162
162
  }
163
- ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
164
- ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipColorEnabled: "chipColorEnabled", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <input matInput type=\"text\" class=\"elder-chip-input\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.elder-chip-input{width:120px!important;max-width:120px!important}.small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatPrefix, selector: "[matPrefix]" }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.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: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i7.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: i7.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: i7.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i8.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i9.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i10.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { kind: "component", type: i11.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i12.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { kind: "component", type: i13.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i13.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i13.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i13.MatChipRemove, selector: "[matChipRemove]" }, { kind: "directive", type: i13.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }, { kind: "pipe", type: i15.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
165
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
163
+ ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
164
+ ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipColorEnabled: "chipColorEnabled", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <input matInput type=\"text\" class=\"elder-chip-input\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.elder-chip-input{width:120px!important;max-width:120px!important}.small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatPrefix, selector: "[matPrefix]" }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.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: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i7.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: i7.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: i7.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i8.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i9.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i10.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { kind: "component", type: i11.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i12.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { kind: "component", type: i13.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i13.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i13.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i13.MatChipRemove, selector: "[matChipRemove]" }, { kind: "directive", type: i13.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }, { kind: "pipe", type: i15.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
166
166
  type: Component,
167
167
  args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <input matInput type=\"text\" class=\"elder-chip-input\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.elder-chip-input{width:120px!important;max-width:120px!important}.small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}\n"] }]
168
168
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { allowRemove: [{
@@ -7,6 +7,7 @@ import { SelectionModel } from '../../../common/selection/selection-model';
7
7
  import { ElderTableProviders } from '../../data-view/table/model/elder-table-model-provider';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/material/dialog";
10
+ import * as i2 from "../../../common/selection/selection-model";
10
11
  /**
11
12
  * Configures the selection mode on supporting components.
12
13
  */
@@ -29,11 +30,12 @@ export class SelectionModelPopupDirective {
29
30
  * Constructor *
30
31
  * *
31
32
  **************************************************************************/
32
- constructor(templateRef, viewContainer, dialog, dataViewSelectionMode) {
33
+ constructor(templateRef, viewContainer, dialog, dataViewSelectionMode, selectionModel) {
33
34
  this.templateRef = templateRef;
34
35
  this.viewContainer = viewContainer;
35
36
  this.dialog = dialog;
36
37
  this.dataViewSelectionMode = dataViewSelectionMode;
38
+ this.selectionModel = selectionModel;
37
39
  /***************************************************************************
38
40
  * *
39
41
  * Fields *
@@ -64,10 +66,14 @@ export class SelectionModelPopupDirective {
64
66
  /**
65
67
  * Let the user choose some entities and return the selection.
66
68
  */
67
- choose(filters, sorts, multi = false) {
69
+ choose(keyGetter, currentSelection, filters, sorts, multi = false) {
68
70
  this.dataViewSelectionMode.filters = filters || [];
69
71
  this.dataViewSelectionMode.sorts = sorts || [];
70
72
  this.dataViewSelectionMode.multi = multi;
73
+ this.selectionModel.isMultipleSelection = multi;
74
+ this.selectionModel.keyGetterFn = keyGetter;
75
+ this.selectionModel.replaceSelection(currentSelection);
76
+ this.log.info('Replaced selection popup with current ' + currentSelection.length + ' entities:', currentSelection);
71
77
  const dialogRef = this.openSelectDialog();
72
78
  return dialogRef.afterClosed().pipe(switchMap((chosenEntities) => {
73
79
  if (chosenEntities) {
@@ -97,8 +103,8 @@ export class SelectionModelPopupDirective {
97
103
  });
98
104
  }
99
105
  }
100
- SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SelectionModelPopupDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.MatDialog }, { token: ElderDataViewSelectionMode }], target: i0.ɵɵFactoryTarget.Directive });
101
- SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.2", type: SelectionModelPopupDirective, selector: "[elderSelectionModelPopup]", inputs: { elderSelectionModelPopupTransform: "elderSelectionModelPopupTransform" }, providers: [
106
+ SelectionModelPopupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: SelectionModelPopupDirective, deps: [{ token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i1.MatDialog }, { token: ElderDataViewSelectionMode }, { token: i2.SelectionModel }], target: i0.ɵɵFactoryTarget.Directive });
107
+ SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: SelectionModelPopupDirective, selector: "[elderSelectionModelPopup]", inputs: { elderSelectionModelPopupTransform: "elderSelectionModelPopupTransform" }, providers: [
102
108
  {
103
109
  provide: SelectionModel,
104
110
  useFactory: createSelectionModel
@@ -109,7 +115,7 @@ SelectionModelPopupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14
109
115
  },
110
116
  ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box
111
117
  ], ngImport: i0 });
112
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SelectionModelPopupDirective, decorators: [{
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: SelectionModelPopupDirective, decorators: [{
113
119
  type: Directive,
114
120
  args: [{
115
121
  selector: '[elderSelectionModelPopup]',
@@ -125,8 +131,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
125
131
  ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box
126
132
  ]
127
133
  }]
128
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i1.MatDialog }, { type: ElderDataViewSelectionMode }]; }, propDecorators: { elderSelectionModelPopupTransform: [{
134
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i1.MatDialog }, { type: ElderDataViewSelectionMode }, { type: i2.SelectionModel }]; }, propDecorators: { elderSelectionModelPopupTransform: [{
129
135
  type: Input,
130
136
  args: ['elderSelectionModelPopupTransform']
131
137
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,KAAK,EAAmD,MAAM,eAAe,CAAC;AACjG,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EAEL,iCAAiC,EAClC,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,KAAK,EAAc,EAAE,EAAC,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAC,cAAc,EAAC,MAAM,2CAA2C,CAAC;AAGzE,OAAO,EAAC,mBAAmB,EAAC,MAAM,wDAAwD,CAAC;;;AAG3F;;GAEG;AACH,MAAM,OAAO,0BAA0B;IAMrC;QAJO,UAAK,GAAW,EAAE,CAAC;QACnB,YAAO,GAAa,EAAE,CAAC;QACvB,UAAK,GAAY,KAAK,CAAC;IAEd,CAAC;CAClB;AAED,MAAM,UAAU,oBAAoB;IAClC,OAAO,IAAI,cAAc,EAAO,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,uBAAuB;IACrC,OAAO,IAAI,0BAA0B,EAAE,CAAC;AAC1C,CAAC;AAgBD,MAAM,OAAO,4BAA4B;IAiBvC;;;;gFAI4E;IAE5E,YACmB,WAA6B,EAC7B,aAA+B,EAC/B,MAAiB,EACjB,qBAAiD;QAHjD,gBAAW,GAAX,WAAW,CAAkB;QAC7B,kBAAa,GAAb,aAAa,CAAkB;QAC/B,WAAM,GAAN,MAAM,CAAW;QACjB,0BAAqB,GAArB,qBAAqB,CAA4B;QAzBpE;;;;oFAI4E;QAE3D,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAoBlE,CAAC;IAhBL,IACW,iCAAiC,CAAC,EAAmB;QAC9D,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC3B,CAAC;IAeD;;;;gFAI4E;IAG5E;;;;gFAI4E;IAErE,QAAQ,KAAW,CAAC;IAEpB,WAAW,KAAW,CAAC;IAE9B;;;;gFAI4E;IAE5E;;OAEG;IACI,MAAM,CACX,OAAkB,EAClB,KAAc,EACd,KAAK,GAAG,KAAK;QAGb,IAAI,CAAC,qBAAqB,CAAC,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;QAC/C,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,KAAK,CAAC;QAEzC,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAE1C,OAAO,SAAS,CAAC,WAAW,EAAE,CAAC,IAAI,CACjC,SAAS,CAAC,CAAC,cAAqB,EAAE,EAAE;YAClC,IAAI,cAAc,EAAE;gBAClB,OAAO,IAAI,CAAC,cAAc;oBACxB,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC7D,CAAC,CAAC,EAAE,CAAC,cAAc,CAAC,CAAC;aACxB;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED;;;;gFAI4E;IAEpE,gBAAgB;QACtB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CACrB,iCAAiC,EACjC;YACE,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,UAAU,EAAE,yBAAyB;YACrC,IAAI,EAAiC;gBACnC,0BAA0B,EAAE,IAAI,CAAC,WAAW;aAC7C;YACD,gBAAgB,EAAE,IAAI,CAAC,aAAa;SACrC,CACF,CAAC;IACJ,CAAC;;yHApGU,4BAA4B,sGA2BG,0BAA0B;6GA3BzD,4BAA4B,yIAZ5B;QACT;YACE,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,oBAAoB;SACjC;QACD;YACE,OAAO,EAAE,0BAA0B;YACnC,UAAU,EAAE,uBAAuB;SACpC;QACD,mBAAmB,CAAC,eAAe,CAAC,uEAAuE;KAC5G;2FAEU,4BAA4B;kBAdxC,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,cAAc;4BACvB,UAAU,EAAE,oBAAoB;yBACjC;wBACD;4BACE,OAAO,EAAE,0BAA0B;4BACnC,UAAU,EAAE,uBAAuB;yBACpC;wBACD,mBAAmB,CAAC,eAAe,CAAC,uEAAuE;qBAC5G;iBACF;2IA4B2C,0BAA0B,0BAdzD,iCAAiC;sBAD3C,KAAK;uBAAC,mCAAmC","sourcesContent":["import {Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\n\n\n/**\n * Configures the selection mode on supporting components.\n */\nexport class ElderDataViewSelectionMode {\n\n  public sorts: Sort[] = [];\n  public filters: Filter[] = [];\n  public multi: boolean = false;\n\n  constructor() { }\n}\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewSelection(): ElderDataViewSelectionMode {\n  return new ElderDataViewSelectionMode();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewSelectionMode,\n      useFactory: createDataViewSelection\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewSelectionMode: ElderDataViewSelectionMode\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(\n    filters?: Filter[],\n    sorts?: Sort[],\n    multi = false\n  ): Observable<any[]> {\n\n    this.dataViewSelectionMode.filters = filters || [];\n    this.dataViewSelectionMode.sorts = sorts || [];\n    this.dataViewSelectionMode.multi = multi;\n\n    const dialogRef = this.openSelectDialog();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-model-popup.directive.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/popup/selection-model-popup.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, OnDestroy, OnInit, TemplateRef, ViewContainerRef} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {MatDialog, MatDialogRef} from '@angular/material/dialog';\nimport {\n  ISelectionModelDialogOptions,\n  TemplatedSelectionDialogComponent\n} from './templated-selection-dialog/templated-selection-dialog.component';\nimport {switchMap} from 'rxjs/operators';\nimport {EMPTY, Observable, of} from 'rxjs';\nimport {KeyGetterFn, SelectionModel} from '../../../common/selection/selection-model';\nimport {Sort} from '../../../common/data/sort';\nimport {Filter} from '../../../common/data/filter';\nimport {ElderTableProviders} from '../../data-view/table/model/elder-table-model-provider';\n\n\n/**\n * Configures the selection mode on supporting components.\n */\nexport class ElderDataViewSelectionMode {\n\n  public sorts: Sort[] = [];\n  public filters: Filter[] = [];\n  public multi: boolean = false;\n\n  constructor() { }\n}\n\nexport function createSelectionModel(): SelectionModel<any> {\n  return new SelectionModel<any>();\n}\n\nexport function createDataViewSelection(): ElderDataViewSelectionMode {\n  return new ElderDataViewSelectionMode();\n}\n\n@Directive({\n  selector: '[elderSelectionModelPopup]',\n  providers: [\n    {\n      provide: SelectionModel,\n      useFactory: createSelectionModel\n    },\n    {\n      provide: ElderDataViewSelectionMode,\n      useFactory: createDataViewSelection\n    },\n    ElderTableProviders.ClearTableModel // Since this popup is frequently used inside an elder-table search box\n  ]\n})\nexport class SelectionModelPopupDirective implements OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  private _transformerFn: (o: any) => any;\n\n  @Input('elderSelectionModelPopupTransform')\n  public set elderSelectionModelPopupTransform(fn: (o: any) => any) {\n    this._transformerFn = fn;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly templateRef: TemplateRef<any>,\n    private readonly viewContainer: ViewContainerRef,\n    private readonly dialog: MatDialog,\n    private readonly dataViewSelectionMode: ElderDataViewSelectionMode,\n    private readonly selectionModel: SelectionModel<any>\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Listeners                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void { }\n\n  public ngOnDestroy(): void { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Let the user choose some entities and return the selection.\n   */\n  public choose(\n    keyGetter: KeyGetterFn<any>,\n    currentSelection: any[],\n    filters?: Filter[],\n    sorts?: Sort[],\n    multi = false\n  ): Observable<any[]> {\n\n    this.dataViewSelectionMode.filters = filters || [];\n    this.dataViewSelectionMode.sorts = sorts || [];\n    this.dataViewSelectionMode.multi = multi;\n\n    this.selectionModel.isMultipleSelection = multi;\n    this.selectionModel.keyGetterFn = keyGetter;\n    this.selectionModel.replaceSelection(currentSelection);\n\n    this.log.info('Replaced selection popup with current '+currentSelection.length+' entities:', currentSelection)\n\n    const dialogRef = this.openSelectDialog();\n\n    return dialogRef.afterClosed().pipe(\n      switchMap((chosenEntities: any[]) => {\n        if (chosenEntities) {\n          return this._transformerFn\n            ? of(chosenEntities.map(value => this._transformerFn(value)))\n            : of(chosenEntities);\n        } else {\n          return EMPTY;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private openSelectDialog(): MatDialogRef<TemplatedSelectionDialogComponent> {\n    return this.dialog.open(\n      TemplatedSelectionDialogComponent,\n      {\n        width: '90vw',\n        height: '90vh',\n        panelClass: 'custom-dialog-container',\n        data: <ISelectionModelDialogOptions> {\n          selectionComponentTemplate: this.templateRef\n        },\n        viewContainerRef: this.viewContainer\n      }\n    );\n  }\n\n}\n"]}
@@ -35,9 +35,9 @@ export class TemplatedSelectionDialogComponent {
35
35
  ngOnInit() {
36
36
  }
37
37
  }
38
- TemplatedSelectionDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: TemplatedSelectionDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.SelectionModel }], target: i0.ɵɵFactoryTarget.Component });
39
- TemplatedSelectionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: TemplatedSelectionDialogComponent, selector: "elder-templated-selection-dialog", ngImport: i0, template: "<div fxFill fxLayout=\"column\">\n\n <mat-toolbar color=\"primary\">\n <button mat-icon-button type=\"button\" mat-dialog-close>\n <mat-icon>close</mat-icon>\n </button>\n\n <span fxFlex></span>\n\n <button mat-flat-button type=\"submit\" color=\"accent\"\n *ngIf=\"selectionModel.selection | async as selection\"\n [disabled]=\"!selection || selection.length === 0\"\n [mat-dialog-close]=\"selection\"\n >\n {{'actions.select' | translate}}\n </button>\n\n </mat-toolbar>\n\n <div fxLayout=\"column\" fxFlex>\n <ng-container *ngTemplateOutlet=\"data.selectionComponentTemplate\"></ng-container>\n </div>\n\n <!--\n <div fxLayout=\"row\" fxLayoutAlign=\"end center\" fxLayoutGap=\"12px\">\n\n </div>\n -->\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i7.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: i7.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i7.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: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: TemplatedSelectionDialogComponent, decorators: [{
38
+ TemplatedSelectionDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: TemplatedSelectionDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i2.SelectionModel }], target: i0.ɵɵFactoryTarget.Component });
39
+ TemplatedSelectionDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: TemplatedSelectionDialogComponent, selector: "elder-templated-selection-dialog", ngImport: i0, template: "<div fxFill fxLayout=\"column\">\n\n <mat-toolbar color=\"primary\">\n <button mat-icon-button type=\"button\" mat-dialog-close>\n <mat-icon>close</mat-icon>\n </button>\n\n <span fxFlex></span>\n\n <button mat-flat-button type=\"submit\" color=\"accent\"\n *ngIf=\"selectionModel.selection | async as selection\"\n [disabled]=\"!selection || selection.length === 0\"\n [mat-dialog-close]=\"selection\"\n >\n {{'actions.select' | translate}}\n </button>\n\n </mat-toolbar>\n\n <div fxLayout=\"column\" fxFlex>\n <ng-container *ngTemplateOutlet=\"data.selectionComponentTemplate\"></ng-container>\n </div>\n\n <!--\n <div fxLayout=\"row\" fxLayoutAlign=\"end center\" fxLayoutGap=\"12px\">\n\n </div>\n -->\n\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i7.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: i7.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i7.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: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: TemplatedSelectionDialogComponent, decorators: [{
41
41
  type: Component,
42
42
  args: [{ selector: 'elder-templated-selection-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div fxFill fxLayout=\"column\">\n\n <mat-toolbar color=\"primary\">\n <button mat-icon-button type=\"button\" mat-dialog-close>\n <mat-icon>close</mat-icon>\n </button>\n\n <span fxFlex></span>\n\n <button mat-flat-button type=\"submit\" color=\"accent\"\n *ngIf=\"selectionModel.selection | async as selection\"\n [disabled]=\"!selection || selection.length === 0\"\n [mat-dialog-close]=\"selection\"\n >\n {{'actions.select' | translate}}\n </button>\n\n </mat-toolbar>\n\n <div fxLayout=\"column\" fxFlex>\n <ng-container *ngTemplateOutlet=\"data.selectionComponentTemplate\"></ng-container>\n </div>\n\n <!--\n <div fxLayout=\"row\" fxLayoutAlign=\"end center\" fxLayoutGap=\"12px\">\n\n </div>\n -->\n\n</div>\n" }]
43
43
  }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
@@ -111,14 +111,14 @@ export class ElderChipListSelectComponent {
111
111
  entity[this.idField] : entity;
112
112
  }
113
113
  }
114
- ElderChipListSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectComponent, deps: [{ token: i1.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Component });
115
- ElderChipListSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: ElderChipListSelectComponent, selector: "elder-chip-list-select", inputs: { data$: "data$", idField: "idField", displayField: "displayField", color: "color", stacked: "stacked", data: "data", selection: "selection", selectionMultiEnabled: "selectionMultiEnabled" }, outputs: { itemClick: "itemClick", selectionChange: "selectionChange", selectionSingleChange: "selectionSingleChange" }, providers: [
114
+ ElderChipListSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectComponent, deps: [{ token: i1.SelectionModel, optional: true }], target: i0.ɵɵFactoryTarget.Component });
115
+ ElderChipListSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: ElderChipListSelectComponent, selector: "elder-chip-list-select", inputs: { data$: "data$", idField: "idField", displayField: "displayField", color: "color", stacked: "stacked", data: "data", selection: "selection", selectionMultiEnabled: "selectionMultiEnabled" }, outputs: { itemClick: "itemClick", selectionChange: "selectionChange", selectionSingleChange: "selectionSingleChange" }, providers: [
116
116
  {
117
117
  provide: ELDER_DATA_VIEW,
118
118
  useExisting: forwardRef(() => ElderChipListSelectComponent)
119
119
  }
120
120
  ], ngImport: i0, template: "\n<div fxLayout=\"column\" fxFill>\n\n <mat-chip-list [ngClass]=\"{'mat-chip-list-stacked' : stacked}\">\n <mat-chip *ngFor=\"let chip of data$ | async\" selected\n [color]=\"isSelected(chip) ? color : 'undefined'\"\n (click)=\"onItemClick(chip)\">\n {{getDisplayText(chip)}}\n </mat-chip>\n </mat-chip-list>\n\n</div>\n\n", styles: [".select-item{padding-left:16px;padding-right:16px;min-height:56px;border-radius:0;font-size:16px;font-weight:400}elder-select-list-item a.select-item-inactive mat-icon{color:#757575}.nested-items-container{overflow:hidden;padding-left:20px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i3.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i4.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { kind: "component", type: i5.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i5.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
121
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectComponent, decorators: [{
121
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectComponent, decorators: [{
122
122
  type: Component,
123
123
  args: [{ selector: 'elder-chip-list-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
124
124
  {
@@ -9,8 +9,8 @@ import * as i0 from "@angular/core";
9
9
  export { ElderChipListSelectComponent } from './chip-list-select/elder-chip-list-select.component';
10
10
  export class ElderChipListSelectModule {
11
11
  }
12
- ElderChipListSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
13
- ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectModule, declarations: [ElderChipListSelectComponent], imports: [
12
+ ElderChipListSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
13
+ ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectModule, declarations: [ElderChipListSelectComponent], imports: [
14
14
  // Angular
15
15
  CommonModule,
16
16
  // Third Party
@@ -18,7 +18,7 @@ ElderChipListSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0
18
18
  // Material
19
19
  MatChipsModule,
20
20
  A11yModule], exports: [ElderChipListSelectComponent] });
21
- ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectModule, imports: [
21
+ ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectModule, imports: [
22
22
  // Angular
23
23
  CommonModule,
24
24
  // Third Party
@@ -26,7 +26,7 @@ ElderChipListSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0
26
26
  // Material
27
27
  MatChipsModule,
28
28
  A11yModule] });
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: ElderChipListSelectModule, decorators: [{
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderChipListSelectModule, decorators: [{
30
30
  type: NgModule,
31
31
  args: [{
32
32
  imports: [