@elderbyte/ngx-starter 13.7.8 → 13.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (261) hide show
  1. package/esm2020/lib/common/data/data-context/data-context-builder.mjs +4 -3
  2. package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +4 -4
  3. package/esm2020/lib/common/forms/form-field-base.component.mjs +4 -4
  4. package/esm2020/lib/common/forms/multi-model-base.component.mjs +4 -4
  5. package/esm2020/lib/common/forms/template-composite-control.mjs +4 -4
  6. package/esm2020/lib/common/forms/value-accessor-base.mjs +4 -4
  7. package/esm2020/lib/common/http/http-client-builder.service.mjs +4 -4
  8. package/esm2020/lib/common/http/http-client-pristine.mjs +4 -4
  9. package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +4 -4
  10. package/esm2020/lib/common/templates/template-slot-manager.mjs +34 -6
  11. package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +4 -4
  12. package/esm2020/lib/common/utils/filter-util.mjs +11 -2
  13. package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +4 -4
  14. package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +5 -5
  15. package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +4 -4
  16. package/esm2020/lib/components/auditing/elder-audit.module.mjs +5 -5
  17. package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +4 -4
  18. package/esm2020/lib/components/button-group/elder-button-group.module.mjs +5 -5
  19. package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -4
  20. package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +4 -4
  21. package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +4 -4
  22. package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +5 -5
  23. package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +4 -4
  24. package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +19 -19
  25. package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +5 -5
  26. package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +5 -5
  27. package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +4 -4
  28. package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +4 -4
  29. package/esm2020/lib/components/containers/elder-containers.module.mjs +5 -5
  30. package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +4 -4
  31. package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +4 -4
  32. package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +4 -4
  33. package/esm2020/lib/components/csv/elder-csv.module.mjs +5 -5
  34. package/esm2020/lib/components/currency/elder-currency.module.mjs +5 -5
  35. package/esm2020/lib/components/currency/elder-currency.pipe.mjs +4 -4
  36. package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +5 -5
  37. package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +4 -4
  38. package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +4 -4
  39. package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -4
  40. package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +4 -4
  41. package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +4 -4
  42. package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +4 -4
  43. package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +5 -5
  44. package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -4
  45. package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +5 -5
  46. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +7 -7
  47. package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -4
  48. package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -4
  49. package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +4 -4
  50. package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +11 -11
  51. package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +5 -5
  52. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +4 -4
  53. package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +5 -5
  54. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +4 -4
  55. package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +4 -4
  56. package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +4 -4
  57. package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +4 -4
  58. package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +5 -5
  59. package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +4 -4
  60. package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +4 -4
  61. package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +4 -4
  62. package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +4 -4
  63. package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +4 -4
  64. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +5 -5
  65. package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +4 -4
  66. package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -4
  67. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +8 -8
  68. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +4 -4
  69. package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -4
  70. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -4
  71. package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +4 -4
  72. package/esm2020/lib/components/errors/elder-error.module.mjs +5 -5
  73. package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +4 -4
  74. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -4
  75. package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +5 -5
  76. package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +4 -4
  77. package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +4 -4
  78. package/esm2020/lib/components/files/elder-file-select.directive.mjs +4 -4
  79. package/esm2020/lib/components/files/elder-file.module.mjs +5 -5
  80. package/esm2020/lib/components/files/file-select/file-select.component.mjs +4 -4
  81. package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +4 -4
  82. package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +4 -4
  83. package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +34 -0
  84. package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +4 -4
  85. package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +4 -4
  86. package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +10 -25
  87. package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +4 -4
  88. package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +34 -0
  89. package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +11 -32
  90. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +24 -18
  91. package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +4 -4
  92. package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +4 -4
  93. package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +4 -4
  94. package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +4 -4
  95. package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +4 -4
  96. package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +4 -4
  97. package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +4 -4
  98. package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +4 -4
  99. package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +4 -4
  100. package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +4 -4
  101. package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +4 -4
  102. package/esm2020/lib/components/forms/elder-forms.module.mjs +5 -5
  103. package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +4 -4
  104. package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +4 -4
  105. package/esm2020/lib/components/forms/search/elder-search.module.mjs +5 -5
  106. package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +4 -4
  107. package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +4 -4
  108. package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -4
  109. package/esm2020/lib/components/global-search/elder-global-search.module.mjs +5 -5
  110. package/esm2020/lib/components/global-search/elder-global-search.service.mjs +4 -4
  111. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +4 -4
  112. package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +5 -5
  113. package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -4
  114. package/esm2020/lib/components/headers/elder-header.module.mjs +5 -5
  115. package/esm2020/lib/components/http-support/elder-http-client.service.mjs +4 -4
  116. package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +5 -5
  117. package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +4 -4
  118. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +4 -4
  119. package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +4 -4
  120. package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +4 -4
  121. package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +4 -4
  122. package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +4 -4
  123. package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +4 -4
  124. package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +4 -4
  125. package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +4 -4
  126. package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +4 -4
  127. package/esm2020/lib/components/i18n/language/elder-language.module.mjs +5 -5
  128. package/esm2020/lib/components/i18n/language/elder-language.service.mjs +4 -4
  129. package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +4 -4
  130. package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +5 -5
  131. package/esm2020/lib/components/iframes/elder-iframe.module.mjs +5 -5
  132. package/esm2020/lib/components/iframes/iframe-close.directive.mjs +4 -4
  133. package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -4
  134. package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +4 -4
  135. package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -4
  136. package/esm2020/lib/components/iframes/iframe.service.mjs +4 -4
  137. package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +4 -4
  138. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +4 -4
  139. package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +8 -8
  140. package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -4
  141. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  142. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +5 -5
  143. package/esm2020/lib/components/labels/elder-labels.module.mjs +5 -5
  144. package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +4 -4
  145. package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +4 -4
  146. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +4 -4
  147. package/esm2020/lib/components/measures/elder-measures.module.mjs +9 -9
  148. package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +4 -4
  149. package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +4 -4
  150. package/esm2020/lib/components/measures/elder-unit.service.mjs +4 -4
  151. package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +4 -4
  152. package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +4 -4
  153. package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +5 -5
  154. package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +4 -4
  155. package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +4 -4
  156. package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +5 -5
  157. package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +5 -5
  158. package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +4 -4
  159. package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -4
  160. package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +4 -4
  161. package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +4 -4
  162. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +5 -5
  163. package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +8 -6
  164. package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +19 -15
  165. package/esm2020/lib/components/navigation/toolbar/toolbar-column-position.mjs +1 -1
  166. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +4 -4
  167. package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +4 -4
  168. package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +4 -4
  169. package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +4 -4
  170. package/esm2020/lib/components/overlays/elder-overlay.component.mjs +4 -4
  171. package/esm2020/lib/components/overlays/elder-overlay.module.mjs +5 -5
  172. package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +4 -4
  173. package/esm2020/lib/components/panels/elder-panel.module.mjs +5 -5
  174. package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +4 -4
  175. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +4 -4
  176. package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +17 -15
  177. package/esm2020/lib/components/select/elder-select-base.mjs +21 -6
  178. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +4 -4
  179. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +4 -4
  180. package/esm2020/lib/components/select/elder-select-value.directive.mjs +4 -4
  181. package/esm2020/lib/components/select/elder-select.module.mjs +9 -8
  182. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +30 -5
  183. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +18 -24
  184. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +7 -5
  185. package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +4 -4
  186. package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -4
  187. package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +5 -5
  188. package/esm2020/lib/components/select-list/elder-select-list.module.mjs +5 -5
  189. package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +4 -4
  190. package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +4 -4
  191. package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +4 -4
  192. package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +4 -4
  193. package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +4 -4
  194. package/esm2020/lib/components/shell/elder-shell.module.mjs +5 -5
  195. package/esm2020/lib/components/shell/elder-shell.service.mjs +4 -4
  196. package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -4
  197. package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +13 -13
  198. package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +4 -4
  199. package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +4 -4
  200. package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +4 -4
  201. package/esm2020/lib/components/tabs/elder-tab.module.mjs +5 -5
  202. package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +4 -4
  203. package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +4 -4
  204. package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +4 -4
  205. package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +4 -4
  206. package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +4 -4
  207. package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +4 -4
  208. package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +4 -4
  209. package/esm2020/lib/components/time/elder-time.module.mjs +9 -9
  210. package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +4 -4
  211. package/esm2020/lib/components/toasts/elder-toast.module.mjs +5 -5
  212. package/esm2020/lib/components/toasts/elder-toast.service.mjs +10 -10
  213. package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +4 -4
  214. package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +5 -5
  215. package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -4
  216. package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +4 -4
  217. package/esm2020/lib/components/viewers/elder-viewers.module.mjs +5 -5
  218. package/esm2020/lib/features/event-source/elder-event-source.service.mjs +4 -4
  219. package/esm2020/lib/features/kafent/access-token-provider.mjs +4 -4
  220. package/esm2020/lib/features/kafent/kafent-config.mjs +4 -4
  221. package/esm2020/lib/features/kafent/kafent-event-stream.mjs +4 -4
  222. package/esm2020/lib/features/kafent/kafent-event.service.mjs +4 -4
  223. package/esm2020/lib/features/kafent/kafent-live-event-request.mjs +1 -1
  224. package/esm2020/lib/features/kafent/kafent.module.mjs +5 -5
  225. package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +4 -4
  226. package/esm2020/lib/pipes/bytes.pipe.mjs +4 -4
  227. package/esm2020/lib/pipes/elder-pipes.module.mjs +12 -10
  228. package/esm2020/lib/pipes/elder-repeat.pipe.mjs +4 -4
  229. package/esm2020/lib/pipes/elder-round.pipe.mjs +4 -4
  230. package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +4 -4
  231. package/esm2020/lib/pipes/elder-trim.pipe.mjs +40 -0
  232. package/esm2020/lib/pipes/iso-duration.pipe.mjs +4 -4
  233. package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +4 -4
  234. package/esm2020/lib/pipes/iso-interval.pipe.mjs +4 -4
  235. package/esm2020/lib/pipes/time-ago.pipe.mjs +4 -4
  236. package/esm2020/lib/pipes/time-duration.pipe.mjs +4 -4
  237. package/esm2020/lib/pipes/weight.pipe.mjs +4 -4
  238. package/fesm2015/elderbyte-ngx-starter.mjs +1086 -943
  239. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  240. package/fesm2020/elderbyte-ngx-starter.mjs +1085 -943
  241. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  242. package/lib/common/templates/template-slot-manager.d.ts +13 -1
  243. package/lib/components/forms/directives/base/elder-class-hostbinding-base.d.ts +32 -0
  244. package/lib/components/forms/directives/elder-form-field-dense.directive.d.ts +3 -17
  245. package/lib/components/forms/directives/elder-form-field-no-hint.directive.d.ts +19 -0
  246. package/lib/components/forms/directives/elder-form-field-no-spinner.directive.d.ts +3 -17
  247. package/lib/components/forms/directives/elder-forms-directives.module.d.ts +5 -3
  248. package/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.d.ts +13 -10
  249. package/lib/components/navigation/toolbar/toolbar-column-position.d.ts +9 -1
  250. package/lib/components/select/elder-select-base.d.ts +10 -2
  251. package/lib/components/select/elder-select.module.d.ts +2 -1
  252. package/lib/components/select/multi/elder-multi-select-base.d.ts +9 -0
  253. package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +0 -3
  254. package/lib/components/select/popup/selection-model-popup.directive.d.ts +2 -1
  255. package/lib/components/shell/shell/elder-shell.component.d.ts +3 -2
  256. package/lib/pipes/elder-pipes.module.d.ts +4 -2
  257. package/lib/pipes/elder-trim.pipe.d.ts +17 -0
  258. package/package.json +1 -1
  259. package/src/lib/components/select/elder-select/elder-select.component.scss +4 -0
  260. package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +4 -0
  261. package/theming/_elder-common.scss +13 -8
