@elderbyte/ngx-starter 14.3.2 → 14.4.0-beta.11
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.
- package/_index.scss +4 -0
- package/esm2020/lib/common/enums/elder-enum-translation.service.mjs +3 -3
- package/esm2020/lib/common/forms/elder-entity-value-accessor.mjs +22 -0
- package/esm2020/lib/common/forms/elder-form-field-control-base.directive.mjs +169 -0
- package/esm2020/lib/common/forms/elder-from-field-base.mjs +94 -0
- package/esm2020/lib/common/forms/elder-from-field-entity-base.mjs +39 -0
- package/esm2020/lib/common/forms/elder-from-field-multi-entity-base.mjs +39 -0
- package/esm2020/lib/common/forms/elder-multi-entity-value-accessor.mjs +22 -0
- package/esm2020/lib/common/forms/form-field-base.component.mjs +3 -3
- package/esm2020/lib/common/forms/multi-model-base.component.mjs +3 -3
- package/esm2020/lib/common/forms/public_api.mjs +7 -1
- package/esm2020/lib/common/forms/template-composite-control.mjs +3 -3
- package/esm2020/lib/common/forms/value-accessor-base.mjs +3 -3
- package/esm2020/lib/common/http/http-client-builder.service.mjs +3 -3
- package/esm2020/lib/common/http/http-client-pristine.mjs +3 -3
- package/esm2020/lib/common/http/transfer/data-transfer-factory.mjs +3 -3
- package/esm2020/lib/common/url/elder-url-fragment-params.service.mjs +3 -3
- package/esm2020/lib/common/utils/sort-util.mjs +17 -1
- package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -3
- package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -4
- package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +3 -3
- package/esm2020/lib/components/auditing/elder-audit.module.mjs +4 -4
- package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -3
- package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -4
- package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +3 -3
- package/esm2020/lib/components/card-organizer/card-organizer/elder-stack-card.directive.mjs +3 -3
- package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +4 -4
- package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -4
- package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -3
- package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +18 -18
- package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -4
- package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -4
- package/esm2020/lib/components/connectivity/elder-connectivity.service.mjs +3 -3
- package/esm2020/lib/components/connectivity/offline-indicator/elder-offline-indicator.component.mjs +3 -3
- package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -4
- package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -3
- package/esm2020/lib/components/csv/elder-csv-export-btn/elder-csv-export-btn.component.mjs +3 -3
- package/esm2020/lib/components/csv/elder-csv-stream-exporter-builder.service.mjs +3 -3
- package/esm2020/lib/components/csv/elder-csv.module.mjs +4 -4
- package/esm2020/lib/components/currency/elder-currency.module.mjs +4 -4
- package/esm2020/lib/components/currency/elder-currency.pipe.mjs +3 -3
- package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -4
- package/esm2020/lib/components/data-transfer/elder-data-transfer.service.mjs +3 -3
- package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -3
- package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +3 -3
- package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +3 -3
- package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +3 -3
- package/esm2020/lib/components/data-view/base/elder-data-view-base.mjs +3 -3
- package/esm2020/lib/components/data-view/base/elder-data-view-base.module.mjs +4 -4
- package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +3 -3
- package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -4
- package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +6 -6
- package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +3 -3
- package/esm2020/lib/components/data-view/common/selection/data-context-selection.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -3
- package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +9 -9
- package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +4 -4
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.component.mjs +3 -3
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -4
- package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-number-cell.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-paginator-intl.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table/elder-table-toolbar.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +5 -5
- package/esm2020/lib/components/data-view/table/elder-table-column.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table-extension.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table-root.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table-row.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table-sort.directive.mjs +3 -3
- package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -4
- package/esm2020/lib/components/data-view/table/model/elder-table-model.mjs +3 -3
- package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +3 -3
- package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +7 -7
- package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +3 -3
- package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +3 -3
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +3 -3
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog.directive.mjs +3 -3
- package/esm2020/lib/components/errors/elder-error.module.mjs +4 -4
- package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -3
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +3 -3
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -4
- package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -3
- package/esm2020/lib/components/files/elder-file-drop-zone.directive.mjs +3 -3
- package/esm2020/lib/components/files/elder-file-select.directive.mjs +3 -3
- package/esm2020/lib/components/files/elder-file.module.mjs +4 -4
- package/esm2020/lib/components/files/file-select/file-select.component.mjs +3 -3
- package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +3 -3
- package/esm2020/lib/components/forms/clipboard/elder-clipboard.service.mjs +3 -3
- package/esm2020/lib/components/forms/directives/base/elder-class-hostbinding-base.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-clipboard-put.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-delayed-focus.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-form-field-dense.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-form-field-label.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-form-field-no-hint.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-form-field-no-spinner.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +20 -14
- package/esm2020/lib/components/forms/directives/elder-input-pattern.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-key-event.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-max.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-min.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-next-focusable.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-plug-parent-form.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-stop-event-propagation.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-tab-focus-trap.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-touched.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/elder-triple-state-checkbox.directive.mjs +3 -3
- package/esm2020/lib/components/forms/directives/validation/elder-multiple-of.validator.mjs +3 -3
- package/esm2020/lib/components/forms/directives/validation/elder-required-ignore-zero.validator.mjs +3 -3
- package/esm2020/lib/components/forms/elder-forms.module.mjs +4 -4
- package/esm2020/lib/components/forms/search/elder-search-context.directive.mjs +3 -3
- package/esm2020/lib/components/forms/search/elder-search-input.directive.mjs +3 -3
- package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -4
- package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +3 -3
- package/esm2020/lib/components/forms/search/search-box/elder-search-panel.component.mjs +3 -3
- package/esm2020/lib/components/global-search/elder-global-search.component.mjs +3 -3
- package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -4
- package/esm2020/lib/components/global-search/elder-global-search.service.mjs +3 -3
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -3
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -4
- package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +3 -3
- package/esm2020/lib/components/headers/elder-header.module.mjs +4 -4
- package/esm2020/lib/components/http-support/elder-http-client.service.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +4 -4
- package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog.service.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-localized-text-column.directive.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/elder-localized-texts.directive.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/picker/i18n-pick-async.pipe.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/picker/i18n-pick.pipe.mjs +3 -3
- package/esm2020/lib/components/i18n/entities/picker/localisation-picker.service.mjs +3 -3
- package/esm2020/lib/components/i18n/language/elder-language-interceptor.mjs +3 -3
- package/esm2020/lib/components/i18n/language/elder-language.module.mjs +4 -4
- package/esm2020/lib/components/i18n/language/elder-language.service.mjs +3 -3
- package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +3 -3
- package/esm2020/lib/components/i18n/locales/elder-locales-de-ch.module.mjs +4 -4
- package/esm2020/lib/components/iframes/elder-iframe.module.mjs +4 -4
- package/esm2020/lib/components/iframes/iframe-close.directive.mjs +3 -3
- package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +3 -3
- package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +3 -3
- package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +3 -3
- package/esm2020/lib/components/iframes/iframe.service.mjs +3 -3
- package/esm2020/lib/components/infinitescroll/elder-infinite-autocomplete.directive.mjs +3 -3
- package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.directive.mjs +3 -3
- package/esm2020/lib/components/infinitescroll/elder-infinite-scroll.module.mjs +7 -7
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +3 -3
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +6 -6
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +4 -4
- package/esm2020/lib/components/labels/elder-labels.module.mjs +4 -4
- package/esm2020/lib/components/labels/labels-input/labels-input.component.mjs +3 -3
- package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +3 -3
- package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +5 -5
- package/esm2020/lib/components/measures/elder-measures.module.mjs +8 -8
- package/esm2020/lib/components/measures/elder-quantity-transform.pipe.mjs +3 -3
- package/esm2020/lib/components/measures/elder-quantity.pipe.mjs +3 -3
- package/esm2020/lib/components/measures/elder-unit.service.mjs +3 -3
- package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +3 -3
- package/esm2020/lib/components/measures/util/elder-quantity.service.mjs +3 -3
- package/esm2020/lib/components/multi-autocomplete/elder-multi-auto-complete.module.mjs +4 -4
- package/esm2020/lib/components/multi-autocomplete/elder-multi-autocomplete.component.mjs +3 -3
- package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +3 -3
- package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -4
- package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -4
- package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -3
- package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +3 -3
- package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -3
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar-column.directive.mjs +3 -3
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -4
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.service.mjs +3 -3
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +3 -3
- package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.component.mjs +3 -3
- package/esm2020/lib/components/navigation/toolbar/toolbar-title/elder-toolbar-title.service.mjs +3 -3
- package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +3 -3
- package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +3 -3
- package/esm2020/lib/components/overlays/elder-overlay.component.mjs +3 -3
- package/esm2020/lib/components/overlays/elder-overlay.module.mjs +4 -4
- package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -3
- package/esm2020/lib/components/panels/elder-panel.module.mjs +4 -4
- package/esm2020/lib/components/panels/flat/elder-panel.component.mjs +3 -3
- package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +5 -5
- package/esm2020/lib/components/select/auto/elder-select-first-util.mjs +3 -3
- package/esm2020/lib/components/select/elder-select-base.mjs +39 -28
- package/esm2020/lib/components/select/elder-select-chip.directive.mjs +23 -9
- package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +5 -5
- package/esm2020/lib/components/select/elder-select-value.directive.mjs +3 -3
- package/esm2020/lib/components/select/elder-select.module.mjs +28 -16
- package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +168 -64
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +124 -81
- package/esm2020/lib/components/select/multi/elder-multi-select-form-field.mjs +67 -0
- package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +11 -6
- package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +7 -6
- package/esm2020/lib/components/select/public_api.mjs +4 -1
- package/esm2020/lib/components/select/single/elder-clear-select.directive.mjs +57 -0
- package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +455 -0
- package/esm2020/lib/components/select/single/elder-select-form-field.mjs +45 -0
- package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +3 -3
- package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -4
- package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -4
- package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -3
- package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -3
- package/esm2020/lib/components/shell/drawers/elder-route-outlet-drawer.service.mjs +3 -3
- package/esm2020/lib/components/shell/drawers/elder-router-outlet.service.mjs +3 -3
- package/esm2020/lib/components/shell/elder-shell-slot.directive.mjs +3 -3
- package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -4
- package/esm2020/lib/components/shell/elder-shell.service.mjs +3 -3
- package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +3 -3
- package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +25 -15
- package/esm2020/lib/components/shell/shell-navigation-toggle/elder-shell-navigation-toggle.component.mjs +3 -3
- package/esm2020/lib/components/tabs/elder-tab/elder-tab.directive.mjs +3 -3
- package/esm2020/lib/components/tabs/elder-tab-group-routing/elder-tab-group-routing.directive.mjs +3 -3
- package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -4
- package/esm2020/lib/components/theme/elder-theme-applier.directive.mjs +3 -3
- package/esm2020/lib/components/theme/elder-theme-preference.service.mjs +3 -3
- package/esm2020/lib/components/theme/elder-theme-toggle/elder-theme-toggle.component.mjs +3 -3
- package/esm2020/lib/components/theme/elder-theme.directive.mjs +3 -3
- package/esm2020/lib/components/theme/elder-theme.module.mjs +4 -4
- package/esm2020/lib/components/theme/elder-theme.service.mjs +3 -3
- package/esm2020/lib/components/time/date-adapters/custom-date-adapter.mjs +3 -3
- package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +3 -3
- package/esm2020/lib/components/time/elder-time.module.mjs +8 -8
- package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +3 -3
- package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -4
- package/esm2020/lib/components/toasts/elder-toast.service.mjs +9 -9
- package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +3 -3
- package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +4 -4
- package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +3 -3
- package/esm2020/lib/components/viewers/elder-svg-viewer/elder-svg-viewer.component.mjs +3 -3
- package/esm2020/lib/components/viewers/elder-viewers.module.mjs +4 -4
- package/esm2020/lib/features/event-source/elder-event-source.service.mjs +3 -3
- package/esm2020/lib/features/kafent/access-token-provider.mjs +3 -3
- package/esm2020/lib/features/kafent/kafent-config.mjs +3 -3
- package/esm2020/lib/features/kafent/kafent-event-stream.mjs +3 -3
- package/esm2020/lib/features/kafent/kafent-event.service.mjs +3 -3
- package/esm2020/lib/features/kafent/kafent.module.mjs +4 -4
- package/esm2020/lib/features/kafent/sse/kafent-event-stream-sse.service.mjs +3 -3
- package/esm2020/lib/pipes/bytes.pipe.mjs +3 -3
- package/esm2020/lib/pipes/elder-pipes.module.mjs +10 -10
- package/esm2020/lib/pipes/elder-repeat.pipe.mjs +3 -3
- package/esm2020/lib/pipes/elder-round.pipe.mjs +3 -3
- package/esm2020/lib/pipes/elder-safe-url.pipe.mjs +3 -3
- package/esm2020/lib/pipes/elder-truncate.pipe.mjs +3 -3
- package/esm2020/lib/pipes/iso-duration.pipe.mjs +3 -3
- package/esm2020/lib/pipes/iso-interval-parse.pipe.mjs +3 -3
- package/esm2020/lib/pipes/iso-interval.pipe.mjs +3 -3
- package/esm2020/lib/pipes/time-ago.pipe.mjs +3 -3
- package/esm2020/lib/pipes/time-duration.pipe.mjs +3 -3
- package/esm2020/lib/pipes/weight.pipe.mjs +3 -3
- package/fesm2015/elderbyte-ngx-starter.mjs +1869 -1121
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +1862 -1119
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/{components/select → common/forms}/elder-entity-value-accessor.d.ts +10 -0
- package/lib/common/forms/elder-form-field-control-base.directive.d.ts +101 -0
- package/lib/common/forms/elder-from-field-base.d.ts +52 -0
- package/lib/common/forms/elder-from-field-entity-base.d.ts +31 -0
- package/lib/common/forms/elder-from-field-multi-entity-base.d.ts +31 -0
- package/lib/common/forms/elder-multi-entity-value-accessor.d.ts +42 -0
- package/lib/common/forms/public_api.d.ts +6 -0
- package/lib/common/utils/sort-util.d.ts +6 -0
- package/lib/components/input/autocomplete/elder-autocomplete.directive.d.ts +1 -1
- package/lib/components/measures/directives/elder-unit-select.directive.d.ts +1 -1
- package/lib/components/select/auto/elder-auto-select-first.directive.d.ts +1 -1
- package/lib/components/select/auto/elder-select-first-util.d.ts +1 -1
- package/lib/components/select/elder-select-base.d.ts +21 -15
- package/lib/components/select/elder-select-chip.directive.d.ts +9 -2
- package/lib/components/select/elder-select.module.d.ts +28 -24
- package/lib/components/select/multi/elder-multi-select-base.d.ts +41 -15
- package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +29 -12
- package/lib/components/select/multi/elder-multi-select-form-field.d.ts +34 -0
- package/lib/components/select/popup/selection-model-popup.directive.d.ts +3 -2
- package/lib/components/select/public_api.d.ts +3 -0
- package/lib/components/select/single/elder-clear-select.directive.d.ts +34 -0
- package/lib/components/select/{elder-select → single/elder-select}/elder-select.component.d.ts +24 -12
- package/lib/components/select/single/elder-select-form-field.d.ts +30 -0
- package/lib/components/shell/shell/elder-shell.component.d.ts +4 -1
- package/package.json +1 -1
- package/src/lib/components/cards/elder-card/elder-card.component.scss +1 -6
- package/src/lib/components/select/_elder-select-base.scss +131 -0
- package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +48 -21
- package/src/lib/components/select/single/elder-select/elder-select.component.scss +77 -0
- package/theming/_elder-common.scss +10 -0
- package/theming/_elder-typography-utils.scss +11 -0
- package/esm2020/lib/components/select/elder-entity-value-accessor.mjs +0 -13
- package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +0 -419
- package/src/lib/components/select/elder-select/elder-select.component.scss +0 -61
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import { Directive, Input, Output } from '@angular/core';
|
|
2
2
|
import { ElderSelectBase, ElderSelectComponentState } from '../elder-select-base';
|
|
3
|
-
import { BehaviorSubject, EMPTY, of } from 'rxjs';
|
|
3
|
+
import { BehaviorSubject, EMPTY, of, throwError } from 'rxjs';
|
|
4
4
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
5
|
-
import { catchError, filter, map, switchMap, take, tap, timeout } from 'rxjs/operators';
|
|
5
|
+
import { catchError, filter, map, skip, switchMap, take, tap, timeout } from 'rxjs/operators';
|
|
6
6
|
import { Sets } from '../../../common/sets';
|
|
7
|
-
import {
|
|
7
|
+
import { SortUtil } from '../../../common/utils/sort-util';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/cdk/a11y";
|
|
10
|
+
import * as i2 from "../../dialogs/elder-dialog.service";
|
|
11
|
+
import * as i3 from "@angular/forms";
|
|
9
12
|
/**
|
|
10
13
|
* Base component implementation of elder-multi-select.
|
|
11
14
|
*
|
|
@@ -22,16 +25,31 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
22
25
|
* Constructor *
|
|
23
26
|
* *
|
|
24
27
|
**************************************************************************/
|
|
25
|
-
constructor(zone) {
|
|
26
|
-
super(zone);
|
|
28
|
+
constructor(zone, hostRef, controlType, focusMonitor, dialogService, ngControl) {
|
|
29
|
+
super(zone, hostRef, controlType, focusMonitor, ngControl);
|
|
30
|
+
this.dialogService = dialogService;
|
|
27
31
|
/***************************************************************************
|
|
28
32
|
* *
|
|
29
33
|
* Fields *
|
|
30
34
|
* *
|
|
31
35
|
**************************************************************************/
|
|
32
36
|
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
33
|
-
this.
|
|
37
|
+
this._entities$ = new BehaviorSubject([]);
|
|
38
|
+
/**
|
|
39
|
+
* Defines how the entities should be sorted locally.
|
|
40
|
+
* This affects how entities are displayed when more than
|
|
41
|
+
* one is selected, such as in a chip list.
|
|
42
|
+
*/
|
|
43
|
+
this.entitiesSorts = [];
|
|
44
|
+
/**
|
|
45
|
+
* If enabled, before removing selected entities
|
|
46
|
+
* the user will be prompted to confirm.
|
|
47
|
+
*/
|
|
48
|
+
this.confirmRemoval = false;
|
|
34
49
|
this.entityIdsChange = this.valueChange.pipe(map(values => this.entityIdsFromValues(values)));
|
|
50
|
+
this._entityIds$ = this.value$.pipe(map(values => this.entityIdsFromValues(values)));
|
|
51
|
+
this.entitiesChange = this._entities$.pipe(skip(1) // Skip the initial or current value
|
|
52
|
+
);
|
|
35
53
|
this.entityIdsUpdated = this.valueUpdated.pipe(map(values => this.entityIdsFromValues(values)));
|
|
36
54
|
this.entitiesUpdated = this.entityIdsUpdated.pipe(tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)), switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)), catchError(err => {
|
|
37
55
|
this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);
|
|
@@ -39,45 +57,73 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
39
57
|
}));
|
|
40
58
|
}
|
|
41
59
|
awaitEntitiesWithId(entityIds, timeoutMs) {
|
|
42
|
-
return this.
|
|
60
|
+
return this._entities$.pipe(tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)), filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)), take(1), timeout(timeoutMs));
|
|
43
61
|
}
|
|
44
62
|
/***************************************************************************
|
|
45
63
|
* *
|
|
46
64
|
* Properties *
|
|
47
65
|
* *
|
|
48
66
|
**************************************************************************/
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
67
|
+
get entities$() {
|
|
68
|
+
return this._entities$.asObservable();
|
|
69
|
+
}
|
|
70
|
+
get entityIds$() {
|
|
71
|
+
return this._entityIds$;
|
|
52
72
|
}
|
|
53
|
-
/***************************************************************************
|
|
54
|
-
* *
|
|
55
|
-
* Properties *
|
|
56
|
-
* *
|
|
57
|
-
**************************************************************************/
|
|
58
73
|
set entities(entities) {
|
|
59
|
-
this.
|
|
60
|
-
|
|
74
|
+
if (!this.equalEntities(this.entities, entities)) {
|
|
75
|
+
entities = this.writeEntitiesSorted(entities);
|
|
76
|
+
this.writeValueInternal(this.entitiesToValues(entities));
|
|
77
|
+
}
|
|
61
78
|
}
|
|
62
79
|
get entities() {
|
|
63
|
-
return this.
|
|
80
|
+
return this._entities$.getValue();
|
|
64
81
|
}
|
|
65
82
|
set entityIds(ids) {
|
|
66
|
-
if (this.
|
|
67
|
-
this.
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
83
|
+
if (!this.equalIds(this.entityIds, ids)) {
|
|
84
|
+
if (this.valueAsId) {
|
|
85
|
+
this.writeValueInternal(ids);
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this.selectEntitiesByIds(ids);
|
|
89
|
+
}
|
|
71
90
|
}
|
|
72
91
|
}
|
|
73
92
|
get entityIds() {
|
|
74
93
|
return this.entityIdsFromValues(this.value);
|
|
75
94
|
}
|
|
95
|
+
get isOptionDisabledInternalFn() {
|
|
96
|
+
return (option) => {
|
|
97
|
+
if (this.isOptionDisabledFn) {
|
|
98
|
+
return this.isOptionDisabledFn(option);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
return false;
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
get isOptionHiddenInternalFn() {
|
|
106
|
+
return (option) => {
|
|
107
|
+
if (this.isAlreadyPresent(option)) {
|
|
108
|
+
return true;
|
|
109
|
+
}
|
|
110
|
+
if (this.isOptionHiddenFn) {
|
|
111
|
+
return this.isOptionHiddenFn(option);
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
}
|
|
76
118
|
/***************************************************************************
|
|
77
119
|
* *
|
|
78
120
|
* Public API *
|
|
79
121
|
* *
|
|
80
122
|
**************************************************************************/
|
|
123
|
+
updateValueByEntities(entities) {
|
|
124
|
+
entities = this.writeEntitiesSorted(entities);
|
|
125
|
+
this.updateValue(this.entitiesToValues(entities));
|
|
126
|
+
}
|
|
81
127
|
appendEntities(newEntities) {
|
|
82
128
|
const current = this.entities ? this.entities : [];
|
|
83
129
|
this.updateValueByEntities([...current, ...newEntities]);
|
|
@@ -85,6 +131,31 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
85
131
|
appendEntity(newEntity) {
|
|
86
132
|
this.appendEntities([newEntity]);
|
|
87
133
|
}
|
|
134
|
+
requestRemoveEntity(toRemove, skipConfirm) {
|
|
135
|
+
this.requestRemoveEntities([toRemove], skipConfirm);
|
|
136
|
+
}
|
|
137
|
+
requestRemoveEntities(toRemove, skipConfirm) {
|
|
138
|
+
if (!skipConfirm && this.confirmRemoval) {
|
|
139
|
+
this.dialogService
|
|
140
|
+
.showConfirm({
|
|
141
|
+
title: 'dialogs.confirm-deletion.title',
|
|
142
|
+
message: 'dialogs.confirm-deletion.message',
|
|
143
|
+
yesNo: true,
|
|
144
|
+
interpolateParams: { numOfItems: toRemove.length },
|
|
145
|
+
})
|
|
146
|
+
.subscribe((confirmed) => {
|
|
147
|
+
if (confirmed) {
|
|
148
|
+
this.removeEntities(toRemove);
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
this.removeEntities(toRemove);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
removeEntities(toRemove) {
|
|
157
|
+
toRemove.forEach(e => this.removeEntity(e));
|
|
158
|
+
}
|
|
88
159
|
removeEntity(toRemove) {
|
|
89
160
|
const remaining = this.entities
|
|
90
161
|
.filter(l => !this.isEqual(l, toRemove));
|
|
@@ -98,12 +169,24 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
98
169
|
this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');
|
|
99
170
|
}
|
|
100
171
|
}
|
|
172
|
+
entityToValue(entity) {
|
|
173
|
+
if (this.valueAsId) {
|
|
174
|
+
const id = this.getEntityId(entity);
|
|
175
|
+
return id;
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
return entity;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
101
181
|
/***************************************************************************
|
|
102
182
|
* *
|
|
103
183
|
* Internal Methods *
|
|
104
184
|
* *
|
|
105
185
|
**************************************************************************/
|
|
106
|
-
|
|
186
|
+
valuesEquals(a, b) {
|
|
187
|
+
return this.equalIds(this.entityIdsFromValues(a), this.entityIdsFromValues(b));
|
|
188
|
+
}
|
|
189
|
+
onDataContextChanged(data) {
|
|
107
190
|
if (this.valueAsId) {
|
|
108
191
|
this.selectEntitiesByIds(this.entityIds);
|
|
109
192
|
}
|
|
@@ -125,7 +208,7 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
125
208
|
const newEntities = value;
|
|
126
209
|
this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);
|
|
127
210
|
if (!this.equalEntities(currentEntities, newEntities)) {
|
|
128
|
-
this.
|
|
211
|
+
this.writeEntitiesSorted(newEntities);
|
|
129
212
|
}
|
|
130
213
|
else {
|
|
131
214
|
this.logger.warn('Ignored written entities as they are already set to entities$!');
|
|
@@ -138,6 +221,14 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
138
221
|
* Private Methods *
|
|
139
222
|
* *
|
|
140
223
|
**************************************************************************/
|
|
224
|
+
isAlreadyPresent(queryValue) {
|
|
225
|
+
if (this.entities) {
|
|
226
|
+
return this.entities.some(v => this.isEqual(v, queryValue));
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
return false;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
141
232
|
entityIdsFromValues(values) {
|
|
142
233
|
if (values) {
|
|
143
234
|
return values.map(v => this.entityIdFromValue(v));
|
|
@@ -159,15 +250,6 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
159
250
|
}
|
|
160
251
|
return null;
|
|
161
252
|
}
|
|
162
|
-
entityToValue(entity) {
|
|
163
|
-
if (this.valueAsId) {
|
|
164
|
-
const id = this.getEntityId(entity);
|
|
165
|
-
return id;
|
|
166
|
-
}
|
|
167
|
-
else {
|
|
168
|
-
return entity;
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
253
|
getEntityIds(values) {
|
|
172
254
|
if (values) {
|
|
173
255
|
return values.map(v => this.getEntityId(v));
|
|
@@ -186,34 +268,35 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
186
268
|
if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {
|
|
187
269
|
return; // Entities already loaded
|
|
188
270
|
}
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
271
|
+
this.findOrLoadEntitiesByIds(ids)
|
|
272
|
+
.subscribe({
|
|
273
|
+
next: entities => this.entities = entities,
|
|
274
|
+
error: err => this.updateState(ElderSelectComponentState.error(err))
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
findOrLoadEntitiesByIds(ids) {
|
|
278
|
+
if (ids.length == 0) {
|
|
279
|
+
return of([]);
|
|
280
|
+
}
|
|
281
|
+
if (this.dataContext) {
|
|
282
|
+
const existing = this.findInDataContext(ids);
|
|
283
|
+
const missingIds = ids.filter(id => !existing.has(id));
|
|
284
|
+
const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntitiesByIds(missingIds) : of(new Map());
|
|
285
|
+
return valueLoadRequest$.pipe(map(loaded => {
|
|
286
|
+
loaded.forEach((v, k) => existing.set(k, v));
|
|
287
|
+
return existing;
|
|
288
|
+
}), map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?
|
|
289
|
+
);
|
|
193
290
|
}
|
|
194
291
|
else {
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
const missingIds = ids.filter(id => !existing.has(id));
|
|
198
|
-
const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntityByIds(missingIds) : of(new Map());
|
|
199
|
-
valueLoadRequest$.pipe(map(loaded => {
|
|
200
|
-
loaded.forEach((v, k) => existing.set(k, v));
|
|
201
|
-
return existing;
|
|
202
|
-
}), map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?
|
|
203
|
-
).subscribe(entities => {
|
|
204
|
-
this.entities = entities;
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
else {
|
|
208
|
-
this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');
|
|
209
|
-
}
|
|
292
|
+
this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');
|
|
293
|
+
return EMPTY;
|
|
210
294
|
}
|
|
211
295
|
}
|
|
212
|
-
|
|
213
|
-
return this.
|
|
214
|
-
this.logger.error('Failed to load
|
|
215
|
-
|
|
216
|
-
return of([]);
|
|
296
|
+
loadEntitiesByIds(ids) {
|
|
297
|
+
return this.dataContext.dataSource.findByIds(ids).pipe(catchError(err => {
|
|
298
|
+
this.logger.error('Failed to load entities by ids: ' + ids, err);
|
|
299
|
+
return throwError(err);
|
|
217
300
|
}), map(values => {
|
|
218
301
|
this.logger.debug('Loaded entities by id:', values);
|
|
219
302
|
const valueMap = new Map();
|
|
@@ -224,7 +307,7 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
224
307
|
findInDataContext(ids) {
|
|
225
308
|
const existingValues = new Map();
|
|
226
309
|
if (ids?.length > 0) {
|
|
227
|
-
const data = this.
|
|
310
|
+
const data = this.dataContext.snapshot.data;
|
|
228
311
|
const requiredIds = new Set(ids);
|
|
229
312
|
data
|
|
230
313
|
.filter(d => requiredIds.has(this.getEntityId(d)))
|
|
@@ -232,12 +315,33 @@ export class ElderMultiSelectBase extends ElderSelectBase {
|
|
|
232
315
|
}
|
|
233
316
|
return existingValues;
|
|
234
317
|
}
|
|
318
|
+
writeEntitiesSorted(entities) {
|
|
319
|
+
const sorted = this.sortEntities(entities);
|
|
320
|
+
this._entities$.next(sorted);
|
|
321
|
+
return sorted;
|
|
322
|
+
}
|
|
323
|
+
sortEntities(entities) {
|
|
324
|
+
if (entities && this.entitiesSorts && this.entitiesSorts.length > 0) {
|
|
325
|
+
const sorted = SortUtil.sortData(entities, this.entitiesSorts);
|
|
326
|
+
if (!SortUtil.equalsExactRefs(entities, sorted)) {
|
|
327
|
+
// Only return a copy of the array if actually something changed
|
|
328
|
+
return sorted;
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
return entities;
|
|
332
|
+
}
|
|
235
333
|
}
|
|
236
|
-
ElderMultiSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.
|
|
237
|
-
ElderMultiSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.
|
|
238
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.
|
|
334
|
+
ElderMultiSelectBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderMultiSelectBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
|
|
335
|
+
ElderMultiSelectBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.6", type: ElderMultiSelectBase, inputs: { entitiesSorts: "entitiesSorts", confirmRemoval: "confirmRemoval", entities: "entities", entityIds: "entityIds" }, outputs: { entityIdsChange: "entityIdsChange", entitiesChange: "entitiesChange", entityIdsUpdated: "entityIdsUpdated", entitiesUpdated: "entitiesUpdated" }, usesInheritance: true, ngImport: i0 });
|
|
336
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: ElderMultiSelectBase, decorators: [{
|
|
239
337
|
type: Directive
|
|
240
|
-
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: {
|
|
338
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: undefined }, { type: i1.FocusMonitor }, { type: i2.ElderDialogService }, { type: i3.NgControl }]; }, propDecorators: { entitiesSorts: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], confirmRemoval: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], entityIdsChange: [{
|
|
343
|
+
type: Output
|
|
344
|
+
}], entitiesChange: [{
|
|
241
345
|
type: Output
|
|
242
346
|
}], entityIdsUpdated: [{
|
|
243
347
|
type: Output
|
|
@@ -248,4 +352,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImpor
|
|
|
248
352
|
}], entityIds: [{
|
|
249
353
|
type: Input
|
|
250
354
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, of} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {CollectionUtil} from '../../../common/utils/collection-util';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue> extends ElderSelectBase<TId, TEntity, TValue[]> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  protected readonly entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this.entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    this.entities$.next(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    this.entities$.next(entities);\n    this.writeValueInternal(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public get entities(): TEntity[] {\n    return this.entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>ids as TValue[]);\n    } else {\n      this.selectEntitiesByIds(ids);\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        this.entities,\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.updateValueByEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.entities$.next(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    if (!CollectionUtil.hasElements(ids)) {\n      if (CollectionUtil.hasElements(currentEntities)) {\n        this.writeValueInternal([]);\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(ids);\n        const missingIds = ids.filter(id => !existing.has(id));\n        const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntityByIds(missingIds) : of(new Map());\n\n        valueLoadRequest$.pipe(\n          map(loaded => {\n            loaded.forEach((v, k) => existing.set(k, v));\n            return existing;\n          }),\n          map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n        ).subscribe(\n          entities => {\n            this.entities = entities;\n          }\n        );\n      } else {\n        this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.suggestionsDc.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load values by ids ' + ids, err);\n        this.updateState(ElderSelectComponentState.error(err));\n        return of(<TEntity[]>[]);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.suggestionsDc.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n\n}\n"]}
|
|
355
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, EMPTY, Observable, of, throwError} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, skip, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {CollectionUtil} from '../../../common/utils/collection-util';\nimport {NgControl} from '@angular/forms';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {IElderMultiEntityValueAccessor} from '../../../common/forms/elder-multi-entity-value-accessor';\nimport {Sort} from '../../../common/data/sort';\nimport {SortUtil} from '../../../common/utils/sort-util';\nimport {ElderDialogService} from '../../dialogs/elder-dialog.service';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue>\n  extends ElderSelectBase<TId, TEntity, TValue[]>\n  implements IElderMultiEntityValueAccessor<TEntity, TId, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _entityIds$: Observable<TId[]>;\n  private readonly _entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  /**\n   * Defines how the entities should be sorted locally.\n   * This affects how entities are displayed when more than\n   * one is selected, such as in a chip list.\n   */\n  @Input()\n  public entitiesSorts: Sort[] = [];\n\n  /**\n   * If enabled, before removing selected entities\n   * the user will be prompted to confirm.\n   */\n  @Input()\n  public confirmRemoval = false;\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  @Output()\n  public readonly entitiesChange: Observable<TEntity[]>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone,\n    hostRef: ElementRef,\n    controlType: string,\n    focusMonitor: FocusMonitor,\n    private readonly dialogService: ElderDialogService,\n    ngControl?: NgControl\n  ) {\n    super(zone, hostRef, controlType, focusMonitor, ngControl);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this._entityIds$ = this.value$.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesChange = this._entities$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this._entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get entities$(): Observable<TEntity[]> {\n    return this._entities$.asObservable();\n  }\n\n  public get entityIds$(): Observable<TId[]> {\n    return this._entityIds$;\n  }\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    if(!this.equalEntities(this.entities, entities)) {\n      entities = this.writeEntitiesSorted(entities);\n      this.writeValueInternal(\n        this.entitiesToValues(entities)\n      );\n    }\n  }\n\n  public get entities(): TEntity[] {\n    return this._entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if(!this.equalIds(this.entityIds, ids)) {\n      if (this.valueAsId) {\n        this.writeValueInternal(<any>ids as TValue[]);\n      } else {\n        this.selectEntitiesByIds(ids);\n      }\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionDisabledFn) {\n        return this.isOptionDisabledFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isAlreadyPresent(option)) {\n        return true;\n      }\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    entities = this.writeEntitiesSorted(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public requestRemoveEntity(toRemove: TEntity, skipConfirm?: boolean): void {\n    this.requestRemoveEntities([toRemove], skipConfirm);\n  }\n\n  public requestRemoveEntities(\n    toRemove: TEntity[],\n    skipConfirm?: boolean\n  ): void {\n    if (!skipConfirm && this.confirmRemoval) {\n      this.dialogService\n        .showConfirm({\n          title: 'dialogs.confirm-deletion.title',\n          message: 'dialogs.confirm-deletion.message',\n          yesNo: true,\n          interpolateParams: {numOfItems: toRemove.length},\n        })\n        .subscribe((confirmed) => {\n          if (confirmed) {\n            this.removeEntities(toRemove);\n          }\n        });\n    } else {\n      this.removeEntities(toRemove);\n    }\n  }\n\n  public removeEntities(toRemove: TEntity[]): void {\n    toRemove.forEach(e => this.removeEntity(e));\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        this.entities,\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.updateValueByEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public 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   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected override valuesEquals(a: TValue[], b: TValue[]): boolean {\n    return this.equalIds(this.entityIdsFromValues(a), this.entityIdsFromValues(b));\n  }\n\n  protected onDataContextChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected override writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.writeEntitiesSorted(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private isAlreadyPresent(queryValue: TEntity): boolean {\n    if (this.entities) {\n      return this.entities.some(v => this.isEqual(v, queryValue));\n    } else {\n      return false;\n    }\n  }\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    this.findOrLoadEntitiesByIds(ids)\n      .subscribe({\n        next: entities => this.entities = entities,\n        error: err => this.updateState(ElderSelectComponentState.error(err))\n      });\n  }\n\n  private findOrLoadEntitiesByIds(ids: TId[]): Observable<TEntity[]> {\n    if (ids.length == 0) {\n      return of([]);\n    }\n    if (this.dataContext) {\n      const existing = this.findInDataContext(ids);\n      const missingIds = ids.filter(id => !existing.has(id));\n      const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntitiesByIds(missingIds) : of(new Map());\n\n      return valueLoadRequest$.pipe(\n        map(loaded => {\n          loaded.forEach((v, k) => existing.set(k, v));\n          return existing;\n        }),\n        map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n      );\n    } else {\n      this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      return EMPTY;\n    }\n  }\n\n  private loadEntitiesByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.dataContext.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load entities by ids: ' + ids, err);\n        return throwError(err);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.dataContext.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n  private writeEntitiesSorted(entities: TEntity[]): TEntity[] {\n    const sorted = this.sortEntities(entities);\n    this._entities$.next(sorted);\n    return sorted;\n  }\n\n  private sortEntities(entities: TEntity[]): TEntity[] {\n    if (entities && this.entitiesSorts && this.entitiesSorts.length > 0) {\n      const sorted = SortUtil.sortData(entities, this.entitiesSorts);\n      if (!SortUtil.equalsExactRefs(entities, sorted)) {\n        // Only return a copy of the array if actually something changed\n        return sorted;\n      }\n    }\n    return entities;\n  }\n}\n"]}
|