@@ -15,9 +15,9 @@ export class ElderPanelComponent extends _ElderPanelMixinBase {
15
15
  ngOnInit() {
16
16
  }
17
17
  }
18
- ElderPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderPanelComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
19
- ElderPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: { color: "color" }, host: { classAttribute: "mat-panel" }, usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n\n", styles: [".test{padding:10px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderPanelComponent, decorators: [{
18
+ ElderPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderPanelComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
19
+ ElderPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderPanelComponent, selector: "elder-panel, mat-panel", inputs: { color: "color" }, host: { classAttribute: "mat-panel" }, usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n\n", styles: [".test{padding:10px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderPanelComponent, decorators: [{
21
21
  type: Component,
22
22
  args: [{ selector: 'elder-panel, mat-panel', inputs: ['color'], host: {
23
23
  'class': 'mat-panel',
@@ -25,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
25
25
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { color: [{
26
26
  type: Input
27
27
  }] } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9wYW5lbHMvZmxhdC9lbGRlci1wYW5lbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3BhbmVscy9mbGF0L2VsZGVyLXBhbmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUN2RyxPQUFPLEVBQTBCLFVBQVUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQUc1RSxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFlBQW1CLFNBQW9CLEVBQVMsV0FBdUI7UUFBcEQsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUFTLGdCQUFXLEdBQVgsV0FBVyxDQUFZO0lBQUcsQ0FBQztDQUM1RTtBQUVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUE0RCxVQUFVLENBQUMsdUJBQXVCLENBQUMsQ0FBQztBQWFqSSxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsb0JBQW9CO0lBSzNELFlBQVksUUFBbUIsRUFBRSxVQUFzQjtRQUNyRCxLQUFLLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxRQUFRO0lBQ1IsQ0FBQzs7Z0hBVlUsbUJBQW1CO29HQUFuQixtQkFBbUIsd0pDckJoQywrQkFFQTsyRkRtQmEsbUJBQW1CO2tCQVYvQixTQUFTOytCQUNFLHdCQUF3QixVQUUxQixDQUFDLE9BQU8sQ0FBQyxRQUVYO3dCQUNKLE9BQU8sRUFBRSxXQUFXO3FCQUNyQixtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTTt5SEFLeEMsS0FBSztzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgT25Jbml0LCBSZW5kZXJlcjJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2FuQ29sb3IsIFRoZW1lUGFsZXR0ZSwgbWl4aW5Db2xvciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHtDb25zdHJ1Y3Rvcn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZS9jb21tb24tYmVoYXZpb3JzL2NvbnN0cnVjdG9yJztcblxuZXhwb3J0IGNsYXNzIEVsZGVyUGFuZWxDb21wb25lbnRCYXNlIHtcbiAgY29uc3RydWN0b3IocHVibGljIF9yZW5kZXJlcjogUmVuZGVyZXIyLCBwdWJsaWMgX2VsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG59XG5cbmV4cG9ydCBjb25zdCBfRWxkZXJQYW5lbE1peGluQmFzZTogQ29uc3RydWN0b3I8Q2FuQ29sb3I+ICYgdHlwZW9mIEVsZGVyUGFuZWxDb21wb25lbnRCYXNlID0gIG1peGluQ29sb3IoRWxkZXJQYW5lbENvbXBvbmVudEJhc2UpO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLXBhbmVsLCBtYXQtcGFuZWwnLFxuICB0ZW1wbGF0ZVVybDogJy4vZWxkZXItcGFuZWwuY29tcG9uZW50Lmh0bWwnLFxuICBpbnB1dHM6IFsnY29sb3InXSxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItcGFuZWwuY29tcG9uZW50LnNjc3MnXSxcbiAgaG9zdDoge1xuICAgICdjbGFzcyc6ICdtYXQtcGFuZWwnLFxuICB9LFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlclBhbmVsQ29tcG9uZW50IGV4dGVuZHMgX0VsZGVyUGFuZWxNaXhpbkJhc2UgaW1wbGVtZW50cyBPbkluaXQsIENhbkNvbG9yIHtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZTsgLy8gRml4IENhbkNvbG9yIGludGVyZmFjZSBpc3N1ZVxuXG4gIGNvbnN0cnVjdG9yKHJlbmRlcmVyOiBSZW5kZXJlcjIsIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICBzdXBlcihyZW5kZXJlciwgZWxlbWVudFJlZik7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9wYW5lbHMvZmxhdC9lbGRlci1wYW5lbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3BhbmVscy9mbGF0L2VsZGVyLXBhbmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFvQixNQUFNLGVBQWUsQ0FBQztBQUN2RyxPQUFPLEVBQTBCLFVBQVUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQUc1RSxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFlBQW1CLFNBQW9CLEVBQVMsV0FBdUI7UUFBcEQsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUFTLGdCQUFXLEdBQVgsV0FBVyxDQUFZO0lBQUcsQ0FBQztDQUM1RTtBQUVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUE0RCxVQUFVLENBQUMsdUJBQXVCLENBQUMsQ0FBQztBQWFqSSxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsb0JBQW9CO0lBSzNELFlBQVksUUFBbUIsRUFBRSxVQUFzQjtRQUNyRCxLQUFLLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxRQUFRO0lBQ1IsQ0FBQzs7aUhBVlUsbUJBQW1CO3FHQUFuQixtQkFBbUIsd0pDckJoQywrQkFFQTs0RkRtQmEsbUJBQW1CO2tCQVYvQixTQUFTOytCQUNFLHdCQUF3QixVQUUxQixDQUFDLE9BQU8sQ0FBQyxRQUVYO3dCQUNKLE9BQU8sRUFBRSxXQUFXO3FCQUNyQixtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTTt5SEFLeEMsS0FBSztzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgT25Jbml0LCBSZW5kZXJlcjJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ2FuQ29sb3IsIFRoZW1lUGFsZXR0ZSwgbWl4aW5Db2xvciB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHtDb25zdHJ1Y3Rvcn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZS9jb21tb24tYmVoYXZpb3JzL2NvbnN0cnVjdG9yJztcblxuZXhwb3J0IGNsYXNzIEVsZGVyUGFuZWxDb21wb25lbnRCYXNlIHtcbiAgY29uc3RydWN0b3IocHVibGljIF9yZW5kZXJlcjogUmVuZGVyZXIyLCBwdWJsaWMgX2VsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG59XG5cbmV4cG9ydCBjb25zdCBfRWxkZXJQYW5lbE1peGluQmFzZTogQ29uc3RydWN0b3I8Q2FuQ29sb3I+ICYgdHlwZW9mIEVsZGVyUGFuZWxDb21wb25lbnRCYXNlID0gIG1peGluQ29sb3IoRWxkZXJQYW5lbENvbXBvbmVudEJhc2UpO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLXBhbmVsLCBtYXQtcGFuZWwnLFxuICB0ZW1wbGF0ZVVybDogJy4vZWxkZXItcGFuZWwuY29tcG9uZW50Lmh0bWwnLFxuICBpbnB1dHM6IFsnY29sb3InXSxcbiAgc3R5bGVVcmxzOiBbJy4vZWxkZXItcGFuZWwuY29tcG9uZW50LnNjc3MnXSxcbiAgaG9zdDoge1xuICAgICdjbGFzcyc6ICdtYXQtcGFuZWwnLFxuICB9LFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbGRlclBhbmVsQ29tcG9uZW50IGV4dGVuZHMgX0VsZGVyUGFuZWxNaXhpbkJhc2UgaW1wbGVtZW50cyBPbkluaXQsIENhbkNvbG9yIHtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZTsgLy8gRml4IENhbkNvbG9yIGludGVyZmFjZSBpc3N1ZVxuXG4gIGNvbnN0cnVjdG9yKHJlbmRlcmVyOiBSZW5kZXJlcjIsIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICBzdXBlcihyZW5kZXJlciwgZWxlbWVudFJlZik7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiJdfQ==
@@ -63,9 +63,9 @@ export class ElderAutoSelectFirstDirective {
63
63
  }
64
64
  }
65
65
  }
66
- ElderAutoSelectFirstDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderAutoSelectFirstDirective, deps: [{ token: i1.ElderSelectComponent }], target: i0.ɵɵFactoryTarget.Directive });
67
- ElderAutoSelectFirstDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderAutoSelectFirstDirective, selector: "[autoSelectFirst]", inputs: { autoSelectFirstEnabled: ["autoSelectFirst", "autoSelectFirstEnabled"] }, ngImport: i0 });
68
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderAutoSelectFirstDirective, decorators: [{
66
+ ElderAutoSelectFirstDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderAutoSelectFirstDirective, deps: [{ token: i1.ElderSelectComponent }], target: i0.ɵɵFactoryTarget.Directive });
67
+ ElderAutoSelectFirstDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderAutoSelectFirstDirective, selector: "[autoSelectFirst]", inputs: { autoSelectFirstEnabled: ["autoSelectFirst", "autoSelectFirstEnabled"] }, ngImport: i0 });
68
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderAutoSelectFirstDirective, decorators: [{
69
69
  type: Directive,
70
70
  args: [{
71
71
  selector: '[autoSelectFirst]'
@@ -74,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
74
74
  type: Input,
75
75
  args: ['autoSelectFirst']
76
76
  }] } });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYXV0by1zZWxlY3QtZmlyc3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QvYXV0by9lbGRlci1hdXRvLXNlbGVjdC1maXJzdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNuRCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQU81RCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQzs7O0FBSy9ELE1BQU0sT0FBTyw2QkFBNkI7SUFZeEM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ2tCLFdBQW9EO1FBQXBELGdCQUFXLEdBQVgsV0FBVyxDQUF5QztRQWpCdEU7Ozs7b0ZBSTRFO1FBRTNELFFBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFZbEUsQ0FBQztJQUVMOzs7O2dGQUk0RTtJQUVyRSxlQUFlO1FBQ3BCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1lBQ3ZFLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQy9CLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNULENBQUM7SUFFRDs7OztnRkFJNEU7SUFFNUU7OztPQUdHO0lBQ0gsSUFDVyxzQkFBc0IsQ0FBQyxHQUFxQjtRQUNyRCxJQUFJLENBQUMsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxJQUFXLE9BQU8sQ0FBQyxHQUFZO1FBQzdCLElBQUksQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFcEUscUJBQXFCO1FBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRTtZQUMzQixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQywyQ0FBMkMsQ0FBQyxDQUFDO1lBQzVELG9CQUFvQixDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDdkQ7YUFBTTtZQUNMLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLDRFQUE0RSxDQUFDLENBQUM7U0FDN0Y7SUFDSCxDQUFDOzswSEF2RVUsNkJBQTZCOzhHQUE3Qiw2QkFBNkI7MkZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2lCQUM5QjsyR0ErQ1ksc0JBQXNCO3NCQURoQyxLQUFLO3VCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7Y29lcmNlQm9vbGVhblByb3BlcnR5fSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHtFTVBUWSwgT2JzZXJ2YWJsZSwgb2Z9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtjYXRjaEVycm9yLCBmaWx0ZXIsIGZpcnN0LCBtYXAsIHN3aXRjaE1hcCwgdGFrZVVudGlsLCB0YXAsIHRpbWVvdXR9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7RWxkZXJTZWxlY3RDb21wb25lbnRTdGF0ZX0gZnJvbSAnLi4vZWxkZXItc2VsZWN0LWJhc2UnO1xuaW1wb3J0IHtJRGF0YUNvbnRleHR9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9kYXRhL2RhdGEtY29udGV4dC9kYXRhLWNvbnRleHQnO1xuaW1wb3J0IHtEYXRhU291cmNlQWRhcHRlcn0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2RhdGEvZGF0YXNvdXJjZS9kYXRhLXNvdXJjZS1hZGFwdGVyJztcbmltcG9ydCB7RWxkZXJTZWxlY3RDb21wb25lbnR9IGZyb20gJy4uL2VsZGVyLXNlbGVjdC9lbGRlci1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7RWxkZXJTZWxlY3RGaXJzdFV0aWx9IGZyb20gJy4vZWxkZXItc2VsZWN0LWZpcnN0LXV0aWwnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXV0b1NlbGVjdEZpcnN0XSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJBdXRvU2VsZWN0Rmlyc3REaXJlY3RpdmU8VEVudGl0eSA9IGFueSwgVElkID0gYW55PiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbG9nID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIodGhpcy5jb25zdHJ1Y3Rvci5uYW1lKTtcblxuICBwcml2YXRlIF9lbmFibGVkOiBib29sZWFuO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBlbGRlclNlbGVjdDogRWxkZXJTZWxlY3RDb21wb25lbnQ8VEVudGl0eSwgVElkLCBhbnk+XG4gICkgeyB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmUgQ3ljbGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHsgLy8gSEFDSzogV2FpdCB1bnRpbCBuZ01vZGVsIGhhcyBkb25lIGl0cyBzdHJhbmdlIG51bGwvZW1wdHkgdmFsdWUgaW5pdC4uLlxuICAgICAgdGhpcy5sb2cuaW5mbygnYXV0b1NlbGVjdEZpcnN0IGFmdGVyLXZpZXcgaW5pdCwgYXV0byBzZWxlY3RpbmcgdmFsdWUnKTtcbiAgICAgIHRoaXMuaGFuZGxlQXV0b1NlbGVjdEZpcnN0KCk7XG4gICAgfSwgMTApO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFByb3BlcnRpZXMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgLyoqXG4gICAqIEFmdGVyIGRhdGEgaXMgbG9hZGVkIGludG8gdGhpcyBzZWxlY3QsIGVuc3VyZSB0aGF0XG4gICAqIGEgdmFsdWUgaXMgc2VsZWN0ZWQgb3Igc2VsZWN0IHRoZSBmaXJzdCBhdXRvbWF0aWNhbGx5LlxuICAgKi9cbiAgQElucHV0KCdhdXRvU2VsZWN0Rmlyc3QnKVxuICBwdWJsaWMgc2V0IGF1dG9TZWxlY3RGaXJzdEVuYWJsZWQodmFsOiBib29sZWFuIHwgc3RyaW5nKSB7XG4gICAgdGhpcy5lbmFibGVkID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbCk7XG4gIH1cblxuICBwdWJsaWMgc2V0IGVuYWJsZWQodmFsOiBib29sZWFuKSB7XG4gICAgdGhpcy5fZW5hYmxlZCA9IHZhbDtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZW5hYmxlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZW5hYmxlZDtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgaGFuZGxlQXV0b1NlbGVjdEZpcnN0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5lbGRlclNlbGVjdC52YWx1ZSkge1xuICAgICAgdGhpcy5sb2cuZGVidWcoJ0F0dGVtcHRpbmcgdG8gYXV0byBzZWxlY3QgZmlyc3QgZW50aXR5Li4uJyk7XG4gICAgICBFbGRlclNlbGVjdEZpcnN0VXRpbC50cnlTZWxlY3RGaXJzdCh0aGlzLmVsZGVyU2VsZWN0KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5sb2cud2FybignQ29uZmxpY3QgYXZvaWRlZDogQWJvcnRlZCBhdXRvIHNlbGVjdGlvbiBiZWNhdXNlIHZhbHVlIGlkIGFscmVhZHkgcHJlc2VudCEnKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItYXV0by1zZWxlY3QtZmlyc3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QvYXV0by9lbGRlci1hdXRvLXNlbGVjdC1maXJzdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNuRCxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQU81RCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQzs7O0FBSy9ELE1BQU0sT0FBTyw2QkFBNkI7SUFZeEM7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ2tCLFdBQW9EO1FBQXBELGdCQUFXLEdBQVgsV0FBVyxDQUF5QztRQWpCdEU7Ozs7b0ZBSTRFO1FBRTNELFFBQUcsR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFZbEUsQ0FBQztJQUVMOzs7O2dGQUk0RTtJQUVyRSxlQUFlO1FBQ3BCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1lBQ3ZFLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQy9CLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNULENBQUM7SUFFRDs7OztnRkFJNEU7SUFFNUU7OztPQUdHO0lBQ0gsSUFDVyxzQkFBc0IsQ0FBQyxHQUFxQjtRQUNyRCxJQUFJLENBQUMsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxJQUFXLE9BQU8sQ0FBQyxHQUFZO1FBQzdCLElBQUksQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFcEUscUJBQXFCO1FBQzNCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssRUFBRTtZQUMzQixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQywyQ0FBMkMsQ0FBQyxDQUFDO1lBQzVELG9CQUFvQixDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDdkQ7YUFBTTtZQUNMLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLDRFQUE0RSxDQUFDLENBQUM7U0FDN0Y7SUFDSCxDQUFDOzsySEF2RVUsNkJBQTZCOytHQUE3Qiw2QkFBNkI7NEZBQTdCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2lCQUM5QjsyR0ErQ1ksc0JBQXNCO3NCQURoQyxLQUFLO3VCQUFDLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QWZ0ZXJWaWV3SW5pdCwgRGlyZWN0aXZlLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7Y29lcmNlQm9vbGVhblByb3BlcnR5fSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHtFTVBUWSwgT2JzZXJ2YWJsZSwgb2Z9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtjYXRjaEVycm9yLCBmaWx0ZXIsIGZpcnN0LCBtYXAsIHN3aXRjaE1hcCwgdGFrZVVudGlsLCB0YXAsIHRpbWVvdXR9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7RWxkZXJTZWxlY3RDb21wb25lbnRTdGF0ZX0gZnJvbSAnLi4vZWxkZXItc2VsZWN0LWJhc2UnO1xuaW1wb3J0IHtJRGF0YUNvbnRleHR9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9kYXRhL2RhdGEtY29udGV4dC9kYXRhLWNvbnRleHQnO1xuaW1wb3J0IHtEYXRhU291cmNlQWRhcHRlcn0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2RhdGEvZGF0YXNvdXJjZS9kYXRhLXNvdXJjZS1hZGFwdGVyJztcbmltcG9ydCB7RWxkZXJTZWxlY3RDb21wb25lbnR9IGZyb20gJy4uL2VsZGVyLXNlbGVjdC9lbGRlci1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7RWxkZXJTZWxlY3RGaXJzdFV0aWx9IGZyb20gJy4vZWxkZXItc2VsZWN0LWZpcnN0LXV0aWwnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXV0b1NlbGVjdEZpcnN0XSdcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJBdXRvU2VsZWN0Rmlyc3REaXJlY3RpdmU8VEVudGl0eSA9IGFueSwgVElkID0gYW55PiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbG9nID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIodGhpcy5jb25zdHJ1Y3Rvci5uYW1lKTtcblxuICBwcml2YXRlIF9lbmFibGVkOiBib29sZWFuO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBlbGRlclNlbGVjdDogRWxkZXJTZWxlY3RDb21wb25lbnQ8VEVudGl0eSwgVElkLCBhbnk+XG4gICkgeyB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmUgQ3ljbGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHsgLy8gSEFDSzogV2FpdCB1bnRpbCBuZ01vZGVsIGhhcyBkb25lIGl0cyBzdHJhbmdlIG51bGwvZW1wdHkgdmFsdWUgaW5pdC4uLlxuICAgICAgdGhpcy5sb2cuaW5mbygnYXV0b1NlbGVjdEZpcnN0IGFmdGVyLXZpZXcgaW5pdCwgYXV0byBzZWxlY3RpbmcgdmFsdWUnKTtcbiAgICAgIHRoaXMuaGFuZGxlQXV0b1NlbGVjdEZpcnN0KCk7XG4gICAgfSwgMTApO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFByb3BlcnRpZXMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgLyoqXG4gICAqIEFmdGVyIGRhdGEgaXMgbG9hZGVkIGludG8gdGhpcyBzZWxlY3QsIGVuc3VyZSB0aGF0XG4gICAqIGEgdmFsdWUgaXMgc2VsZWN0ZWQgb3Igc2VsZWN0IHRoZSBmaXJzdCBhdXRvbWF0aWNhbGx5LlxuICAgKi9cbiAgQElucHV0KCdhdXRvU2VsZWN0Rmlyc3QnKVxuICBwdWJsaWMgc2V0IGF1dG9TZWxlY3RGaXJzdEVuYWJsZWQodmFsOiBib29sZWFuIHwgc3RyaW5nKSB7XG4gICAgdGhpcy5lbmFibGVkID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbCk7XG4gIH1cblxuICBwdWJsaWMgc2V0IGVuYWJsZWQodmFsOiBib29sZWFuKSB7XG4gICAgdGhpcy5fZW5hYmxlZCA9IHZhbDtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZW5hYmxlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fZW5hYmxlZDtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgaGFuZGxlQXV0b1NlbGVjdEZpcnN0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5lbGRlclNlbGVjdC52YWx1ZSkge1xuICAgICAgdGhpcy5sb2cuZGVidWcoJ0F0dGVtcHRpbmcgdG8gYXV0byBzZWxlY3QgZmlyc3QgZW50aXR5Li4uJyk7XG4gICAgICBFbGRlclNlbGVjdEZpcnN0VXRpbC50cnlTZWxlY3RGaXJzdCh0aGlzLmVsZGVyU2VsZWN0KTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5sb2cud2FybignQ29uZmxpY3QgYXZvaWRlZDogQWJvcnRlZCBhdXRvIHNlbGVjdGlvbiBiZWNhdXNlIHZhbHVlIGlkIGFscmVhZHkgcHJlc2VudCEnKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -12,14 +12,16 @@ import * as i2 from "@angular/material/icon";
12
12
  import * as i3 from "../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
13
13
  import * as i4 from "@angular/material/button";
14
14
  import * as i5 from "@angular/common";
15
- import * as i6 from "@angular/flex-layout/flex";
16
- import * as i7 from "@angular/material/input";
17
- import * as i8 from "@angular/material/autocomplete";
18
- import * as i9 from "@angular/forms";
19
- import * as i10 from "../elder-select-on-tab.directive";
20
- import * as i11 from "../../input/autocomplete/elder-autocomplete.directive";
21
- import * as i12 from "../../forms/directives/elder-stop-event-propagation.directive";
22
- import * as i13 from "@ngx-translate/core";
15
+ import * as i6 from "../../forms/directives/elder-form-field-dense.directive";
16
+ import * as i7 from "../../forms/directives/elder-form-field-no-hint.directive";
17
+ import * as i8 from "@angular/flex-layout/flex";
18
+ import * as i9 from "@angular/material/input";
19
+ import * as i10 from "@angular/material/autocomplete";
20
+ import * as i11 from "@angular/forms";
21
+ import * as i12 from "../elder-select-on-tab.directive";
22
+ import * as i13 from "../../input/autocomplete/elder-autocomplete.directive";
23
+ import * as i14 from "../../forms/directives/elder-stop-event-propagation.directive";
24
+ import * as i15 from "@ngx-translate/core";
23
25
  class EntityContext {
24
26
  constructor(value, hintText, displayText) {
25
27
  this.value = value;
@@ -219,7 +221,7 @@ export class ElderSelectComponent extends ElderSelectBase {
219
221
  }
220
222
  openSelectionPopup(event) {
221
223
  if (this.selectionPopup) {
222
- this.selectionPopup.choose(this.filters, this.sorts).subscribe((selection) => {
224
+ this.selectionPopup.choose(this.filters, this.sorts, false).subscribe((selection) => {
223
225
  this.updateValueByEntity(selection[0]);
224
226
  });
225
227
  }
@@ -348,15 +350,15 @@ export class ElderSelectComponent extends ElderSelectBase {
348
350
  super.writeToControl(value);
349
351
  }
350
352
  }
351
- ElderSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderSelectComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
352
- ElderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: ElderSelectComponent, selector: "elder-select", inputs: { nullDisplay: "nullDisplay", autocomplete: "autocomplete", allowNull: "allowNull", entity: "entity", entityId: "entityId", hintProperty: "hintProperty", hintPropertyResolver: "hintPropertyResolver" }, outputs: { entityIdChange: "entityIdChange", entityIdUpdated: "entityIdUpdated", entityChange: "entityChange", entityUpdated: "entityUpdated" }, providers: [
353
+ ElderSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
354
+ ElderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.10", type: ElderSelectComponent, selector: "elder-select", inputs: { nullDisplay: "nullDisplay", autocomplete: "autocomplete", allowNull: "allowNull", entity: "entity", entityId: "entityId", hintProperty: "hintProperty", hintPropertyResolver: "hintPropertyResolver" }, outputs: { entityIdChange: "entityIdChange", entityIdUpdated: "entityIdUpdated", entityChange: "entityChange", entityUpdated: "entityUpdated" }, providers: [
353
355
  {
354
356
  provide: ELDER_SELECT_BASE,
355
357
  useExisting: forwardRef(() => ElderSelectComponent)
356
358
  },
357
359
  ...buildFormIntegrationProviders(ElderSelectComponent)
358
- ], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\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 <!-- A dynamic input -->\n <input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!autocomplete\" class=\"select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { 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"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i1.MatPrefix, selector: "[matPrefix]" }, { type: i7.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"] }, { type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i10.ElderSelectOnTabDirective, selector: "[elderSelectOnTab]" }, { type: i9.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i11.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }, { type: i12.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }], pipes: { "async": i5.AsyncPipe, "translate": i13.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
359
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderSelectComponent, decorators: [{
360
+ ], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\"\n (click)=\"onCurrentClicked(entity)\"\n >\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 <!-- A dynamic input -->\n <input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.clickable-icon{cursor:pointer}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { 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"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { type: i7.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { type: i8.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i1.MatPrefix, selector: "[matPrefix]" }, { type: i9.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"] }, { type: i10.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i11.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i12.ElderSelectOnTabDirective, selector: "[elderSelectOnTab]" }, { type: i11.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i13.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { type: i11.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i11.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }, { type: i14.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }], pipes: { "async": i5.AsyncPipe, "translate": i15.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
361
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectComponent, decorators: [{
360
362
  type: Component,
361
363
  args: [{ selector: 'elder-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
362
364
  {
@@ -364,7 +366,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
364
366
  useExisting: forwardRef(() => ElderSelectComponent)
365
367
  },
366
368
  ...buildFormIntegrationProviders(ElderSelectComponent)
367
- ], template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\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 <!-- A dynamic input -->\n <input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!autocomplete\" class=\"select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"] }]
369
+ ], template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\"\n (click)=\"onCurrentClicked(entity)\"\n >\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 <!-- A dynamic input -->\n <input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.clickable-icon{cursor:pointer}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"] }]
368
370
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { nullDisplay: [{
369
371
  type: Input
370
372
  }], entityIdChange: [{
@@ -388,4 +390,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
388
390
  }], hintPropertyResolver: [{
389
391
  type: Input
390
392
  }] } });
391
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, forwardRef,\n  Input, NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {\n  map,\n  takeUntil,\n  tap, skip, filter, startWith, withLatestFrom, switchMap, take, timeout, catchError\n} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState, TextResolverFn} from '../elder-select-base';\nimport {IElderEntityValueAccessor} from '../elder-entity-value-accessor';\nimport {ElderSelectFirstUtil} from '../auto/elder-select-first-util';\n\nclass EntityContext<T> {\n  constructor(\n    public readonly value: T,\n    public readonly hintText: string,\n    public readonly displayText: string\n  ) {\n  }\n}\n\n\n/**\n * The elder-select control allows to select a single\n * entity.\n *\n * Primary focus is on easy usage for common scenarios:\n *\n * - Integrated into angular forms and validation\n * - Support entity id handling, input / output is the entity id vs full value.\n *\n */\n@Component({\n  selector: 'elder-select',\n  templateUrl: './elder-select.component.html',\n  styleUrls: ['./elder-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderSelectComponent)\n    },\n    ...buildFormIntegrationProviders(ElderSelectComponent)\n  ]\n})\nexport class ElderSelectComponent<TEntity = any, TId = any, TValue = TEntity | TId>\n  extends ElderSelectBase<TId, TEntity, TValue>\n  implements IElderEntityValueAccessor<TEntity, TId>, OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly hintPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => null);\n\n  private _allowNull = false;\n\n  /**\n   * String to display for the 'nothing' / null value.\n   */\n  @Input()\n  public nullDisplay = '-';\n\n  @Output()\n  public readonly entityIdChange: 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 entityIdUpdated: Observable<TId>;\n\n  @Output()\n  public readonly entityChange: Observable<TEntity>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityUpdated: Observable<TEntity>;\n\n  private readonly _entity$ = new BehaviorSubject<TEntity>(undefined);\n\n  private _autocomplete = false;\n\n  public readonly entityWrapped$: Observable<EntityContext<TEntity>>;\n\n  private readonly unsubscribe$ = new Subject();\n\n  public readonly inputText$: Observable<string>;\n\n  private entityContext: EntityContext<TEntity>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone,\n  ) {\n    super(zone);\n\n    this.entityIdChange = this.valueChange.pipe(\n      map(v => this.entityIdFromValue(v))\n    );\n\n    this.entityChange = this._entity$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdUpdated = this.valueUpdated.pipe(\n      map(value => this.entityIdFromValue(value))\n    );\n\n    this.entityUpdated = this.entityIdUpdated.pipe(\n      switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n\n    this.entityWrapped$ = combineLatest(\n      [\n        this._entity$,\n        this.displayPropertyResolver$,\n        this.hintPropertyResolver$\n      ]\n    ).pipe(\n      map(([value, dPR, hPR]) => new EntityContext<TEntity>(value, hPR(value), dPR(value)))\n    );\n\n    this.inputText$ = this.entityWrapped$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(valueContext => this.entityContext = valueContext),\n      map(valueContext => {\n        if (valueContext.value) {\n          return valueContext.displayText;\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Behaviour Properties                                                    *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set autocomplete(value: boolean) {\n    this._autocomplete = coerceBooleanProperty(value);\n  }\n\n  public get autocomplete(): boolean {\n    return this._autocomplete;\n  }\n\n  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entity(entity: TEntity) {\n    this._entity$.next(entity);\n    this.writeValueInternal(\n      this.entityToValue(entity)\n    );\n  }\n\n  public get entity(): TEntity {\n    return this._entity$.getValue();\n  }\n\n  /**\n   * Gets the current entity as observable stream. (BehaviourSubject)\n   */\n  public get entity$(): Observable<TEntity> {\n    return this._entity$.asObservable();\n  }\n\n  @Input()\n  public set entityId(id: TId) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>id as TValue);\n    } else {\n      this.selectEntityById(id);\n    }\n  }\n\n  public get entityId(): TId {\n    return this.entityIdFromValue(this.value);\n  }\n\n  @Input()\n  public set hintProperty(property: string) {\n    this.hintPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set hintPropertyResolver(resolver: TextResolverFn) {\n    this.hintPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onInputBlur(event: FocusEvent): void {\n    const input = event.target as HTMLInputElement;\n    if (this.entityContext.value) {\n      input.value = this.entityContext.displayText;\n    } else {\n      input.value = null;\n    }\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (!this.isEntitySelected(option)) {\n        if (this.isOptionDisabledFn) {\n          return this.isOptionDisabledFn(option);\n        } else {\n          return false;\n        }\n      }\n      return true;\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n\n  public togglePanel(autoTrigger: MatAutocompleteTrigger): void {\n    if (autoTrigger.autocomplete.isOpen) {\n      autoTrigger.closePanel();\n    } else {\n      this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);\n      if (this.suggestionsDc) {\n        try {\n          this.suggestionsDc.start(this.sorts, this.filters);\n        } catch (err) {\n          this.logger.error('Failed to start DC!', err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      }\n      autoTrigger.openPanel();\n    }\n  }\n\n  public onInputClicked(autoTrigger: MatAutocompleteTrigger): void {\n\n    // this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);\n    if (this.isLocked || this.autocomplete) {\n      return;\n    }\n    this.togglePanel(autoTrigger);\n  }\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if (this.isEntitySelected(selectedValue)) {\n      this.writeValueInternal(null); // HACK: Ensure we trigger view redraw\n    }\n    this.updateValueByEntity(selectedValue);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        this.filters,\n        this.sorts\n      ).subscribe(\n        (selection: TEntity[]) => {\n          this.updateValueByEntity(selection[0]);\n        }\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public forceReloadFirst() {\n    this.value = null; // valueId is set to null automatically\n    ElderSelectFirstUtil.trySelectFirst(this);\n  }\n\n  public updateValueByEntity(entity: TEntity): void {\n    this._entity$.next(entity);\n    this.updateValue(\n      this.entityToValue(entity)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract Implementation                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntityById(this.entityId);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: TValue, b: TValue): boolean {\n    return this.entityIdFromValue(a) === this.entityIdFromValue(b);\n  }\n\n  private awaitEntityWithId(entityId: TId, timeoutMs: number): Observable<TEntity> {\n    return this.entity$.pipe(\n      filter(entity => this.getEntityId(entity) === entityId),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  private isEntitySelected(entity: TEntity): boolean {\n    return this.getEntityId(entity) === this.entityId;\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 selectEntityById(id: TId): void {\n\n    const currentEntity = this.entity;\n    if (currentEntity && this.getEntityId(currentEntity) === id) {\n      return; // Entity already loaded\n    }\n\n    if (id === null || id === undefined) {\n      if (currentEntity !== null && currentEntity !== undefined) {\n        this.entity = null;\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(id);\n        if (existing) {\n          this.entity = existing;\n        } else {\n          this.loadEntityById(id);\n        }\n      } else {\n        this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityById(id: TId): void {\n    this.suggestionsDc.dataSource.findById(<any>id)\n      .subscribe(\n        entity => {\n          this.logger.debug('Loaded missing entity by id ' + id + ':', entity);\n          this.entity = entity;\n        },\n        err => {\n          this.logger.error('Failed to load entity by id ' + id, err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      );\n  }\n\n  private findInDataContext(id: TId): TEntity | null {\n    return this.suggestionsDc.snapshot.data\n      .find(v => this.getEntityId(v) === id);\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  /**\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 entityId = <any>value as TId;\n      // Value was written as entity id, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as id: ' + entityId, value);\n      this.selectEntityById(entityId);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntity = this.entity;\n      const newEntity = <any>value as TEntity;\n      this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);\n      if (!this.isEqual(currentEntity, newEntity)) {\n        this._entity$.next(newEntity);\n      } else {\n        this.logger.warn('Ignored written entity as it is already set to entity$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n}\n","<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\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  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\" fxFlex=\"grow\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [readonly]=\"readonly || !autocomplete\"\n    [name]=\"name + '-inner-input'\"\n    [placeholder]=\"placeholder | translate\"\n    [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n    [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n    elderSelectOnTab\n    [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n    (blur)=\"onInputBlur($event)\"\n  >\n\n  <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [enabled]=\"autocomplete\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n\n  <ng-container matSuffix>\n\n    <mat-icon\n      *ngIf=\"!autocomplete\" class=\"select-arrow noselect\"\n      (click)=\"onInputClicked(autoTrigger)\">\n      arrow_drop_down\n    </mat-icon>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"entityWrapper.value && allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n"]}
393
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, forwardRef,\n  Input, NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {\n  map,\n  takeUntil,\n  tap, skip, filter, startWith, withLatestFrom, switchMap, take, timeout, catchError\n} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState, TextResolverFn} from '../elder-select-base';\nimport {IElderEntityValueAccessor} from '../elder-entity-value-accessor';\nimport {ElderSelectFirstUtil} from '../auto/elder-select-first-util';\n\nclass EntityContext<T> {\n  constructor(\n    public readonly value: T,\n    public readonly hintText: string,\n    public readonly displayText: string\n  ) {\n  }\n}\n\n\n/**\n * The elder-select control allows to select a single\n * entity.\n *\n * Primary focus is on easy usage for common scenarios:\n *\n * - Integrated into angular forms and validation\n * - Support entity id handling, input / output is the entity id vs full value.\n *\n */\n@Component({\n  selector: 'elder-select',\n  templateUrl: './elder-select.component.html',\n  styleUrls: ['./elder-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderSelectComponent)\n    },\n    ...buildFormIntegrationProviders(ElderSelectComponent)\n  ]\n})\nexport class ElderSelectComponent<TEntity = any, TId = any, TValue = TEntity | TId>\n  extends ElderSelectBase<TId, TEntity, TValue>\n  implements IElderEntityValueAccessor<TEntity, TId>, OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly hintPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => null);\n\n  private _allowNull = false;\n\n  /**\n   * String to display for the 'nothing' / null value.\n   */\n  @Input()\n  public nullDisplay = '-';\n\n  @Output()\n  public readonly entityIdChange: 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 entityIdUpdated: Observable<TId>;\n\n  @Output()\n  public readonly entityChange: Observable<TEntity>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityUpdated: Observable<TEntity>;\n\n  private readonly _entity$ = new BehaviorSubject<TEntity>(undefined);\n\n  private _autocomplete = false;\n\n  public readonly entityWrapped$: Observable<EntityContext<TEntity>>;\n\n  private readonly unsubscribe$ = new Subject();\n\n  public readonly inputText$: Observable<string>;\n\n  private entityContext: EntityContext<TEntity>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone,\n  ) {\n    super(zone);\n\n    this.entityIdChange = this.valueChange.pipe(\n      map(v => this.entityIdFromValue(v))\n    );\n\n    this.entityChange = this._entity$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdUpdated = this.valueUpdated.pipe(\n      map(value => this.entityIdFromValue(value))\n    );\n\n    this.entityUpdated = this.entityIdUpdated.pipe(\n      switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n\n    this.entityWrapped$ = combineLatest(\n      [\n        this._entity$,\n        this.displayPropertyResolver$,\n        this.hintPropertyResolver$\n      ]\n    ).pipe(\n      map(([value, dPR, hPR]) => new EntityContext<TEntity>(value, hPR(value), dPR(value)))\n    );\n\n    this.inputText$ = this.entityWrapped$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(valueContext => this.entityContext = valueContext),\n      map(valueContext => {\n        if (valueContext.value) {\n          return valueContext.displayText;\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Behaviour Properties                                                    *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set autocomplete(value: boolean) {\n    this._autocomplete = coerceBooleanProperty(value);\n  }\n\n  public get autocomplete(): boolean {\n    return this._autocomplete;\n  }\n\n  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entity(entity: TEntity) {\n    this._entity$.next(entity);\n    this.writeValueInternal(\n      this.entityToValue(entity)\n    );\n  }\n\n  public get entity(): TEntity {\n    return this._entity$.getValue();\n  }\n\n  /**\n   * Gets the current entity as observable stream. (BehaviourSubject)\n   */\n  public get entity$(): Observable<TEntity> {\n    return this._entity$.asObservable();\n  }\n\n  @Input()\n  public set entityId(id: TId) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>id as TValue);\n    } else {\n      this.selectEntityById(id);\n    }\n  }\n\n  public get entityId(): TId {\n    return this.entityIdFromValue(this.value);\n  }\n\n  @Input()\n  public set hintProperty(property: string) {\n    this.hintPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set hintPropertyResolver(resolver: TextResolverFn) {\n    this.hintPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onInputBlur(event: FocusEvent): void {\n    const input = event.target as HTMLInputElement;\n    if (this.entityContext.value) {\n      input.value = this.entityContext.displayText;\n    } else {\n      input.value = null;\n    }\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (!this.isEntitySelected(option)) {\n        if (this.isOptionDisabledFn) {\n          return this.isOptionDisabledFn(option);\n        } else {\n          return false;\n        }\n      }\n      return true;\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n\n  public togglePanel(autoTrigger: MatAutocompleteTrigger): void {\n    if (autoTrigger.autocomplete.isOpen) {\n      autoTrigger.closePanel();\n    } else {\n      this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);\n      if (this.suggestionsDc) {\n        try {\n          this.suggestionsDc.start(this.sorts, this.filters);\n        } catch (err) {\n          this.logger.error('Failed to start DC!', err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      }\n      autoTrigger.openPanel();\n    }\n  }\n\n  public onInputClicked(autoTrigger: MatAutocompleteTrigger): void {\n\n    // this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);\n    if (this.isLocked || this.autocomplete) {\n      return;\n    }\n    this.togglePanel(autoTrigger);\n  }\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if (this.isEntitySelected(selectedValue)) {\n      this.writeValueInternal(null); // HACK: Ensure we trigger view redraw\n    }\n    this.updateValueByEntity(selectedValue);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        this.filters,\n        this.sorts,\n        false\n      ).subscribe(\n        (selection: TEntity[]) => {\n          this.updateValueByEntity(selection[0]);\n        }\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public forceReloadFirst() {\n    this.value = null; // valueId is set to null automatically\n    ElderSelectFirstUtil.trySelectFirst(this);\n  }\n\n  public updateValueByEntity(entity: TEntity): void {\n    this._entity$.next(entity);\n    this.updateValue(\n      this.entityToValue(entity)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract Implementation                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntityById(this.entityId);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: TValue, b: TValue): boolean {\n    return this.entityIdFromValue(a) === this.entityIdFromValue(b);\n  }\n\n  private awaitEntityWithId(entityId: TId, timeoutMs: number): Observable<TEntity> {\n    return this.entity$.pipe(\n      filter(entity => this.getEntityId(entity) === entityId),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  private isEntitySelected(entity: TEntity): boolean {\n    return this.getEntityId(entity) === this.entityId;\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 selectEntityById(id: TId): void {\n\n    const currentEntity = this.entity;\n    if (currentEntity && this.getEntityId(currentEntity) === id) {\n      return; // Entity already loaded\n    }\n\n    if (id === null || id === undefined) {\n      if (currentEntity !== null && currentEntity !== undefined) {\n        this.entity = null;\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(id);\n        if (existing) {\n          this.entity = existing;\n        } else {\n          this.loadEntityById(id);\n        }\n      } else {\n        this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityById(id: TId): void {\n    this.suggestionsDc.dataSource.findById(<any>id)\n      .subscribe(\n        entity => {\n          this.logger.debug('Loaded missing entity by id ' + id + ':', entity);\n          this.entity = entity;\n        },\n        err => {\n          this.logger.error('Failed to load entity by id ' + id, err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      );\n  }\n\n  private findInDataContext(id: TId): TEntity | null {\n    return this.suggestionsDc.snapshot.data\n      .find(v => this.getEntityId(v) === id);\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  /**\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 entityId = <any>value as TId;\n      // Value was written as entity id, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as id: ' + entityId, value);\n      this.selectEntityById(entityId);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntity = this.entity;\n      const newEntity = <any>value as TEntity;\n      this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);\n      if (!this.isEqual(currentEntity, newEntity)) {\n        this._entity$.next(newEntity);\n      } else {\n        this.logger.warn('Ignored written entity as it is already set to entity$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n}\n","<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\"\n              (click)=\"onCurrentClicked(entity)\"\n    >\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  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\" fxFlex=\"grow\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [readonly]=\"readonly || !autocomplete\"\n    [name]=\"name + '-inner-input'\"\n    [placeholder]=\"placeholder | translate\"\n    [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n    [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n    elderSelectOnTab\n    [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n    (blur)=\"onInputBlur($event)\"\n  >\n\n  <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [enabled]=\"autocomplete\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n\n  <ng-container matSuffix>\n\n    <mat-icon\n      *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow noselect\"\n      (click)=\"onInputClicked(autoTrigger)\">\n      arrow_drop_down\n    </mat-icon>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"entityWrapper.value && allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n"]}
@@ -1,4 +1,4 @@
1
- import { ContentChild, Directive, InjectionToken, Input, TemplateRef } from '@angular/core';
1
+ import { ContentChild, Directive, EventEmitter, InjectionToken, Input, Output, TemplateRef } from '@angular/core';
2
2
  import { FormFieldBaseComponent } from '../../common/forms/form-field-base.component';
3
3
  import { BehaviorSubject, combineLatest } from 'rxjs';
4
4
  import { LoggerFactory } from '@elderbyte/ts-logger';
@@ -49,7 +49,7 @@ export const ELDER_SELECT_BASE = new InjectionToken('ElderSelectBase');
49
49
  * @param T Entity Type
50
50
  * @param TValue Value backing the control. Can be the entity, the id or something else.
51
51
  */
52
- // tslint:disable-next-line:directive-class-suffix
52
+ // eslint-disable-next-line @angular-eslint/directive-class-suffix
53
53
  export class ElderSelectBase extends FormFieldBaseComponent {
54
54
  /***************************************************************************
55
55
  * *
@@ -84,6 +84,11 @@ export class ElderSelectBase extends FormFieldBaseComponent {
84
84
  this.pageSize = 10;
85
85
  this.queryFilter = 'query';
86
86
  this.sorts = [];
87
+ /**
88
+ * Emits an event when the user has clicked on the current
89
+ * selected entity.
90
+ */
91
+ this.currentClicked = new EventEmitter();
87
92
  this.state$ = new BehaviorSubject(ElderSelectComponentState.idle());
88
93
  this.mergedState$ = combineLatest([
89
94
  this.suggestionsDc$.pipe(filter(dc => !!dc), switchMap(dc => dc.status)),
@@ -132,6 +137,7 @@ export class ElderSelectBase extends FormFieldBaseComponent {
132
137
  this.autoCleanUp();
133
138
  if (data instanceof Array) {
134
139
  this.suggestionsDc = DataContextBuilder.start()
140
+ .localSort()
135
141
  .buildLocal(data); // Memory leak
136
142
  this.suggestionsDc.start();
137
143
  }
@@ -163,6 +169,9 @@ export class ElderSelectBase extends FormFieldBaseComponent {
163
169
  * Public API *
164
170
  * *
165
171
  **************************************************************************/
172
+ onCurrentClicked(entity) {
173
+ this.currentClicked.emit(entity);
174
+ }
166
175
  updateFilter(updatedFilter) {
167
176
  this._filterContext.updateFilter(updatedFilter);
168
177
  }
@@ -217,9 +226,9 @@ export class ElderSelectBase extends FormFieldBaseComponent {
217
226
  return String(value);
218
227
  }
219
228
  }
220
- ElderSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderSelectBase, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
221
- ElderSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.4", type: ElderSelectBase, inputs: { cleanUp: "cleanUp", pageSize: "pageSize", queryFilter: "queryFilter", sorts: "sorts", isOptionDisabledFn: "isOptionDisabledFn", isOptionHiddenFn: "isOptionHiddenFn", valueAsId: "valueAsId", displayProperty: "displayProperty", displayPropertyResolver: "displayPropertyResolver", filters: "filters", dataSource: "dataSource", data: "data", valueTemplate: "valueTemplate" }, queries: [{ propertyName: "valueTemplateQuery", first: true, predicate: ElderSelectValueDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "selectionPopup", first: true, predicate: SelectionModelPopupDirective, descendants: true }], usesInheritance: true, ngImport: i0 });
222
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: ElderSelectBase, decorators: [{
229
+ ElderSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectBase, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
230
+ ElderSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.10", type: ElderSelectBase, inputs: { cleanUp: "cleanUp", pageSize: "pageSize", queryFilter: "queryFilter", sorts: "sorts", dense: "dense", noHint: "noHint", isOptionDisabledFn: "isOptionDisabledFn", isOptionHiddenFn: "isOptionHiddenFn", valueAsId: "valueAsId", displayProperty: "displayProperty", displayPropertyResolver: "displayPropertyResolver", filters: "filters", dataSource: "dataSource", data: "data", valueTemplate: "valueTemplate" }, outputs: { currentClicked: "currentClicked" }, queries: [{ propertyName: "valueTemplateQuery", first: true, predicate: ElderSelectValueDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "selectionPopup", first: true, predicate: SelectionModelPopupDirective, descendants: true }], usesInheritance: true, ngImport: i0 });
231
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.10", ngImport: i0, type: ElderSelectBase, decorators: [{
223
232
  type: Directive
224
233
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { cleanUp: [{
225
234
  type: Input
@@ -229,6 +238,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
229
238
  type: Input
230
239
  }], sorts: [{
231
240
  type: Input
241
+ }], dense: [{
242
+ type: Input
243
+ }], noHint: [{
244
+ type: Input
232
245
  }], valueTemplateQuery: [{
233
246
  type: ContentChild,
234
247
  args: [ElderSelectValueDirective, { read: TemplateRef, static: true }]
@@ -239,6 +252,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
239
252
  type: Input
240
253
  }], isOptionHiddenFn: [{
241
254
  type: Input
255
+ }], currentClicked: [{
256
+ type: Output
242
257
  }], valueAsId: [{
243
258
  type: Input
244
259
  }], displayProperty: [{
@@ -254,4 +269,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImpor
254
269
  }], valueTemplate: [{
255
270
  type: Input
256
271
  }] } });
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-base.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {ContentChild, Directive, InjectionToken, Input, NgZone, TemplateRef} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../common/forms/form-field-base.component';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../common/data/data-context/data-context';\nimport {IDataSource} from '../../common/data/datasource/data-source';\nimport {DataContextBuilder} from '../../common/data/data-context/data-context-builder';\nimport {Filter} from '../../common/data/filter';\nimport {Sort} from '../../common/data/sort';\nimport {ElderSelectValueDirective} from './elder-select-value.directive';\nimport {SelectionModelPopupDirective} from './popup/selection-model-popup.directive';\nimport {DataContextStatus} from '../../common/data/data-context/data-context-status';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../common/utils/ng-zone-utils';\nimport {FilterContext} from '../../common/data/filter-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nexport type TextResolverFn = (value: any) => string;\n\n\n\nexport class ElderSelectComponentState {\n\n  public static fromDataContext(dcState: DataContextStatus): ElderSelectComponentState {\n    if (dcState.loading) {\n      return ElderSelectComponentState.loading();\n    } else if (dcState.error) {\n      return ElderSelectComponentState.error(dcState.error);\n    } else {\n      return ElderSelectComponentState.idle();\n    }\n  }\n\n\n  public static idle(): ElderSelectComponentState {\n    return new ElderSelectComponentState(true, false, null);\n  }\n\n  public static loading(): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, true, null);\n  }\n\n  public static error(error: string): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, false, error);\n  }\n\n  constructor(\n    public readonly idle: boolean,\n    public readonly loading: boolean,\n    public readonly error: string\n  ) {\n  }\n}\n\nexport const ELDER_SELECT_BASE = new InjectionToken<ElderSelectBase<any, any, any>>('ElderSelectBase');\n\n\n/**\n * Base component for Elder Selection Controls.\n *\n *  Elder Selection has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n *\n * @param TID Entity Id Type\n * @param T Entity Type\n * @param TValue Value backing the control. Can be the entity, the id or something else.\n */\n@Directive()\n// tslint:disable-next-line:directive-class-suffix\nexport abstract class ElderSelectBase<TId, TEntity, TValue> extends FormFieldBaseComponent<TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _logger = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _filterContext = new FilterContext();\n\n  private _valueAsId: boolean;\n\n  protected timeoutAfterMs = 5000;\n\n  /**\n   * Define if elder-select should clean up the\n   * data-context resources for you.\n   *\n   * In more advanced scenarios where you plan to reuse the same data-context\n   * set this to false and release the resources yourself. (dataContext.close)\n   */\n  @Input()\n  public cleanUp = true;\n\n  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => this.propertyStringValue(value, null));\n\n  /** Underlying data context. */\n  public readonly suggestionsDc$ = new BehaviorSubject<IDataContext<TEntity>>(null);\n\n  /**\n   * Page size. (Used for infinite scrolling chunks)\n   */\n  @Input()\n  public pageSize = 10;\n\n  @Input()\n  public queryFilter = 'query';\n\n  @Input()\n  public sorts: Sort[] = [];\n\n  /**\n   * The option template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  @ContentChild(SelectionModelPopupDirective)\n  public selectionPopup: SelectionModelPopupDirective;\n\n  @Input()\n  public isOptionDisabledFn: (option: TEntity) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: TEntity) => boolean;\n\n  public readonly state$ = new BehaviorSubject<ElderSelectComponentState>(ElderSelectComponentState.idle());\n  public readonly mergedState$: Observable<ElderSelectComponentState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    private readonly zone: NgZone,\n  ) {\n    super();\n\n    this.mergedState$ = combineLatest([\n      this.suggestionsDc$.pipe(filter(dc => !!dc), switchMap(dc => dc.status)),\n      this.state$\n    ]).pipe(\n      map(([dcState, state]) => {\n        if (dcState.idle) {\n          return state;\n        } else {\n          return ElderSelectComponentState.fromDataContext(dcState);\n        }\n      }),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set valueAsId(valueAsId: boolean) {\n    this._valueAsId = coerceBooleanProperty(valueAsId);\n  }\n\n  public get valueAsId(): boolean {\n    return this._valueAsId;\n  }\n\n  /**\n   * The property used to display the values.\n   */\n  @Input()\n  public set displayProperty(property: string) {\n    this.displayPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  @Input()\n  public set filters(filters: Filter[]) {\n    this.replaceFilters(filters);\n  }\n\n  public get filters(): Filter[] {\n    return this._filterContext.filtersSnapshot;\n  }\n\n  @Input()\n  public set dataSource(source: IDataSource<TEntity>) {\n    this.suggestionsDc = DataContextBuilder.start<TEntity>()\n      .pageSize(this.pageSize)\n      .build(source);\n  }\n\n  @Input()\n  public set data(data: Array<TEntity> | IDataContext<TEntity>) {\n\n    this.autoCleanUp();\n\n    if (data instanceof Array) {\n      this.suggestionsDc = DataContextBuilder.start<TEntity>()\n        .buildLocal(data); // Memory leak\n      this.suggestionsDc.start();\n    } else {\n      if (data) {\n        this.suggestionsDc = data;\n      } else {\n        this.suggestionsDc = DataContextBuilder.start<TEntity>().buildEmpty();\n      }\n    }\n  }\n\n  public set suggestionsDc(data: IDataContext<TEntity>) {\n    this.autoCleanUp();\n    this.suggestionsDc$.next(data);\n    this.onSuggestionsDcChanged(data);\n  }\n\n  public get suggestionsDc(): IDataContext<TEntity> {\n    return this.suggestionsDc$.getValue();\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateFilter(updatedFilter?: Filter): void {\n    this._filterContext.updateFilter(updatedFilter);\n  }\n\n  public updateFilters(updatedFilters?: Filter[]): void {\n    this._filterContext.updateFilters(updatedFilters);\n  }\n\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filterContext.replaceFilters(newFilters);\n  }\n\n  public clearFilters(): void {\n    this._filterContext.clear();\n  }\n\n  public updateState(state: ElderSelectComponentState): void {\n    this.state$.next(state);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected abstract onSuggestionsDcChanged(data: IDataContext<TEntity>): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected getEntityId(entity: TEntity): TId {\n    return this.suggestionsDc?.dataSource?.getId(entity) || entity;\n  }\n\n  protected isEqual(a: TEntity, b: TEntity): boolean {\n    if (a === b) {\n      return true;\n    }\n    if (this.isEmpty(a) && this.isEmpty(b)) { // HACK: Handle empty string as undefined.\n      return true;\n    }\n    return this.getEntityId(a) === this.getEntityId(b);\n  }\n\n  protected isEmpty(a: TEntity): boolean {\n    return (a === null || a === undefined || <any>a === '');\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  protected autoCleanUp(): void {\n    if (this.cleanUp && this.suggestionsDc) {\n      this._logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.suggestionsDc.close();\n    }\n  }\n\n  protected propertyStringValue(value: TEntity, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n"]}
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-base.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {ContentChild, Directive, EventEmitter, InjectionToken, Input, NgZone, Output, TemplateRef} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../common/forms/form-field-base.component';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../common/data/data-context/data-context';\nimport {IDataSource} from '../../common/data/datasource/data-source';\nimport {DataContextBuilder} from '../../common/data/data-context/data-context-builder';\nimport {Filter} from '../../common/data/filter';\nimport {Sort} from '../../common/data/sort';\nimport {ElderSelectValueDirective} from './elder-select-value.directive';\nimport {SelectionModelPopupDirective} from './popup/selection-model-popup.directive';\nimport {DataContextStatus} from '../../common/data/data-context/data-context-status';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../common/utils/ng-zone-utils';\nimport {FilterContext} from '../../common/data/filter-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nexport type TextResolverFn = (value: any) => string;\n\n\n\nexport class ElderSelectComponentState {\n\n  public static fromDataContext(dcState: DataContextStatus): ElderSelectComponentState {\n    if (dcState.loading) {\n      return ElderSelectComponentState.loading();\n    } else if (dcState.error) {\n      return ElderSelectComponentState.error(dcState.error);\n    } else {\n      return ElderSelectComponentState.idle();\n    }\n  }\n\n\n  public static idle(): ElderSelectComponentState {\n    return new ElderSelectComponentState(true, false, null);\n  }\n\n  public static loading(): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, true, null);\n  }\n\n  public static error(error: string): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, false, error);\n  }\n\n  constructor(\n    public readonly idle: boolean,\n    public readonly loading: boolean,\n    public readonly error: string\n  ) {\n  }\n}\n\nexport const ELDER_SELECT_BASE = new InjectionToken<ElderSelectBase<any, any, any>>('ElderSelectBase');\n\n\n/**\n * Base component for Elder Selection Controls.\n *\n *  Elder Selection has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n *\n * @param TID Entity Id Type\n * @param T Entity Type\n * @param TValue Value backing the control. Can be the entity, the id or something else.\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderSelectBase<TId, TEntity, TValue> extends FormFieldBaseComponent<TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _logger = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _filterContext = new FilterContext();\n\n  private _valueAsId: boolean;\n\n  protected timeoutAfterMs = 5000;\n\n  /**\n   * Define if elder-select should clean up the\n   * data-context resources for you.\n   *\n   * In more advanced scenarios where you plan to reuse the same data-context\n   * set this to false and release the resources yourself. (dataContext.close)\n   */\n  @Input()\n  public cleanUp = true;\n\n  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => this.propertyStringValue(value, null));\n\n  /** Underlying data context. */\n  public readonly suggestionsDc$ = new BehaviorSubject<IDataContext<TEntity>>(null);\n\n  /**\n   * Page size. (Used for infinite scrolling chunks)\n   */\n  @Input()\n  public pageSize = 10;\n\n  @Input()\n  public queryFilter = 'query';\n\n  @Input()\n  public sorts: Sort[] = [];\n\n  @Input()\n  public dense: boolean | string;\n\n  @Input()\n  public noHint: boolean | string;\n\n  /**\n   * The option template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  @ContentChild(SelectionModelPopupDirective)\n  public selectionPopup: SelectionModelPopupDirective;\n\n  @Input()\n  public isOptionDisabledFn: (option: TEntity) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: TEntity) => boolean;\n\n  /**\n   * Emits an event when the user has clicked on the current\n   * selected entity.\n   */\n  @Output()\n  public readonly currentClicked = new EventEmitter<TEntity>();\n\n  public readonly state$ = new BehaviorSubject<ElderSelectComponentState>(ElderSelectComponentState.idle());\n  public readonly mergedState$: Observable<ElderSelectComponentState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    private readonly zone: NgZone,\n  ) {\n    super();\n\n    this.mergedState$ = combineLatest([\n      this.suggestionsDc$.pipe(filter(dc => !!dc), switchMap(dc => dc.status)),\n      this.state$\n    ]).pipe(\n      map(([dcState, state]) => {\n        if (dcState.idle) {\n          return state;\n        } else {\n          return ElderSelectComponentState.fromDataContext(dcState);\n        }\n      }),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set valueAsId(valueAsId: boolean) {\n    this._valueAsId = coerceBooleanProperty(valueAsId);\n  }\n\n  public get valueAsId(): boolean {\n    return this._valueAsId;\n  }\n\n  /**\n   * The property used to display the values.\n   */\n  @Input()\n  public set displayProperty(property: string) {\n    this.displayPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  @Input()\n  public set filters(filters: Filter[]) {\n    this.replaceFilters(filters);\n  }\n\n  public get filters(): Filter[] {\n    return this._filterContext.filtersSnapshot;\n  }\n\n  @Input()\n  public set dataSource(source: IDataSource<TEntity>) {\n    this.suggestionsDc = DataContextBuilder.start<TEntity>()\n      .pageSize(this.pageSize)\n      .build(source);\n  }\n\n  @Input()\n  public set data(data: Array<TEntity> | IDataContext<TEntity>) {\n\n    this.autoCleanUp();\n\n    if (data instanceof Array) {\n      this.suggestionsDc = DataContextBuilder.start<TEntity>()\n        .localSort()\n        .buildLocal(data); // Memory leak\n      this.suggestionsDc.start();\n    } else {\n      if (data) {\n        this.suggestionsDc = data;\n      } else {\n        this.suggestionsDc = DataContextBuilder.start<TEntity>().buildEmpty();\n      }\n    }\n  }\n\n  public set suggestionsDc(data: IDataContext<TEntity>) {\n    this.autoCleanUp();\n    this.suggestionsDc$.next(data);\n    this.onSuggestionsDcChanged(data);\n  }\n\n  public get suggestionsDc(): IDataContext<TEntity> {\n    return this.suggestionsDc$.getValue();\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onCurrentClicked(entity: TEntity): void {\n    this.currentClicked.emit(entity);\n  }\n\n  public updateFilter(updatedFilter?: Filter): void {\n    this._filterContext.updateFilter(updatedFilter);\n  }\n\n  public updateFilters(updatedFilters?: Filter[]): void {\n    this._filterContext.updateFilters(updatedFilters);\n  }\n\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filterContext.replaceFilters(newFilters);\n  }\n\n  public clearFilters(): void {\n    this._filterContext.clear();\n  }\n\n  public updateState(state: ElderSelectComponentState): void {\n    this.state$.next(state);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected abstract onSuggestionsDcChanged(data: IDataContext<TEntity>): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected getEntityId(entity: TEntity): TId {\n    return this.suggestionsDc?.dataSource?.getId(entity) || entity;\n  }\n\n  protected isEqual(a: TEntity, b: TEntity): boolean {\n    if (a === b) {\n      return true;\n    }\n    if (this.isEmpty(a) && this.isEmpty(b)) { // HACK: Handle empty string as undefined.\n      return true;\n    }\n    return this.getEntityId(a) === this.getEntityId(b);\n  }\n\n  protected isEmpty(a: TEntity): boolean {\n    return (a === null || a === undefined || <any>a === '');\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  protected autoCleanUp(): void {\n    if (this.cleanUp && this.suggestionsDc) {\n      this._logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.suggestionsDc.close();\n    }\n  }\n\n  protected propertyStringValue(value: TEntity, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n"]}